X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/a5cbc9ddb6ad65b17f83d2931e3318d94e498a0e..f547127c637332119b42329ca78d0e1a659d9739:/article.inc.php?ds=inline diff --git a/article.inc.php b/article.inc.php index 6c3ca93..30de51e 100644 --- a/article.inc.php +++ b/article.inc.php @@ -1,23 +1,9 @@ 0 ? $monthname[intval($parts[1])] : '', $parts[0], - count($parts) > 5 ? "$parts[3]:$parts[4]" : '', - ])); -} - class ArchiveArticle { public $raw, $title, $body; # file contents - public $meta = []; + public $meta = []; # head metadata properties + public $place = []; # template variables replaced in render() function __construct($path) { @@ -46,6 +32,8 @@ class ArchiveArticle if (preg_match('{
[[warn]]
'; + if ($offset = strpos($doc, '')) { + $doc = substr_replace($doc, "\n\n".$warn, $offset + 5, 0); + } + else { + $doc = $warn . "\n\n" . $doc; + } + } + + # keep either login or logout parts depending on user level + global $User; + $hideclass = $User && property_exists($User, 'login') && $User->login ? 'logout' : 'login'; + $doc = preg_replace('{\s*<([a-z]+) class="'.$hideclass.'">.*?\1>}s', '', $doc); + + return preg_replace_callback( + '{ \[\[ ([^] ]+) ([^]]*) \]\] }x', + function ($sub) { + list ($placeholder, $name, $params) = $sub; + $html = $this->place[$name] ?? + $this->widget($name, $params); + if (empty($html) or $html[0] != '<') { + $html = "$html"; + } + $attr = sprintf(' data-dyn="%s"', is_numeric($name) ? '' : $name.$params); + # contents with identifier in first tag + return preg_replace( '/(?=>)/', $attr, $html, 1); + }, + $doc + ); + } } class PageSearch