X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/a332183ffe74a1580779a5eeeeb7dbe02a398075..e6e54fe22ae87eb9487595b3e6afa5b80c12e3f1:/nieuws.inc.php?ds=sidebyside
diff --git a/nieuws.inc.php b/nieuws.inc.php
index 454c91c..35ae092 100644
--- a/nieuws.inc.php
+++ b/nieuws.inc.php
@@ -5,63 +5,128 @@ $monthname = ['?',
'juli', 'augustus', 'september', 'oktober', 'november', 'december',
];
-function shownewsdate($url)
+function showdate($parts)
{
- if (!preg_match('(\d{4})/(\d{2})-(\d{2})->', $url, $parts)) return;
global $monthname;
return implode(' ', array_filter([
intval($parts[3]), $parts[2] > 0 ? $monthname[intval($parts[2])] : '', $parts[1],
+ count($parts) > 6 ? "$parts[4]:$parts[5]" : '',
]));
}
-function shownewsimage($url)
+class ArchiveArticle
{
- foreach (['jpg', 'png'] as $ext) {
- if (file_exists("$url.$ext")) {
- return "$url.$ext";
+ function __construct($path)
+ {
+ $this->page = $path;
+ $this->link = preg_replace('{(?:/index)?\.html$}', '', $path);
+ }
+
+ function __get($col)
+ {
+ return $this->$col = $this->$col(); # run method and cache
+ }
+
+ function file()
+ {
+ if (!file_exists($this->page)) return;
+ return fopen($this->page, 'r');
+ }
+
+ function title()
+ {
+ return preg_replace('{
(.*)
\s*}', '\1', fgets($this->file));
+ }
+
+ function safetitle()
+ {
+ return trim(strip_tags($this->title));
+ }
+
+ function name()
+ {
+ return $this->safetitle ?: $this->link;
+ }
+
+ function last()
+ {
+ return filemtime($this->page);
+ }
+
+ function lastiso()
+ {
+ return date(DATE_ATOM, $this->last);
+ }
+
+ function dateparts()
+ {
+ preg_match('(\d{4})[/-](\d{2})-(\d{2})->', $this->page, $ymd);
+ return $ymd;
+ }
+
+ function dateiso()
+ {
+ return implode('-', $this->dateparts());
+ }
+
+ function date()
+ {
+ return showdate($this->dateparts);
+ }
+
+ function body()
+ {
+ $this->title;
+ $rest = fread($this->file, filesize($this->page));
+ if ( preg_match('{\n(]*>)
\s*\z}', $rest, $img, PREG_OFFSET_CAPTURE) ) {
+ $this->img = $img[1][0];
+ return substr($rest, 0, $img[0][1]);
}
+ $this->img = NULL;
+ return $rest;
}
-}
-function shownewsarticle($url, $link = TRUE, $title = NULL)
-{
- $html = ob_get_clean();
- $date = shownewsdate($url);
- ob_start();
- print $title ?: '\1';
- print '[[1]]';
-
- $title = sprintf(
- $link ? '' : '%s
',
- getoutput([1 => ' '.$date.'']),
- $url
- );
-
- if (!$link and $image = shownewsimage($url)) {
- global $Place;
- $Place['image'] = "https://lijtweg.nl/thumb/600x/".$image;
- ob_start();
- print '[[1]]';
- $html .= getoutput([
- 1 => sprintf("\n".'', "/thumb/640x/".$image),
- ]);
- }
-
- return preg_replace('{(.*?)
}', $title, $html);
+ function img()
+ {
+ $this->body;
+ return $this->img;
+ }
+
+ function image()
+ {
+ if ( preg_match('/\bsrc="([^"]*)"/', $this->img, $src) ) {
+ return $src[1];
+ }
+ }
+
+ function thumb($size = '300x')
+ {
+ if (!$this->image or $this->image[0] !== '/') return;
+ return preg_replace('{^(?:/thumb/[^/]*)?}', "thumb/$size", $this->image);
+ }
}
function shownews($input, $limit = 1000)
{
if (!is_array($input)) $input = glob("$input/*.html");
- foreach (array_reverse($input) as $url) {
- print "";
- ob_start();
- include $url;
- print shownewsarticle(preg_replace('/\.html$/', '', $url));
- print "\n\n";
+ print ''."\n\n";
+ foreach (array_reverse($input) as $filename) {
+ $article = new ArchiveArticle($filename);
+ print '- ';
+ if ($article->thumb) {
+ printf('', $article->thumb);
+ }
+ print '';
+ printf(
+ '',
+ $article->link, $article->title, $article->date
+ );
+ print $article->body;
+ print "
\n\n";
if (--$limit <= 0) break;
}
+ print "
\n\n";
}
function printtoc($input)
@@ -69,11 +134,9 @@ function printtoc($input)
if (!is_array($input)) $input = glob("$input/*.html");
print '';
foreach (array_reverse($input) as $page) {
- $title = fgets(fopen($page, 'r'));
- $title = strip_tags($title);
- $linkurl = preg_replace('/\.html$/', '', $page);
+ $article = new ArchiveArticle($page);
printf('- %s %s
',
- $linkurl, $title, shownewsdate($linkurl));
+ $article->link, $article->safetitle, $article->date);
}
print "
\n";
}