X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/3e6d760fac53bc2fc4324ddba062b5ec924a0573..ead24d57321f965db99178336e9a72c03c966bd1:/nieuws.inc.php
diff --git a/nieuws.inc.php b/nieuws.inc.php
index 7133474..35ae092 100644
--- a/nieuws.inc.php
+++ b/nieuws.inc.php
@@ -10,49 +10,100 @@ function showdate($parts)
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 shownewsdate($url)
+class ArchiveArticle
{
- if (!preg_match('(\d{4})/(\d{2})-(\d{2})->', $url, $parts)) return;
- return showdate($parts);
-}
+ function __construct($path)
+ {
+ $this->page = $path;
+ $this->link = preg_replace('{(?:/index)?\.html$}', '', $path);
+ }
-function shownewsimage($url)
-{
- foreach (['jpg', 'png'] as $ext) {
- if (file_exists("$url.$ext")) {
- return "$url.$ext";
+ 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)
@@ -60,15 +111,17 @@ function shownews($input, $limit = 1000)
if (!is_array($input)) $input = glob("$input/*.html");
print ''."\n\n";
foreach (array_reverse($input) as $filename) {
- $url = preg_replace('/\.html$/', '', $filename);
+ $article = new ArchiveArticle($filename);
print '- ';
- if ($image = shownewsimage($url)) {
- printf('', "/thumb/300x/".$image);
+ if ($article->thumb) {
+ printf('', $article->thumb);
}
print '';
- ob_start();
- include $filename;
- print shownewsarticle($url);
+ printf(
+ '',
+ $article->link, $article->title, $article->date
+ );
+ print $article->body;
print "
\n\n";
if (--$limit <= 0) break;
@@ -81,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";
}