X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/328e964708c7e9dc479a25f9358b2d03e9d7f66c..130231b1c611644b68b8a6635589dcfff457b5c3:/nieuws.inc.php?ds=sidebyside
diff --git a/nieuws.inc.php b/nieuws.inc.php
index 7e723e4..40313e4 100644
--- a/nieuws.inc.php
+++ b/nieuws.inc.php
@@ -1,58 +1,155 @@
%s %s %s',
- intval($day), $monthname[intval($month)], $year);
+ return implode(' ', array_filter([
+ intval(@$parts[3]), $parts[2] > 0 ? $monthname[intval($parts[2])] : '', $parts[1],
+ count($parts) > 6 ? "$parts[4]:$parts[5]" : '',
+ ]));
}
-function shownewsarticle($url, $link = TRUE, $title = NULL)
+class ArchiveArticle
{
- $html = ob_get_clean();
- $date = shownewsdate($url);
- ob_start();
- print $title ?: '\1';
- print '[[1]]';
-
- $title = sprintf(
- $link ? '
' : '%s
',
- getoutput([1 => ' '.$date.'']),
- preg_replace('/\.html$/', '', $url)
- );
- return preg_replace('{(.*?)
}', $title, $html);
+ 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}) )? - >x', $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(]*>)
}', $rest, $img, PREG_OFFSET_CAPTURE) ) {
+ $this->img = $img[1][0];
+ return substr($rest, 0, $img[0][1]);
+ }
+ $this->img = NULL;
+ return $rest;
+ }
+
+ 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($root, $limit = 5)
+function shownews($input, $limit = 1000)
{
- if (strpos($root, '/') === FALSE) $root .= '/*';
- foreach (array_reverse(glob("$root/*.html")) as $url) {
- print "";
- ob_start();
- include $url;
- print shownewsarticle($url);
+ if (!is_array($input)) $input = glob("$input/*.html");
+ foreach (array_reverse($input) as $filename) {
+ $article = new ArchiveArticle($filename);
+ print '';
+ if ($article->thumb) {
+ $img = preg_replace('{(?<= \b src="/) [^"]* }x', $article->thumb, $article->img);
+ $img = preg_replace('{(?= />$)}', ' class="left"', $img);
+ print $img;
+ }
+ print '';
+ printf(
+ '
',
+ $article->link, $article->title, $article->date
+ );
+ print $article->body;
+ print '
';
print "\n\n";
if (--$limit <= 0) break;
}
}
-function printtoc($root)
+function printtoc($input, $class = FALSE)
{
- print '';
- foreach (array_reverse(glob("$root/*.html")) as $page) {
- $title = fgets(fopen($page, 'r'));
- $title = strip_tags($title);
- $linkurl = preg_replace('/\.html$/', '', $page);
- printf('- %s %s
',
- $linkurl, $title, shownewsdate($linkurl));
+ if (!is_array($input)) $input = glob("$input/*.html");
+ print '';
+ foreach (array_reverse($input) as $page) {
+ $article = new ArchiveArticle($page);
+ $html = $article->safetitle;
+ $dateparts = $article->dateparts;
+ if ($class) {
+ $dateparts[1] = NULL; # omit year
+ }
+ $html .= sprintf(' %s', showdate($dateparts));
+ if ($class == 'gallery' and $article->img) {
+ $html = "$html
";
+ $html = sprintf('', $article->thumb(200)) . $html;
+ }
+ $html = sprintf('%s', $article->link, $html);
+ print "- $html
\n";
}
print "
\n";
}