mirror of
https://github.com/silverstripe/silverstripe-reports
synced 2024-10-22 11:05:53 +02:00
MERGE List view breadcrumbs
This commit is contained in:
parent
ca853d73f2
commit
e5000dd330
@ -26,4 +26,36 @@ class CMSPagesController extends CMSMain {
|
|||||||
public function isCurrentPage(DataObject $record) {
|
public function isCurrentPage(DataObject $record) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function Breadcrumbs($unlinked = false) {
|
||||||
|
$items = parent::Breadcrumbs($unlinked);
|
||||||
|
|
||||||
|
//special case for building the breadcrumbs when calling the listchildren Pages ListView action
|
||||||
|
if($parentID = $this->request->getVar('ParentID')) {
|
||||||
|
$page = DataObject::get_by_id('SiteTree', $parentID);
|
||||||
|
|
||||||
|
//build a reversed list of the parent tree
|
||||||
|
$pages = array();
|
||||||
|
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(
|
||||||
|
'view' => $this->request->getVar('view'),
|
||||||
|
'q' => $this->request->getVar('q')
|
||||||
|
));
|
||||||
|
foreach($pages as $page) {
|
||||||
|
$params['ParentID'] = $page->ID;
|
||||||
|
$item = new StdClass();
|
||||||
|
$item->Title = $page->Title;
|
||||||
|
$item->Link = Controller::join_links($this->Link(), '?' . http_build_query($params));
|
||||||
|
$items->push(new ArrayData($item));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $items;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user