xref: /dokuwiki/inc/Ui/Revisions.php (revision ae5d2354c9aa93da542d9f0607167c5e0a6100be)
16c9fde82SSatoshi Sahara<?php
26c9fde82SSatoshi Sahara
36c9fde82SSatoshi Saharanamespace dokuwiki\Ui;
46c9fde82SSatoshi Sahara
56c9fde82SSatoshi Sahara/**
69e316641SSatoshi Sahara * DokuWiki Revisions Interface
7*ae5d2354SSatoshi Sahara * parent class of PageRevisions and MediaRevisions
86c9fde82SSatoshi Sahara *
96c9fde82SSatoshi Sahara * @package dokuwiki\Ui
106c9fde82SSatoshi Sahara */
11*ae5d2354SSatoshi Saharaabstract class Revisions extends Ui
126c9fde82SSatoshi Sahara{
13*ae5d2354SSatoshi Sahara    /* @var string */
14*ae5d2354SSatoshi Sahara    protected $id;
159e316641SSatoshi Sahara
169e316641SSatoshi Sahara    /**
179e316641SSatoshi Sahara     * Revisions Ui constructor
189e316641SSatoshi Sahara     *
19*ae5d2354SSatoshi Sahara     * @param string $id  id of page or media
209e316641SSatoshi Sahara     */
21*ae5d2354SSatoshi Sahara    public function __construct($id)
229e316641SSatoshi Sahara    {
23*ae5d2354SSatoshi Sahara        $this->id = $id;
249e316641SSatoshi Sahara    }
259e316641SSatoshi Sahara
266c9fde82SSatoshi Sahara    /**
2767ef3e88SSatoshi Sahara     * Get revisions, and set correct pagenation parameters (first, hasNext)
2867ef3e88SSatoshi Sahara     *
2967ef3e88SSatoshi Sahara     * @param int  $first
3067ef3e88SSatoshi Sahara     * @param bool $hasNext
3167ef3e88SSatoshi Sahara     * @return array  revisions to be shown in a pagenated list
325525369fSSatoshi Sahara     * @see also https://www.dokuwiki.org/devel:changelog
3367ef3e88SSatoshi Sahara     */
34*ae5d2354SSatoshi Sahara    abstract protected function getRevisions(&$first, &$hasNext);
3567ef3e88SSatoshi Sahara
3667ef3e88SSatoshi Sahara    /**
3767ef3e88SSatoshi Sahara     * Navigation buttons for Pagenation (prev/next)
3867ef3e88SSatoshi Sahara     *
3967ef3e88SSatoshi Sahara     * @param int  $first
4067ef3e88SSatoshi Sahara     * @param bool $hasNext
41*ae5d2354SSatoshi Sahara     * @param callable $callback returns array of hidden fields for the form button
4267ef3e88SSatoshi Sahara     * @return array  html
4367ef3e88SSatoshi Sahara     */
44*ae5d2354SSatoshi Sahara    protected function navigation($first, $hasNext, $callback)
4567ef3e88SSatoshi Sahara    {
4667ef3e88SSatoshi Sahara        global $conf;
4767ef3e88SSatoshi Sahara
4867ef3e88SSatoshi Sahara        $html = '<div class="pagenav">';
496c9fde82SSatoshi Sahara        $last = $first + $conf['recent'];
506c9fde82SSatoshi Sahara        if ($first > 0) {
5167ef3e88SSatoshi Sahara            $first = max($first - $conf['recent'], 0);
5267ef3e88SSatoshi Sahara            $html.= '<div class="pagenav-prev">';
53*ae5d2354SSatoshi Sahara            $html.= html_btn('newer', $this->id, "p", $callback($first));
5467ef3e88SSatoshi Sahara            $html.= '</div>';
556c9fde82SSatoshi Sahara        }
566c9fde82SSatoshi Sahara        if ($hasNext) {
5767ef3e88SSatoshi Sahara            $html.= '<div class="pagenav-next">';
58*ae5d2354SSatoshi Sahara            $html.= html_btn('older', $this->id, "n", $callback($last));
5967ef3e88SSatoshi Sahara            $html.= '</div>';
606c9fde82SSatoshi Sahara        }
6167ef3e88SSatoshi Sahara        $html.= '</div>';
6267ef3e88SSatoshi Sahara        return $html;
6367ef3e88SSatoshi Sahara    }
646c9fde82SSatoshi Sahara
6567ef3e88SSatoshi Sahara    /**
6667ef3e88SSatoshi Sahara     * Returns instance of objRevInfo
6767ef3e88SSatoshi Sahara     *
6867ef3e88SSatoshi Sahara     * @param array $info  Revision info structure of a page or media file
6967ef3e88SSatoshi Sahara     * @return objRevInfo object (anonymous class)
7067ef3e88SSatoshi Sahara     */
7167ef3e88SSatoshi Sahara    protected function getObjRevInfo(array $info)
7267ef3e88SSatoshi Sahara    {
7367ef3e88SSatoshi Sahara        return new class ($info) // anonymous class (objRevInfo)
7467ef3e88SSatoshi Sahara        {
7567ef3e88SSatoshi Sahara            protected $info;
7667ef3e88SSatoshi Sahara
7767ef3e88SSatoshi Sahara            public function __construct(array $info)
7867ef3e88SSatoshi Sahara            {
7967ef3e88SSatoshi Sahara                $this->info = $info;
8067ef3e88SSatoshi Sahara            }
8167ef3e88SSatoshi Sahara
8267ef3e88SSatoshi Sahara            // current indicator
8367ef3e88SSatoshi Sahara            public function currentIndicator()
8467ef3e88SSatoshi Sahara            {
8567ef3e88SSatoshi Sahara                global $lang;
8667ef3e88SSatoshi Sahara                return ($this->info['current']) ? '('.$lang['current'].')' : '';
8767ef3e88SSatoshi Sahara            }
8867ef3e88SSatoshi Sahara
8967ef3e88SSatoshi Sahara            // edit date and time of the page or media file
9067ef3e88SSatoshi Sahara            public function editDate()
9167ef3e88SSatoshi Sahara            {
9267ef3e88SSatoshi Sahara                return '<span class="date">'. dformat($this->info['date']) .'</span>';
9367ef3e88SSatoshi Sahara            }
9467ef3e88SSatoshi Sahara
9567ef3e88SSatoshi Sahara            // edit summary
9667ef3e88SSatoshi Sahara            public function editSummary()
9767ef3e88SSatoshi Sahara            {
9867ef3e88SSatoshi Sahara                return '<span class="sum">'.' – '. hsc($this->info['sum']).'</span>';
9967ef3e88SSatoshi Sahara            }
10067ef3e88SSatoshi Sahara
10167ef3e88SSatoshi Sahara            // editor of the page or media file
10267ef3e88SSatoshi Sahara            public function editor()
10367ef3e88SSatoshi Sahara            {
10467ef3e88SSatoshi Sahara                // slightly different with display of Ui\Recent, i.e. external edit
10567ef3e88SSatoshi Sahara                global $lang;
10667ef3e88SSatoshi Sahara                $html = '<span class="user">';
10767ef3e88SSatoshi Sahara                if (!$this->info['user'] && !$this->info['ip']) {
10867ef3e88SSatoshi Sahara                    $html.= '('.$lang['external_edit'].')';
10967ef3e88SSatoshi Sahara                } elseif ($this->info['user']) {
11067ef3e88SSatoshi Sahara                    $html.= '<bdi>'. editorinfo($this->info['user']) .'</bdi>';
11167ef3e88SSatoshi Sahara                    if (auth_ismanager()) $html.= ' <bdo dir="ltr">('. $this->info['ip'] .')</bdo>';
11267ef3e88SSatoshi Sahara                } else {
11367ef3e88SSatoshi Sahara                    $html.= '<bdo dir="ltr">'. $this->info['ip'] .'</bdo>';
11467ef3e88SSatoshi Sahara                }
11567ef3e88SSatoshi Sahara                $html.= '</span>';
11667ef3e88SSatoshi Sahara                return $html;
11767ef3e88SSatoshi Sahara            }
11867ef3e88SSatoshi Sahara
11967ef3e88SSatoshi Sahara            // name of the page or media file
12067ef3e88SSatoshi Sahara            public function itemName()
12167ef3e88SSatoshi Sahara            {
12267ef3e88SSatoshi Sahara                // slightly different with display of Ui\Recent, i.e. revison may not exists
12367ef3e88SSatoshi Sahara                $id = $this->info['id'];
12467ef3e88SSatoshi Sahara                $rev = $this->info['date'];
12567ef3e88SSatoshi Sahara
12667ef3e88SSatoshi Sahara                if (isset($this->info['media'])) {
12767ef3e88SSatoshi Sahara                    // media file revision
12867ef3e88SSatoshi Sahara                    if (isset($this->info['current'])) {
12967ef3e88SSatoshi Sahara                        $href = media_managerURL(['image'=> $id, 'tab_details'=> 'view'], '&');
13067ef3e88SSatoshi Sahara                        $html = '<a href="'.$href.'" class="wikilink1">'.$id.'</a>';
13167ef3e88SSatoshi Sahara                    } elseif (file_exists(mediaFN($id, $rev))) {
13267ef3e88SSatoshi Sahara                        $href = media_managerURL(['image'=> $id, 'tab_details'=> 'view', 'rev'=> $rev], '&');
13367ef3e88SSatoshi Sahara                        $html = '<a href="'.$href.'" class="wikilink1">'.$id.'</a>';
13467ef3e88SSatoshi Sahara                    } else {
13567ef3e88SSatoshi Sahara                        $html = $id;
13667ef3e88SSatoshi Sahara                    }
13767ef3e88SSatoshi Sahara                    return $html;
13867ef3e88SSatoshi Sahara                } else {
13967ef3e88SSatoshi Sahara                    // page revision
14067ef3e88SSatoshi Sahara                    $display_name = useHeading('navigation') ? hsc(p_get_first_heading($id)) : $id;
14167ef3e88SSatoshi Sahara                    if (!$display_name) $display_name = $id;
14267ef3e88SSatoshi Sahara                    if ($this->info['current'] || page_exists($id, $rev)) {
14367ef3e88SSatoshi Sahara                        $href = wl($id, "rev=$rev", false, '&');
14467ef3e88SSatoshi Sahara                        $html = '<a href="'.$href.'" class="wikilink1">'.$display_name.'</a>';
14567ef3e88SSatoshi Sahara                    } else {
14667ef3e88SSatoshi Sahara                        $html = $display_name;
14767ef3e88SSatoshi Sahara                    }
14867ef3e88SSatoshi Sahara                    return $html;
14967ef3e88SSatoshi Sahara                }
15067ef3e88SSatoshi Sahara            }
15167ef3e88SSatoshi Sahara
15267ef3e88SSatoshi Sahara            // icon difflink
15367ef3e88SSatoshi Sahara            public function difflink()
15467ef3e88SSatoshi Sahara            {
15567ef3e88SSatoshi Sahara                global $lang;
15667ef3e88SSatoshi Sahara                $id = $this->info['id'];
15767ef3e88SSatoshi Sahara                $rev = $this->info['date'];
15867ef3e88SSatoshi Sahara
15967ef3e88SSatoshi Sahara                if (isset($this->info['media'])) {
16067ef3e88SSatoshi Sahara                    // media file revision
16167ef3e88SSatoshi Sahara                    if (isset($this->info['current']) || !file_exists(mediaFN($id, $rev))) {
16267ef3e88SSatoshi Sahara                        $html = '<img src="'.DOKU_BASE.'lib/images/blank.gif" width="15" height="11" alt="" />';
16367ef3e88SSatoshi Sahara                    } else {
16467ef3e88SSatoshi Sahara                        $href = media_managerURL(['image'=> $id, 'rev'=> $rev, 'mediado'=>'diff'], '&');
16567ef3e88SSatoshi Sahara                        $html = '<a href="'.$href.'" class="diff_link">'
16667ef3e88SSatoshi Sahara                              . '<img src="'.DOKU_BASE.'lib/images/diff.png" width="15" height="11"'
16767ef3e88SSatoshi Sahara                              . ' title="'. $lang['diff'] .'" alt="'.$lang['diff'] .'" />'
16867ef3e88SSatoshi Sahara                              . '</a> ';
16967ef3e88SSatoshi Sahara                    }
17067ef3e88SSatoshi Sahara                    return $html;
17167ef3e88SSatoshi Sahara                } else {
17267ef3e88SSatoshi Sahara                    // page revision
17367ef3e88SSatoshi Sahara                    if ($this->info['current'] || !page_exists($id, $rev)) {
17467ef3e88SSatoshi Sahara                        $html = '<img src="'.DOKU_BASE.'lib/images/blank.gif" width="15" height="11" alt="" />';
17567ef3e88SSatoshi Sahara                    } else {
17667ef3e88SSatoshi Sahara                        $href = wl($id, "rev=$rev,do=diff", false, '&');
17767ef3e88SSatoshi Sahara                        $html = '<a href="'.$href.'" class="diff_link">'
17867ef3e88SSatoshi Sahara                              . '<img src="'.DOKU_BASE.'lib/images/diff.png" width="15" height="11"'
17967ef3e88SSatoshi Sahara                              . ' title="'.$lang['diff'].'" alt="'.$lang['diff'].'" />'
18067ef3e88SSatoshi Sahara                              . '</a>';
18167ef3e88SSatoshi Sahara                    }
18267ef3e88SSatoshi Sahara                    return $html;
18367ef3e88SSatoshi Sahara                }
18467ef3e88SSatoshi Sahara            }
18567ef3e88SSatoshi Sahara
18667ef3e88SSatoshi Sahara            // size change
18767ef3e88SSatoshi Sahara            public function sizeChange()
18867ef3e88SSatoshi Sahara            {
18967ef3e88SSatoshi Sahara                $class = 'sizechange';
19067ef3e88SSatoshi Sahara                $value = filesize_h(abs($this->info['sizechange']));
19167ef3e88SSatoshi Sahara                if ($this->info['sizechange'] > 0) {
19267ef3e88SSatoshi Sahara                    $class .= ' positive';
19367ef3e88SSatoshi Sahara                    $value = '+' . $value;
19467ef3e88SSatoshi Sahara                } elseif ($this->info['sizechange'] < 0) {
19567ef3e88SSatoshi Sahara                    $class .= ' negative';
19667ef3e88SSatoshi Sahara                    $value = '-' . $value;
19767ef3e88SSatoshi Sahara                } else {
19867ef3e88SSatoshi Sahara                    $value = '±' . $value;
19967ef3e88SSatoshi Sahara                }
20067ef3e88SSatoshi Sahara                return '<span class="'.$class.'">'.$value.'</span>';
20167ef3e88SSatoshi Sahara            }
20267ef3e88SSatoshi Sahara        }; // end of anonymous class (objRevInfo)
2036c9fde82SSatoshi Sahara    }
2046c9fde82SSatoshi Sahara
2056c9fde82SSatoshi Sahara}
206