X-Git-Url: http://git.shiar.nl/minimedit.git/blobdiff_plain/f065f4739ae477d8877805463017f2e7b15e2db5..b04f76050d54c67844d5d4026993f6fab0edeae5:/article.inc.php diff --git a/article.inc.php b/article.inc.php index c630898..cff69ff 100644 --- a/article.inc.php +++ b/article.inc.php @@ -18,6 +18,7 @@ class ArchiveArticle { public $raw, $title, $body; # file contents public $meta = []; # head metadata properties + public $place = []; # template variables replaced in render() function __construct($path) { @@ -184,10 +185,9 @@ class ArchiveArticle $Page = clone $this; $Page->handler = $Page->handler . $Page->path; // .= with explicit getter $Page->path = ''; - $Place = $GLOBALS['Place']; foreach ($params as $param) { if ($set = strpos($param, '=')) { - $Place[ substr($param, 0, $set) ] = substr($param, $set + 1); + $Page->place[ substr($param, 0, $set) ] = substr($param, $set + 1); } elseif (!empty($param)) { $Page->path .= '/'.$param; @@ -205,11 +205,11 @@ class ArchiveArticle } } - function render($blocks = []) + function render() { $doc = ob_get_clean(); - if (!empty($blocks['warn'])) { + if (!empty($this->place['warn'])) { $warn = '

[[warn]]

'; if ($offset = strpos($doc, '')) { $doc = substr_replace($doc, "\n\n".$warn, $offset + 5, 0); @@ -226,9 +226,9 @@ class ArchiveArticle return preg_replace_callback( '{ \[\[ ([^] ]+) ([^]]*) \]\] }x', - function ($sub) use ($blocks) { + function ($sub) { list ($placeholder, $name, $params) = $sub; - $html = $blocks[$name] ?? + $html = $this->place[$name] ?? $this->widget($name, explode(' ', $params)); if (empty($html) or $html[0] != '<') { $html = "$html";