X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/3080864c4cd697bd083f9fd0315f0ffababd593d..1428caff970f73f026f1467c7741798ca7c9272c:/nieuws.inc.php diff --git a/nieuws.inc.php b/nieuws.inc.php index a925a91..40313e4 100644 --- a/nieuws.inc.php +++ b/nieuws.inc.php @@ -9,7 +9,7 @@ function showdate($parts) { global $monthname; return implode(' ', array_filter([ - intval($parts[3]), $parts[2] > 0 ? $monthname[intval($parts[2])] : '', $parts[1], + intval(@$parts[3]), $parts[2] > 0 ? $monthname[intval($parts[2])] : '', $parts[1], count($parts) > 6 ? "$parts[4]:$parts[5]" : '', ])); } @@ -19,7 +19,7 @@ class ArchiveArticle function __construct($path) { $this->page = $path; - $this->link = preg_replace('/\.html$/', '', $path); + $this->link = preg_replace('{(?:/index)?\.html$}', '', $path); } function __get($col) @@ -29,6 +29,7 @@ class ArchiveArticle function file() { + if (!file_exists($this->page)) return; return fopen($this->page, 'r'); } @@ -39,67 +40,116 @@ class ArchiveArticle function safetitle() { - return strip_tags($this->title); + 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() { - if (!preg_match('', $this->page, $parts)) return; - return showdate($parts); + return showdate($this->dateparts); } function body() { - return fread($this->file, filesize($this->page)); + $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() { - foreach (['jpg', 'png'] as $ext) { - if (file_exists("{$this->link}.$ext")) { - return "{$this->link}.$ext"; - } + if ( preg_match('/\bsrc="([^"]*)"/', $this->img, $src) ) { + return $src[1]; } } function thumb($size = '300x') { - if ($this->image) - return "thumb/$size/{$this->image}"; + 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"); - print '\n\n"; } -function printtoc($input) +function printtoc($input, $class = FALSE) { if (!is_array($input)) $input = glob("$input/*.html"); - print '\n"; }