From 7d9873472b51c362910f6d5610b9b855f3ae48b2 Mon Sep 17 00:00:00 2001 From: Normann Lou Date: Thu, 5 Apr 2012 17:32:24 +1200 Subject: [PATCH] ENHANCEMENT SSF-124 customise displayed fields of page list view, add children list view links --- code/controllers/CMSMain.php | 44 ++++++++++++++++++++++++++++++++---- code/model/SiteTree.php | 7 ++++++ 2 files changed, 46 insertions(+), 5 deletions(-) diff --git a/code/controllers/CMSMain.php b/code/controllers/CMSMain.php index 0b0919cb..52c5203a 100644 --- a/code/controllers/CMSMain.php +++ b/code/controllers/CMSMain.php @@ -524,7 +524,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr * * @return SS_List */ - public function getList() { + public function getList(&$filterOnOff) { $list = new DataList($this->stat('tree_class')); $request = $this->request; @@ -535,26 +535,51 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr throw new Exception(sprintf('Invalid filter class passed: %s', $filterClass)); } $filter = new $filterClass($request->requestVars()); + $filterOn = true; foreach($pages=$filter->pagesIncluded() as $pageMap){ $ids[] = $pageMap['ID']; } + if(count($ids)) $list->where('"'.$this->stat('tree_class').'"."ID" IN ('.implode(",", $ids).')'); + }else{ + $list->filter("ParentID", 0); } - - if(count($ids)) $list->where('"'.$this->stat('tree_class').'"."ID" IN ('.implode(",", $ids).')'); + return $list; } public function getListView(){ - $list = $this->getList(); + $filterOn = false; + $list = $this->getList($filterOn); $gridFieldConfig = GridFieldConfig::create()->addComponents( new GridFieldSortableHeader(), new GridFieldDataColumns(), new GridFieldPaginator(15), new GridFieldEditButton(), - new GridFieldDeleteAction(), new GridFieldDetailForm() ); $gridField = new GridField('Page','Pages', $list, $gridFieldConfig); + + if($filterOn){ + $gridField->setDisplayFields(array( + 'getTreeTitle' => _t('SiteTree.PAGETITLE', 'Page Title'), + 'Created' => _t('SiteTree.CREATED', 'Date Created'), + 'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'), + )); + }else{ + $gridField->setDisplayFields(array( + 'listChildrenLink' => "", + 'getTreeTitle' => _t('SiteTree.PAGETITLE', 'Page Title'), + 'Created' => _t('SiteTree.CREATED', 'Date Created'), + 'LastEdited' => _t('SiteTree.LASTUPDATED', 'Last Updated'), + )); + } + + $gridField->setFieldCasting(array( + 'Created' => 'Date->Ago', + 'LastEdited' => 'Date->Ago', + + )); + $listview = new Form( $this, 'ListView', @@ -563,6 +588,7 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr ); $this->extend('updateListView', $listview); + $listview->disableSecurityToken(); return $listview; } @@ -587,6 +613,14 @@ class CMSMain extends LeftAndMain implements CurrentPageIdentifier, PermissionPr return $id; } + + public function listchildren(){ + if(Director::is_ajax()){ + return $this; + }else{ + + } + } //------------------------------------------------------------------------------------------// // Data saving handlers diff --git a/code/model/SiteTree.php b/code/model/SiteTree.php index 3e11def3..cbb98c38 100644 --- a/code/model/SiteTree.php +++ b/code/model/SiteTree.php @@ -2448,6 +2448,13 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid Deprecation::notice('3.0', 'Use getTreeTitle() instead.'); return $this->getTreeTitle(); } + + function listChildrenLink(){ + if($num = $this->numChildren()){ + $link = singleton('CMSPagesController')->Link('listchildren')."/".$this->ID; + return ''.$num.''; + } + } /** * TitleWithStatus will return the title in an , or