-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathDefinitionItem.php
181 lines (149 loc) · 4.27 KB
/
DefinitionItem.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
<?php namespace RainLab\Sitemap\Classes;
use Model;
use Event;
use Illuminate\Database\Eloquent\Collection;
/**
* Item Model
*/
class DefinitionItem
{
/**
* @var string How frequently the page is likely to change.
*/
public $changefreq;
/**
* @var string The priority of this URL relative to other URLs on the site.
*/
public $priority;
/**
* @var boolean Determines whether the auto-generated items could have subitems.
*/
public $nesting;
/**
* @var string Specifies the item type - URL, static page, etc.
*/
public $type;
/**
* @var string Specifies the URL for URL-type items.
*/
public $url;
/**
* @var string Specifies the item code.
*/
public $code;
/**
* @var string Specifies the object identifier the item refers to.
* The identifier could be the database identifier or an object code.
*/
public $reference;
/**
* @var string Specifies the CMS page path to resolve dynamic items to.
*/
public $cmsPage;
/**
* @var boolean Used by the system internally.
*/
public $exists = false;
/**
* @var array Fillable fields
*/
public $fillable = [
'changefreq',
'priority',
'nesting',
'type',
'url',
'reference',
'cmsPage'
];
/**
* Initializes a item from a data array.
* @param array $items Specifies the item data.
* @return Returns an array of the Item objects.
*/
public static function initFromArray($items)
{
if (!is_array($items)) {
return null;
}
$result = [];
foreach ($items as $itemData) {
$obj = new self;
foreach ($itemData as $name => $value) {
if (property_exists($obj, $name)) {
$obj->$name = $value;
}
}
$result[] = $obj;
}
return new Collection($result);
}
/**
* Returns a list of registered item types
* @return array Returns an array of registered item types
*/
public function getTypeOptions($keyValue = null)
{
$result = ['url' => 'URL'];
$apiResult = Event::fire('pages.menuitem.listTypes');
if (is_array($apiResult)) {
foreach ($apiResult as $typeList) {
if (!is_array($typeList)) {
continue;
}
foreach ($typeList as $typeCode => $typeName) {
$result[$typeCode] = $typeName;
}
}
}
return $result;
}
public function getCmsPageOptions($keyValue = null)
{
return []; // CMS Pages are loaded client-side
}
public function getReferenceOptions($keyValue = null)
{
return []; // References are loaded client-side
}
public static function getTypeInfo($type)
{
$result = [];
$apiResult = Event::fire('pages.menuitem.getTypeInfo', [$type]);
if (is_array($apiResult)) {
foreach ($apiResult as $typeInfo) {
if (!is_array($typeInfo)) {
continue;
}
foreach ($typeInfo as $name=>$value) {
if ($name == 'cmsPages') {
$cmsPages = [];
foreach ($value as $page) {
$baseName = $page->getBaseFileName();
$pos = strrpos ($baseName, '/');
$dir = $pos !== false ? substr($baseName, 0, $pos).' / ' : null;
$cmsPages[$baseName] = strlen($page->title)
? $dir.$page->title
: $baseName;
}
$value = $cmsPages;
}
$result[$name] = $value;
}
}
}
return $result;
}
/**
* Converts the item data to an array
* @return array Returns the item data as array
*/
public function toArray()
{
$result = [];
foreach ($this->fillable as $property) {
$result[$property] = $this->$property;
}
return $result;
}
}