X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/a5cbc9ddb6ad65b17f83d2931e3318d94e498a0e..2ec9c2255379e0a0a6043bbb129d34900e17c6be:/article.inc.php
diff --git a/article.inc.php b/article.inc.php
index 6c3ca93..3e67d6f 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('{
(.*?)
\s*(.*)}s', $this->body, $titlematch)) {
list (, $this->title, $this->body) = $titlematch;
}
+
+ return $this->raw;
}
function __get($col)
@@ -77,6 +65,12 @@ class ArchiveArticle
return;
}
+ function restricted()
+ {
+ $this->handler;
+ return $this->restricted;
+ }
+
function safetitle()
{
return trim($this->meta['og:title'] ?? strip_tags($this->title));
@@ -105,10 +99,6 @@ class ArchiveArticle
{
return implode('-', $this->dateparts()) . 'T12:00:00+02:00';
}
- function date()
- {
- return showdate($this->dateparts);
- }
function story()
{
@@ -159,11 +149,84 @@ class ArchiveArticle
function thumb($size = '300x')
{
if (!$this->image or $this->image[0] !== '/') return;
+ if (preg_match('{^/thumb/\D}', $this->image)) {
+ return ltrim($this->image, '/');
+ }
return preg_replace(
['{^(?:/thumb/[^/]*)?}', '/\.groot(?=\.\w+$)/'], ["thumb/$size", ''],
$this->image
);
}
+
+ function widget($name, $params = [])
+ {
+ $path = stream_resolve_include_path("widget/$name.php");
+ if (!file_exists($path)) {
+ return ''.$name.' ontbreekt';
+ }
+
+ ob_start();
+ $Page = clone $this;
+ if (is_array($params)) {
+ $Page->place += $params;
+ }
+ else {
+ foreach (explode(' ', $params) as $param) {
+ if ($set = strpos($param, '=')) {
+ $Page->place[ substr($param, 0, $set) ] = substr($param, $set + 1);
+ }
+ elseif (!empty($param)) {
+ $Page->place[] = $param;
+ }
+ }
+ }
+
+ try {
+ include "widget/$name.php";
+ return ob_get_clean();
+ }
+ catch (Exception $e) {
+ return sprintf('%s',
+ "fout in $name: {$e->getMessage()}"
+ );
+ }
+ }
+
+ function render()
+ {
+ $doc = $this->raw;
+
+ if (!empty($this->place['warn'])) {
+ $warn = '[[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