| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290 |
- <?php
- /**
- * MINZ - Copyright 2011 Marien Fressinaud
- * Sous licence AGPL3 <http://www.gnu.org/licenses/>
- */
- /**
- * The Minz_View represents a view in the MVC paradigm
- */
- class Minz_View {
- const VIEWS_PATH_NAME = '/views';
- const LAYOUT_PATH_NAME = '/layout/';
- const LAYOUT_DEFAULT = 'layout';
- private $view_filename = '';
- private $layout_filename = '';
- private static $base_pathnames = array(APP_PATH);
- private static $title = '';
- private static $styles = array ();
- private static $scripts = array ();
- private static $params = array ();
- /**
- * Constructeur
- * Détermine si on utilise un layout ou non
- */
- public function __construct() {
- $this->_layout(self::LAYOUT_DEFAULT);
- $conf = Minz_Configuration::get('system');
- self::$title = $conf->title;
- }
- /**
- * [deprecated] Change the view file based on controller and action.
- */
- public function change_view($controller_name, $action_name) {
- Minz_Log::warning('Minz_View::change_view is deprecated, it will be removed in a future version. Please use Minz_View::_path instead.');
- $this->_path($controller_name. '/' . $action_name . '.phtml');
- }
- /**
- * Change the view file based on a pathname relative to VIEWS_PATH_NAME.
- *
- * @param string $path the new path
- */
- public function _path($path) {
- $this->view_filename = self::VIEWS_PATH_NAME . '/' . $path;
- }
- /**
- * Add a base pathname to search views.
- *
- * New pathnames will be added at the beginning of the list.
- *
- * @param string $base_pathname the new base pathname.
- */
- public static function addBasePathname($base_pathname) {
- array_unshift(self::$base_pathnames, $base_pathname);
- }
- /**
- * Construit la vue
- */
- public function build () {
- if ($this->layout_filename !== '') {
- $this->buildLayout ();
- } else {
- $this->render ();
- }
- }
- /**
- * Include a view file.
- *
- * The file is searched inside list of $base_pathnames.
- *
- * @param string $filename the name of the file to include.
- * @return boolean true if the file has been included, false else.
- */
- private function includeFile($filename) {
- // We search the filename in the list of base pathnames. Only the first view
- // found is considered.
- foreach (self::$base_pathnames as $base) {
- $absolute_filename = $base . $filename;
- if (file_exists($absolute_filename)) {
- include $absolute_filename;
- return true;
- }
- }
- return false;
- }
- /**
- * Construit le layout
- */
- public function buildLayout () {
- header('Content-Type: text/html; charset=UTF-8');
- if (!$this->includeFile($this->layout_filename)) {
- Minz_Log::notice('File not found: `' . $this->layout_filename . '`');
- }
- }
- /**
- * Affiche la Vue en elle-même
- */
- public function render () {
- if (!$this->includeFile($this->view_filename)) {
- Minz_Log::notice('File not found: `' . $this->view_filename . '`');
- }
- }
- /**
- * Ajoute un élément du layout
- * @param string $part l'élément partial à ajouter
- */
- public function partial ($part) {
- $fic_partial = self::LAYOUT_PATH_NAME . '/' . $part . '.phtml';
- if (!$this->includeFile($fic_partial)) {
- Minz_Log::warning('File not found: `' . $fic_partial . '`');
- }
- }
- /**
- * Affiche un élément graphique situé dans APP./views/helpers/
- * @param string $helper l'élément à afficher
- */
- public function renderHelper ($helper) {
- $fic_helper = '/views/helpers/' . $helper . '.phtml';
- if (!$this->includeFile($fic_helper)) {
- Minz_Log::warning('File not found: `' . $fic_helper . '`');
- }
- }
- /**
- * Retourne renderHelper() dans une chaîne
- * @param string $helper l'élément à traîter
- */
- public function helperToString($helper) {
- ob_start();
- $this->renderHelper($helper);
- return ob_get_clean();
- }
- /**
- * Choose the current view layout.
- * @param string|false $layout the layout name to use, false to use no layouts.
- */
- public function _layout($layout) {
- if ($layout) {
- $this->layout_filename = self::LAYOUT_PATH_NAME . $layout . '.phtml';
- } else {
- $this->layout_filename = '';
- }
- }
- /**
- * Choose if we want to use the layout or not.
- * @deprecated Please use the `_layout` function instead.
- * @param bool $use true if we want to use the layout, false else
- */
- public function _useLayout ($use) {
- Minz_Log::warning('Minz_View::_useLayout is deprecated, it will be removed in a future version. Please use Minz_View::_layout instead.');
- if ($use) {
- $this->_layout(self::LAYOUT_DEFAULT);
- } else {
- $this->_layout(false);
- }
- }
- /**
- * Gestion du titre
- */
- public static function title () {
- return self::$title;
- }
- public static function headTitle () {
- return '<title>' . self::$title . '</title>' . "\n";
- }
- public static function _title ($title) {
- self::$title = $title;
- }
- public static function prependTitle ($title) {
- self::$title = $title . self::$title;
- }
- public static function appendTitle ($title) {
- self::$title = self::$title . $title;
- }
- /**
- * Gestion des feuilles de style
- */
- public static function headStyle () {
- $styles = '';
- foreach(self::$styles as $style) {
- $cond = $style['cond'];
- if ($cond) {
- $styles .= '<!--[if ' . $cond . ']>';
- }
- $styles .= '<link rel="stylesheet" ' .
- ($style['media'] === 'all' ? '' : 'media="' . $style['media'] . '" ') .
- 'href="' . $style['url'] . '" />';
- if ($cond) {
- $styles .= '<![endif]-->';
- }
- $styles .= "\n";
- }
- return $styles;
- }
- public static function prependStyle ($url, $media = 'all', $cond = false) {
- array_unshift (self::$styles, array (
- 'url' => $url,
- 'media' => $media,
- 'cond' => $cond
- ));
- }
- public static function appendStyle ($url, $media = 'all', $cond = false) {
- self::$styles[] = array (
- 'url' => $url,
- 'media' => $media,
- 'cond' => $cond
- );
- }
- /**
- * Gestion des scripts JS
- */
- public static function headScript () {
- $scripts = '';
- foreach (self::$scripts as $script) {
- $cond = $script['cond'];
- if ($cond) {
- $scripts .= '<!--[if ' . $cond . ']>';
- }
- $scripts .= '<script src="' . $script['url'] . '"';
- if ($script['defer']) {
- $scripts .= ' defer="defer"';
- }
- if ($script['async']) {
- $scripts .= ' async="async"';
- }
- $scripts .= '></script>';
- if ($cond) {
- $scripts .= '<![endif]-->';
- }
- $scripts .= "\n";
- }
- return $scripts;
- }
- public static function prependScript ($url, $cond = false, $defer = true, $async = true) {
- array_unshift(self::$scripts, array (
- 'url' => $url,
- 'cond' => $cond,
- 'defer' => $defer,
- 'async' => $async,
- ));
- }
- public static function appendScript ($url, $cond = false, $defer = true, $async = true) {
- self::$scripts[] = array (
- 'url' => $url,
- 'cond' => $cond,
- 'defer' => $defer,
- 'async' => $async,
- );
- }
- /**
- * Gestion des paramètres ajoutés à la vue
- */
- public static function _param ($key, $value) {
- self::$params[$key] = $value;
- }
- public function attributeParams () {
- foreach (Minz_View::$params as $key => $value) {
- $this->$key = $value;
- }
- }
- }
|