silverstripe-widgets/code/extension/WidgetPageExtension.php

60 lines
1.4 KiB
PHP
Raw Normal View History

2013-04-16 16:07:41 +02:00
<?php
/**
* Adds a single {@link WidgetArea} called "SideBar" to {@link Page} classes.
* Adjust your templates to render the resulting
* {@link WidgetArea} as required, through the $SideBarView placeholder.
*
* This extension is just an example on how to use the widgets functionality,
* feel free to create your own relationships, naming conventions, etc.
* without using this class.
*/
class WidgetPageExtension extends DataExtension {
private static $db = array(
2013-04-16 16:07:41 +02:00
'InheritSideBar' => 'Boolean',
);
private static $defaults = array(
2013-04-16 16:07:41 +02:00
'InheritSideBar' => true
);
private static $has_one = array(
2013-04-16 16:07:41 +02:00
'SideBar' => 'WidgetArea'
);
public function updateCMSFields(FieldList $fields) {
2013-04-16 16:07:41 +02:00
$fields->addFieldToTab(
"Root.Widgets",
new CheckboxField("InheritSideBar", 'Inherit Sidebar From Parent')
);
$fields->addFieldToTab(
"Root.Widgets",
new WidgetAreaEditor("SideBar")
);
}
/**
* @return WidgetArea
*/
public function SideBarView() {
2013-04-16 16:07:41 +02:00
if(
$this->owner->InheritSideBar
&& ($parent = $this->owner->getParent())
&& $parent->hasMethod('SideBarView')
2013-04-16 16:07:41 +02:00
) {
return $parent->SideBarView();
2013-04-16 16:07:41 +02:00
} elseif($this->owner->SideBar()->exists()){
return $this->owner->SideBar();
}
}
/**
* Support Translatable so that we don't link WidgetAreas across translations
*/
public function onTranslatableCreate() {
//reset the sidebar ID
$this->owner->SideBarID = 0;
}
}