X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/f9b855c241ac7273399d1d405b63071b86b87faa..ee9702f9ff640f0108e52490d256c789acb09433:/nieuws/index.php
diff --git a/nieuws/index.php b/nieuws/index.php
index c90034f..6ea68dc 100644
--- a/nieuws/index.php
+++ b/nieuws/index.php
@@ -1,69 +1,61 @@
handler == 'melding' && $User->login;
+@list ($year, $page) = explode('/', trim($Page->path, '/'));
-$replyform = $Page == 'melding' && !empty($User);
-@list ($year, $page) = explode('/', trim($Args, '/'));
-
-if ($page and !is_numeric($page)) {
- $edit = !empty($User['admin']) ? htmlspecialchars(@$_GET['edit']) : NULL;
- print shownewsarticle($Page.$Args, FALSE, $edit);
+if (!$User) {
+ if ($Page->path) return;
+ return (new PageSearch($Page->link))->files();
+}
- if ($replyform) {
- print '
Reacties
'."\n";
- $pagelink = $Page.$Args;
+if ($User->admin("edit {$Page->handler}")) {
+ $Page->raw = ''."\n" . $Page->raw;
+}
- if ($_POST) {
- try {
- @mkdir($pagelink);
- $target = $pagelink.'/'.date('YmdHis').':'.$User['name'].'.txt';
- $written = file_put_contents($target, $_POST['reply']);
- if ($written === FALSE) {
- throw new Exception('Fout bij opslaan');
- }
- $_POST['reply'] = NULL;
- }
- catch (Exception $e) {
- print 'Antwoord niet opgeslagen.
'."\n\n";
- }
+if ($page and !is_numeric($page)) {
+ $Page->meta['og:type'] = 'article';
+ $edit = $User->admin("edit {$Page->link}") ? htmlspecialchars(@$_GET['edit']) : NULL;
+ if ($edit) {
+ $Page->title = $edit;
+ }
+ if ($Page->dateparts) {
+ $Page->place[1] = ' '.showdate($Page->dateparts).'';
+ }
+ else {
+ $Page->place[1] = '';
+ }
+ print preg_replace('{(?<=)(.*?)(?=
)}', ($edit ?: '\1').' [[1]]', $Page->raw);
+ if ($User->admin("edit {$Page->link}")) {
+ $taglist = [];
+ foreach (glob("{$Page->handler}/.tags/*") as $tagpath) {
+ $tagname = pathinfo($tagpath, PATHINFO_BASENAME);
+ $tagvalue = file_exists("$tagpath/$year-$page.html");
+ $tagtarget = is_writable($tagpath);
+ $taglist[] = sprintf(
+ '' .
+ '',
+ "tags[$tagname]", $tagname, "tag-$tagname",
+ $tagvalue ? ' checked' : '',
+ ' disabled',
+ ucfirst($tagname)
+ );
}
-
- print '';
-
- foreach (glob("$pagelink/*.txt") as $reply) {
- preg_match('(\d{14}) : ([^:]*) [^/]* \.txt$>x', $reply, $replymeta);
- if (!$replymeta) continue;
- $replydate = str_split($replymeta[1], 2);
- $replydate[1] = $replydate[0] . $replydate[1];
- print '- ';
- printf('%s %s',
- $replymeta[2], showdate($replydate)
+ if ($taglist) {
+ printf('
Tags: %s
'."\n",
+ implode("\n\t", $taglist)
);
- $replydata = file_get_contents($reply);
- printf('%s
', nl2br(htmlspecialchars($replydata)));
- print " \n";
}
-
- print '- ';
- print '
\n";
-
- print "
\n\n";
}
-
- return 1;
+ if ($replyform) {
+ print $Page->widget('reply');
+ }
+ return;
}
if ($year) {
- ob_clean();
+ $match = $Page->handler;
$title = "Nieuws";
if (is_numeric($year) and $year > 999) {
- $match = "$Page/$year/";
+ $match .= "/$year";
if (is_numeric($page)) {
$title .= ' '.$monthname[intval($page)];
$match .= sprintf('%02d-', $page);
@@ -71,30 +63,15 @@ if ($year) {
$title .= ' '.$year;
}
elseif ($year === '19') {
- $match = "$Page/19??/";
+ $match .= "/19??";
$title .= " vóór 2000";
}
+ elseif (file_exists("{$Page->handler}/.tags/$year")) {
+ $match .= "/.tags/$year";
+ $title .= " met $year";
+ }
print "$title
\n\n";
- shownews(glob($match.'*.html'));
- return 1;
-}
-
-print ''."\n\n";
-
-foreach (array_reverse(glob("$Page/2???")) as $page) {
- $year = basename($page, '.html');
- printf('
'."\n", $page, $year);
- printtoc($page);
-}
-
-if ($pages = glob("$Page/19??/*.html")) {
- printf('
'."\n", "$Page/19", 'Eerder');
- printtoc($pages);
-}
-
-print "
\n\n";
-
-if (!empty($User['admin'])) {
- print ''."\n";
+ print $Page->widget('nieuws', [$match]);
+ return;
}