nieuws/feed: include domain part in article link
[minimedit.git] / nieuws.inc.php
index 7e723e4095e68febd3abde4fcc957217320168f8..34b565a1358b656df7072c20d8d1ef222a31e50f 100644 (file)
 <?php
+global $monthname;
 $monthname = ['?',
        'januari', 'februari', 'maart', 'april', 'mei', 'juni',
        'juli', 'augustus', 'september', 'oktober', 'november', 'december',
 ];
 
-function shownewsdate($url)
+function showdate($parts)
 {
-       $parts = pathinfo($url);
-       $year = pathinfo($parts['dirname'], PATHINFO_FILENAME);
-       @list ($month, $day) = explode('-', $parts['filename'], 3);
        global $monthname;
-       return sprintf('<small class="date">%s %s %s</small>',
-               intval($day), $monthname[intval($month)], $year);
+       return implode(' ', array_filter([
+               intval(@$parts[2]), $parts[1] > 0 ? $monthname[intval($parts[1])] : '', $parts[0],
+               count($parts) > 5 ? "$parts[3]:$parts[4]" : '',
+       ]));
 }
 
-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 ? '<h3><a href="/%2$s">%s</a></h3>' : '<h2>%s</h2>',
-               getoutput([1 => ' <small class="date">'.$date.'</small>']),
-               preg_replace('/\.html$/', '', $url)
-       );
-       return preg_replace('{<h2>(.*?)</h2>}', $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('{<h2>(.*)</h2>\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);
+               array_shift($ymd);
+               return $ymd;
+       }
+
+       function dateiso()
+       {
+               return implode('-', $this->dateparts()) . 'T12:00:00+02:00';
+       }
+
+       function date()
+       {
+               return showdate($this->dateparts);
+       }
+
+       function body()
+       {
+               $this->title;
+               $rest = fread($this->file, filesize($this->page));
+               if ( preg_match('{
+                       \n (?: < (?: p | figure [^>]* ) >\s* )+ (<img\ [^>]*>) | \n <hr\ />
+               }x', $rest, $img, PREG_OFFSET_CAPTURE) ) {
+                       if (isset($img[1])) {
+                               $this->img = $img[1][0];
+                       }
+                       return substr($rest, 0, $img[0][1]);
+               }
+               return $rest;
+       }
+
+       function teaser()
+       {
+               if (preg_match('{<p>(.*?)</p>}s', $this->body, $bodyp)) {
+                       return $bodyp[1];
+               }
+       }
+
+       function img()
+       {
+               $this->img = NULL;
+               $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/[^/]*)?}', '/\.groot(?=\.\w+$)/'], ["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 "<article>";
-               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 '<article class="left">';
+               if ($article->thumb) {
+                       $imgattr = ' class="left"';
+                       if (preg_match('{ (\s alt="[^"]+") }x', $article->img, $img)) {
+                               $imgattr .= $img[0];  # preserve alt value
+                       }
+                       printf('<img src="/%s"%s />', $article->thumb, $imgattr);
+               }
+               print '<div>';
+               printf(
+                       '<h3><a href="/%s">%s <small class="date">%s</small></a></h3>',
+                       $article->link, $article->title, $article->date
+               );
+               print $article->body;
+               print '</div>';
                print "</article>\n\n";
 
                if (--$limit <= 0) break;
        }
 }
 
-function printtoc($root)
+function printtoc($input, $class = FALSE)
 {
-       print '<ul>';
-       foreach (array_reverse(glob("$root/*.html")) as $page) {
-               $title = fgets(fopen($page, 'r'));
-               $title = strip_tags($title);
-               $linkurl = preg_replace('/\.html$/', '', $page);
-               printf('<li><a href="/%s">%s <small class="date">%s</small></a></li>',
-                       $linkurl, $title, shownewsdate($linkurl));
+       if (!is_array($input)) $input = glob("$input/*.html");
+       print '<ul';
+       if ($class) printf(' class="%s"', $class);
+       print '>';
+       foreach (array_reverse($input) as $page) {
+               $article = new ArchiveArticle($page);
+               $html = $article->safetitle;
+               $dateparts = $article->dateparts;
+               if ($class) {
+                       $dateparts[0] = NULL;  # omit year
+               }
+               $html .= sprintf(' <small class="date">%s</small>', showdate($dateparts));
+               if ($class == 'gallery' and $article->img) {
+                       $html = "<div>$html</div>";
+                       $html = sprintf('<img src="%s" />', $article->thumb(200)) . $html;
+               }
+               $html = sprintf('<a href="/%s">%s</a>', $article->link, $html);
+               print "<li><article>$html</article></li>\n";
        }
        print "</ul>\n";
 }