16c9fde82SSatoshi Sahara<?php 26c9fde82SSatoshi Sahara 36c9fde82SSatoshi Saharanamespace dokuwiki\Ui; 46c9fde82SSatoshi Sahara 56c9fde82SSatoshi Sahara/** 69e316641SSatoshi Sahara * DokuWiki Revisions Interface 7ae5d2354SSatoshi Sahara * parent class of PageRevisions and MediaRevisions 86c9fde82SSatoshi Sahara * 96c9fde82SSatoshi Sahara * @package dokuwiki\Ui 106c9fde82SSatoshi Sahara */ 11ae5d2354SSatoshi Saharaabstract class Revisions extends Ui 126c9fde82SSatoshi Sahara{ 13ae5d2354SSatoshi Sahara /* @var string */ 14e71e09a6SSatoshi Sahara protected $id; // page id or media id 15e71e09a6SSatoshi Sahara protected $item; // page or media 16e71e09a6SSatoshi Sahara 17e71e09a6SSatoshi Sahara /* @var ChangeLog */ 18e71e09a6SSatoshi Sahara protected $changelog; // PageChangeLog or MediaChangeLog object 199e316641SSatoshi Sahara 209e316641SSatoshi Sahara /** 219e316641SSatoshi Sahara * Revisions Ui constructor 229e316641SSatoshi Sahara * 23e71e09a6SSatoshi Sahara * @param string $id page id or media id 249e316641SSatoshi Sahara */ 25ae5d2354SSatoshi Sahara public function __construct($id) 269e316641SSatoshi Sahara { 27ae5d2354SSatoshi Sahara $this->id = $id; 28e71e09a6SSatoshi Sahara $this->setChangeLog(); 29e71e09a6SSatoshi Sahara } 30e71e09a6SSatoshi Sahara 31e71e09a6SSatoshi Sahara /** 32e71e09a6SSatoshi Sahara * set class property changelog 33e71e09a6SSatoshi Sahara */ 34e71e09a6SSatoshi Sahara abstract protected function setChangeLog(); 35e71e09a6SSatoshi Sahara 36e71e09a6SSatoshi Sahara /** 37*d9c75b22SSatoshi Sahara * item filename resolver 38e71e09a6SSatoshi Sahara * 39e71e09a6SSatoshi Sahara * @param string $id page id or media id 40*d9c75b22SSatoshi Sahara * @param int|string $rev revision timestamp, or empty string for current one 41e71e09a6SSatoshi Sahara * @return string full path 42e71e09a6SSatoshi Sahara */ 43*d9c75b22SSatoshi Sahara abstract protected function itemFN($id, $rev = ''); 449e316641SSatoshi Sahara 456c9fde82SSatoshi Sahara /** 4667ef3e88SSatoshi Sahara * Get revisions, and set correct pagenation parameters (first, hasNext) 4767ef3e88SSatoshi Sahara * 4867ef3e88SSatoshi Sahara * @param int $first 4967ef3e88SSatoshi Sahara * @param bool $hasNext 5067ef3e88SSatoshi Sahara * @return array revisions to be shown in a pagenated list 515525369fSSatoshi Sahara * @see also https://www.dokuwiki.org/devel:changelog 5267ef3e88SSatoshi Sahara */ 53e71e09a6SSatoshi Sahara protected function getRevisions(&$first, &$hasNext) 54e71e09a6SSatoshi Sahara { 55e71e09a6SSatoshi Sahara global $conf; 56e71e09a6SSatoshi Sahara 57e71e09a6SSatoshi Sahara $changelog =& $this->changelog; 58e71e09a6SSatoshi Sahara 59e71e09a6SSatoshi Sahara $revisions = array(); 60e71e09a6SSatoshi Sahara 61e71e09a6SSatoshi Sahara /* we need to get one additional log entry to be able to 62e71e09a6SSatoshi Sahara * decide if this is the last page or is there another one. 63e71e09a6SSatoshi Sahara * see also Ui\Recent::getRecents() 64e71e09a6SSatoshi Sahara */ 65e71e09a6SSatoshi Sahara $revlist = $changelog->getRevisions($first, $conf['recent'] +1); 66e71e09a6SSatoshi Sahara if (count($revlist) == 0 && $first != 0) { 67e71e09a6SSatoshi Sahara $first = 0; 68e71e09a6SSatoshi Sahara $revlist = $changelog->getRevisions($first, $conf['recent'] +1); 69e71e09a6SSatoshi Sahara } 70e71e09a6SSatoshi Sahara 71e71e09a6SSatoshi Sahara // add current page or media as revision[0] when necessary 72e71e09a6SSatoshi Sahara if ($first === 0 && file_exists($this->itemFN($this->id))) { 73e71e09a6SSatoshi Sahara $rev = filemtime(fullpath($this->itemFN($this->id))); 74e71e09a6SSatoshi Sahara $changelog->setChunkSize(1024); //FIXME why does chunksize change wanted? 75e71e09a6SSatoshi Sahara $revinfo = $changelog->getRevisionInfo($rev) ?: array( 76e71e09a6SSatoshi Sahara 'date' => $rev, 77e71e09a6SSatoshi Sahara 'ip' => null, 78e71e09a6SSatoshi Sahara 'type' => null, 79e71e09a6SSatoshi Sahara 'id' => $this->id, 80e71e09a6SSatoshi Sahara 'user' => null, 81e71e09a6SSatoshi Sahara 'sum' => null, 82e71e09a6SSatoshi Sahara 'extra' => null, 83e71e09a6SSatoshi Sahara 'sizechange' => null, 84e71e09a6SSatoshi Sahara ); 85e71e09a6SSatoshi Sahara $revisions[] = $revinfo + array( 86e71e09a6SSatoshi Sahara 'item' => $this->item, 87e71e09a6SSatoshi Sahara 'current' => true, 88e71e09a6SSatoshi Sahara ); 89e71e09a6SSatoshi Sahara } 90e71e09a6SSatoshi Sahara 91e71e09a6SSatoshi Sahara // decide if this is the last page or is there another one 92e71e09a6SSatoshi Sahara $hasNext = false; 93e71e09a6SSatoshi Sahara if (count($revlist) > $conf['recent']) { 94e71e09a6SSatoshi Sahara $hasNext = true; 95e71e09a6SSatoshi Sahara array_pop($revlist); // remove one additional log entry 96e71e09a6SSatoshi Sahara } 97e71e09a6SSatoshi Sahara 98e71e09a6SSatoshi Sahara // append each revison info array to the revisions 99e71e09a6SSatoshi Sahara foreach ($revlist as $rev) { 100e71e09a6SSatoshi Sahara $revisions[] = $changelog->getRevisionInfo($rev) + array('item' => $this->item); 101e71e09a6SSatoshi Sahara } 102e71e09a6SSatoshi Sahara return $revisions; 103e71e09a6SSatoshi Sahara } 10467ef3e88SSatoshi Sahara 10567ef3e88SSatoshi Sahara /** 10667ef3e88SSatoshi Sahara * Navigation buttons for Pagenation (prev/next) 10767ef3e88SSatoshi Sahara * 10867ef3e88SSatoshi Sahara * @param int $first 10967ef3e88SSatoshi Sahara * @param bool $hasNext 110ae5d2354SSatoshi Sahara * @param callable $callback returns array of hidden fields for the form button 11167ef3e88SSatoshi Sahara * @return array html 11267ef3e88SSatoshi Sahara */ 113ae5d2354SSatoshi Sahara protected function navigation($first, $hasNext, $callback) 11467ef3e88SSatoshi Sahara { 11567ef3e88SSatoshi Sahara global $conf; 11667ef3e88SSatoshi Sahara 11767ef3e88SSatoshi Sahara $html = '<div class="pagenav">'; 1186c9fde82SSatoshi Sahara $last = $first + $conf['recent']; 1196c9fde82SSatoshi Sahara if ($first > 0) { 12067ef3e88SSatoshi Sahara $first = max($first - $conf['recent'], 0); 12167ef3e88SSatoshi Sahara $html.= '<div class="pagenav-prev">'; 122ae5d2354SSatoshi Sahara $html.= html_btn('newer', $this->id, "p", $callback($first)); 12367ef3e88SSatoshi Sahara $html.= '</div>'; 1246c9fde82SSatoshi Sahara } 1256c9fde82SSatoshi Sahara if ($hasNext) { 12667ef3e88SSatoshi Sahara $html.= '<div class="pagenav-next">'; 127ae5d2354SSatoshi Sahara $html.= html_btn('older', $this->id, "n", $callback($last)); 12867ef3e88SSatoshi Sahara $html.= '</div>'; 1296c9fde82SSatoshi Sahara } 13067ef3e88SSatoshi Sahara $html.= '</div>'; 13167ef3e88SSatoshi Sahara return $html; 13267ef3e88SSatoshi Sahara } 1336c9fde82SSatoshi Sahara 13467ef3e88SSatoshi Sahara /** 13567ef3e88SSatoshi Sahara * Returns instance of objRevInfo 13667ef3e88SSatoshi Sahara * 13767ef3e88SSatoshi Sahara * @param array $info Revision info structure of a page or media file 13867ef3e88SSatoshi Sahara * @return objRevInfo object (anonymous class) 13967ef3e88SSatoshi Sahara */ 1400bb448f0SSatoshi Sahara public function getObjRevInfo(array $info) 14167ef3e88SSatoshi Sahara { 14267ef3e88SSatoshi Sahara return new class ($info) // anonymous class (objRevInfo) 14367ef3e88SSatoshi Sahara { 14467ef3e88SSatoshi Sahara protected $info; 14567ef3e88SSatoshi Sahara 14667ef3e88SSatoshi Sahara public function __construct(array $info) 14767ef3e88SSatoshi Sahara { 14867ef3e88SSatoshi Sahara $this->info = $info; 14967ef3e88SSatoshi Sahara } 15067ef3e88SSatoshi Sahara 15167ef3e88SSatoshi Sahara // current indicator 15267ef3e88SSatoshi Sahara public function currentIndicator() 15367ef3e88SSatoshi Sahara { 15467ef3e88SSatoshi Sahara global $lang; 15567ef3e88SSatoshi Sahara return ($this->info['current']) ? '('.$lang['current'].')' : ''; 15667ef3e88SSatoshi Sahara } 15767ef3e88SSatoshi Sahara 15867ef3e88SSatoshi Sahara // edit date and time of the page or media file 15967ef3e88SSatoshi Sahara public function editDate() 16067ef3e88SSatoshi Sahara { 16167ef3e88SSatoshi Sahara return '<span class="date">'. dformat($this->info['date']) .'</span>'; 16267ef3e88SSatoshi Sahara } 16367ef3e88SSatoshi Sahara 16467ef3e88SSatoshi Sahara // edit summary 16567ef3e88SSatoshi Sahara public function editSummary() 16667ef3e88SSatoshi Sahara { 16767ef3e88SSatoshi Sahara return '<span class="sum">'.' – '. hsc($this->info['sum']).'</span>'; 16867ef3e88SSatoshi Sahara } 16967ef3e88SSatoshi Sahara 17067ef3e88SSatoshi Sahara // editor of the page or media file 17167ef3e88SSatoshi Sahara public function editor() 17267ef3e88SSatoshi Sahara { 17367ef3e88SSatoshi Sahara // slightly different with display of Ui\Recent, i.e. external edit 17467ef3e88SSatoshi Sahara global $lang; 17567ef3e88SSatoshi Sahara $html = '<span class="user">'; 17667ef3e88SSatoshi Sahara if (!$this->info['user'] && !$this->info['ip']) { 17767ef3e88SSatoshi Sahara $html.= '('.$lang['external_edit'].')'; 17867ef3e88SSatoshi Sahara } elseif ($this->info['user']) { 17967ef3e88SSatoshi Sahara $html.= '<bdi>'. editorinfo($this->info['user']) .'</bdi>'; 18067ef3e88SSatoshi Sahara if (auth_ismanager()) $html.= ' <bdo dir="ltr">('. $this->info['ip'] .')</bdo>'; 18167ef3e88SSatoshi Sahara } else { 18267ef3e88SSatoshi Sahara $html.= '<bdo dir="ltr">'. $this->info['ip'] .'</bdo>'; 18367ef3e88SSatoshi Sahara } 18467ef3e88SSatoshi Sahara $html.= '</span>'; 18567ef3e88SSatoshi Sahara return $html; 18667ef3e88SSatoshi Sahara } 18767ef3e88SSatoshi Sahara 18867ef3e88SSatoshi Sahara // name of the page or media file 18967ef3e88SSatoshi Sahara public function itemName() 19067ef3e88SSatoshi Sahara { 19167ef3e88SSatoshi Sahara // slightly different with display of Ui\Recent, i.e. revison may not exists 19267ef3e88SSatoshi Sahara $id = $this->info['id']; 19367ef3e88SSatoshi Sahara $rev = $this->info['date']; 19467ef3e88SSatoshi Sahara 195e71e09a6SSatoshi Sahara switch ($this->info['item']) { 196e71e09a6SSatoshi Sahara case 'media': // media file revision 19767ef3e88SSatoshi Sahara if (isset($this->info['current'])) { 19867ef3e88SSatoshi Sahara $href = media_managerURL(['image'=> $id, 'tab_details'=> 'view'], '&'); 19967ef3e88SSatoshi Sahara $html = '<a href="'.$href.'" class="wikilink1">'.$id.'</a>'; 20067ef3e88SSatoshi Sahara } elseif (file_exists(mediaFN($id, $rev))) { 20167ef3e88SSatoshi Sahara $href = media_managerURL(['image'=> $id, 'tab_details'=> 'view', 'rev'=> $rev], '&'); 20267ef3e88SSatoshi Sahara $html = '<a href="'.$href.'" class="wikilink1">'.$id.'</a>'; 20367ef3e88SSatoshi Sahara } else { 20467ef3e88SSatoshi Sahara $html = $id; 20567ef3e88SSatoshi Sahara } 20667ef3e88SSatoshi Sahara return $html; 207e71e09a6SSatoshi Sahara case 'page': // page revision 20867ef3e88SSatoshi Sahara $display_name = useHeading('navigation') ? hsc(p_get_first_heading($id)) : $id; 20967ef3e88SSatoshi Sahara if (!$display_name) $display_name = $id; 21067ef3e88SSatoshi Sahara if ($this->info['current'] || page_exists($id, $rev)) { 21167ef3e88SSatoshi Sahara $href = wl($id, "rev=$rev", false, '&'); 21267ef3e88SSatoshi Sahara $html = '<a href="'.$href.'" class="wikilink1">'.$display_name.'</a>'; 21367ef3e88SSatoshi Sahara } else { 21467ef3e88SSatoshi Sahara $html = $display_name; 21567ef3e88SSatoshi Sahara } 21667ef3e88SSatoshi Sahara return $html; 21767ef3e88SSatoshi Sahara } 218e71e09a6SSatoshi Sahara return ''; 21967ef3e88SSatoshi Sahara } 22067ef3e88SSatoshi Sahara 22167ef3e88SSatoshi Sahara // icon difflink 22267ef3e88SSatoshi Sahara public function difflink() 22367ef3e88SSatoshi Sahara { 22467ef3e88SSatoshi Sahara global $lang; 22567ef3e88SSatoshi Sahara $id = $this->info['id']; 22667ef3e88SSatoshi Sahara $rev = $this->info['date']; 22767ef3e88SSatoshi Sahara 228e71e09a6SSatoshi Sahara switch ($this->info['item']) { 229e71e09a6SSatoshi Sahara case 'media': // media file revision 23067ef3e88SSatoshi Sahara if (isset($this->info['current']) || !file_exists(mediaFN($id, $rev))) { 23167ef3e88SSatoshi Sahara $html = '<img src="'.DOKU_BASE.'lib/images/blank.gif" width="15" height="11" alt="" />'; 23267ef3e88SSatoshi Sahara } else { 23367ef3e88SSatoshi Sahara $href = media_managerURL(['image'=> $id, 'rev'=> $rev, 'mediado'=>'diff'], '&'); 23467ef3e88SSatoshi Sahara $html = '<a href="'.$href.'" class="diff_link">' 23567ef3e88SSatoshi Sahara . '<img src="'.DOKU_BASE.'lib/images/diff.png" width="15" height="11"' 23667ef3e88SSatoshi Sahara . ' title="'. $lang['diff'] .'" alt="'.$lang['diff'] .'" />' 23767ef3e88SSatoshi Sahara . '</a> '; 23867ef3e88SSatoshi Sahara } 23967ef3e88SSatoshi Sahara return $html; 240e71e09a6SSatoshi Sahara case 'page': // page revision 24167ef3e88SSatoshi Sahara if ($this->info['current'] || !page_exists($id, $rev)) { 24267ef3e88SSatoshi Sahara $html = '<img src="'.DOKU_BASE.'lib/images/blank.gif" width="15" height="11" alt="" />'; 24367ef3e88SSatoshi Sahara } else { 24467ef3e88SSatoshi Sahara $href = wl($id, "rev=$rev,do=diff", false, '&'); 24567ef3e88SSatoshi Sahara $html = '<a href="'.$href.'" class="diff_link">' 24667ef3e88SSatoshi Sahara . '<img src="'.DOKU_BASE.'lib/images/diff.png" width="15" height="11"' 24767ef3e88SSatoshi Sahara . ' title="'.$lang['diff'].'" alt="'.$lang['diff'].'" />' 24867ef3e88SSatoshi Sahara . '</a>'; 24967ef3e88SSatoshi Sahara } 25067ef3e88SSatoshi Sahara return $html; 25167ef3e88SSatoshi Sahara } 252e71e09a6SSatoshi Sahara return ''; 25367ef3e88SSatoshi Sahara } 25467ef3e88SSatoshi Sahara 25567ef3e88SSatoshi Sahara // size change 25667ef3e88SSatoshi Sahara public function sizeChange() 25767ef3e88SSatoshi Sahara { 25867ef3e88SSatoshi Sahara $class = 'sizechange'; 25967ef3e88SSatoshi Sahara $value = filesize_h(abs($this->info['sizechange'])); 26067ef3e88SSatoshi Sahara if ($this->info['sizechange'] > 0) { 26167ef3e88SSatoshi Sahara $class .= ' positive'; 26267ef3e88SSatoshi Sahara $value = '+' . $value; 26367ef3e88SSatoshi Sahara } elseif ($this->info['sizechange'] < 0) { 26467ef3e88SSatoshi Sahara $class .= ' negative'; 26567ef3e88SSatoshi Sahara $value = '-' . $value; 26667ef3e88SSatoshi Sahara } else { 26767ef3e88SSatoshi Sahara $value = '±' . $value; 26867ef3e88SSatoshi Sahara } 26967ef3e88SSatoshi Sahara return '<span class="'.$class.'">'.$value.'</span>'; 27067ef3e88SSatoshi Sahara } 27167ef3e88SSatoshi Sahara }; // end of anonymous class (objRevInfo) 2726c9fde82SSatoshi Sahara } 2736c9fde82SSatoshi Sahara 2746c9fde82SSatoshi Sahara} 275