2014-05-14 13:24:20 +00:00
|
|
|
<?php namespace Cms\Classes;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The CMS layout class.
|
|
|
|
|
*
|
|
|
|
|
* @package october\cms
|
|
|
|
|
* @author Alexey Bobkov, Samuel Georges
|
|
|
|
|
*/
|
|
|
|
|
class Layout extends CmsCompoundObject
|
|
|
|
|
{
|
2016-03-12 04:32:16 +00:00
|
|
|
/**
|
|
|
|
|
* Fallback layout name.
|
|
|
|
|
*/
|
2014-05-14 13:24:20 +00:00
|
|
|
const FALLBACK_FILE_NAME = 'fallback';
|
|
|
|
|
|
|
|
|
|
/**
|
2016-03-12 04:32:16 +00:00
|
|
|
* @var string The container name associated with the model, eg: pages.
|
2014-05-14 13:24:20 +00:00
|
|
|
*/
|
2016-03-12 04:32:16 +00:00
|
|
|
protected $dirName = 'layouts';
|
|
|
|
|
|
2014-05-14 13:24:20 +00:00
|
|
|
/**
|
|
|
|
|
* Initializes the fallback layout.
|
2016-03-04 15:50:58 +00:00
|
|
|
* @param \Cms\Classes\Theme $theme Specifies a theme the file belongs to.
|
2015-10-05 22:26:29 +00:00
|
|
|
* @return \Cms\Classes\Layout
|
2014-05-14 13:24:20 +00:00
|
|
|
*/
|
|
|
|
|
public static function initFallback($theme)
|
|
|
|
|
{
|
2016-03-12 04:32:16 +00:00
|
|
|
$obj = self::inTheme($theme);
|
2014-05-14 13:24:20 +00:00
|
|
|
$obj->markup = '{% page %}';
|
|
|
|
|
$obj->fileName = self::FALLBACK_FILE_NAME;
|
|
|
|
|
return $obj;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns true if the layout is a fallback layout
|
|
|
|
|
* @return boolean
|
|
|
|
|
*/
|
|
|
|
|
public function isFallBack()
|
|
|
|
|
{
|
2018-03-22 16:55:13 +00:00
|
|
|
return $this->fileName === self::FALLBACK_FILE_NAME;
|
2014-05-14 13:24:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns name of a PHP class to us a parent for the PHP class created for the object's PHP section.
|
|
|
|
|
* @return mixed Returns the class name or null.
|
|
|
|
|
*/
|
|
|
|
|
public function getCodeClassParent()
|
|
|
|
|
{
|
2018-03-22 16:55:13 +00:00
|
|
|
return LayoutCode::class;
|
2014-05-14 13:24:20 +00:00
|
|
|
}
|
|
|
|
|
}
|