2014-05-14 23:24:20 +10:00
|
|
|
<?php namespace Cms\Classes;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The CMS layout class.
|
|
|
|
*
|
|
|
|
* @package october\cms
|
|
|
|
* @author Alexey Bobkov, Samuel Georges
|
|
|
|
*/
|
|
|
|
class Layout extends CmsCompoundObject
|
|
|
|
{
|
2016-03-12 15:32:16 +11:00
|
|
|
/**
|
|
|
|
* Fallback layout name.
|
|
|
|
*/
|
2014-05-14 23:24:20 +10:00
|
|
|
const FALLBACK_FILE_NAME = 'fallback';
|
|
|
|
|
|
|
|
/**
|
2016-03-12 15:32:16 +11:00
|
|
|
* @var string The container name associated with the model, eg: pages.
|
2014-05-14 23:24:20 +10:00
|
|
|
*/
|
2016-03-12 15:32:16 +11:00
|
|
|
protected $dirName = 'layouts';
|
|
|
|
|
2014-05-14 23:24:20 +10:00
|
|
|
/**
|
|
|
|
* Initializes the fallback layout.
|
2016-03-04 16:50:58 +01:00
|
|
|
* @param \Cms\Classes\Theme $theme Specifies a theme the file belongs to.
|
2015-10-06 00:26:29 +02:00
|
|
|
* @return \Cms\Classes\Layout
|
2014-05-14 23:24:20 +10:00
|
|
|
*/
|
|
|
|
public static function initFallback($theme)
|
|
|
|
{
|
2016-03-12 15:32:16 +11:00
|
|
|
$obj = self::inTheme($theme);
|
2014-05-14 23:24:20 +10: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 19:55:13 +03:00
|
|
|
return $this->fileName === self::FALLBACK_FILE_NAME;
|
2014-05-14 23:24:20 +10: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 19:55:13 +03:00
|
|
|
return LayoutCode::class;
|
2014-05-14 23:24:20 +10:00
|
|
|
}
|
|
|
|
}
|