Merge pull request #2542 from chrometoasters/pulls/array-short-syntax

Use short array syntax across the module's codebase
This commit is contained in:
Guy Marriott 2020-04-20 10:01:10 -07:00 committed by GitHub
commit d46c2a3827
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
56 changed files with 432 additions and 429 deletions

View File

@ -30,7 +30,7 @@ call_user_func(function () {
*/
ShortcodeParser::get('default')->register(
'sitetree_link',
array(SiteTree::class, 'link_shortcode_handler')
[SiteTree::class, 'link_shortcode_handler']
);
// TODO Remove once we can configure CMSMenu through static, nested configuration files

View File

@ -51,8 +51,8 @@ class CMSBatchAction_Restore extends CMSBatchAction
public function applicablePages($ids)
{
// Basic permission check based on SiteTree::canEdit
if (!Permission::check(array("ADMIN", "SITETREE_EDIT_ALL"))) {
return array();
if (!Permission::check(["ADMIN", "SITETREE_EDIT_ALL"])) {
return [];
}
// Get pages that exist in stage and remove them from the restore-able set

View File

@ -127,7 +127,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
*/
private static $page_length = 15;
private static $allowed_actions = array(
private static $allowed_actions = [
'archive',
'deleteitems',
'DeleteItemsForm',
@ -151,13 +151,13 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
'listview',
'ListViewForm',
'childfilter',
);
];
private static $url_handlers = [
'EditForm/$ID' => 'EditForm',
];
private static $casting = array(
private static $casting = [
'TreeIsFiltered' => 'Boolean',
'AddForm' => 'HTMLFragment',
'LinkPages' => 'Text',
@ -169,7 +169,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
'SiteTreeHints' => 'HTMLFragment',
'SecurityID' => 'Text',
'SiteTreeAsUL' => 'HTMLFragment',
);
];
private static $dependencies = [
'HintsCache' => '%$' . CacheInterface::class . '.CMSMain_SiteTreeHints',
@ -448,10 +448,10 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
public function LinkWithSearch($link)
{
// Whitelist to avoid side effects
$params = array(
$params = [
'q' => (array)$this->getRequest()->getVar('q'),
'ParentID' => $this->getRequest()->getVar('ParentID')
);
];
$link = Controller::join_links(
$link,
array_filter(array_values($params)) ? '?' . http_build_query($params) : null
@ -681,7 +681,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
*/
public function updatetreenodes($request)
{
$data = array();
$data = [];
$ids = explode(',', $request->getVar('ids'));
foreach ($ids as $id) {
if ($id === "") {
@ -724,12 +724,12 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$this->getTreeNodeCustomisations()
);
$data[$id] = array(
$data[$id] = [
'html' => $html,
'ParentID' => $record->ParentID,
'NextID' => $next ? $next->ID : null,
'PrevID' => $prev ? $prev->ID : null
);
];
}
return $this
->getResponse()
@ -799,7 +799,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
}
$siblingIDs = $request->requestVar('SiblingIDs');
$statusUpdates = array('modified'=>array());
$statusUpdates = ['modified'=>[]];
if (!$node->canEdit()) {
return Security::permissionFailure($this);
@ -810,16 +810,16 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$node->ParentID = (int)$parentID;
$node->write();
$statusUpdates['modified'][$node->ID] = array(
$statusUpdates['modified'][$node->ID] = [
'TreeTitle' => $node->TreeTitle
);
];
// Update all dependent pages
$virtualPages = VirtualPage::get()->filter("CopyContentFromID", $node->ID);
foreach ($virtualPages as $virtualPage) {
$statusUpdates['modified'][$virtualPage->ID] = array(
$statusUpdates['modified'][$virtualPage->ID] = [
'TreeTitle' => $virtualPage->TreeTitle()
);
];
}
$this->getResponse()->addHeader(
@ -835,9 +835,9 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
if ($id == $node->ID) {
$node->Sort = ++$counter;
$node->write();
$statusUpdates['modified'][$node->ID] = array(
$statusUpdates['modified'][$node->ID] = [
'TreeTitle' => $node->TreeTitle
);
];
} elseif (is_numeric($id)) {
// Nodes that weren't "actually moved" shouldn't be registered as
// having been edited; do a direct SQL update instead
@ -845,7 +845,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$table = DataObject::getSchema()->baseDataTable($className);
DB::prepared_query(
"UPDATE \"$table\" SET \"Sort\" = ? WHERE \"ID\" = ?",
array($counter, $id)
[$counter, $id]
);
}
}
@ -1013,7 +1013,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
*/
protected function getPageTypes()
{
$pageTypes = array();
$pageTypes = [];
foreach (SiteTree::page_type_classes() as $pageTypeClass) {
$pageTypes[$pageTypeClass] = SiteTree::singleton($pageTypeClass)->i18n_singular_name();
}
@ -1070,10 +1070,10 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
/** @var SiteTree $record */
$record = $this->currentPage();
if (!$record) {
$items->push(new ArrayData(array(
$items->push(new ArrayData([
'Title' => CMSPagesController::menu_title(),
'Link' => ($unlinked) ? false : $this->LinkPages()
)));
]));
$this->extend('updateBreadcrumbs', $items);
@ -1086,12 +1086,12 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$ancestors->push($record);
/** @var SiteTree $ancestor */
foreach ($ancestors as $ancestor) {
$items->push(new ArrayData(array(
$items->push(new ArrayData([
'Title' => $ancestor->getMenuTitle(),
'Link' => ($unlinked)
? false
: $ancestor->CMSEditLink()
)));
]));
}
$this->extend('updateBreadcrumbs', $items);
@ -1196,13 +1196,13 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
continue;
}
$result->push(new ArrayData(array(
$result->push(new ArrayData([
'ClassName' => $class,
'AddAction' => $instance->i18n_singular_name(),
'Description' => $instance->i18n_classDescription(),
'IconURL' => $instance->getPageIconURL(),
'Title' => $instance->i18n_singular_name(),
)));
]));
}
$result = $result->sort('AddAction');
@ -1376,7 +1376,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
// TODO Can't merge $FormAttributes in template at the moment
$form->addExtraClass('center ' . $this->BaseCSSClasses());
// Set validation exemptions for specific actions
$form->setValidationExemptActions(array(
$form->setValidationExemptActions([
'restore',
'revert',
'deletefromlive',
@ -1385,7 +1385,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
'rollback',
'doRollback',
'archive',
));
]);
// Announce the capability so the frontend can decide whether to allow preview or not.
if ($record instanceof CMSPreviewable) {
@ -1562,14 +1562,14 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
// Build hints specific to this class
// Identify disallows and set globals
$classes = SiteTree::page_type_classes();
$disallowedChildren = array();
$disallowedChildren = [];
foreach ($classes as $class) {
$obj = singleton($class);
if ($obj instanceof HiddenClass) {
continue;
}
if (!$obj->canCreate(null, array('Parent' => $parent))) {
if (!$obj->canCreate(null, ['Parent' => $parent])) {
$disallowedChildren[] = $class;
}
}
@ -1610,7 +1610,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
* @return SS_List
* @throws InvalidArgumentException if invalid filter class is passed.
*/
public function getList($params = array(), $parentID = 0)
public function getList($params = [], $parentID = 0)
{
if ($filter = $this->getQueryFilter($params)) {
return $filter->getFilteredPages();
@ -1643,7 +1643,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$gridFieldConfig->addComponent(
GridFieldLevelup::create($parentID)
->setLinkSpec($linkSpec)
->setAttributes(array('data-pjax-target' => 'ListViewForm,Breadcrumbs'))
->setAttributes(['data-pjax-target' => 'ListViewForm,Breadcrumbs'])
);
$this->setCurrentPageID($parentID);
}
@ -1653,28 +1653,28 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$columns = $gridField->getConfig()->getComponentByType(GridFieldDataColumns::class);
// Don't allow navigating into children nodes on filtered lists
$fields = array(
$fields = [
'getTreeTitle' => _t('SilverStripe\\CMS\\Model\\SiteTree.PAGETITLE', 'Page Title'),
'singular_name' => _t('SilverStripe\\CMS\\Model\\SiteTree.PAGETYPE', 'Page Type'),
'LastEdited' => _t('SilverStripe\\CMS\\Model\\SiteTree.LASTUPDATED', 'Last Updated'),
);
];
/** @var GridFieldSortableHeader $sortableHeader */
$sortableHeader = $gridField->getConfig()->getComponentByType(GridFieldSortableHeader::class);
$sortableHeader->setFieldSorting(array('getTreeTitle' => 'Title'));
$sortableHeader->setFieldSorting(['getTreeTitle' => 'Title']);
$gridField->getState()->ParentID = $parentID;
if (!$params) {
$fields = array_merge(array('listChildrenLink' => ''), $fields);
$fields = array_merge(['listChildrenLink' => ''], $fields);
}
$columns->setDisplayFields($fields);
$columns->setFieldCasting(array(
$columns->setFieldCasting([
'Created' => 'DBDatetime->Ago',
'LastEdited' => 'DBDatetime->FormatFromSettings',
'getTreeTitle' => 'HTMLFragment'
));
]);
$columns->setFieldFormatting(array(
$columns->setFieldFormatting([
'listChildrenLink' => function ($value, &$item) {
/** @var SiteTree $item */
$num = $item ? $item->numChildren() : null;
@ -1700,7 +1700,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$breadcrumbs = preg_replace('/\s?\/\s?/', '/', trim($breadcrumbs));
return $title . sprintf('<p class="small cms-list__item-breadcrumbs">%s</p>', $breadcrumbs);
}
));
]);
$negotiator = $this->getResponseNegotiator();
$listview = Form::create(
@ -1714,11 +1714,11 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$request = $this->getRequest();
if ($request->isAjax() && $negotiator) {
$result = $listview->forTemplate();
return $negotiator->respond($request, array(
return $negotiator->respond($request, [
'CurrentForm' => function () use ($result) {
return $result;
}
));
]);
}
});
@ -1843,7 +1843,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
__CLASS__ . '.NEWPAGE',
"New {pagetype}",
'followed by a page type title',
array('pagetype' => singleton($className)->i18n_singular_name())
['pagetype' => singleton($className)->i18n_singular_name()]
);
$newItem->ClassName = $className;
$newItem->ParentID = $parentID;
@ -1854,7 +1854,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$table = DataObject::singleton(SiteTree::class)->baseTable();
$maxSort = DB::prepared_query(
"SELECT MAX(\"Sort\") FROM \"$table\" WHERE \"ParentID\" = ?",
array($parentID)
[$parentID]
)->value();
$newItem->Sort = (int)$maxSort + 1;
}
@ -1911,9 +1911,9 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
/** @var SiteTree $record */
$table = DataObject::singleton(SiteTree::class)->baseTable();
$liveTable = DataObject::singleton(SiteTree::class)->stageTable($table, Versioned::LIVE);
$record = Versioned::get_one_by_stage(SiteTree::class, Versioned::LIVE, array(
$record = Versioned::get_one_by_stage(SiteTree::class, Versioned::LIVE, [
"\"$liveTable\".\"ID\"" => $id
));
]);
// a user can restore a page without publication rights, as it just adds a new draft state
// (this action should just be available when page has been "deleted from draft")
@ -1932,7 +1932,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
__CLASS__ . '.RESTORED',
"Restored '{title}' successfully",
'Param {title} is a title',
array('title' => $record->Title)
['title' => $record->Title]
))
);
@ -2051,10 +2051,10 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
*/
public function rollback()
{
return $this->doRollback(array(
return $this->doRollback([
'ID' => $this->currentPageID(),
'Version' => $this->getRequest()->param('VersionID')
), null);
], null);
}
/**
@ -2082,7 +2082,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
$message = _t(
__CLASS__ . '.ROLLEDBACKVERSIONv2',
"Rolled back to version #{version}.",
array('version' => $data['Version'])
['version' => $data['Version']]
);
} else {
$record->doRevertToLive();
@ -2118,7 +2118,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
{
$batchActions = CMSBatchActionHandler::config()->batch_actions;
$forms = array();
$forms = [];
foreach ($batchActions as $urlSegment => $batchAction) {
$SNG_action = singleton($batchAction);
if ($SNG_action->canView() && $fieldset = $SNG_action->getParameterFields()) {
@ -2189,7 +2189,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
break;
}
}
$response .= _t(__CLASS__ . '.PUBPAGES', "Done: Published {count} pages", array('count' => $count));
$response .= _t(__CLASS__ . '.PUBPAGES', "Done: Published {count} pages", ['count' => $count]);
} else {
$token = SecurityToken::inst();
$fields = new FieldList();
@ -2243,7 +2243,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
rawurlencode(_t(
__CLASS__ . '.RESTORED',
"Restored '{title}' successfully",
array('title' => $restoredPage->Title)
['title' => $restoredPage->Title]
))
);
@ -2281,7 +2281,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
rawurlencode(_t(
__CLASS__ . '.DUPLICATED',
"Duplicated '{title}' successfully",
array('title' => $newPage->Title)
['title' => $newPage->Title]
))
);
$url = $newPage->CMSEditLink();
@ -2319,7 +2319,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
rawurlencode(_t(
__CLASS__ . '.DUPLICATEDWITHCHILDREN',
"Duplicated '{title}' and children successfully",
array('title' => $newPage->Title)
['title' => $newPage->Title]
))
);
$url = $newPage->CMSEditLink();
@ -2335,17 +2335,17 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr
public function providePermissions()
{
$title = CMSPagesController::menu_title();
return array(
"CMS_ACCESS_CMSMain" => array(
'name' => _t(__CLASS__ . '.ACCESS', "Access to '{title}' section", array('title' => $title)),
return [
"CMS_ACCESS_CMSMain" => [
'name' => _t(__CLASS__ . '.ACCESS', "Access to '{title}' section", ['title' => $title]),
'category' => _t('SilverStripe\\Security\\Permission.CMS_ACCESS_CATEGORY', 'CMS Access'),
'help' => _t(
__CLASS__ . '.ACCESS_HELP',
'Allow viewing of the section containing page tree and content. View and edit permissions can be handled through page specific dropdowns, as well as the separate "Content permissions".'
),
'sort' => -99 // below "CMS_ACCESS_LeftAndMain", but above everything else
)
);
]
];
}
/**

View File

@ -31,18 +31,18 @@ class CMSPageAddController extends CMSPageEditController
private static $menu_title = 'Add page';
private static $required_permission_codes = 'CMS_ACCESS_CMSMain';
private static $allowed_actions = array(
private static $allowed_actions = [
'AddForm',
'doAdd',
'doCancel'
);
];
/**
* @return Form
*/
public function AddForm()
{
$pageTypes = array();
$pageTypes = [];
$defaultIcon = Config::inst()->get(SiteTree::class, 'icon_class');
foreach ($this->PageTypes() as $type) {
@ -67,7 +67,7 @@ class CMSPageAddController extends CMSPageEditController
// Ensure generic page type shows on top
if (isset($pageTypes['Page'])) {
$pageTitle = $pageTypes['Page'];
$pageTypes = array_merge(array('Page' => $pageTitle), $pageTypes);
$pageTypes = array_merge(['Page' => $pageTitle], $pageTypes);
}
$numericLabelTmpl = '<span class="step-label"><span class="flyout">Step %d. </span><span class="title">%s</span></span>';
@ -78,7 +78,7 @@ class CMSPageAddController extends CMSPageEditController
$fields = new FieldList(
$parentModeField = new SelectionGroup(
"ParentModeField",
array(
[
new SelectionGroup_Item(
"top",
null,
@ -95,7 +95,7 @@ class CMSPageAddController extends CMSPageEditController
),
$childTitle
)
)
]
),
new LiteralField(
'RestrictedNote',
@ -170,11 +170,11 @@ class CMSPageAddController extends CMSPageEditController
$request = $this->getRequest();
if ($request->isAjax() && $negotiator) {
$result = $form->forTemplate();
return $negotiator->respond($request, array(
return $negotiator->respond($request, [
'CurrentForm' => function () use ($result) {
return $result;
}
));
]);
}
return null;
});
@ -211,7 +211,7 @@ class CMSPageAddController extends CMSPageEditController
$parentID = 0;
}
if (!singleton($className)->canCreate(Security::getCurrentUser(), array('Parent' => $parentObj))) {
if (!singleton($className)->canCreate(Security::getCurrentUser(), ['Parent' => $parentObj])) {
return Security::permissionFailure($this);
}

View File

@ -28,9 +28,9 @@ class CMSPageEditController extends CMSMain
private static $required_permission_codes = 'CMS_ACCESS_CMSMain';
private static $allowed_actions = array(
private static $allowed_actions = [
'AddToCampaignForm',
);
];
public function getClientConfig()
{

View File

@ -39,18 +39,18 @@ class CMSPageHistoryController extends CMSMain
private static $required_permission_codes = 'CMS_ACCESS_CMSMain';
private static $allowed_actions = array(
private static $allowed_actions = [
'EditForm',
'VersionsForm',
'CompareVersionsForm',
'show',
'compare'
);
];
private static $url_handlers = array(
private static $url_handlers = [
'$Action/$ID/$VersionID/$OtherVersionID' => 'handleAction',
'EditForm/$ID/$VersionID' => 'EditForm',
);
];
/**
* Current version ID for this request. Can be 0 for latest version
@ -101,7 +101,7 @@ class CMSPageHistoryController extends CMSMain
});
$negotiator->setCallback('default', function () use ($form) {
return $this
->customise(array('EditForm' => $form))
->customise(['EditForm' => $form])
->renderWith($this->getViewer('show'));
});
@ -124,7 +124,7 @@ class CMSPageHistoryController extends CMSMain
return $form ? $form->forTemplate() : $this->renderWith($this->getTemplatesWithSuffix('_Content'));
});
$negotiator->setCallback('default', function () use ($form) {
return $this->customise(array('EditForm' => $form))->renderWith($this->getViewer('show'));
return $this->customise(['EditForm' => $form])->renderWith($this->getViewer('show'));
});
return $negotiator->respond($request);
@ -229,10 +229,10 @@ class CMSPageHistoryController extends CMSMain
$message = _t(
__CLASS__ . '.COMPARINGVERSION',
"Comparing versions {version1} and {version2}.",
array(
[
'version1' => sprintf('%s (<a href="%s">%s</a>)', $versionID, Controller::join_links($link, $versionID), $view),
'version2' => sprintf('%s (<a href="%s">%s</a>)', $compareID, Controller::join_links($link, $compareID), $view)
)
]
);
$revert->setReadonly(true);
@ -243,7 +243,7 @@ class CMSPageHistoryController extends CMSMain
$message = _t(
__CLASS__ . '.VIEWINGVERSION',
"Currently viewing version {version}.",
array('version' => $versionID)
['version' => $versionID]
);
}
}
@ -251,17 +251,17 @@ class CMSPageHistoryController extends CMSMain
/** @var Tab $mainTab */
$mainTab = $fields->fieldByName('Root.Main');
$mainTab->unshift(
LiteralField::create('CurrentlyViewingMessage', ArrayData::create(array(
LiteralField::create('CurrentlyViewingMessage', ArrayData::create([
'Content' => DBField::create_field('HTMLFragment', $message),
'Classes' => 'alert alert-info'
))->renderWith($this->getTemplatesWithSuffix('_notice')))
])->renderWith($this->getTemplatesWithSuffix('_notice')))
);
$form->setFields($fields->makeReadonly());
$form->loadDataFrom(array(
$form->loadDataFrom([
"ID" => $id,
"Version" => $versionID,
));
]);
if ($record->isLatestVersion()) {
$revert->setReadonly(true);
@ -322,9 +322,9 @@ class CMSPageHistoryController extends CMSMain
$vd = new ViewableData();
$versionsHtml = $vd->customise(array(
$versionsHtml = $vd->customise([
'Versions' => $versions
))->renderWith($this->getTemplatesWithSuffix('_versions'));
])->renderWith($this->getTemplatesWithSuffix('_versions'));
}
$fields = new FieldList(
@ -411,10 +411,10 @@ class CMSPageHistoryController extends CMSMain
$form->addExtraClass('compare');
$form->loadDataFrom($record);
$form->loadDataFrom(array(
$form->loadDataFrom([
"ID" => $id,
"Version" => $fromVersion,
));
]);
// Comparison views shouldn't be editable.
// As the comparison output is HTML and not valid values for the various field types

View File

@ -40,17 +40,17 @@ class CMSPagesController extends CMSMain
$page = SiteTree::get()->byID($parentID);
//build a reversed list of the parent tree
$pages = array();
$pages = [];
while ($page) {
array_unshift($pages, $page); //add to start of array so that array is in reverse order
$page = $page->Parent;
}
//turns the title and link of the breadcrumbs into template-friendly variables
$params = array_filter(array(
$params = array_filter([
'view' => $this->getRequest()->getVar('view'),
'q' => $this->getRequest()->getVar('q')
));
]);
foreach ($pages as $page) {
$params['ParentID'] = $page->ID;
$item = new stdClass();

View File

@ -32,7 +32,7 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
*
* @var array
*/
protected $params = array();
protected $params = [];
/**
* List of filtered items and all their parents
@ -54,7 +54,7 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
/**
* @var array
*/
protected $_cache_expanded = array();
protected $_cache_expanded = [];
/**
* @var string
@ -80,7 +80,7 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
array_shift($filters);
// add filters to map
$filterMap = array();
$filterMap = [];
foreach ($filters as $filter) {
$filterMap[$filter] = $filter::title();
}
@ -148,9 +148,9 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
*/
protected function populateIDs()
{
$parents = array();
$this->_cache_ids = array();
$this->_cache_highlight_ids = array();
$parents = [];
$this->_cache_ids = [];
$this->_cache_highlight_ids = [];
if ($pages = $this->pagesIncluded()) {
// And keep a record of parents we don't need to get
@ -165,7 +165,7 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
$q = Versioned::get_including_deleted(SiteTree::class)
->byIDs(array_keys($parents));
$list = $q->map('ID', 'ParentID');
$parents = array();
$parents = [];
foreach ($list as $id => $parentID) {
if ($parentID) {
$parents[$parentID] = true;
@ -202,12 +202,12 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
switch ($name) {
case 'Term':
$query = $query->filterAny(array(
$query = $query->filterAny([
'URLSegment:PartialMatch' => $val,
'Title:PartialMatch' => $val,
'MenuTitle:PartialMatch' => $val,
'Content:PartialMatch' => $val
));
]);
break;
case 'LastEditedFrom':
@ -231,7 +231,7 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
if ($field) {
$filter = $field->defaultSearchFilter();
$filter->setValue($val);
$query = $query->alterDataQuery(array($filter, 'apply'));
$query = $query->alterDataQuery([$filter, 'apply']);
}
}
}
@ -246,10 +246,10 @@ abstract class CMSSiteTreeFilter implements LeftAndMain_SearchFilter
*/
protected function mapIDs($pages)
{
$ids = array();
$ids = [];
if ($pages) {
foreach ($pages as $page) {
$ids[] = array('ID' => $page->ID, 'ParentID' => $page->ParentID);
$ids[] = ['ID' => $page->ID, 'ParentID' => $page->ParentID];
}
}
return $ids;

View File

@ -523,11 +523,11 @@ HTML;
$content = new DBHTMLText('Content');
// As of SS4, index.php is required and should never be deleted.
$installfiles = array(
$installfiles = [
'install.php',
'install-frameworkmissing.html',
'index.html'
);
];
$unsuccessful = new ArrayList();
foreach ($installfiles as $installfile) {
@ -537,7 +537,7 @@ HTML;
}
if (file_exists($installfilepath)) {
$unsuccessful->push(new ArrayData(array('File' => $installfile)));
$unsuccessful->push(new ArrayData(['File' => $installfile]));
}
}

View File

@ -63,9 +63,9 @@ class ModelAsController extends Controller implements NestedController
$this->getResponse()->redirect(Controller::join_links(
Director::absoluteBaseURL(),
'dev/build',
'?' . http_build_query(array(
'?' . http_build_query([
'returnURL' => isset($_GET['url']) ? $_GET['url'] : null,
))
])
));
}
}

View File

@ -54,7 +54,7 @@ class OldPageRedirector extends Extension
/**
* Attempt to find an old/renamed page from some given the URL as an array
*
* @param array $params The array of URL, e.g. /foo/bar as array('foo', 'bar')
* @param array $params The array of URL, e.g. /foo/bar as ['foo', 'bar']
* @param SiteTree|null $parent The current parent in the recursive flow
* @param boolean $redirect Whether we've found an old page worthy of a redirect
*
@ -68,13 +68,13 @@ class OldPageRedirector extends Extension
if (empty($URL)) {
return false;
}
$pages = SiteTree::get()->filter(array(
$pages = SiteTree::get()->filter([
'URLSegment' => $URL,
));
]);
if ($parent || is_numeric($parent)) {
$pages = $pages->filter(array(
$pages = $pages->filter([
'ParentID' => is_numeric($parent) ? $parent : $parent->ID,
));
]);
}
/** @var SiteTree $page */
$page = $pages->first();

View File

@ -78,9 +78,9 @@ class RootURLController extends Controller implements Resettable
$this->getResponse()->redirect(Controller::join_links(
Director::absoluteBaseURL(),
'dev/build',
'?' . http_build_query(array(
'?' . http_build_query([
'returnURL' => isset($_GET['url']) ? $_GET['url'] : null,
))
])
));
}
}

View File

@ -41,7 +41,7 @@ class SilverStripeNavigator extends ViewableData
*/
public function getItems()
{
$items = array();
$items = [];
$classes = ClassInfo::subclassesFor(SilverStripeNavigatorItem::class);
array_shift($classes);
@ -99,9 +99,9 @@ class SilverStripeNavigator extends ViewableData
}
}
return array(
return [
'items' => $html,
'message' => $message
);
];
}
}

View File

@ -17,10 +17,10 @@ class InternalLinkModalExtension extends Extension
'editorAnchorLink/$ItemID' => 'editorAnchorLink', // Matches LeftAndMain::methodSchema args
];
private static $allowed_actions = array(
private static $allowed_actions = [
'editorInternalLink',
'editorAnchorLink',
);
];
/**
* @return ModalController

View File

@ -38,9 +38,9 @@ class SiteTreeURLSegmentField extends TextField
*/
protected $defaultUrl;
private static $allowed_actions = array(
private static $allowed_actions = [
'suggest'
);
];
public function Value()
{
@ -51,15 +51,15 @@ class SiteTreeURLSegmentField extends TextField
{
return array_merge(
parent::getAttributes(),
array(
[
'data-prefix' => $this->getURLPrefix(),
'data-suffix' => '?stage=Stage',
'data-default-url' => $this->getDefaultURL()
)
]
);
}
public function Field($properties = array())
public function Field($properties = [])
{
return parent::Field($properties);
}
@ -87,7 +87,7 @@ class SiteTreeURLSegmentField extends TextField
}
Controller::curr()->getResponse()->addHeader('Content-Type', 'application/json');
return json_encode(array('value' => $page->URLSegment));
return json_encode(['value' => $page->URLSegment]);
}
/**

View File

@ -158,10 +158,10 @@ class RedirectorPage extends Page
if (empty($urlParts['scheme'])) {
// no scheme, assume http
$this->ExternalURL = 'http://' . $this->ExternalURL;
} elseif (!in_array($urlParts['scheme'], array(
} elseif (!in_array($urlParts['scheme'], [
'http',
'https',
))) {
])) {
// we only allow http(s) urls
$this->ExternalURL = '';
}
@ -182,15 +182,15 @@ class RedirectorPage extends Page
$fields->addFieldsToTab(
'Root.Main',
array(
[
new HeaderField('RedirectorDescHeader', _t(__CLASS__.'.HEADER', "This page will redirect users to another page")),
new OptionsetField(
"RedirectionType",
_t(__CLASS__.'.REDIRECTTO', "Redirect to"),
array(
[
"Internal" => _t(__CLASS__.'.REDIRECTTOPAGE', "A page on your website"),
"External" => _t(__CLASS__.'.REDIRECTTOEXTERNAL', "Another website"),
),
],
"Internal"
),
new TreeDropdownField(
@ -199,7 +199,7 @@ class RedirectorPage extends Page
SiteTree::class
),
new TextField("ExternalURL", _t(__CLASS__.'.OTHERURL', "Other website URL"))
)
]
);
});

View File

@ -135,7 +135,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
* Drastically reduces admin page load when there are a lot of page types
* @var array
*/
protected static $_allowedChildren = array();
protected static $_allowedChildren = [];
/**
* Determines if the Draft Preview panel will appear when in the CMS admin
@ -213,7 +213,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
*/
private static $controller_name = null;
private static $db = array(
private static $db = [
"URLSegment" => "Varchar(255)",
"Title" => "Varchar(255)",
"MenuTitle" => "Varchar(100)",
@ -226,26 +226,26 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
"HasBrokenFile" => "Boolean",
"HasBrokenLink" => "Boolean",
"ReportClass" => "Varchar",
);
];
private static $indexes = array(
private static $indexes = [
"URLSegment" => true,
);
];
private static $has_many = [
"VirtualPages" => VirtualPage::class . '.CopyContentFrom',
'BackLinks' => SiteTreeLink::class . '.Linked',
];
private static $owned_by = array(
private static $owned_by = [
"VirtualPages"
);
];
private static $cascade_deletes = [
'VirtualPages',
];
private static $casting = array(
private static $casting = [
"Breadcrumbs" => "HTMLFragment",
"LastEdited" => "Datetime",
"Created" => "Datetime",
@ -255,18 +255,18 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
'CMSEditLink' => 'Text',
'TreeTitle' => 'HTMLFragment',
'MetaTags' => 'HTMLFragment',
);
];
private static $defaults = array(
private static $defaults = [
"ShowInMenus" => 1,
"ShowInSearch" => 1,
);
];
private static $table_name = 'SiteTree';
private static $versioning = array(
private static $versioning = [
"Stage", "Live"
);
];
private static $default_sort = "\"Sort\"";
@ -300,14 +300,14 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
InheritedPermissionsExtension::class,
];
private static $searchable_fields = array(
private static $searchable_fields = [
'Title',
'Content',
);
];
private static $field_labels = array(
private static $field_labels = [
'URLSegment' => 'URL'
);
];
/**
* @config
@ -422,9 +422,9 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
// Grab the initial root level page to traverse down from.
$URLSegment = array_shift($parts);
$conditions = array($urlSegmentExpr => rawurlencode($URLSegment));
$conditions = [$urlSegmentExpr => rawurlencode($URLSegment)];
if (self::config()->get('nested_urls')) {
$conditions[] = array($parentIDExpr => 0);
$conditions[] = [$parentIDExpr => 0];
}
/** @var SiteTree $sitetree */
$sitetree = DataObject::get_one(self::class, $conditions, $cache);
@ -432,9 +432,9 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
/// Fall back on a unique URLSegment for b/c.
if (!$sitetree
&& self::config()->get('nested_urls')
&& $sitetree = DataObject::get_one(self::class, array(
&& $sitetree = DataObject::get_one(self::class, [
$urlSegmentExpr => $URLSegment
), $cache)
], $cache)
) {
return $sitetree;
}
@ -465,10 +465,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
foreach ($parts as $segment) {
$next = DataObject::get_one(
self::class,
array(
[
$urlSegmentExpr => $segment,
$parentIDExpr => $sitetree->ID
),
],
$cache
);
@ -509,7 +509,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
unset($classes[$baseClassIndex]);
}
$kill_ancestors = array();
$kill_ancestors = [];
// figure out if there are any classes we don't want to appear
foreach ($classes as $class) {
@ -678,9 +678,9 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
Versioned::set_stage(Versioned::LIVE);
$tablename = $this->baseTable();
/** @var SiteTree $live */
$live = Versioned::get_one_by_stage(self::class, Versioned::LIVE, array(
$live = Versioned::get_one_by_stage(self::class, Versioned::LIVE, [
"\"$tablename\".\"ID\"" => $this->ID
));
]);
if ($live) {
$link = $live->AbsoluteLink();
if ($includeStageEqualsLive) {
@ -890,11 +890,11 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
{
$pages = $this->getBreadcrumbItems($maxDepth, $stopAtPageType, $showHidden);
$template = SSViewer::create('BreadcrumbsTemplate');
return $template->process($this->customise(new ArrayData(array(
return $template->process($this->customise(new ArrayData([
"Pages" => $pages,
"Unlinked" => $unlinked,
"Delimiter" => $delimiter,
))));
])));
}
@ -910,7 +910,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
public function getBreadcrumbItems($maxDepth = 20, $stopAtPageType = false, $showHidden = false)
{
$page = $this;
$pages = array();
$pages = [];
while ($page
&& $page->exists()
@ -1016,7 +1016,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
* @param array $context Context argument for canCreate()
* @return bool True if the the member is allowed to do the given action
*/
public function can($perm, $member = null, $context = array())
public function can($perm, $member = null, $context = [])
{
if (!$member) {
$member = Security::getCurrentUser();
@ -1111,7 +1111,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
}
// admin override
if ($member && Permission::checkMember($member, array("ADMIN", "SITETREE_VIEW_ALL"))) {
if ($member && Permission::checkMember($member, ["ADMIN", "SITETREE_VIEW_ALL"])) {
return true;
}
@ -1212,7 +1212,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
}
// Default permission check
if (Permission::checkMember($member, array("ADMIN", "SITETREE_EDIT_ALL"))) {
if (Permission::checkMember($member, ["ADMIN", "SITETREE_EDIT_ALL"])) {
return true;
}
@ -1234,12 +1234,12 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
* @uses DataExtension->canCreate()
*
* @param Member $member
* @param array $context Optional array which may contain array('Parent' => $parentObj)
* @param array $context Optional array which may contain ['Parent' => $parentObj]
* If a parent page is known, it will be checked for validity.
* If omitted, it will be assumed this is to be created as a top level page.
* @return bool True if the current user can create pages on this class.
*/
public function canCreate($member = null, $context = array())
public function canCreate($member = null, $context = [])
{
if (!$member) {
$member = Security::getCurrentUser();
@ -1557,7 +1557,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$tablename = $this->baseTable();
$this->Sort = DB::prepared_query(
"SELECT MAX(\"Sort\") + 1 FROM \"$tablename\" WHERE \"ParentID\" = ?",
array($parentID)
[$parentID]
)->value();
}
@ -1565,7 +1565,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$defaultSegment = $this->generateURLSegment(_t(
'SilverStripe\\CMS\\Controllers\\CMSMain.NEWPAGE',
'New {pagetype}',
array('pagetype' => $this->i18n_singular_name())
['pagetype' => $this->i18n_singular_name()]
));
if ((!$this->URLSegment || $this->URLSegment == $defaultSegment) && $this->Title) {
$this->URLSegment = $this->generateURLSegment($this->Title);
@ -1597,7 +1597,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
}
// Check to see if we've only altered fields that shouldn't affect versioning
$fieldsIgnoredByVersioning = array('HasBrokenLink', 'Status', 'HasBrokenFile', 'ToDo', 'VersionID', 'SaveCount');
$fieldsIgnoredByVersioning = ['HasBrokenLink', 'Status', 'HasBrokenFile', 'ToDo', 'VersionID', 'SaveCount'];
$changedFields = array_keys($this->getChangedFields(true, 2));
// This more rigorous check is inline with the test that write() does to decide whether or not to write to the
@ -1682,7 +1682,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
_t(
'SilverStripe\\CMS\\Model\\SiteTree.PageTypeNotAllowed',
'Page type "{type}" not allowed as child of this parent page',
array('type' => $subject->i18n_singular_name())
['type' => $subject->i18n_singular_name()]
),
ValidationResult::TYPE_ERROR,
'ALLOWED_CHILDREN'
@ -1696,7 +1696,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
_t(
'SilverStripe\\CMS\\Model\\SiteTree.PageTypNotAllowedOnRoot',
'Page type "{type}" is not allowed on the root level',
array('type' => $this->i18n_singular_name())
['type' => $this->i18n_singular_name()]
),
ValidationResult::TYPE_ERROR,
'CAN_BE_ROOT'
@ -1888,10 +1888,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
}
// Redirector pages
$redirectors = RedirectorPage::get()->where(array(
$redirectors = RedirectorPage::get()->where([
'"RedirectorPage"."RedirectionType"' => 'Internal',
'"RedirectorPage"."LinkToID"' => $this->ID
))->alterDataQuery(function ($query) {
])->alterDataQuery(function ($query) {
$query->selectField("'Redirector page'", "DependentLinkType");
});
$items->merge($redirectors);
@ -1937,7 +1937,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
if ($this->ID && is_numeric($this->ID)) {
$linkedPages = $this->VirtualPages();
$parentPageLinks = array();
$parentPageLinks = [];
if ($linkedPages->count() > 0) {
/** @var VirtualPage $linkedPage */
@ -1964,7 +1964,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$statusMessage[] = _t(
'SilverStripe\\CMS\\Model\\SiteTree.APPEARSVIRTUALPAGES',
"This content also appears on the virtual pages in the {title} sections.",
array('title' => $parentList)
['title' => $parentList]
);
}
}
@ -1980,10 +1980,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$dependentPages = $this->DependentPages();
$dependentPagesCount = $dependentPages->count();
if ($dependentPagesCount) {
$dependentColumns = array(
$dependentColumns = [
'Title' => $this->fieldLabel('Title'),
'DependentLinkType' => _t(__CLASS__.'.DependtPageColumnLinkType', 'Link type'),
);
];
if (class_exists(Subsite::class)) {
$dependentColumns['Subsite.Title'] = Subsite::singleton()->i18n_singular_name();
}
@ -1998,7 +1998,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$dataColumns = $dependentTable->getConfig()->getComponentByType(GridFieldDataColumns::class);
$dataColumns
->setDisplayFields($dependentColumns)
->setFieldFormatting(array(
->setFieldFormatting([
'Title' => function ($value, &$item) {
$title = $item->Title;
$untitled = _t(
@ -2016,7 +2016,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$tag
);
}
));
]);
$dependentTable->getConfig()->addComponent(new GridFieldLazyLoader());
}
@ -2030,7 +2030,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
->setDefaultURL($this->generateURLSegment(_t(
'SilverStripe\\CMS\\Controllers\\CMSMain.NEWPAGE',
'New {pagetype}',
array('pagetype' => $this->i18n_singular_name())
['pagetype' => $this->i18n_singular_name()]
)))
->addExtraClass(($this->isHomePage() ? 'homepage-warning' : ''));
$helpText = (self::config()->get('nested_urls') && $this->numChildren())
@ -2053,10 +2053,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
ToggleCompositeField::create(
'Metadata',
_t(__CLASS__.'.MetadataToggle', 'Metadata'),
array(
[
$metaFieldDesc = new TextareaField("MetaDescription", $this->fieldLabel('MetaDescription')),
$metaFieldExtra = new TextareaField("ExtraMeta", $this->fieldLabel('ExtraMeta'))
)
]
)->setHeadingLevel(4)
),
$tabDependent = new Tab(
@ -2099,7 +2099,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$obsoleteWarning = _t(
'SilverStripe\\CMS\\Model\\SiteTree.OBSOLETECLASS',
"This page is of obsolete type {type}. Saving will reset its type and you may lose data",
array('type' => $this->ObsoleteClassName)
['type' => $this->ObsoleteClassName]
);
$fields->addFieldToTab(
@ -2159,10 +2159,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$this->getClassDropdown()
),
$parentTypeSelector = new CompositeField(
$parentType = new OptionsetField("ParentType", _t("SilverStripe\\CMS\\Model\\SiteTree.PAGELOCATION", "Page location"), array(
$parentType = new OptionsetField("ParentType", _t("SilverStripe\\CMS\\Model\\SiteTree.PAGELOCATION", "Page location"), [
"root" => _t("SilverStripe\\CMS\\Model\\SiteTree.PARENTTYPE_ROOT", "Top-level page"),
"subpage" => _t("SilverStripe\\CMS\\Model\\SiteTree.PARENTTYPE_SUBPAGE", "Sub-page underneath a parent page"),
)),
]),
$parentIDField = new TreeDropdownField("ParentID", $this->fieldLabel('ParentID'), self::class, 'ID', 'MenuTitle')
),
$visibility = new FieldGroup(
@ -2361,10 +2361,10 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$moreOptions->push(
new LiteralField(
'Information',
$this->customise(array(
$this->customise([
'Live' => $liveRecord,
'ExistsOnLive' => $isPublished
))->renderWith($infoTemplate)
])->renderWith($infoTemplate)
)
);
@ -2375,7 +2375,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
if ($stageRecord && $stageRecord->Version != $this->Version) {
$moreOptions->push(FormAction::create('email', _t('SilverStripe\\CMS\\Controllers\\CMSMain.EMAIL', 'Email')));
$moreOptions->push(FormAction::create('rollback', _t('SilverStripe\\CMS\\Controllers\\CMSMain.ROLLBACK', 'Roll back to this version')));
$actions = new FieldList(array($majorActions, $rootTabSet));
$actions = new FieldList([$majorActions, $rootTabSet]);
// getCMSActions() can be extended with updateCMSActions() on a extension
$this->extend('updateCMSActions', $actions);
@ -2481,7 +2481,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
}
}
$actions = new FieldList(array($majorActions, $rootTabSet));
$actions = new FieldList([$majorActions, $rootTabSet]);
// Hook for extensions to add/remove actions.
$this->extend('updateCMSActions', $actions);
@ -2599,7 +2599,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
$classes = self::page_type_classes();
$currentClass = null;
$result = array();
$result = [];
foreach ($classes as $class) {
$instance = singleton($class);
@ -2613,7 +2613,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
if ($instance instanceof HiddenClass) {
continue;
}
if (!$instance->canCreate(null, array('Parent' => $this->ParentID ? $this->Parent() : null))) {
if (!$instance->canCreate(null, ['Parent' => $this->ParentID ? $this->Parent() : null])) {
continue;
}
}
@ -2829,7 +2829,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
* "deletedonlive" => "Deleted"
*
* Example (with optional title attribute):
* "deletedonlive" => array('text' => "Deleted", 'title' => 'This page has been deleted')
* "deletedonlive" => ['text' => "Deleted", 'title' => 'This page has been deleted']
*
* @param bool $cached Whether to serve the fields from cache; false regenerate them
* @return array
@ -2837,27 +2837,27 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
public function getStatusFlags($cached = true)
{
if (!$this->_cache_statusFlags || !$cached) {
$flags = array();
$flags = [];
if ($this->isOnLiveOnly()) {
$flags['removedfromdraft'] = array(
$flags['removedfromdraft'] = [
'text' => _t(__CLASS__.'.ONLIVEONLYSHORT', 'On live only'),
'title' => _t(__CLASS__.'.ONLIVEONLYSHORTHELP', 'Page is published, but has been deleted from draft'),
);
];
} elseif ($this->isArchived()) {
$flags['archived'] = array(
$flags['archived'] = [
'text' => _t(__CLASS__.'.ARCHIVEDPAGESHORT', 'Archived'),
'title' => _t(__CLASS__.'.ARCHIVEDPAGEHELP', 'Page is removed from draft and live'),
);
];
} elseif ($this->isOnDraftOnly()) {
$flags['addedtodraft'] = array(
$flags['addedtodraft'] = [
'text' => _t(__CLASS__.'.ADDEDTODRAFTSHORT', 'Draft'),
'title' => _t(__CLASS__.'.ADDEDTODRAFTHELP', "Page has not been published yet")
);
];
} elseif ($this->isModifiedOnDraft()) {
$flags['modified'] = array(
$flags['modified'] = [
'text' => _t(__CLASS__.'.MODIFIEDONDRAFTSHORT', 'Modified'),
'title' => _t(__CLASS__.'.MODIFIEDONDRAFTHELP', 'Page has unpublished changes'),
);
];
}
$this->extend('updateStatusFlags', $flags);
@ -2898,11 +2898,11 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
Convert::raw2htmlid(static::class),
$this->isHomePage() ? ' homepage' : '',
Convert::raw2att(json_encode($children)),
Convert::raw2xml(str_replace(array("\n","\r"), "", $this->MenuTitle))
Convert::raw2xml(str_replace(["\n","\r"], "", $this->MenuTitle))
);
foreach ($flags as $class => $data) {
if (is_string($data)) {
$data = array('text' => $data);
$data = ['text' => $data];
}
$treeTitle .= sprintf(
"<span class=\"badge %s\"%s>%s</span>",
@ -2925,7 +2925,7 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
public function Level($level)
{
$parent = $this;
$stack = array($parent);
$stack = [$parent];
while (($parent = $parent->Parent()) && $parent->exists()) {
array_unshift($stack, $parent);
}
@ -3039,38 +3039,38 @@ class SiteTree extends DataObject implements PermissionProvider, i18nEntityProvi
public function providePermissions()
{
return array(
'SITETREE_GRANT_ACCESS' => array(
return [
'SITETREE_GRANT_ACCESS' => [
'name' => _t(__CLASS__.'.PERMISSION_GRANTACCESS_DESCRIPTION', 'Manage access rights for content'),
'help' => _t(__CLASS__.'.PERMISSION_GRANTACCESS_HELP', 'Allow setting of page-specific access restrictions in the "Pages" section.'),
'category' => _t('SilverStripe\\Security\\Permission.PERMISSIONS_CATEGORY', 'Roles and access permissions'),
'sort' => 100
),
'SITETREE_VIEW_ALL' => array(
],
'SITETREE_VIEW_ALL' => [
'name' => _t(__CLASS__.'.VIEW_ALL_DESCRIPTION', 'View any page'),
'category' => _t('SilverStripe\\Security\\Permission.CONTENT_CATEGORY', 'Content permissions'),
'sort' => -100,
'help' => _t(__CLASS__.'.VIEW_ALL_HELP', 'Ability to view any page on the site, regardless of the settings on the Access tab. Requires the "Access to \'Pages\' section" permission')
),
'SITETREE_EDIT_ALL' => array(
],
'SITETREE_EDIT_ALL' => [
'name' => _t(__CLASS__.'.EDIT_ALL_DESCRIPTION', 'Edit any page'),
'category' => _t('SilverStripe\\Security\\Permission.CONTENT_CATEGORY', 'Content permissions'),
'sort' => -50,
'help' => _t(__CLASS__.'.EDIT_ALL_HELP', 'Ability to edit any page on the site, regardless of the settings on the Access tab. Requires the "Access to \'Pages\' section" permission')
),
'SITETREE_REORGANISE' => array(
],
'SITETREE_REORGANISE' => [
'name' => _t(__CLASS__.'.REORGANISE_DESCRIPTION', 'Change site structure'),
'category' => _t('SilverStripe\\Security\\Permission.CONTENT_CATEGORY', 'Content permissions'),
'help' => _t(__CLASS__.'.REORGANISE_HELP', 'Rearrange pages in the site tree through drag&drop.'),
'sort' => 100
),
'VIEW_DRAFT_CONTENT' => array(
],
'VIEW_DRAFT_CONTENT' => [
'name' => _t(__CLASS__.'.VIEW_DRAFT_CONTENT', 'View draft content'),
'category' => _t('SilverStripe\\Security\\Permission.CONTENT_CATEGORY', 'Content permissions'),
'help' => _t(__CLASS__.'.VIEW_DRAFT_CONTENT_HELP', 'Applies to viewing pages outside of the CMS in draft mode. Useful for external collaborators without CMS access.'),
'sort' => 100
)
);
]
];
}
/**

View File

@ -26,7 +26,7 @@ class SiteTreeLinkTracking_Parser
*/
public function process(HTMLValue $htmlValue)
{
$results = array();
$results = [];
$links = $htmlValue->getElementsByTagName('a');
if (!$links) {
@ -46,19 +46,19 @@ class SiteTreeLinkTracking_Parser
// Definitely broken links.
if ($href == '' || $href[0] == '/') {
$results[] = array(
$results[] = [
'Type' => 'broken',
'Target' => null,
'Anchor' => null,
'DOMReference' => $link,
'Broken' => true
);
];
continue;
}
// Link to a page on this site.
$matches = array();
$matches = [];
if (preg_match('/\[sitetree_link(?:\s*|%20|,)?id=(?<id>[0-9]+)\](#(?<anchor>.*))?/i', $href, $matches)) {
// Check if page link is broken
/** @var SiteTree $page */
@ -74,13 +74,13 @@ class SiteTreeLinkTracking_Parser
$broken = false;
}
$results[] = array(
$results[] = [
'Type' => 'sitetree',
'Target' => $matches['id'],
'Anchor' => empty($matches['anchor']) ? null : $matches['anchor'],
'DOMReference' => $link,
'Broken' => $broken
);
];
continue;
}
@ -88,13 +88,13 @@ class SiteTreeLinkTracking_Parser
// Local anchor.
if (preg_match('/^#(.*)/i', $href, $matches)) {
$anchor = preg_quote($matches[1], '#');
$results[] = array(
$results[] = [
'Type' => 'localanchor',
'Target' => null,
'Anchor' => $matches[1],
'DOMReference' => $link,
'Broken' => !preg_match("#(name|id)=\"{$anchor}\"#", $htmlValue->getContent())
);
];
continue;
}

View File

@ -37,7 +37,7 @@ class VirtualPage extends Page
* @var array Define fields that are not virtual - the virtual page must define these fields themselves.
* Note that anything in {@link self::config()->initially_copied_fields} is implicitly included in this list.
*/
private static $non_virtual_fields = array(
private static $non_virtual_fields = [
"ID",
"ClassName",
"ObsoleteClassName",
@ -57,28 +57,28 @@ class VirtualPage extends Page
"CanEditType",
"CopyContentFromID",
"HasBrokenLink",
);
];
/**
* @var array Define fields that are initially copied to virtual pages but left modifiable after that.
*/
private static $initially_copied_fields = array(
private static $initially_copied_fields = [
'ShowInMenus',
'ShowInSearch',
'URLSegment',
);
];
private static $has_one = array(
private static $has_one = [
"CopyContentFrom" => SiteTree::class,
);
];
private static $owns = array(
private static $owns = [
"CopyContentFrom",
);
];
private static $db = array(
private static $db = [
"VersionID" => "Int",
);
];
private static $table_name = 'VirtualPage';
@ -92,7 +92,7 @@ class VirtualPage extends Page
// Check if copied page exists
$record = $this->CopyContentFrom();
if (!$record || !$record->exists()) {
return array();
return [];
}
// Diff db with non-virtual fields
@ -160,7 +160,7 @@ class VirtualPage extends Page
if ($copy && $copy->exists()) {
return $copy->allowedChildren();
}
return array();
return [];
}
public function syncLinkTracking()
@ -237,7 +237,7 @@ class VirtualPage extends Page
}
}
$msgs = array();
$msgs = [];
$fields->addFieldToTab('Root.Main', $copyContentFromField, 'Title');
@ -350,7 +350,7 @@ class VirtualPage extends Page
_t(
self::class . '.PageTypNotAllowedOnRoot',
'Original page type "{type}" is not allowed on the root level for this virtual page',
array('type' => $orig->i18n_singular_name())
['type' => $orig->i18n_singular_name()]
),
ValidationResult::TYPE_ERROR,
'CAN_BE_ROOT_VIRTUAL'
@ -474,7 +474,7 @@ class VirtualPage extends Page
if (parent::hasMethod($method)) {
return parent::__call($method, $args);
} else {
return call_user_func_array(array($this->CopyContentFrom(), $method), $args);
return call_user_func_array([$this->CopyContentFrom(), $method], $args);
}
}

View File

@ -34,9 +34,9 @@ class BrokenFilesReport extends Report
ClassInfo::subclassesFor(RedirectorPage::class)
);
$classParams = DB::placeholders($classes);
$classFilter = array(
$classFilter = [
"\"ClassName\" IN ($classParams) AND \"HasBrokenFile\" = 1" => $classes
);
];
$stage = isset($params['OnLive']) ? Versioned::LIVE : Versioned::DRAFT;
return Versioned::get_by_stage(SiteTree::class, $stage, $classFilter);
@ -44,12 +44,12 @@ class BrokenFilesReport extends Report
public function columns()
{
return array(
"Title" => array(
return [
"Title" => [
"title" => "Title", // todo: use NestedTitle(2)
"link" => true,
),
);
],
];
}
public function getParameterFields()

View File

@ -157,10 +157,10 @@ class BrokenLinksReport extends Report
public function parameterFields()
{
return FieldList::create(
DropdownField::create('CheckSite', _t(__CLASS__ . '.CheckSite', 'Check site'), array(
DropdownField::create('CheckSite', _t(__CLASS__ . '.CheckSite', 'Check site'), [
'Published' => _t(__CLASS__ . '.CheckSiteDropdownPublished', 'Published Site'),
'Draft' => _t(__CLASS__ . '.CheckSiteDropdownDraft', 'Draft Site')
)),
]),
DropdownField::create(
'Reason',
_t(__CLASS__ . '.ReasonDropdown', 'Problem to check'),

View File

@ -28,21 +28,21 @@ class BrokenRedirectorPagesReport extends Report
{
$classes = ClassInfo::subclassesFor(RedirectorPage::class);
$classParams = DB::placeholders($classes);
$classFilter = array(
$classFilter = [
"\"ClassName\" IN ($classParams) AND \"HasBrokenLink\" = 1" => $classes
);
];
$stage = isset($params['OnLive']) ? 'Live' : 'Stage';
return Versioned::get_by_stage(SiteTree::class, $stage, $classFilter);
}
public function columns()
{
return array(
"Title" => array(
return [
"Title" => [
"title" => "Title", // todo: use NestedTitle(2)
"link" => true,
),
);
],
];
}
public function getParameterFields()

View File

@ -28,21 +28,21 @@ class BrokenVirtualPagesReport extends Report
{
$classes = ClassInfo::subclassesFor(VirtualPage::class);
$classParams = DB::placeholders($classes);
$classFilter = array(
$classFilter = [
"\"ClassName\" IN ($classParams) AND \"HasBrokenLink\" = 1" => $classes
);
];
$stage = isset($params['OnLive']) ? 'Live' : 'Stage';
return Versioned::get_by_stage(SiteTree::class, $stage, $classFilter);
}
public function columns()
{
return array(
"Title" => array(
return [
"Title" => [
"title" => "Title", // todo: use NestedTitle(2)
"link" => true,
),
);
],
];
}
public function getParameterFields()

View File

@ -41,11 +41,11 @@ class EmptyPagesReport extends Report
public function columns()
{
return array(
"Title" => array(
return [
"Title" => [
"title" => "Title", // todo: use NestedTitle(2)
"link" => true,
),
);
],
];
}
}

View File

@ -36,11 +36,11 @@ class RecentlyEditedReport extends Report
public function columns()
{
return array(
"Title" => array(
return [
"Title" => [
"title" => "Title", // todo: use NestedTitle(2)
"link" => true,
),
);
],
];
}
}

View File

@ -15,9 +15,9 @@ use SilverStripe\ORM\Search\FulltextSearchable;
*/
class ContentControllerSearchExtension extends Extension
{
private static $allowed_actions = array(
private static $allowed_actions = [
'SearchForm',
);
];
/**
* Site search form
@ -54,11 +54,11 @@ class ContentControllerSearchExtension extends Extension
*/
public function results($data, $form, $request)
{
$data = array(
$data = [
'Results' => $form->getResults(),
'Query' => DBField::create_field('Text', $form->getSearchQuery()),
'Title' => _t('SilverStripe\\CMS\\Search\\SearchForm.SearchResults', 'Search Results')
);
return $this->owner->customise($data)->renderWith(array('Page_results', 'Page'));
];
return $this->owner->customise($data)->renderWith(['Page_results', 'Page']);
}
}

View File

@ -41,14 +41,14 @@ class SearchForm extends Form
*
* @var array
*/
protected $classesToSearch = array(
protected $classesToSearch = [
SiteTree::class,
File::class
);
];
private static $casting = array(
private static $casting = [
'SearchQuery' => 'Text'
);
];
/**
* @skipUpgrade
@ -97,7 +97,7 @@ class SearchForm extends Form
*/
public function classesToSearch($classes)
{
$supportedClasses = array(SiteTree::class, File::class);
$supportedClasses = [SiteTree::class, File::class];
$illegalClasses = array_diff($classes, $supportedClasses);
if ($illegalClasses) {
throw new BadMethodCallException(

View File

@ -40,12 +40,12 @@ use SilverStripe\View\Requirements;
class RemoveOrphanedPagesTask extends Controller
{
private static $allowed_actions = array(
private static $allowed_actions = [
'index' => 'ADMIN',
'Form' => 'ADMIN',
'run' => 'ADMIN',
'handleAction' => 'ADMIN',
);
];
protected $title = 'Removed orphaned pages without existing parents from both stage and live';
@ -92,7 +92,7 @@ in the other stage:<br />
public function Form()
{
$fields = new FieldList();
$source = array();
$source = [];
$fields->push(new HeaderField(
'Header',
@ -113,7 +113,7 @@ in the other stage:<br />
$liveRecord = Versioned::get_one_by_stage(
$this->orphanedSearchClass,
'Live',
array("\"$orphanBaseTable\".\"ID\"" => $orphan->ID)
["\"$orphanBaseTable\".\"ID\"" => $orphan->ID]
);
$label = sprintf(
'<a href="admin/pages/edit/show/%d">%s</a> <small>(#%d, Last Modified Date: %s, Last Modifier: %s, %s)</small>',
@ -147,7 +147,7 @@ in the other stage:<br />
$fields->push(new OptionsetField(
'OrphanOperation',
_t('SilverStripe\\CMS\\Tasks\\RemoveOrphanedPagesTask.CHOOSEOPERATION', 'Choose operation:'),
array(
[
'rebase' => _t(
'SilverStripe\\CMS\\Tasks\\RemoveOrphanedPagesTask.OPERATION_REBASE',
sprintf(
@ -156,7 +156,7 @@ in the other stage:<br />
)
),
'remove' => _t('SilverStripe\\CMS\\Tasks\\RemoveOrphanedPagesTask.OPERATION_REMOVE', 'Remove selected from all stages (WARNING: Will destroy all selected pages from both stage and live)'),
),
],
'rebase'
));
$fields->push(new LiteralField(
@ -231,22 +231,22 @@ in the other stage:<br />
$content = _t('SilverStripe\\CMS\\Tasks\\RemoveOrphanedPagesTask.NONEREMOVED', 'None removed');
}
return $this->customise(array(
return $this->customise([
'Content' => $content,
'Form' => ' '
))->renderWith('BlankPage');
])->renderWith('BlankPage');
}
protected function removeOrphans($orphanIDs)
{
$removedOrphans = array();
$removedOrphans = [];
$orphanBaseTable = DataObject::getSchema()->baseDataTable($this->orphanedSearchClass);
foreach ($orphanIDs as $id) {
/** @var SiteTree $stageRecord */
$stageRecord = Versioned::get_one_by_stage(
$this->orphanedSearchClass,
Versioned::DRAFT,
array("\"$orphanBaseTable\".\"ID\"" => $id)
["\"$orphanBaseTable\".\"ID\"" => $id]
);
if ($stageRecord) {
$removedOrphans[$stageRecord->ID] = sprintf('Removed %s (#%d) from Stage', $stageRecord->Title, $stageRecord->ID);
@ -258,7 +258,7 @@ in the other stage:<br />
$liveRecord = Versioned::get_one_by_stage(
$this->orphanedSearchClass,
Versioned::LIVE,
array("\"$orphanBaseTable\".\"ID\"" => $id)
["\"$orphanBaseTable\".\"ID\"" => $id]
);
if ($liveRecord) {
$removedOrphans[$liveRecord->ID] = sprintf('Removed %s (#%d) from Live', $liveRecord->Title, $liveRecord->ID);
@ -285,14 +285,14 @@ in the other stage:<br />
$holder->Title = $this->rebaseHolderTitle();
$holder->write();
$removedOrphans = array();
$removedOrphans = [];
$orphanBaseTable = DataObject::getSchema()->baseDataTable($this->orphanedSearchClass);
foreach ($orphanIDs as $id) {
/** @var SiteTree $stageRecord */
$stageRecord = Versioned::get_one_by_stage(
$this->orphanedSearchClass,
'Stage',
array("\"$orphanBaseTable\".\"ID\"" => $id)
["\"$orphanBaseTable\".\"ID\"" => $id]
);
if ($stageRecord) {
$removedOrphans[$stageRecord->ID] = sprintf('Rebased %s (#%d)', $stageRecord->Title, $stageRecord->ID);
@ -308,7 +308,7 @@ in the other stage:<br />
$liveRecord = Versioned::get_one_by_stage(
$this->orphanedSearchClass,
'Live',
array("\"$orphanBaseTable\".\"ID\"" => $id)
["\"$orphanBaseTable\".\"ID\"" => $id]
);
if ($liveRecord) {
$removedOrphans[$liveRecord->ID] = sprintf('Rebased %s (#%d)', $liveRecord->Title, $liveRecord->ID);
@ -341,22 +341,22 @@ in the other stage:<br />
* @param int|array $limit
* @return SS_List
*/
public function getOrphanedPages($class = SiteTree::class, $filter = array(), $sort = null, $join = null, $limit = null)
public function getOrphanedPages($class = SiteTree::class, $filter = [], $sort = null, $join = null, $limit = null)
{
// Alter condition
$table = DataObject::getSchema()->tableName($class);
if (empty($filter)) {
$where = array();
$where = [];
} elseif (is_array($filter)) {
$where = $filter;
} else {
$where = array($filter);
$where = [$filter];
}
$where[] = array("\"{$table}\".\"ParentID\" != ?" => 0);
$where[] = ["\"{$table}\".\"ParentID\" != ?" => 0];
$where[] = '"Parents"."ID" IS NULL';
$orphans = new ArrayList();
foreach (array(Versioned::DRAFT, Versioned::LIVE) as $stage) {
foreach ([Versioned::DRAFT, Versioned::LIVE] as $stage) {
$table .= ($stage == Versioned::LIVE) ? '_Live' : '';
$stageOrphans = Versioned::get_by_stage(
$class,

View File

@ -9,9 +9,9 @@ use SilverStripe\ORM\DataObject;
class SiteTreeMaintenanceTask extends Controller
{
private static $allowed_actions = array(
private static $allowed_actions = [
'*' => 'ADMIN'
);
];
public function makelinksunique()
{
@ -27,13 +27,13 @@ class SiteTreeMaintenanceTask extends Controller
echo _t(
'SilverStripe\\CMS\\Model\\SiteTree.LINKSCHANGEDTO',
" changed {url1} -> {url2}",
array('url1' => $urlSegment, 'url2' => $page->URLSegment)
['url1' => $urlSegment, 'url2' => $page->URLSegment]
);
} else {
echo _t(
'SilverStripe\\CMS\\Model\\SiteTree.LINKSALREADYUNIQUE',
" {url} is already unique",
array('url' => $urlSegment)
['url' => $urlSegment]
);
}
die();

View File

@ -10,5 +10,8 @@
<exclude name="Squiz.Classes.ValidClassName.NotCamelCaps" />
<exclude name="Generic.Files.LineLength.TooLong" />
</rule>
<!-- use short array syntax -->
<rule ref="Generic.Arrays.DisallowLongArraySyntax" />
</ruleset>

View File

@ -52,7 +52,7 @@ class FixtureContext extends BehatFixtureContext
$targetObj = $this->fixtureFactory->get($targetClass, $targetId);
}
$fields = array('LinkToID' => $targetObj->ID);
$fields = ['LinkToID' => $targetObj->ID];
/** @var RedirectorPage $obj */
$obj = $this->fixtureFactory->get($class, $id);
if ($obj) {

View File

@ -12,8 +12,8 @@ class ThemeContext implements Context
{
use MainContextAwareTrait;
protected $restoreFiles = array();
protected $restoreDirectories = array();
protected $restoreFiles = [];
protected $restoreDirectories = [];
/**
* Create a test theme
@ -98,7 +98,7 @@ class ThemeContext implements Context
}
}
$this->restoreFiles = array();
$this->restoreFiles = [];
}
// Restore any created directories: that is, delete them
@ -109,7 +109,7 @@ class ThemeContext implements Context
rmdir($dir);
}
$this->restoreDirectories = array();
$this->restoreDirectories = [];
}
}
}

View File

@ -144,9 +144,9 @@ class CMSBatchActionsTest extends SapphireTest
// Run restore
$result = json_decode($action->run($list), true);
$this->assertEquals(
array(
[
$archivedxID => $archivedxID
),
],
$result['success']
);
$archivedx = SiteTree::get()->byID($archivedxID);
@ -164,12 +164,12 @@ class CMSBatchActionsTest extends SapphireTest
// Run restore
$result = json_decode($action->run($list), true);
$this->assertEquals(
array(
[
// Order of archived is opposite to order items are passed in, as
// these are sorted by level first
$archivedID => $archivedID,
$archivedyID => $archivedyID
),
],
$result['success']
);
$archived = SiteTree::get()->byID($archivedID);

View File

@ -30,7 +30,7 @@ class CMSMainTest extends FunctionalTest
{
protected static $fixture_file = 'CMSMainTest.yml';
protected static $orig = array();
protected static $orig = [];
public function setUp()
{
@ -136,7 +136,7 @@ class CMSMainTest extends FunctionalTest
// Some modules (e.g., cmsworkflow) will remove this action
$actions = CMSBatchActionHandler::config()->batch_actions;
if (isset($actions['publish'])) {
$response = $this->get('admin/pages/batchactions/publish?ajax=1&csvIDs=' . implode(',', array($page1->ID, $page2->ID)));
$response = $this->get('admin/pages/batchactions/publish?ajax=1&csvIDs=' . implode(',', [$page1->ID, $page2->ID]));
$responseData = json_decode($response->getBody(), true);
$this->assertArrayHasKey($page1->ID, $responseData['modified']);
$this->assertArrayHasKey($page2->ID, $responseData['modified']);
@ -144,8 +144,8 @@ class CMSMainTest extends FunctionalTest
// Get the latest version of the redirector page
$pageID = $this->idFromFixture(RedirectorPage::class, 'page5');
$latestID = DB::prepared_query('select max("Version") from "RedirectorPage_Versions" where "RecordID" = ?', array($pageID))->value();
$dsCount = DB::prepared_query('select count("Version") from "RedirectorPage_Versions" where "RecordID" = ? and "Version"= ?', array($pageID, $latestID))->value();
$latestID = DB::prepared_query('select max("Version") from "RedirectorPage_Versions" where "RecordID" = ?', [$pageID])->value();
$dsCount = DB::prepared_query('select count("Version") from "RedirectorPage_Versions" where "RecordID" = ? and "Version"= ?', [$pageID, $latestID])->value();
$this->assertEquals(1, $dsCount, "Published page has no duplicate version records: it has " . $dsCount . " for version " . $latestID);
$this->session()->clear('loggedInAs');
@ -213,9 +213,9 @@ class CMSMainTest extends FunctionalTest
$response = $this->get('admin/pages/edit/show/' . $pageID);
$livePage = Versioned::get_one_by_stage(SiteTree::class, Versioned::LIVE, array(
$livePage = Versioned::get_one_by_stage(SiteTree::class, Versioned::LIVE, [
'"SiteTree"."ID"' => $pageID
));
]);
$this->assertInstanceOf(SiteTree::class, $livePage);
$this->assertTrue($livePage->canDelete());
@ -274,16 +274,16 @@ class CMSMainTest extends FunctionalTest
$this->get('admin/pages/add');
$response = $this->post(
'admin/pages/add/AddForm',
array(
[
'ParentID' => '0',
'PageType' => 'Page',
'Locale' => 'en_US',
'action_doAdd' => 1,
'ajax' => 1,
),
array(
],
[
'X-Pjax' => 'CurrentForm,Breadcrumbs',
)
]
);
// should redirect, which is a permission error
$this->assertEquals(403, $response->getStatusCode(), 'Add TopLevel page must fail for normal user');
@ -294,16 +294,16 @@ class CMSMainTest extends FunctionalTest
$response = $this->post(
'admin/pages/add/AddForm',
array(
[
'ParentID' => '0',
'PageType' => 'Page',
'Locale' => 'en_US',
'action_doAdd' => 1,
'ajax' => 1,
),
array(
],
[
'X-Pjax' => 'CurrentForm,Breadcrumbs',
)
]
);
$location = $response->getHeader('X-ControllerURL');
@ -327,16 +327,16 @@ class CMSMainTest extends FunctionalTest
$this->get('admin/pages/add');
$response = $this->post(
'admin/pages/add/AddForm',
array(
[
'ParentID' => '0',
'PageType' => CMSMainTest_ClassA::class,
'Locale' => 'en_US',
'action_doAdd' => 1,
'ajax' => 1
),
array(
],
[
'X-Pjax' => 'CurrentForm,Breadcrumbs',
)
]
);
$this->assertFalse($response->isError());
$ok = preg_match('/edit\/show\/(\d*)/', $response->getHeader('X-ControllerURL'), $matches);
@ -347,16 +347,16 @@ class CMSMainTest extends FunctionalTest
$this->get('admin/pages/add');
$response = $this->post(
'admin/pages/add/AddForm',
array(
[
'ParentID' => $newPageId,
'PageType' => CMSMainTest_ClassB::class,
'Locale' => 'en_US',
'action_doAdd' => 1,
'ajax' => 1
),
array(
],
[
'X-Pjax' => 'CurrentForm,Breadcrumbs',
)
]
);
$this->assertFalse($response->isError());
$this->assertEmpty($response->getBody());
@ -373,16 +373,16 @@ class CMSMainTest extends FunctionalTest
$this->get('admin/pages/add');
$response = $this->post(
'admin/pages/add/AddForm',
array(
[
'ParentID' => $newPageId,
'PageType' => 'Page',
'Locale' => 'en_US',
'action_doAdd' => 1,
'ajax' => 1
),
array(
],
[
'X-Pjax' => 'CurrentForm,Breadcrumbs',
)
]
);
$this->assertEquals(403, $response->getStatusCode(), 'Add disallowed child should fail');
@ -445,7 +445,7 @@ class CMSMainTest extends FunctionalTest
$pages = $controller->getList()->sort('Title');
$this->assertEquals(28, $pages->count());
$this->assertEquals(
array('Home', 'Page 1', 'Page 10', 'Page 11', 'Page 12'),
['Home', 'Page 1', 'Page 10', 'Page 11', 'Page 12'],
$pages->Limit(5)->column('Title')
);
@ -467,40 +467,40 @@ class CMSMainTest extends FunctionalTest
$pages = $controller->getList()->sort('Title');
$this->assertEquals(26, $pages->count());
$this->assertEquals(
array('Home', 'Page 10', 'Page 11', 'Page 13', 'Page 14'),
['Home', 'Page 10', 'Page 11', 'Page 13', 'Page 14'],
$pages->Limit(5)->column('Title')
);
// Test deleted page filter
$params = array(
$params = [
'FilterClass' => 'SilverStripe\\CMS\\Controllers\\CMSSiteTreeFilter_StatusDeletedPages'
);
];
$pages = $controller->getList($params);
$this->assertEquals(1, $pages->count());
$this->assertEquals(
array('Page 1'),
['Page 1'],
$pages->column('Title')
);
// Test live, but not on draft filter
$params = array(
$params = [
'FilterClass' => 'SilverStripe\\CMS\\Controllers\\CMSSiteTreeFilter_StatusRemovedFromDraftPages'
);
];
$pages = $controller->getList($params);
$this->assertEquals(1, $pages->count());
$this->assertEquals(
array('Page 12'),
['Page 12'],
$pages->column('Title')
);
// Test live pages filter
$params = array(
$params = [
'FilterClass' => 'SilverStripe\\CMS\\Controllers\\CMSSiteTreeFilter_PublishedPages'
);
];
$pages = $controller->getList($params);
$this->assertEquals(2, $pages->count());
$this->assertEquals(
array('Page 11', 'Page 12'),
['Page 11', 'Page 12'],
$pages->column('Title')
);
@ -508,15 +508,15 @@ class CMSMainTest extends FunctionalTest
$pages = $controller->getList($params, $page3->ID);
$this->assertEquals(2, $pages->count());
$this->assertEquals(
array('Page 11', 'Page 12'),
['Page 11', 'Page 12'],
$pages->column('Title')
);
// Test that parentID is respected when not filtering
$pages = $controller->getList(array(), $page3->ID);
$pages = $controller->getList([], $page3->ID);
$this->assertEquals(2, $pages->count());
$this->assertEquals(
array('Page 3.1', 'Page 3.2'),
['Page 3.1', 'Page 3.2'],
$pages->column('Title')
);
}

View File

@ -10,7 +10,7 @@ class CMSMainTest_ClassA extends Page implements TestOnly
{
private static $table_name = 'CMSMainTest_ClassA';
private static $allowed_children = array(CMSMainTest_ClassB::class);
private static $allowed_children = [CMSMainTest_ClassB::class];
protected function onBeforeWrite()
{

View File

@ -131,12 +131,12 @@ class CMSPageHistoryControllerTest extends FunctionalTest
$form = $this->cssParser()->getBySelector('#Form_VersionsForm');
$rows = $form[0]->xpath("fieldset/table/tbody/tr");
$expected = array(
array('version' => $this->versionPublishCheck2, 'status' => 'published'),
array('version' => $this->versionUnpublishedCheck2, 'status' => 'internal'),
array('version' => $this->versionPublishCheck, 'status' => 'published'),
array('version' => $this->versionUnpublishedCheck, 'status' => 'internal')
);
$expected = [
['version' => $this->versionPublishCheck2, 'status' => 'published'],
['version' => $this->versionUnpublishedCheck2, 'status' => 'internal'],
['version' => $this->versionPublishCheck, 'status' => 'published'],
['version' => $this->versionUnpublishedCheck, 'status' => 'internal']
];
// goes the reverse order that we created in setUp()
$i = 0;

View File

@ -35,14 +35,14 @@ class CMSSiteTreeFilterTest extends SapphireTest
$page1 = $this->objFromFixture('Page', 'page1');
$page2 = $this->objFromFixture('Page', 'page2');
$f = new CMSSiteTreeFilter_Search(array('Title' => 'Page 1'));
$f = new CMSSiteTreeFilter_Search(['Title' => 'Page 1']);
$results = $f->pagesIncluded();
$this->assertTrue($f->isPageIncluded($page1));
$this->assertFalse($f->isPageIncluded($page2));
$this->assertEquals(1, count($results));
$this->assertEquals(
array('ID' => $page1->ID, 'ParentID' => 0),
['ID' => $page1->ID, 'ParentID' => 0],
$results[0]
);
}
@ -52,14 +52,14 @@ class CMSSiteTreeFilterTest extends SapphireTest
$parent = $this->objFromFixture('Page', 'page3');
$child = $this->objFromFixture('Page', 'page3b');
$f = new CMSSiteTreeFilter_Search(array('Title' => 'Page 3b'));
$f = new CMSSiteTreeFilter_Search(['Title' => 'Page 3b']);
$results = $f->pagesIncluded();
$this->assertTrue($f->isPageIncluded($parent));
$this->assertTrue($f->isPageIncluded($child));
$this->assertEquals(1, count($results));
$this->assertEquals(
array('ID' => $child->ID, 'ParentID' => $parent->ID),
['ID' => $child->ID, 'ParentID' => $parent->ID],
$results[0]
);
}
@ -79,19 +79,19 @@ class CMSSiteTreeFilterTest extends SapphireTest
$changedPageVersion = $changedPage->Version;
// Check that only changed pages are returned
$f = new CMSSiteTreeFilter_ChangedPages(array('Term' => 'Changed'));
$f = new CMSSiteTreeFilter_ChangedPages(['Term' => 'Changed']);
$results = $f->pagesIncluded();
$this->assertTrue($f->isPageIncluded($changedPage));
$this->assertFalse($f->isPageIncluded($unchangedPage));
$this->assertEquals(1, count($results));
$this->assertEquals(
array('ID' => $changedPage->ID, 'ParentID' => 0),
['ID' => $changedPage->ID, 'ParentID' => 0],
$results[0]
);
// Check that only changed pages are returned
$f = new CMSSiteTreeFilter_ChangedPages(array('Term' => 'No Matches'));
$f = new CMSSiteTreeFilter_ChangedPages(['Term' => 'No Matches']);
$results = $f->pagesIncluded();
$this->assertEquals(0, count($results));
@ -101,11 +101,11 @@ class CMSSiteTreeFilterTest extends SapphireTest
$changedPage->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
$changedPage->doRollbackTo($changedPageVersion);
$f = new CMSSiteTreeFilter_ChangedPages(array('Term' => 'Changed'));
$f = new CMSSiteTreeFilter_ChangedPages(['Term' => 'Changed']);
$results = $f->pagesIncluded();
$this->assertEquals(1, count($results));
$this->assertEquals(array('ID' => $changedPage->ID, 'ParentID' => 0), $results[0]);
$this->assertEquals(['ID' => $changedPage->ID, 'ParentID' => 0], $results[0]);
}
public function testDeletedPagesFilter()
@ -117,14 +117,14 @@ class CMSSiteTreeFilterTest extends SapphireTest
$deletedPage = Versioned::get_one_by_stage(
SiteTree::class,
'Live',
array('"SiteTree_Live"."ID"' => $deletedPageID)
['"SiteTree_Live"."ID"' => $deletedPageID]
);
$f = new CMSSiteTreeFilter_DeletedPages(array('Term' => 'Page'));
$f = new CMSSiteTreeFilter_DeletedPages(['Term' => 'Page']);
$this->assertTrue($f->isPageIncluded($deletedPage));
// Check that only changed pages are returned
$f = new CMSSiteTreeFilter_DeletedPages(array('Term' => 'No Matches'));
$f = new CMSSiteTreeFilter_DeletedPages(['Term' => 'No Matches']);
$this->assertFalse($f->isPageIncluded($deletedPage));
}
@ -138,11 +138,11 @@ class CMSSiteTreeFilterTest extends SapphireTest
);
// Check draft page is shown
$f = new CMSSiteTreeFilter_StatusDraftPages(array('Term' => 'Page'));
$f = new CMSSiteTreeFilter_StatusDraftPages(['Term' => 'Page']);
$this->assertTrue($f->isPageIncluded($draftPage));
// Check filter respects parameters
$f = new CMSSiteTreeFilter_StatusDraftPages(array('Term' => 'No Match'));
$f = new CMSSiteTreeFilter_StatusDraftPages(['Term' => 'No Match']);
$this->assertEmpty($f->isPageIncluded($draftPage));
// Ensures empty array returned if no data to show
@ -157,10 +157,10 @@ class CMSSiteTreeFilterTest extends SapphireTest
// Grab the date
$date = substr($draftPage->LastEdited, 0, 10);
// Filter with that date
$filter = new CMSSiteTreeFilter_Search(array(
$filter = new CMSSiteTreeFilter_Search([
'LastEditedFrom' => $date,
'LastEditedTo' => $date
));
]);
$this->assertTrue($filter->isPageIncluded($draftPage), 'Using the same date for from and to should show find that page');
}
@ -176,11 +176,11 @@ class CMSSiteTreeFilterTest extends SapphireTest
);
// Check live-only page is included
$f = new CMSSiteTreeFilter_StatusRemovedFromDraftPages(array('LastEditedFrom' => '2000-01-01 00:00'));
$f = new CMSSiteTreeFilter_StatusRemovedFromDraftPages(['LastEditedFrom' => '2000-01-01 00:00']);
$this->assertTrue($f->isPageIncluded($removedDraftPage));
// Check filter is respected
$f = new CMSSiteTreeFilter_StatusRemovedFromDraftPages(array('LastEditedTo' => '1999-01-01 00:00'));
$f = new CMSSiteTreeFilter_StatusRemovedFromDraftPages(['LastEditedTo' => '1999-01-01 00:00']);
$this->assertEmpty($f->isPageIncluded($removedDraftPage));
// Ensures empty array returned if no data to show
@ -201,11 +201,11 @@ class CMSSiteTreeFilterTest extends SapphireTest
$checkParentExists = Versioned::get_latest_version(SiteTree::class, $deletedPageID);
// Check deleted page is included
$f = new CMSSiteTreeFilter_StatusDeletedPages(array('Title' => 'Page'));
$f = new CMSSiteTreeFilter_StatusDeletedPages(['Title' => 'Page']);
$this->assertTrue($f->isPageIncluded($checkParentExists));
// Check filter is respected
$f = new CMSSiteTreeFilter_StatusDeletedPages(array('Title' => 'Bobby'));
$f = new CMSSiteTreeFilter_StatusDeletedPages(['Title' => 'Bobby']);
$this->assertFalse($f->isPageIncluded($checkParentExists));
}
}

View File

@ -29,11 +29,11 @@ class CMSTreeTest extends FunctionalTest
// Move page2 before page1
$siblingIDs[0] = $page2->ID;
$siblingIDs[1] = $page1->ID;
$data = array(
$data = [
'SiblingIDs' => $siblingIDs,
'ID' => $page2->ID,
'ParentID' => 0
);
];
$response = $this->post('admin/pages/edit/savetreenode', $data);
$this->assertEquals(200, $response->getStatusCode());
@ -59,16 +59,16 @@ class CMSTreeTest extends FunctionalTest
$page32 = $this->objFromFixture(SiteTree::class, 'page32');
// Move page2 into page3, between page3.1 and page 3.2
$siblingIDs = array(
$siblingIDs = [
$page31->ID,
$page2->ID,
$page32->ID
);
$data = array(
];
$data = [
'SiblingIDs' => $siblingIDs,
'ID' => $page2->ID,
'ParentID' => $page3->ID
);
];
$response = $this->post('admin/pages/edit/savetreenode', $data);
$this->assertEquals(200, $response->getStatusCode());
$page2 = DataObject::get_by_id(SiteTree::class, $page2->ID, false);

View File

@ -12,11 +12,11 @@ use Page;
class ContentControllerSearchExtensionTest extends SapphireTest
{
protected static $required_extensions = array(
protected static $required_extensions = [
ContentController::class => [
ContentControllerSearchExtension::class,
]
);
];
public function testCustomSearchFormClassesToTest()
{

View File

@ -7,13 +7,13 @@ use PageController;
class ContentControllerTestPageController extends PageController implements TestOnly
{
private static $allowed_actions = array(
private static $allowed_actions = [
'test',
'testwithouttemplate'
);
];
public function testwithouttemplate()
{
return array();
return [];
}
}

View File

@ -8,9 +8,9 @@ use PageController;
class ContentControllerTest_PageController extends PageController implements TestOnly
{
private static $allowed_actions = array(
private static $allowed_actions = [
'second_index'
);
];
public function index()
{

View File

@ -188,9 +188,9 @@ class ModelAsControllerTest extends FunctionalTest
{
$this->generateNestedPagesFixture();
$otherParent = new Page(array(
$otherParent = new Page([
'URLSegment' => 'otherparent'
));
]);
$otherParent->write();
$otherParent->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);
@ -232,10 +232,10 @@ class ModelAsControllerTest extends FunctionalTest
{
$this->generateNestedPagesFixture();
$otherLevel1 = new Page(array(
$otherLevel1 = new Page([
'Title' => "Other Level 1",
'URLSegment' => 'level1'
));
]);
$otherLevel1->write();
$otherLevel1->copyVersionToStage(Versioned::DRAFT, Versioned::LIVE);

View File

@ -79,15 +79,15 @@ class RedirectorPageTest extends FunctionalTest
public function testAllowsProtocolRelative()
{
$noProtocol = new RedirectorPage(array('ExternalURL' => 'mydomain.com'));
$noProtocol = new RedirectorPage(['ExternalURL' => 'mydomain.com']);
$noProtocol->write();
$this->assertEquals('http://mydomain.com', $noProtocol->ExternalURL);
$protocolAbsolute = new RedirectorPage(array('ExternalURL' => 'http://mydomain.com'));
$protocolAbsolute = new RedirectorPage(['ExternalURL' => 'http://mydomain.com']);
$protocolAbsolute->write();
$this->assertEquals('http://mydomain.com', $protocolAbsolute->ExternalURL);
$protocolRelative = new RedirectorPage(array('ExternalURL' => '//mydomain.com'));
$protocolRelative = new RedirectorPage(['ExternalURL' => '//mydomain.com']);
$protocolRelative->write();
$this->assertEquals('//mydomain.com', $protocolRelative->ExternalURL);
}

View File

@ -9,10 +9,10 @@ class SiteTreeBacklinksTestContentObject extends DataObject implements TestOnly
{
private static $table_name = 'BacklinkContent';
private static $db = array(
private static $db = [
'Title' => 'Text',
'Content' => 'HTMLText',
);
];
private static $singular_name = 'Backlink test content object';
}

View File

@ -9,9 +9,9 @@ use SilverStripe\ORM\DataExtension;
class SiteTreeBacklinksTest_DOD extends DataExtension implements TestOnly
{
private static $db = array(
private static $db = [
'ExtraContent' => 'HTMLText',
);
];
public function updateCMSFields(FieldList $fields)
{

View File

@ -55,7 +55,7 @@ class SiteTreeHTMLEditorFieldTest extends FunctionalTest
$editor->setValue("<a href=\"[sitetree_link,id=$aboutID]\">Example Link</a>");
$editor->saveInto($sitetree);
$sitetree->write();
$this->assertEquals(array($aboutID => $aboutID), $sitetree->LinkTracking()->getIdList(), 'Basic link tracking works.');
$this->assertEquals([$aboutID => $aboutID], $sitetree->LinkTracking()->getIdList(), 'Basic link tracking works.');
$editor->setValue(
"<a href=\"[sitetree_link,id=$aboutID]\"></a><a href=\"[sitetree_link,id=$contactID]\"></a>"
@ -63,7 +63,7 @@ class SiteTreeHTMLEditorFieldTest extends FunctionalTest
$editor->saveInto($sitetree);
$sitetree->write();
$this->assertEquals(
array($aboutID => $aboutID, $contactID => $contactID),
[$aboutID => $aboutID, $contactID => $contactID],
$sitetree->LinkTracking()->getIdList(),
'Tracking works on multiple links'
);
@ -71,14 +71,14 @@ class SiteTreeHTMLEditorFieldTest extends FunctionalTest
$editor->setValue(null);
$editor->saveInto($sitetree);
$sitetree->write();
$this->assertEquals(array(), $sitetree->LinkTracking()->getIdList(), 'Link tracking is removed when links are.');
$this->assertEquals([], $sitetree->LinkTracking()->getIdList(), 'Link tracking is removed when links are.');
// Legacy support - old CMS versions added link shortcodes with spaces instead of commas
$editor->setValue("<a href=\"[sitetree_link id=$aboutID]\">Example Link</a>");
$editor->saveInto($sitetree);
$sitetree->write();
$this->assertEquals(
array($aboutID => $aboutID),
[$aboutID => $aboutID],
$sitetree->LinkTracking()->getIdList(),
'Link tracking with space instead of comma in shortcode works.'
);

View File

@ -9,5 +9,5 @@ class SiteTreeTest_ClassC extends Page implements TestOnly
{
private static $table_name = 'SiteTreeTest_ClassC';
private static $allowed_children = array();
private static $allowed_children = [];
}

View File

@ -7,9 +7,9 @@ use PageController;
class SiteTreeTest_ConflictedController extends PageController implements TestOnly
{
private static $allowed_actions = array(
private static $allowed_actions = [
'conflicted-action'
);
];
public function hasActionTemplate($template)
{

View File

@ -9,12 +9,12 @@ class VirtualPageTest_ClassA extends Page implements TestOnly
{
private static $table_name = 'VirtualPageTest_ClassA';
private static $db = array(
private static $db = [
'MyInitiallyCopiedField' => 'Text',
'MyVirtualField' => 'Text',
'MyNonVirtualField' => 'Text',
'CastingTest' => VirtualPageTest_TestDBField::class,
);
];
private static $allowed_children = [
VirtualPageTest_ClassB::class,

View File

@ -9,5 +9,5 @@ class VirtualPageTest_ClassC extends Page implements TestOnly
{
private static $table_name = 'VirtualPageTest_ClassC';
private static $allowed_children = array();
private static $allowed_children = [];
}

View File

@ -7,10 +7,10 @@ use SilverStripe\ORM\DataExtension;
class VirtualPageTest_PageExtension extends DataExtension implements TestOnly
{
private static $db = array(
private static $db = [
// These fields are just on an extension to simulate shared properties between Page and VirtualPage.
// Not possible through direct $db definitions due to VirtualPage inheriting from Page, and Page being defined elsewhere.
'MySharedVirtualField' => 'Text',
'MySharedNonVirtualField' => 'Text',
);
];
}

View File

@ -10,8 +10,8 @@ class VirtualPageTest_PageWithAllowedChildren extends Page implements TestOnly
{
private static $table_name = 'VirtualPageTest_PageWithAllowedChildren';
private static $allowed_children = array(
private static $allowed_children = [
VirtualPageTest_ClassA::class,
VirtualPage::class,
);
];
}

View File

@ -9,7 +9,7 @@ class VirtualPageTest_VirtualPageSub extends VirtualPage implements TestOnly
{
private static $table_name = 'VirtualPageTest_VirtualPageSub';
private static $db = array(
private static $db = [
'MyProperty' => 'Varchar',
);
];
}

View File

@ -51,12 +51,12 @@ class CmsReportsTest extends SapphireTest
$class = get_class($report);
// ASSERT that the "draft" report is returning the correct results.
$parameters = array('CheckSite' => 'Draft');
$parameters = ['CheckSite' => 'Draft'];
$results = count($report->sourceRecords($parameters, null, null)) > 0;
$isDraftBroken ? $this->assertTrue($results, "{$class} has NOT returned the correct DRAFT results, as NO pages were found.") : $this->assertFalse($results, "{$class} has NOT returned the correct DRAFT results, as pages were found.");
// ASSERT that the "published" report is returning the correct results.
$parameters = array('CheckSite' => 'Published', 'OnLive' => 1);
$parameters = ['CheckSite' => 'Published', 'OnLive' => 1];
$results = count($report->sourceRecords($parameters, null, null)) > 0;
$isPublishedBroken ? $this->assertTrue($results, "{$class} has NOT returned the correct PUBLISHED results, as NO pages were found.") : $this->assertFalse($results, "{$class} has NOT returned the correct PUBLISHED results, as pages were found.");
}
@ -71,9 +71,9 @@ class CmsReportsTest extends SapphireTest
$r = new RecentlyEditedReport();
// check if contains only elements not older than $daysAgo days
$this->assertNotNull($r->records(array()));
$this->assertContains($after->ID, $r->records(array())->column('ID'));
$this->assertNotContains($before->ID, $r->records(array())->column('ID'));
$this->assertNotNull($r->records([]));
$this->assertContains($after->ID, $r->records([])->column('ID'));
$this->assertNotContains($before->ID, $r->records([])->column('ID'));
DBDatetime::clear_mock_now();
}

View File

@ -16,12 +16,12 @@ class CMSMainSearchFormTest extends FunctionalTest
$this->get(
'admin/pages/?' .
http_build_query(array(
'q' => array(
http_build_query([
'q' => [
'Term' => 'Page 10',
'FilterClass' => CMSSiteTreeFilter_Search::class,
)
))
]
])
);
$titles = $this->getPageTitles();
@ -33,7 +33,7 @@ class CMSMainSearchFormTest extends FunctionalTest
protected function getPageTitles()
{
$titles = array();
$titles = [];
$links = $this->cssParser()->getBySelector('.col-getTreeTitle span.item');
if ($links) {
foreach ($links as $link) {

View File

@ -95,13 +95,13 @@ class RemoveOrphanedPagesTaskTest extends FunctionalTest
$orphans = $task->getOrphanedPages();
$orphanIDs = $orphans->column('ID');
sort($orphanIDs);
$compareIDs = array(
$compareIDs = [
$child1_3_orphaned->ID,
$child1_4_orphaned_published->ID,
$grandchild1_1_3_orphaned->ID,
$grandchild1_1_4_orphaned_published->ID,
$child2_1_published_orphaned->ID
);
];
sort($compareIDs);
$this->assertEquals($orphanIDs, $compareIDs);