You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
flight-core/flight/template/View.php

210 lines
4.1 KiB

14 years ago
<?php
declare(strict_types=1);
14 years ago
/**
* Flight: An extensible micro-framework.
14 years ago
*
* @copyright Copyright (c) 2011, Mike Cao <mike@mikecao.com>
* @license MIT, http://flightphp.com/license
14 years ago
*/
namespace flight\template;
/**
* The View class represents output to be displayed. It provides
* methods for managing view data and inserts the data into
* view templates upon rendering.
*/
class View
{
/**
11 years ago
* Location of view templates.
*
* @var string
*/
public $path;
/**
* File extension.
*
* @var string
*/
public $extension = '.php';
/**
* View variables.
*
* @var array<string, mixed>
*/
protected $vars = [];
14 years ago
/**
* Template file.
*
* @var string
*/
private $template;
/**
* Constructor.
*
* @param string $path Path to templates directory
*/
public function __construct($path = '.')
{
$this->path = $path;
14 years ago
}
/**
* Gets a template variable.
*
* @param string $key Key
*
* @return mixed Value
*/
public function get($key)
{
return $this->vars[$key] ?? null;
}
/**
* Sets a template variable.
*
* @param string|iterable<string, mixed> $key Key
* @param mixed $value Value
* @return static
*/
public function set($key, $value = null)
{
if (\is_array($key) || \is_object($key)) {
foreach ($key as $k => $v) {
$this->vars[$k] = $v;
}
} else {
$this->vars[$key] = $value;
}
return $this;
}
/**
* Checks if a template variable is set.
*
* @param string $key Key
*
* @return bool If key exists
*/
public function has($key)
{
return isset($this->vars[$key]);
}
/**
* Unsets a template variable. If no key is passed in, clear all variables.
*
* @param string $key Key
* @return static
*/
public function clear($key = null)
{
if (null === $key) {
$this->vars = [];
} else {
unset($this->vars[$key]);
}
return $this;
}
14 years ago
/**
* Renders a template.
*
* @param string $file Template file
* @param array<string, mixed> $data Template data
*
12 years ago
* @throws \Exception If template not found
* @return void
14 years ago
*/
public function render($file, $data = null)
{
$this->template = $this->getTemplate($file);
if (!file_exists($this->template)) {
throw new \Exception("Template file not found: {$this->template}.");
}
if (\is_array($data)) {
$this->vars = array_merge($this->vars, $data);
}
extract($this->vars);
include $this->template;
14 years ago
}
/**
* Gets the output of a template.
*
* @param string $file Template file
* @param array<string, mixed> $data Template data
*
12 years ago
* @return string Output of template
14 years ago
*/
public function fetch($file, $data = null)
{
14 years ago
ob_start();
$this->render($file, $data);
return ob_get_clean();
14 years ago
}
/**
* Checks if a template file exists.
*
* @param string $file Template file
*
* @return bool Template file exists
*/
public function exists($file)
{
return file_exists($this->getTemplate($file));
}
/**
* Gets the full path to a template file.
*
* @param string $file Template file
*
* @return string Template file location
*/
public function getTemplate($file)
{
$ext = $this->extension;
if (!empty($ext) && (substr($file, -1 * \strlen($ext)) != $ext)) {
$file .= $ext;
}
if (('/' == substr($file, 0, 1))) {
return $file;
}
return $this->path . '/' . $file;
}
14 years ago
/**
* Displays escaped output.
14 years ago
*
* @param string $str String to escape
*
* @return string Escaped string
14 years ago
*/
public function e($str)
{
$value = htmlentities($str);
echo $value;
return $value;
14 years ago
}
}