xref: /dokuwiki/inc/Ui/PageRevisions.php (revision ae5d2354c9aa93da542d9f0607167c5e0a6100be)
1b370ebcdSSatoshi Sahara<?php
2b370ebcdSSatoshi Sahara
3b370ebcdSSatoshi Saharanamespace dokuwiki\Ui;
4b370ebcdSSatoshi Sahara
5b370ebcdSSatoshi Saharause dokuwiki\ChangeLog\PageChangeLog;
6b370ebcdSSatoshi Saharause dokuwiki\Form\Form;
7b370ebcdSSatoshi Sahara
8b370ebcdSSatoshi Sahara/**
9b370ebcdSSatoshi Sahara * DokuWiki PageRevisions Interface
10b370ebcdSSatoshi Sahara *
11b370ebcdSSatoshi Sahara * @package dokuwiki\Ui
12b370ebcdSSatoshi Sahara */
13*ae5d2354SSatoshi Saharaclass PageRevisions extends Revisions
14b370ebcdSSatoshi Sahara{
15b370ebcdSSatoshi Sahara    /**
16b370ebcdSSatoshi Sahara     * PageRevisions Ui constructor
17b370ebcdSSatoshi Sahara     *
18b370ebcdSSatoshi Sahara     * @param string $id  id of page
19b370ebcdSSatoshi Sahara     */
20b370ebcdSSatoshi Sahara    public function __construct($id)
21b370ebcdSSatoshi Sahara    {
22b370ebcdSSatoshi Sahara        global $ID, $INFO;
23b370ebcdSSatoshi Sahara        if (!$id) $id = $INFO['id'];
24*ae5d2354SSatoshi Sahara        parent::__construct($id);
25b370ebcdSSatoshi Sahara    }
26b370ebcdSSatoshi Sahara
27b370ebcdSSatoshi Sahara    /**
28b370ebcdSSatoshi Sahara     * Display list of old revisions of the page
29b370ebcdSSatoshi Sahara     *
30b370ebcdSSatoshi Sahara     * @author Andreas Gohr <andi@splitbrain.org>
31b370ebcdSSatoshi Sahara     * @author Ben Coburn <btcoburn@silicodon.net>
32b370ebcdSSatoshi Sahara     * @author Kate Arzamastseva <pshns@ukr.net>
33b370ebcdSSatoshi Sahara     * @author Satoshi Sahara <sahara.satoshi@gmail.com>
34b370ebcdSSatoshi Sahara     *
35b370ebcdSSatoshi Sahara     * @param int $first  skip the first n changelog lines
36b370ebcdSSatoshi Sahara     * @return void
37b370ebcdSSatoshi Sahara     */
38b370ebcdSSatoshi Sahara    public function show($first = 0)
39b370ebcdSSatoshi Sahara    {
40b370ebcdSSatoshi Sahara        global $lang;
41b370ebcdSSatoshi Sahara
42b370ebcdSSatoshi Sahara        // get revisions, and set correct pagenation parameters (first, hasNext)
43b370ebcdSSatoshi Sahara        if ($first === null) $first = 0;
44b370ebcdSSatoshi Sahara        $hasNext = false;
45b370ebcdSSatoshi Sahara        $revisions = $this->getRevisions($first, $hasNext);
46b370ebcdSSatoshi Sahara
47b370ebcdSSatoshi Sahara        // print intro
48b370ebcdSSatoshi Sahara        print p_locale_xhtml('revisions');
49b370ebcdSSatoshi Sahara
50b370ebcdSSatoshi Sahara        // create the form
51b370ebcdSSatoshi Sahara        $form = new Form([
52b370ebcdSSatoshi Sahara                'id' => 'page__revisions',
53b370ebcdSSatoshi Sahara                'class' => 'changes',
54b370ebcdSSatoshi Sahara        ]);
55b370ebcdSSatoshi Sahara        $form->addTagOpen('div')->addClass('no');
56b370ebcdSSatoshi Sahara
57b370ebcdSSatoshi Sahara        // start listing
58b370ebcdSSatoshi Sahara        $form->addTagOpen('ul');
59b370ebcdSSatoshi Sahara        foreach ($revisions as $info) {
60b370ebcdSSatoshi Sahara            $rev = $info['date'];
61b370ebcdSSatoshi Sahara            $class = ($info['type'] === DOKU_CHANGE_TYPE_MINOR_EDIT) ? 'minor' : '';
62b370ebcdSSatoshi Sahara            $form->addTagOpen('li')->addClass($class);
63b370ebcdSSatoshi Sahara            $form->addTagOpen('div')->addClass('li');
64b370ebcdSSatoshi Sahara
65b370ebcdSSatoshi Sahara            if (page_exists($this->id, $rev)) {
66b370ebcdSSatoshi Sahara                $form->addCheckbox('rev2[]')->val($rev);
67b370ebcdSSatoshi Sahara            } else {
68b370ebcdSSatoshi Sahara                $form->addCheckbox('')->val($rev)->attr('disabled','disabled');
69b370ebcdSSatoshi Sahara            }
70b370ebcdSSatoshi Sahara            $form->addHTML(' ');
71b370ebcdSSatoshi Sahara
72b370ebcdSSatoshi Sahara            $objRevInfo = $this->getObjRevInfo($info);
73b370ebcdSSatoshi Sahara            $html = implode(' ', [
74b370ebcdSSatoshi Sahara                $objRevInfo->editDate(),          // edit date and time
75b370ebcdSSatoshi Sahara                $objRevInfo->difflink(),          // link to diffview icon
76b370ebcdSSatoshi Sahara                $objRevInfo->itemName(),          // name of page or media
77b370ebcdSSatoshi Sahara                $objRevInfo->editSummary(),       // edit summary
78b370ebcdSSatoshi Sahara                $objRevInfo->editor(),            // editor info
79b370ebcdSSatoshi Sahara                $objRevInfo->sizechange(),        // size change indicator
80b370ebcdSSatoshi Sahara                $objRevInfo->currentIndicator(),  // current indicator (only when k=1)
81b370ebcdSSatoshi Sahara            ]);
82b370ebcdSSatoshi Sahara            $form->addHTML($html);
83b370ebcdSSatoshi Sahara            $form->addTagClose('div');
84b370ebcdSSatoshi Sahara            $form->addTagClose('li');
85b370ebcdSSatoshi Sahara        }
86b370ebcdSSatoshi Sahara        $form->addTagClose('ul');  // end of revision list
87b370ebcdSSatoshi Sahara
88b370ebcdSSatoshi Sahara        // show button for diff view
89b370ebcdSSatoshi Sahara        $form->addButton('do[diff]', $lang['diff2'])->attr('type', 'submit');
90b370ebcdSSatoshi Sahara
91b370ebcdSSatoshi Sahara        $form->addTagClose('div'); // close div class=no
92b370ebcdSSatoshi Sahara
93b370ebcdSSatoshi Sahara        print $form->toHTML('Revisions');
94b370ebcdSSatoshi Sahara
95b370ebcdSSatoshi Sahara        // provide navigation for pagenated revision list (of pages and/or media files)
96*ae5d2354SSatoshi Sahara        print $this->navigation($first, $hasNext, function ($n) {
97*ae5d2354SSatoshi Sahara            return array('do' => 'revisions', 'first' => $n);
98*ae5d2354SSatoshi Sahara        });
99b370ebcdSSatoshi Sahara    }
100b370ebcdSSatoshi Sahara
101b370ebcdSSatoshi Sahara    /**
102b370ebcdSSatoshi Sahara     * Get revisions, and set correct pagenation parameters (first, hasNext)
103b370ebcdSSatoshi Sahara     *
104b370ebcdSSatoshi Sahara     * @param int  $first
105b370ebcdSSatoshi Sahara     * @param bool $hasNext
106b370ebcdSSatoshi Sahara     * @return array  revisions to be shown in a pagenated list
107b370ebcdSSatoshi Sahara     * @see also https://www.dokuwiki.org/devel:changelog
108b370ebcdSSatoshi Sahara     */
109b370ebcdSSatoshi Sahara    protected function getRevisions(&$first, &$hasNext)
110b370ebcdSSatoshi Sahara    {
111b370ebcdSSatoshi Sahara        global $INFO, $conf;
112b370ebcdSSatoshi Sahara
113b370ebcdSSatoshi Sahara        $changelog = new PageChangeLog($INFO['id']);
114b370ebcdSSatoshi Sahara
115b370ebcdSSatoshi Sahara        $revisions = [];
116b370ebcdSSatoshi Sahara
117b370ebcdSSatoshi Sahara        /* we need to get one additional log entry to be able to
118b370ebcdSSatoshi Sahara         * decide if this is the last page or is there another one.
119b370ebcdSSatoshi Sahara         * see also Ui\Recent::getRecents()
120b370ebcdSSatoshi Sahara         */
121b370ebcdSSatoshi Sahara        $revlist = $changelog->getRevisions($first, $conf['recent'] +1);
122b370ebcdSSatoshi Sahara        if (count($revlist) == 0 && $first != 0) {
123b370ebcdSSatoshi Sahara            $first = 0;
124b370ebcdSSatoshi Sahara            $revlist = $changelog->getRevisions($first, $conf['recent'] +1);
125b370ebcdSSatoshi Sahara        }
126b370ebcdSSatoshi Sahara        $exists = $INFO['exists'];
127b370ebcdSSatoshi Sahara        if ($first === 0 && $exists) {
128b370ebcdSSatoshi Sahara            // add current page as revision[0]
129b370ebcdSSatoshi Sahara            $revisions[] = array(
130b370ebcdSSatoshi Sahara                    'date' => $INFO['lastmod'],
131b370ebcdSSatoshi Sahara                    'ip'   => null,
132b370ebcdSSatoshi Sahara                    'type' => $INFO['meta']['last_change']['type'],
133b370ebcdSSatoshi Sahara                    'id'   => $INFO['id'],
134b370ebcdSSatoshi Sahara                    'user' => $INFO['editor'],
135b370ebcdSSatoshi Sahara                    'sum'  => $INFO['sum'],
136b370ebcdSSatoshi Sahara                    'extra' => null,
137b370ebcdSSatoshi Sahara                    'sizechange' => $INFO['meta']['last_change']['sizechange'],
138b370ebcdSSatoshi Sahara                    'current' => true,
139b370ebcdSSatoshi Sahara            );
140b370ebcdSSatoshi Sahara        }
141b370ebcdSSatoshi Sahara
142b370ebcdSSatoshi Sahara        // decide if this is the last page or is there another one
143b370ebcdSSatoshi Sahara        $hasNext = false;
144b370ebcdSSatoshi Sahara        if (count($revlist) > $conf['recent']) {
145b370ebcdSSatoshi Sahara            $hasNext = true;
146b370ebcdSSatoshi Sahara            array_pop($revlist); // remove one additional log entry
147b370ebcdSSatoshi Sahara        }
148b370ebcdSSatoshi Sahara
149b370ebcdSSatoshi Sahara        // append each revison info array to the revisions
150b370ebcdSSatoshi Sahara        foreach ($revlist as $rev) {
151b370ebcdSSatoshi Sahara            $revisions[] = $changelog->getRevisionInfo($rev);
152b370ebcdSSatoshi Sahara        }
153b370ebcdSSatoshi Sahara        return $revisions;
154b370ebcdSSatoshi Sahara    }
155b370ebcdSSatoshi Sahara
156b370ebcdSSatoshi Sahara}
157