371f11a665216d744b6526918b1363fadd2d05a1
[minimedit.git] / widget / issue / activity.php
1 <?php
2 global $Db;
3 require_once 'database.inc.php';
4
5 $limit = $Page->place['n'] ?? 50;
6 $cols = 'm.*, i.subject, i.updated, i.closed';
7 $sql = "SELECT $cols FROM messages m JOIN issues i ON i.id = issue";
8 $sql .= " WHERE message IS NOT NULL";
9 $sql .= " ORDER BY m.created DESC LIMIT $limit";
10 $query = $Db->query($sql);
11
12 $msgformat = [
13         "{(?=</p>\n).+}s" => ' <small class="footer">(Meer op de site)</small>',
14         '{(.*)(<p><img [^>]+></p>)\s*}s' => "$2\n$1",
15         '{(?<=<img src=")(?=/)}' => '/thumb/300x',
16 ];
17
18 print '<dl class="replies">';
19
20 $prev = NULL;
21 while ($row = $query->fetch()) {
22         if (!$prev or $prev->issue !== $row->issue or $prev->author !== $row->author
23         or !preg_match('/\A<p><img/', $prev->message)) {
24                 print '<dt>';
25                 if (!$prev or $prev->issue !== $row->issue) {
26                         printf('<a href="/%s">%s</a>', $row->page, $row->subject);
27                         if ($row->closed) {
28                                 print ' <em>(opgelost)</em>';
29                         }
30                 }
31                 print '<span class="right">';
32                 if ($row->author and $rowuser = new User("profile/{$row->author}")) {
33                         printf('<strong>%s</strong> ', $rowuser->html);
34                 }
35                 printf('<small class="date">%s</small>',
36                         showdate(preg_split('/\D/', $row->created))
37                 );
38                 print "</span>";
39                 print '</dt>';
40                 print '<dd>';
41         }
42         print preg_replace(array_keys($msgformat), array_values($msgformat), $row->message);
43         $prev = $row;
44 }
45
46 print "</dl>\n";