A naive PHP template library. Version 2 is a complete rewrite.
Extend Manychois\Views\AbstractView and define your template in body() function.
Use $this->inner() or $this->region() to set where you would like child content to be injected.
For child template, override getParentViewClass() to inform this library its parent class name.
Then you can use AbstractView::render($templateClassName, $viewData) for rendering.
The tests/ folder contains some example usages of AbstractView.
There are a few classes to help you generate HTML.
It contains 5 methods to escape string in different contexts.
attr(string $text, bool $unquoted = false)css(string $text)html(string $text)js(string $text, bool $templateMode = false)url(string $text)
It is used to manage stylesheet / script dependencies.
<?php
$r = new \Manychois\Views\ResourceLibrary();
$r->push('a', '<link rel="stylesheet" type="text/css" href="a.css" />', ['b']);
$r->push('b', '<link rel="stylesheet" type="text/css" href="b.css" />');
$result = $r->pull('a');The above $result will hold this array data:
[
'b' => '<link rel="stylesheet" type="text/css" href="b.css" />',
'a' => '<link rel="stylesheet" type="text/css" href="a.css" />'
]