*/ /** * La classe View représente la vue de l'application */ class Minz_View { const VIEWS_PATH_NAME = '/views'; const LAYOUT_PATH_NAME = '/layout'; const LAYOUT_FILENAME = '/layout.phtml'; private $view_filename = ''; private $use_layout = true; 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->change_view(Minz_Request::controllerName(), Minz_Request::actionName()); $conf = Minz_Configuration::get('system'); self::$title = $conf->title; } /** * Change le fichier de vue en fonction d'un controller / action */ public function change_view($controller_name, $action_name) { $this->view_filename = self::VIEWS_PATH_NAME . '/' . $controller_name . '/' . $action_name . '.phtml'; } /** * Add a base pathname to search views. * * New pathnames will be added at the beginning of the list. * * @param $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->use_layout) { $this->buildLayout (); } else { $this->render (); } } /** * Include a view file. * * The file is searched inside list of $base_pathnames. * * @param $filename the name of the file to include. * @return 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'); $this->includeFile(self::LAYOUT_PATH_NAME . self::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 $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 $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 $helper l'élément à traîter */ public function helperToString($helper) { ob_start(); $this->renderHelper($helper); return ob_get_clean(); } /** * Permet de choisir si on souhaite utiliser le layout * @param $use true si on souhaite utiliser le layout, false sinon */ public function _useLayout ($use) { $this->use_layout = $use; } /** * Gestion du titre */ public static function title () { return self::$title; } public static function headTitle () { return '