2012-04-18 23:15:45 +02:00
|
|
|
<?php
|
2013-05-07 20:56:38 +12:00
|
|
|
|
2012-04-18 23:15:45 +02:00
|
|
|
/**
|
|
|
|
* Represents a set of widgets shown on a page.
|
2013-05-07 20:56:38 +12:00
|
|
|
*
|
|
|
|
* @package widgets
|
2012-04-18 23:15:45 +02:00
|
|
|
*/
|
2015-11-18 17:08:21 +13:00
|
|
|
class WidgetArea extends DataObject
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private static $has_many = array(
|
|
|
|
"Widgets" => "Widget"
|
|
|
|
);
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $template = __CLASS__;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Used in template instead of {@link Widgets()} to wrap each widget in its
|
|
|
|
* controller, making it easier to access and process form logic and
|
|
|
|
* actions stored in {@link WidgetController}.
|
|
|
|
*
|
|
|
|
* @return SS_List - Collection of {@link WidgetController} instances.
|
|
|
|
*/
|
|
|
|
public function WidgetControllers()
|
|
|
|
{
|
|
|
|
$controllers = new ArrayList();
|
2015-12-06 01:04:35 +01:00
|
|
|
$items = $this->ItemsToRender();
|
|
|
|
if (!is_null($items)){
|
|
|
|
foreach ($items as $widget) {
|
|
|
|
$controller = $widget->getController();
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-12-06 01:04:35 +01:00
|
|
|
$controller->init();
|
|
|
|
$controllers->push($controller);
|
|
|
|
}
|
2015-11-18 17:08:21 +13:00
|
|
|
}
|
|
|
|
return $controllers;
|
|
|
|
}
|
2012-04-18 23:15:45 +02:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
* @return HasManyList
|
|
|
|
*/
|
|
|
|
public function Items()
|
|
|
|
{
|
|
|
|
return $this->getComponents('Widgets');
|
|
|
|
}
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
* @return HasManyList
|
|
|
|
*/
|
|
|
|
public function ItemsToRender()
|
|
|
|
{
|
|
|
|
return $this->getComponents('Widgets')
|
|
|
|
->filter("Enabled", 1);
|
|
|
|
}
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
* @return string - HTML
|
|
|
|
*/
|
|
|
|
public function forTemplate()
|
|
|
|
{
|
|
|
|
return $this->renderWith($this->template);
|
|
|
|
}
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $template
|
|
|
|
*/
|
|
|
|
public function setTemplate($template)
|
|
|
|
{
|
|
|
|
$this->template = $template;
|
|
|
|
}
|
2012-10-06 10:47:26 +13:00
|
|
|
|
2015-11-18 17:08:21 +13:00
|
|
|
/**
|
|
|
|
* Delete all connected Widgets when this WidgetArea gets deleted
|
|
|
|
*/
|
|
|
|
public function onBeforeDelete()
|
|
|
|
{
|
|
|
|
parent::onBeforeDelete();
|
|
|
|
foreach ($this->Widgets() as $widget) {
|
|
|
|
$widget->delete();
|
|
|
|
}
|
|
|
|
}
|
2012-04-18 23:15:45 +02:00
|
|
|
}
|