phpOMS/Model/Html/Head.php

345 lines
6.5 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.4
*
* @package phpOMS\Model\Html
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link https://orange-management.org
*/
declare(strict_types=1);
namespace phpOMS\Model\Html;
use phpOMS\Asset\AssetType;
use phpOMS\Contract\RenderableInterface;
use phpOMS\Localization\ISO639x1Enum;
/**
* Head class.
*
* Responsible for handling everything that's going on in the <head>
*
* @package phpOMS\Model\Html
* @license OMS License 1.0
* @link https://orange-management.org
* @since 1.0.0
*/
class Head implements RenderableInterface
{
/**
* Page language.
*
* @var string
* @since 1.0.0
*/
private $language = ISO639x1Enum::_EN;
/**
* Page title.
*
* @var string
* @since 1.0.0
*/
private $title = '';
/**
* Assets bound to this page instance.
*
* @var array
* @since 1.0.0
*/
private $assets = [];
/**
* Is the header set?
*
* @var bool
* @since 1.0.0
*/
private $hasContent = false;
/**
* Page meta.
*
* @var Meta
* @since 1.0.0
*/
private $meta = null;
/**
* html style.
*
* Inline style
*
* @var mixed[]
* @since 1.0.0
*/
private $style = [];
/**
* html script.
*
* @var mixed[]
* @since 1.0.0
*/
private $script = [];
/**
* Constructor.
*
* @since 1.0.0
*/
public function __construct()
{
$this->meta = new Meta();
}
/**
* Set page meta.
*
* @return Meta
*
* @since 1.0.0
*/
public function getMeta() : Meta
{
return $this->meta;
}
/**
* Set page title.
*
* @return string
*
* @since 1.0.0
*/
public function getTitle() : string
{
return $this->title;
}
/**
* Set page title.
*
* @param string $title Page title
*
* @return void
*
* @since 1.0.0
*/
public function setTitle(string $title) : void
{
$this->title = $title;
}
/**
* Set page title.
*
* @param int $type Asset type
* @param string $uri Asset uri
*
* @return void
*
* @since 1.0.0
*/
public function addAsset(int $type, string $uri, array $attributes = []) : void
{
$this->assets[$uri] = ['type' => $type, 'attributes' => $attributes];
}
/**
* Set page language.
*
* @param string $language language string
*
* @return void
*
* @since 1.0.0
*/
public function setLanguage(string $language) : void
{
$this->language = $language;
}
/**
* Get page language.
*
* @return string
*
* @since 1.0.0
*/
public function getLanguage() : string
{
return $this->language;
}
/**
* Get the evaluated contents of the object.
*
* @return string
*
* @since 1.0.0
*/
public function render() : string
{
$head = '';
$head .= $this->meta->render();
$head .= $this->renderAssets();
$head .= empty($this->style) ? '' : '<style>' . $this->renderStyle() . '</style>';
$head .= empty($this->script) ? '' : '<script>' . $this->renderScript() . '</script>';
return $head;
}
/**
* Render style.
*
* @return string
*
* @since 1.0.0
*/
public function renderStyle() : string
{
$style = '';
foreach ($this->style as $css) {
$style .= $css;
}
return $style;
}
/**
* Render script.
*
* @return string
*
* @since 1.0.0
*/
public function renderScript() : string
{
$script = '';
foreach ($this->script as $js) {
$script .= $js;
}
return $script;
}
/**
* Set a style.
*
* @param string $key Style key
* @param string $style Style source
* @param bool $overwrite Overwrite if already existing
*
* @return void
*
* @since 1.0.0
*/
public function setStyle(string $key, string $style, bool $overwrite = true) : void
{
if ($overwrite || !isset($this->script[$key])) {
$this->style[$key] = $style;
}
}
/**
* Set a script.
*
* @param string $key Script key
* @param string $script Script source
* @param bool $overwrite Overwrite if already existing
*
* @return void
*
* @since 1.0.0
*/
public function setScript(string $key, string $script, bool $overwrite = true) : void
{
if ($overwrite || !isset($this->script[$key])) {
$this->script[$key] = $script;
}
}
/**
* Get all styles.
*
* @return array
*
* @since 1.0.0
*/
public function getStyleAll() : array
{
return $this->style;
}
/**
* Get all scripts.
*
* @return array
*
* @since 1.0.0
*/
public function getScriptAll() : array
{
return $this->script;
}
/**
* Render assets.
*
* @return string
*
* @since 1.0.0
*/
public function renderAssets() : string
{
$rendered = '';
foreach ($this->assets as $uri => $asset) {
if ($asset['type'] === AssetType::CSS) {
$rendered .= '<link rel="stylesheet" type="text/css" href="' . $uri . '">';
} elseif ($asset['type'] === AssetType::JS) {
$rendered .= '<script src="' . $uri . '"';
foreach ($asset['attributes'] as $key => $attribute) {
$rendered .= ' ' . $key . '="' . $attribute . '"';
}
$rendered .= '></script>';
}
}
return $rendered;
}
/**
* Render assets.
*
* @return string
*
* @since 1.0.0
*/
public function renderAssetsLate() : string
{
$rendered = '';
foreach ($this->assets as $uri => $asset) {
if ($asset['type'] === AssetType::JSLATE) {
$rendered .= '<script src="' . $uri . '"';
foreach ($asset['attributes'] as $key => $attribute) {
$rendered .= ' ' . $key . '="' . $attribute . '"';
}
$rendered .= '></script>';
}
}
return $rendered;
}
}