/src/View/ViewBuilder.php
https://gitlab.com/0072016/0072016-fbphp · PHP · 427 lines · 176 code · 54 blank · 197 comment · 19 complexity · 3a5f5aaedb00cd87a206fe545a693765 MD5 · raw file
- <?php
- /**
- * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
- * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- *
- * Licensed under The MIT License
- * For full copyright and license information, please see the LICENSE.txt
- * Redistributions of files must retain the above copyright notice.
- *
- * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- * @link http://cakephp.org CakePHP(tm) Project
- * @since 3.1.0
- * @license http://www.opensource.org/licenses/mit-license.php MIT License
- */
- namespace Cake\View;
- use Cake\Core\App;
- use Cake\Event\EventManager;
- use Cake\Network\Request;
- use Cake\Network\Response;
- use Cake\View\Exception\MissingViewException;
- use JsonSerializable;
- use Serializable;
- /**
- * Provides an API for iteratively building a view up.
- *
- * Once you have configured the view and established all the context
- * you can create a view instance with `build()`.
- */
- class ViewBuilder implements JsonSerializable, Serializable
- {
- /**
- * The subdirectory to the template.
- *
- * @var string
- */
- protected $_templatePath;
- /**
- * The template file to render.
- *
- * @var string
- */
- protected $_template;
- /**
- * The plugin name to use.
- *
- * @var string
- */
- protected $_plugin;
- /**
- * The theme name to use.
- *
- * @var string
- */
- protected $_theme;
- /**
- * The layout name to render.
- *
- * @var string
- */
- protected $_layout;
- /**
- * Whether or not autoLayout should be enabled.
- *
- * @var bool
- */
- protected $_autoLayout;
- /**
- * The layout path to build the view with.
- *
- * @var string
- */
- protected $_layoutPath;
- /**
- * The view variables to use
- *
- * @var string
- */
- protected $_name;
- /**
- * The view class name to use.
- * Can either use plugin notation, a short name
- * or a fully namespaced classname.
- *
- * @var string
- */
- protected $_className;
- /**
- * Additional options used when constructing the view.
- *
- * This options array lets you provide custom constructor
- * arguments to application/plugin view classes.
- *
- * @var array
- */
- protected $_options = [];
- /**
- * The helpers to use
- *
- * @var array
- */
- protected $_helpers = [];
- /**
- * Get/set path for template files.
- *
- * @param string|null $path Path for view files. If null returns current path.
- * @return string|$this
- */
- public function templatePath($path = null)
- {
- if ($path === null) {
- return $this->_templatePath;
- }
- $this->_templatePath = $path;
- return $this;
- }
- /**
- * Get/set path for layout files.
- *
- * @param string|null $path Path for layout files. If null returns current path.
- * @return string|$this
- */
- public function layoutPath($path = null)
- {
- if ($path === null) {
- return $this->_layoutPath;
- }
- $this->_layoutPath = $path;
- return $this;
- }
- /**
- * Turns on or off CakePHP's conventional mode of applying layout files.
- * On by default. Setting to off means that layouts will not be
- * automatically applied to rendered views.
- *
- * @param bool|null $autoLayout Boolean to turn on/off. If null returns current value.
- * @return bool|$this
- */
- public function autoLayout($autoLayout = null)
- {
- if ($autoLayout === null) {
- return $this->_autoLayout;
- }
- $this->_autoLayout = (bool)$autoLayout;
- return $this;
- }
- /**
- * The plugin name to use
- *
- * @param string|null|false $name Plugin name. If null returns current plugin.
- * Use false to remove the current plugin name.
- * @return string|$this
- */
- public function plugin($name = null)
- {
- if ($name === null) {
- return $this->_plugin;
- }
- $this->_plugin = $name;
- return $this;
- }
- /**
- * The helpers to use
- *
- * @param array|null $helpers Helpers to use.
- * @param bool $merge Whether or not to merge existing data with the new data.
- * @return array|$this
- */
- public function helpers(array $helpers = null, $merge = true)
- {
- if ($helpers === null) {
- return $this->_helpers;
- }
- if ($merge) {
- $helpers = array_merge($this->_helpers, $helpers);
- }
- $this->_helpers = $helpers;
- return $this;
- }
- /**
- * The view theme to use.
- *
- * @param string|null|false $theme Theme name. If null returns current theme.
- * Use false to remove the current theme.
- * @return string|$this
- */
- public function theme($theme = null)
- {
- if ($theme === null) {
- return $this->_theme;
- }
- $this->_theme = $theme;
- return $this;
- }
- /**
- * Get/set the name of the view file to render. The name specified is the
- * filename in /src/Template/<SubFolder> without the .ctp extension.
- *
- * @param string|null $name View file name to set. If null returns current name.
- * @return string|$this
- */
- public function template($name = null)
- {
- if ($name === null) {
- return $this->_template;
- }
- $this->_template = $name;
- return $this;
- }
- /**
- * Get/set the name of the layout file to render the view inside of.
- * The name specified is the filename of the layout in /src/Template/Layout
- * without the .ctp extension.
- *
- * @param string|null $name Layout file name to set. If null returns current name.
- * @return string|$this
- */
- public function layout($name = null)
- {
- if ($name === null) {
- return $this->_layout;
- }
- $this->_layout = $name;
- return $this;
- }
- /**
- * Set additional options for the view.
- *
- * This lets you provide custom constructor arguments to application/plugin view classes.
- *
- * @param array|null $options Either an array of options or null to get current options.
- * @param bool $merge Whether or not to merge existing data with the new data.
- * @return array|$this
- */
- public function options(array $options = null, $merge = true)
- {
- if ($options === null) {
- return $this->_options;
- }
- if ($merge) {
- $options = array_merge($this->_options, $options);
- }
- $this->_options = $options;
- return $this;
- }
- /**
- * Get/set the view name
- *
- * @param string|null $name The name of the view
- * @return array|$this
- */
- public function name($name = null)
- {
- if ($name === null) {
- return $this->_name;
- }
- $this->_name = $name;
- return $this;
- }
- /**
- * Get/set the view classname.
- *
- * Accepts either a short name (Ajax) a plugin name (MyPlugin.Ajax)
- * or a fully namespaced name (App\View\AppView).
- *
- * @param string|null $name The class name for the view. Can
- * be a plugin.class name reference, a short alias, or a fully
- * namespaced name.
- * @return array|$this
- */
- public function className($name = null)
- {
- if ($name === null) {
- return $this->_className;
- }
- $this->_className = $name;
- return $this;
- }
- /**
- * Using the data in the builder, create a view instance.
- *
- * If className() is null, App\View\AppView will be used.
- * If that class does not exist, then Cake\View\View will be used.
- *
- * @param array $vars The view variables/context to use.
- * @param \Cake\Network\Request|null $request The request to use.
- * @param \Cake\Network\Response|null $response The response to use.
- * @param \Cake\Event\EventManager|null $events The event manager to use.
- * @return \Cake\View\View
- * @throws \Cake\View\Exception\MissingViewException
- */
- public function build($vars = [], Request $request = null, Response $response = null, EventManager $events = null)
- {
- $className = $this->_className;
- if ($className === null) {
- $className = App::className('App', 'View', 'View') ?: 'Cake\View\View';
- }
- if ($className === 'View') {
- $className = App::className($className, 'View');
- } else {
- $className = App::className($className, 'View', 'View');
- }
- if (!$className) {
- throw new MissingViewException(['class' => $this->_className]);
- }
- $data = [
- 'name' => $this->_name,
- 'templatePath' => $this->_templatePath,
- 'template' => $this->_template,
- 'plugin' => $this->_plugin,
- 'theme' => $this->_theme,
- 'layout' => $this->_layout,
- 'autoLayout' => $this->_autoLayout,
- 'layoutPath' => $this->_layoutPath,
- 'helpers' => $this->_helpers,
- 'viewVars' => $vars,
- ];
- $data += $this->_options;
- return new $className($request, $response, $events, $data);
- }
- /**
- * Serializes the view builder object to a value that can be natively
- * serialized and re-used to clone this builder instance.
- *
- * @return array Serializable array of configuration properties.
- */
- public function jsonSerialize()
- {
- $properties = [
- '_templatePath', '_template', '_plugin', '_theme', '_layout', '_autoLayout',
- '_layoutPath', '_name', '_className', '_options', '_helpers'
- ];
- $array = [];
- foreach ($properties as $property) {
- $array[$property] = $this->{$property};
- }
- return array_filter($array, function ($i) {
- return !is_array($i) && strlen($i) || !empty($i);
- });
- }
- /**
- * Configures a view builder instance from serialized config.
- *
- * @param array $config View builder configuration array.
- * @return $this Configured view builder instance.
- */
- public function createFromArray($config)
- {
- foreach ($config as $property => $value) {
- $this->{$property} = $value;
- }
- return $this;
- }
- /**
- * Serializes the view builder object.
- *
- * @return string
- */
- public function serialize()
- {
- $array = $this->jsonSerialize();
- return serialize($array);
- }
- /**
- * Unserializes the view builder object.
- *
- * @param string $data Serialized string.
- * @return $this Configured view builder instance.
- */
- public function unserialize($data)
- {
- return $this->createFromArray(unserialize($data));
- }
- }