xref: /dokuwiki/inc/Ui/Recent.php (revision bde2a644b7f10af4f4d8a7ca52281cd954538ea9)
13d7df1dcSSatoshi Sahara<?php
23d7df1dcSSatoshi Sahara
33d7df1dcSSatoshi Saharanamespace dokuwiki\Ui;
43d7df1dcSSatoshi Sahara
53d7df1dcSSatoshi Saharause dokuwiki\ChangeLog\MediaChangeLog;
63d7df1dcSSatoshi Saharause dokuwiki\Form\Form;
73d7df1dcSSatoshi Sahara
83d7df1dcSSatoshi Sahara/**
99e316641SSatoshi Sahara * DokuWiki Recent Interface
103d7df1dcSSatoshi Sahara *
113d7df1dcSSatoshi Sahara * @package dokuwiki\Ui
123d7df1dcSSatoshi Sahara */
133d7df1dcSSatoshi Saharaclass Recent extends Ui
143d7df1dcSSatoshi Sahara{
159e316641SSatoshi Sahara    protected $first;
169e316641SSatoshi Sahara    protected $show_changes;
179e316641SSatoshi Sahara
189e316641SSatoshi Sahara    /**
199e316641SSatoshi Sahara     * Recent Ui constructor
209e316641SSatoshi Sahara     *
219e316641SSatoshi Sahara     * @param int $first  skip the first n changelog lines
229e316641SSatoshi Sahara     * @param string $show_changes  type of changes to show; pages, mediafiles, or both
239e316641SSatoshi Sahara     */
249e316641SSatoshi Sahara    public function __construct($first = 0, $show_changes = 'both')
259e316641SSatoshi Sahara    {
269e316641SSatoshi Sahara        $this->first        = $first;
279e316641SSatoshi Sahara        $this->show_changes = $show_changes;
289e316641SSatoshi Sahara    }
299e316641SSatoshi Sahara
303d7df1dcSSatoshi Sahara    /**
313d7df1dcSSatoshi Sahara     * Display recent changes
323d7df1dcSSatoshi Sahara     *
333d7df1dcSSatoshi Sahara     * @author Andreas Gohr <andi@splitbrain.org>
343d7df1dcSSatoshi Sahara     * @author Matthias Grimm <matthiasgrimm@users.sourceforge.net>
353d7df1dcSSatoshi Sahara     * @author Ben Coburn <btcoburn@silicodon.net>
363d7df1dcSSatoshi Sahara     * @author Kate Arzamastseva <pshns@ukr.net>
3721b96b63SSatoshi Sahara     * @author Satoshi Sahara <sahara.satoshi@gmail.com>
383d7df1dcSSatoshi Sahara     *
39e6adf5b7SSatoshi Sahara     * @triggers HTMLFORM_RECENT_OUTPUT
403d7df1dcSSatoshi Sahara     * @return void
413d7df1dcSSatoshi Sahara     */
429e316641SSatoshi Sahara    public function show()
433d7df1dcSSatoshi Sahara    {
44*bde2a644SSatoshi Sahara        global $conf, $lang;
453d7df1dcSSatoshi Sahara        global $ID;
463d7df1dcSSatoshi Sahara
4721b96b63SSatoshi Sahara        // get recent items, and set correct pagenation parameters (first, hasNext)
489e316641SSatoshi Sahara        $first = $this->first;
49e6adf5b7SSatoshi Sahara        $hasNext = false;
5021b96b63SSatoshi Sahara        $recents = $this->getRecents($first, $hasNext);
513d7df1dcSSatoshi Sahara
523d7df1dcSSatoshi Sahara        // print intro
533d7df1dcSSatoshi Sahara        print p_locale_xhtml('recent');
543d7df1dcSSatoshi Sahara
553d7df1dcSSatoshi Sahara        if (getNS($ID) != '') {
563d7df1dcSSatoshi Sahara            print '<div class="level1"><p>'
573d7df1dcSSatoshi Sahara                . sprintf($lang['recent_global'], getNS($ID), wl('', 'do=recent'))
583d7df1dcSSatoshi Sahara                .'</p></div>';
593d7df1dcSSatoshi Sahara        }
603d7df1dcSSatoshi Sahara
613d7df1dcSSatoshi Sahara        // create the form
6221b96b63SSatoshi Sahara        $form = new Form(['id'=>'dw__recent', 'method'=>'GET', 'action'=> wl($ID), 'class'=>'changes']);
633d7df1dcSSatoshi Sahara        $form->addTagOpen('div')->addClass('no');
643d7df1dcSSatoshi Sahara        $form->setHiddenField('sectok', null);
653d7df1dcSSatoshi Sahara        $form->setHiddenField('do', 'recent');
663d7df1dcSSatoshi Sahara        $form->setHiddenField('id', $ID);
673d7df1dcSSatoshi Sahara
683d7df1dcSSatoshi Sahara        // show dropdown selector, whether include not only recent pages but also recent media files?
693d7df1dcSSatoshi Sahara        if ($conf['mediarevisions']) {
7021b96b63SSatoshi Sahara            $this->addRecentItemSelector($form);
7121b96b63SSatoshi Sahara        }
7221b96b63SSatoshi Sahara
7321b96b63SSatoshi Sahara        // start listing of recent items
7421b96b63SSatoshi Sahara        $form->addTagOpen('ul');
7521b96b63SSatoshi Sahara        foreach ($recents as $recent) {
7621b96b63SSatoshi Sahara            $objRevInfo = $this->getObjRevInfo($recent);
7721b96b63SSatoshi Sahara            $class = ($recent['type'] === DOKU_CHANGE_TYPE_MINOR_EDIT) ? 'minor': '';
7821b96b63SSatoshi Sahara            $form->addTagOpen('li')->addClass($class);
7921b96b63SSatoshi Sahara            $form->addTagOpen('div')->addClass('li');
8021b96b63SSatoshi Sahara            $html = implode(' ', [
8121b96b63SSatoshi Sahara                $objRevInfo->itemIcon(),          // filetype icon
8221b96b63SSatoshi Sahara                $objRevInfo->editDate(),          // edit date and time
8321b96b63SSatoshi Sahara                $objRevInfo->difflink(),          // link to diffview icon
8421b96b63SSatoshi Sahara                $objRevInfo->revisionlink(),      // linkto revisions icon
8521b96b63SSatoshi Sahara                $objRevInfo->itemName(),          // name of page or media
8621b96b63SSatoshi Sahara                $objRevInfo->editSummary(),       // edit summary
8721b96b63SSatoshi Sahara                $objRevInfo->editor(),            // editor info
88*bde2a644SSatoshi Sahara                $objRevInfo->sizechange(),        // size change indicator
8921b96b63SSatoshi Sahara            ]);
9021b96b63SSatoshi Sahara            $form->addHTML($html);
9121b96b63SSatoshi Sahara            $form->addTagClose('div');
9221b96b63SSatoshi Sahara            $form->addTagClose('li');
9321b96b63SSatoshi Sahara        }
9421b96b63SSatoshi Sahara        $form->addTagClose('ul');
9521b96b63SSatoshi Sahara
9621b96b63SSatoshi Sahara        $form->addTagClose('div'); // close div class=no
9721b96b63SSatoshi Sahara
9821b96b63SSatoshi Sahara        // provide navigation for pagenated recent list (of pages and/or media files)
9921b96b63SSatoshi Sahara        $form->addHTML($this->htmlNavigation($first, $hasNext));
10021b96b63SSatoshi Sahara
101e6adf5b7SSatoshi Sahara        // print form that might be modified by HTMLFORM_RECENT_OUTPUT event handlers
102e6adf5b7SSatoshi Sahara        print $form->toHTML('recent');
10321b96b63SSatoshi Sahara    }
10421b96b63SSatoshi Sahara
10521b96b63SSatoshi Sahara    /**
10621b96b63SSatoshi Sahara     * Get recent items, and set correct pagenation parameters (first, hasNext)
10721b96b63SSatoshi Sahara     *
10821b96b63SSatoshi Sahara     * @param int  $first
10921b96b63SSatoshi Sahara     * @param bool $hasNext
11021b96b63SSatoshi Sahara     * @return array  recent items to be shown in a pagenated list
11121b96b63SSatoshi Sahara     *
11221b96b63SSatoshi Sahara     * @see also dokuwiki\Changelog::getRevisionInfo()
11321b96b63SSatoshi Sahara     */
11421b96b63SSatoshi Sahara    protected function getRecents(&$first, &$hasNext)
11521b96b63SSatoshi Sahara    {
11621b96b63SSatoshi Sahara        global $ID, $conf;
11721b96b63SSatoshi Sahara
11821b96b63SSatoshi Sahara        $flags = 0;
11921b96b63SSatoshi Sahara        if ($this->show_changes == 'mediafiles' && $conf['mediarevisions']) {
12021b96b63SSatoshi Sahara            $flags = RECENTS_MEDIA_CHANGES;
12121b96b63SSatoshi Sahara        } elseif ($this->show_changes == 'pages') {
12221b96b63SSatoshi Sahara            $flags = 0;
12321b96b63SSatoshi Sahara        } elseif ($conf['mediarevisions']) {
12421b96b63SSatoshi Sahara            $flags = RECENTS_MEDIA_PAGES_MIXED;
12521b96b63SSatoshi Sahara        }
12621b96b63SSatoshi Sahara
12721b96b63SSatoshi Sahara        /* we need to get one additionally log entry to be able to
12821b96b63SSatoshi Sahara         * decide if this is the last page or is there another one.
12921b96b63SSatoshi Sahara         * This is the cheapest solution to get this information.
13021b96b63SSatoshi Sahara         */
13121b96b63SSatoshi Sahara        $recents = getRecents($first, $conf['recent'] + 1, getNS($ID), $flags);
13221b96b63SSatoshi Sahara        if (count($recents) == 0 && $first != 0) {
13321b96b63SSatoshi Sahara            $first = 0;
13421b96b63SSatoshi Sahara            $recents = getRecents($first, $conf['recent'] + 1, getNS($ID), $flags);
13521b96b63SSatoshi Sahara        }
13621b96b63SSatoshi Sahara
13721b96b63SSatoshi Sahara        $hasNext = false;
13821b96b63SSatoshi Sahara        if (count($recents) > $conf['recent']) {
13921b96b63SSatoshi Sahara            $hasNext = true;
14021b96b63SSatoshi Sahara            array_pop($recents); // remove extra log entry
14121b96b63SSatoshi Sahara        }
14221b96b63SSatoshi Sahara        return $recents;
14321b96b63SSatoshi Sahara    }
14421b96b63SSatoshi Sahara
14521b96b63SSatoshi Sahara    /**
14621b96b63SSatoshi Sahara     * Navigation buttons for Pagenation (prev/next)
14721b96b63SSatoshi Sahara     *
14821b96b63SSatoshi Sahara     * @param int  $first
14921b96b63SSatoshi Sahara     * @param bool $hasNext
15021b96b63SSatoshi Sahara     * @return array  html
15121b96b63SSatoshi Sahara     */
15221b96b63SSatoshi Sahara    protected function htmlNavigation($first, $hasNext)
15321b96b63SSatoshi Sahara    {
15421b96b63SSatoshi Sahara        global $conf, $lang;
15521b96b63SSatoshi Sahara
15621b96b63SSatoshi Sahara        $last = $first + $conf['recent'];
15721b96b63SSatoshi Sahara        $html = '<div class="pagenav">';
15821b96b63SSatoshi Sahara        if ($first > 0) {
15921b96b63SSatoshi Sahara            $first = max($first - $conf['recent'], 0);
16021b96b63SSatoshi Sahara            $html.= '<div class="pagenav-prev">';
16121b96b63SSatoshi Sahara            $html.= '<button type="submit" name="first['.$first.']" accesskey="n"'
16221b96b63SSatoshi Sahara                  . ' title="'.$lang['btn_newer'].' [N]" class="button show">'
16321b96b63SSatoshi Sahara                  . $lang['btn_newer']
16421b96b63SSatoshi Sahara                  . '</button>';
16521b96b63SSatoshi Sahara            $html.= '</div>';
16621b96b63SSatoshi Sahara        }
16721b96b63SSatoshi Sahara        if ($hasNext) {
16821b96b63SSatoshi Sahara            $html.= '<div class="pagenav-next">';
16921b96b63SSatoshi Sahara            $html.= '<button type="submit" name="first['.$last.']" accesskey="p"'
17021b96b63SSatoshi Sahara                  . ' title="'.$lang['btn_older'].' [P]" class="button show">'
17121b96b63SSatoshi Sahara                  . $lang['btn_older']
17221b96b63SSatoshi Sahara                  . '</button>';
17321b96b63SSatoshi Sahara            $html.= '</div>';
17421b96b63SSatoshi Sahara        }
17521b96b63SSatoshi Sahara        $html.= '</div>';
17621b96b63SSatoshi Sahara        return $html;
17721b96b63SSatoshi Sahara    }
17821b96b63SSatoshi Sahara
17921b96b63SSatoshi Sahara    /**
18021b96b63SSatoshi Sahara     * Add dropdown selector of item types to the form instance
18121b96b63SSatoshi Sahara     *
18221b96b63SSatoshi Sahara     * @param Form $form
18321b96b63SSatoshi Sahara     * @return void
18421b96b63SSatoshi Sahara     */
18521b96b63SSatoshi Sahara    protected function addRecentItemSelector(Form $form)
18621b96b63SSatoshi Sahara    {
18721b96b63SSatoshi Sahara        global $lang;
18821b96b63SSatoshi Sahara
1893d7df1dcSSatoshi Sahara        $form->addTagOpen('div')->addClass('changeType');
1903d7df1dcSSatoshi Sahara        $options = array(
1913d7df1dcSSatoshi Sahara                    'pages'      => $lang['pages_changes'],
1923d7df1dcSSatoshi Sahara                    'mediafiles' => $lang['media_changes'],
1933d7df1dcSSatoshi Sahara                    'both'       => $lang['both_changes'],
1943d7df1dcSSatoshi Sahara        );
1953d7df1dcSSatoshi Sahara        $form->addDropdown('show_changes', $options, $lang['changes_type'])
19621b96b63SSatoshi Sahara                ->val($this->show_changes)->addClass('quickselect');
1973d7df1dcSSatoshi Sahara        $form->addButton('do[recent]', $lang['btn_apply'])->attr('type','submit');
1983d7df1dcSSatoshi Sahara        $form->addTagClose('div');
1993d7df1dcSSatoshi Sahara    }
2003d7df1dcSSatoshi Sahara
20121b96b63SSatoshi Sahara    /**
20221b96b63SSatoshi Sahara     * Returns instance of objRevInfo
20321b96b63SSatoshi Sahara     * @param array $info  Revision info structure of page or media
204628d5475SSatoshi Sahara     * @return objRevInfo object (anonymous class)
20521b96b63SSatoshi Sahara     */
20621b96b63SSatoshi Sahara    protected function getObjRevInfo(array $info)
20721b96b63SSatoshi Sahara    {
208628d5475SSatoshi Sahara        return new class ($info) // anonymous class (objRevInfo)
20921b96b63SSatoshi Sahara        {
21021b96b63SSatoshi Sahara            protected $info;
2113d7df1dcSSatoshi Sahara
21221b96b63SSatoshi Sahara            public function __construct(array $info)
21321b96b63SSatoshi Sahara            {
21421b96b63SSatoshi Sahara                $this->info = $info;
2153d7df1dcSSatoshi Sahara            }
2163d7df1dcSSatoshi Sahara
21721b96b63SSatoshi Sahara            // fileicon of the page or media file
21821b96b63SSatoshi Sahara            public function itemIcon()
21921b96b63SSatoshi Sahara            {
22021b96b63SSatoshi Sahara                $id = $this->info['id'];
22121b96b63SSatoshi Sahara                if (isset($this->info['media'])) {
22221b96b63SSatoshi Sahara                    $html = media_printicon($id);
22321b96b63SSatoshi Sahara                } else {
22421b96b63SSatoshi Sahara                    $html = '<img class="icon" src="'.DOKU_BASE.'lib/images/fileicons/file.png" alt="'.$id.'" />';
22521b96b63SSatoshi Sahara                }
22621b96b63SSatoshi Sahara                return $html;
22721b96b63SSatoshi Sahara            }
2283d7df1dcSSatoshi Sahara
22921b96b63SSatoshi Sahara            // edit date and time of the page or media file
23021b96b63SSatoshi Sahara            public function editDate()
23121b96b63SSatoshi Sahara            {
232*bde2a644SSatoshi Sahara                return '<span class="date">'. dformat($this->info['date']) .'</span>';
233*bde2a644SSatoshi Sahara            }
234*bde2a644SSatoshi Sahara
235*bde2a644SSatoshi Sahara            // edit summary
236*bde2a644SSatoshi Sahara            public function editSummary()
237*bde2a644SSatoshi Sahara            {
238*bde2a644SSatoshi Sahara                return '<span class="sum">'.' – '. hsc($this->info['sum']).'</span>';
239*bde2a644SSatoshi Sahara            }
240*bde2a644SSatoshi Sahara
241*bde2a644SSatoshi Sahara            // editor of the page or media file
242*bde2a644SSatoshi Sahara            public function editor()
243*bde2a644SSatoshi Sahara            {
244*bde2a644SSatoshi Sahara                $html = '<span class="user">';
245*bde2a644SSatoshi Sahara                if ($this->info['user']) {
246*bde2a644SSatoshi Sahara                    $html.= '<bdi>'. editorinfo($this->info['user']) .'</bdi>';
247*bde2a644SSatoshi Sahara                    if (auth_ismanager()) $html.= ' <bdo dir="ltr">('. $this->info['ip'] .')</bdo>';
248*bde2a644SSatoshi Sahara                } else {
249*bde2a644SSatoshi Sahara                    $html.= '<bdo dir="ltr">'. $this->info['ip'] .'</bdo>';
250*bde2a644SSatoshi Sahara                }
251*bde2a644SSatoshi Sahara                $html.= '</span>';
252*bde2a644SSatoshi Sahara                return $html;
253*bde2a644SSatoshi Sahara            }
254*bde2a644SSatoshi Sahara
255*bde2a644SSatoshi Sahara            // name of the page or media file
256*bde2a644SSatoshi Sahara            public function itemName()
257*bde2a644SSatoshi Sahara            {
258*bde2a644SSatoshi Sahara                $id = $this->info['id'];
259*bde2a644SSatoshi Sahara                if (isset($this->info['media'])) {
260*bde2a644SSatoshi Sahara                    $href = media_managerURL(['tab_details'=>'view', 'image'=> $id, 'ns'=> getNS($id)], '&');
261*bde2a644SSatoshi Sahara                    $class = file_exists(mediaFN($id)) ? 'wikilink1' : 'wikilink2';
262*bde2a644SSatoshi Sahara                    $html = '<a href="'.$href.'" class="'.$class.'">'.$id.'</a>';
263*bde2a644SSatoshi Sahara                } else {
264*bde2a644SSatoshi Sahara                    $html = html_wikilink(':'.$id, (useHeading('navigation') ? null : $id));
265*bde2a644SSatoshi Sahara                }
26621b96b63SSatoshi Sahara                return $html;
26721b96b63SSatoshi Sahara            }
26821b96b63SSatoshi Sahara
26921b96b63SSatoshi Sahara            // icon difflink
27021b96b63SSatoshi Sahara            public function difflink()
27121b96b63SSatoshi Sahara            {
27221b96b63SSatoshi Sahara                global $lang;
27321b96b63SSatoshi Sahara                $id = $this->info['id'];
2743d7df1dcSSatoshi Sahara                $diff = false;
2753d7df1dcSSatoshi Sahara
27621b96b63SSatoshi Sahara                if (isset($this->info['media'])) {
27721b96b63SSatoshi Sahara                    $revs = (new MediaChangeLog($id))->getRevisions(0, 1);
27821b96b63SSatoshi Sahara                    $diff = (count($revs) && file_exists(mediaFN($id)));
2793d7df1dcSSatoshi Sahara                    if ($diff) {
2803d7df1dcSSatoshi Sahara                        $href = media_managerURL(
28121b96b63SSatoshi Sahara                            ['tab_details'=>'history', 'mediado'=>'diff', 'image'=> $id, 'ns'=> getNS($id)], '&'
2823d7df1dcSSatoshi Sahara                        );
283*bde2a644SSatoshi Sahara                    } else {
284*bde2a644SSatoshi Sahara                        $href = '';
2853d7df1dcSSatoshi Sahara                    }
2863d7df1dcSSatoshi Sahara                } else {
28721b96b63SSatoshi Sahara                    $href = wl($id, "do=diff", false, '&');
2883d7df1dcSSatoshi Sahara                }
2893d7df1dcSSatoshi Sahara
290*bde2a644SSatoshi Sahara                if ($href) {
29121b96b63SSatoshi Sahara                    $html = '<a href="'.$href.'" class="diff_link">'
29221b96b63SSatoshi Sahara                          . '<img src="'.DOKU_BASE.'lib/images/diff.png" width="15" height="11"'
29321b96b63SSatoshi Sahara                          . ' title="'.$lang['diff'].'" alt="'.$lang['diff'].'" />'
29421b96b63SSatoshi Sahara                          . '</a>';
295*bde2a644SSatoshi Sahara                } else {
296*bde2a644SSatoshi Sahara                    $html = '<img src="'.DOKU_BASE.'lib/images/blank.gif" width="15" height="11" alt="" />';
2973d7df1dcSSatoshi Sahara                }
29821b96b63SSatoshi Sahara                return $html;
29921b96b63SSatoshi Sahara            }
3003d7df1dcSSatoshi Sahara
30121b96b63SSatoshi Sahara            // icon revision link
30221b96b63SSatoshi Sahara            public function revisionlink()
30321b96b63SSatoshi Sahara            {
30421b96b63SSatoshi Sahara                global $lang;
30521b96b63SSatoshi Sahara                $id = $this->info['id'];
30621b96b63SSatoshi Sahara                if (isset($this->info['media'])) {
30721b96b63SSatoshi Sahara                    $href = media_managerURL(['tab_details'=>'history', 'image'=> $id, 'ns'=> getNS($id)], '&');
3083d7df1dcSSatoshi Sahara                } else {
30921b96b63SSatoshi Sahara                    $href = wl($id, "do=revisions", false, '&');
3103d7df1dcSSatoshi Sahara                }
31121b96b63SSatoshi Sahara                $html = '<a href="'.$href.'" class="revisions_link">'
31221b96b63SSatoshi Sahara                      . '<img src="'.DOKU_BASE.'lib/images/history.png" width="12" height="14"'
31321b96b63SSatoshi Sahara                      . ' title="'.$lang['btn_revs'].'" alt="'.$lang['btn_revs'].'" />'
31421b96b63SSatoshi Sahara                      . '</a>';
31521b96b63SSatoshi Sahara                return $html;
31621b96b63SSatoshi Sahara            }
3173d7df1dcSSatoshi Sahara
318*bde2a644SSatoshi Sahara            // size change
319*bde2a644SSatoshi Sahara            public function sizeChange()
32021b96b63SSatoshi Sahara            {
321*bde2a644SSatoshi Sahara                $class = 'sizechange';
322*bde2a644SSatoshi Sahara                $value = filesize_h(abs($this->info['sizechange']));
323*bde2a644SSatoshi Sahara                if ($this->info['sizechange'] > 0) {
324*bde2a644SSatoshi Sahara                    $class .= ' positive';
325*bde2a644SSatoshi Sahara                    $value = '+' . $value;
326*bde2a644SSatoshi Sahara                } elseif ($this->info['sizechange'] < 0) {
327*bde2a644SSatoshi Sahara                    $class .= ' negative';
328*bde2a644SSatoshi Sahara                    $value = '-' . $value;
3293d7df1dcSSatoshi Sahara                } else {
330*bde2a644SSatoshi Sahara                    $value = '±' . $value;
3313d7df1dcSSatoshi Sahara                }
332*bde2a644SSatoshi Sahara                return '<span class="'.$class.'">'.$value.'</span>';
3333d7df1dcSSatoshi Sahara            }
33421b96b63SSatoshi Sahara        }; // end of anonymous class (objRevInfo)
3353d7df1dcSSatoshi Sahara    }
3363d7df1dcSSatoshi Sahara
3373d7df1dcSSatoshi Sahara}
338