163ab9afeSSatoshi Sahara<?php 263ab9afeSSatoshi Sahara 363ab9afeSSatoshi Saharanamespace dokuwiki\Ui; 463ab9afeSSatoshi Sahara 563ab9afeSSatoshi Saharause dokuwiki\ChangeLog\MediaChangeLog; 663ab9afeSSatoshi Saharause dokuwiki\Extension\Event; 763ab9afeSSatoshi Saharause dokuwiki\Form\Form; 863ab9afeSSatoshi Sahara 963ab9afeSSatoshi Sahara/** 1063ab9afeSSatoshi Sahara * DokuWiki MediaDiff Interface 1163ab9afeSSatoshi Sahara * 1263ab9afeSSatoshi Sahara * @package dokuwiki\Ui 1363ab9afeSSatoshi Sahara */ 1463ab9afeSSatoshi Saharaclass MediaDiff extends Diff 1563ab9afeSSatoshi Sahara{ 1663ab9afeSSatoshi Sahara /** 1763ab9afeSSatoshi Sahara * MediaDiff Ui constructor 1863ab9afeSSatoshi Sahara * 19edb50e6aSSatoshi Sahara * @param string $id media id 2063ab9afeSSatoshi Sahara */ 21edb50e6aSSatoshi Sahara public function __construct($id) 2263ab9afeSSatoshi Sahara { 2363ab9afeSSatoshi Sahara $this->id = $id; 24edb50e6aSSatoshi Sahara 25edb50e6aSSatoshi Sahara $this->preference['fromAjax'] = false; // see doluwiki\Ajax::callMediadiff() 26edb50e6aSSatoshi Sahara $this->preference['showIntro'] = false; 27*309aaee5SSatoshi Sahara $this->preference['difftype'] = null; // diff view type for media: both, opacity or portions 288068440fSSatoshi Sahara 298068440fSSatoshi Sahara $this->setChangeLog(); 308068440fSSatoshi Sahara } 318068440fSSatoshi Sahara 328068440fSSatoshi Sahara /** @inheritdoc */ 338068440fSSatoshi Sahara protected function setChangeLog() 348068440fSSatoshi Sahara { 358068440fSSatoshi Sahara $this->changelog = new MediaChangeLog($this->id); 3663ab9afeSSatoshi Sahara } 3763ab9afeSSatoshi Sahara 38b4b4c5c6SSatoshi Sahara /** @inheritdoc */ 39b4b4c5c6SSatoshi Sahara protected function preProcess() 40b4b4c5c6SSatoshi Sahara { 41b4b4c5c6SSatoshi Sahara parent::preProcess(); 42b4b4c5c6SSatoshi Sahara if (!isset($this->old_rev, $this->new_rev)) { 43b4b4c5c6SSatoshi Sahara // no revision was given, compare previous to current 448068440fSSatoshi Sahara $revs = $this->changelog->getRevisions(0, 1); 45b4b4c5c6SSatoshi Sahara $this->old_rev = file_exists(mediaFN($this->id, $revs[0])) ? $revs[0] : ''; 46b4b4c5c6SSatoshi Sahara $this->new_rev = ''; 47b4b4c5c6SSatoshi Sahara } 48b4b4c5c6SSatoshi Sahara } 49b4b4c5c6SSatoshi Sahara 5063ab9afeSSatoshi Sahara /** 5163ab9afeSSatoshi Sahara * Shows difference between two revisions of media 52675f74fbSSatoshi Sahara * 53675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 5463ab9afeSSatoshi Sahara */ 55*309aaee5SSatoshi Sahara public function show() 5663ab9afeSSatoshi Sahara { 57675f74fbSSatoshi Sahara global $conf; 58675f74fbSSatoshi Sahara 5963ab9afeSSatoshi Sahara $ns = getNS($this->id); 6063ab9afeSSatoshi Sahara $auth = auth_quickaclcheck("$ns:*"); 61675f74fbSSatoshi Sahara 62675f74fbSSatoshi Sahara if ($auth < AUTH_READ || !$this->id || !$conf['mediarevisions']) return ''; 63675f74fbSSatoshi Sahara 64675f74fbSSatoshi Sahara // determine left and right revision 65b4b4c5c6SSatoshi Sahara $this->preProcess(); 66b4b4c5c6SSatoshi Sahara [$l_rev, $r_rev] = [$this->old_rev, $this->new_rev]; 67675f74fbSSatoshi Sahara 68675f74fbSSatoshi Sahara // prepare event data 69675f74fbSSatoshi Sahara // NOTE: MEDIA_DIFF event does not found in DokuWiki Event List? 70675f74fbSSatoshi Sahara $data = array(); 71675f74fbSSatoshi Sahara $data[0] = $this->id; 72675f74fbSSatoshi Sahara $data[1] = $l_rev; 73675f74fbSSatoshi Sahara $data[2] = $r_rev; 74675f74fbSSatoshi Sahara $data[3] = $ns; 75675f74fbSSatoshi Sahara $data[4] = $auth; // permission level 76675f74fbSSatoshi Sahara $data[5] = $this->preference['fromAjax']; 77675f74fbSSatoshi Sahara 78675f74fbSSatoshi Sahara // trigger event 79675f74fbSSatoshi Sahara Event::createAndTrigger('MEDIA_DIFF', $data, null, false); 80675f74fbSSatoshi Sahara 81675f74fbSSatoshi Sahara if (is_array($data) && count($data) === 6) { 82675f74fbSSatoshi Sahara $this->id = $data[0]; 83675f74fbSSatoshi Sahara $l_rev = $data[1]; 84675f74fbSSatoshi Sahara $r_rev = $data[2]; 85675f74fbSSatoshi Sahara $ns = $data[3]; 86675f74fbSSatoshi Sahara $auth = $data[4]; 87675f74fbSSatoshi Sahara $this->preference['fromAjax'] = $data[5]; 88675f74fbSSatoshi Sahara } else { 89675f74fbSSatoshi Sahara return ''; 90675f74fbSSatoshi Sahara } 91675f74fbSSatoshi Sahara 92675f74fbSSatoshi Sahara $l_meta = new \JpegMeta(mediaFN($this->id, $l_rev)); 93675f74fbSSatoshi Sahara $r_meta = new \JpegMeta(mediaFN($this->id, $r_rev)); 94675f74fbSSatoshi Sahara 95675f74fbSSatoshi Sahara $is_img = preg_match('/\.(jpe?g|gif|png)$/', $this->id); 96675f74fbSSatoshi Sahara if ($is_img) { 97675f74fbSSatoshi Sahara // get image width and height for the mediamanager preview panel 98675f74fbSSatoshi Sahara $l_size = media_image_preview_size($this->id, $l_rev, $l_meta); 99675f74fbSSatoshi Sahara $r_size = media_image_preview_size($this->id, $r_rev, $r_meta); 100675f74fbSSatoshi Sahara // re-check image, ensure minimum image width for showImageDiff() 101675f74fbSSatoshi Sahara $is_img = ($l_size && $r_size && ($l_size[0] >= 30 || $r_size[0] >= 30)); 102675f74fbSSatoshi Sahara } 103675f74fbSSatoshi Sahara 104675f74fbSSatoshi Sahara // determine requested diff view type 105*309aaee5SSatoshi Sahara if (!$is_img) { 106*309aaee5SSatoshi Sahara $this->preference['difftype'] = 'both'; 107*309aaee5SSatoshi Sahara } 108675f74fbSSatoshi Sahara 109675f74fbSSatoshi Sahara // display intro 110675f74fbSSatoshi Sahara if ($this->preference['showIntro']) echo p_locale_xhtml('diff'); 111675f74fbSSatoshi Sahara 112675f74fbSSatoshi Sahara // print form to choose diff view type 113675f74fbSSatoshi Sahara if ($is_img && !$this->preference['fromAjax']) { 114675f74fbSSatoshi Sahara $this->showDiffViewSelector($l_rev, $r_rev); 115675f74fbSSatoshi Sahara echo '<div id="mediamanager__diff" >'; 116675f74fbSSatoshi Sahara } 117675f74fbSSatoshi Sahara 118*309aaee5SSatoshi Sahara switch ($this->preference['difftype']) { 119675f74fbSSatoshi Sahara case 'opacity': 120675f74fbSSatoshi Sahara case 'portions': 121675f74fbSSatoshi Sahara $this->showImageDiff($l_rev, $r_rev, $l_size, $r_size, $difftype); 122675f74fbSSatoshi Sahara break; 123675f74fbSSatoshi Sahara case 'both': 124675f74fbSSatoshi Sahara default: 125675f74fbSSatoshi Sahara $this->showFileDiff($l_rev, $r_rev, $l_meta, $r_meta, $auth); 126675f74fbSSatoshi Sahara break; 127675f74fbSSatoshi Sahara } 128675f74fbSSatoshi Sahara 129675f74fbSSatoshi Sahara if ($is_img && !$this->preference['fromAjax']) { 130675f74fbSSatoshi Sahara echo '</div>'; 131675f74fbSSatoshi Sahara } 1322db397b2SSatoshi Sahara } 1332db397b2SSatoshi Sahara 1342db397b2SSatoshi Sahara /** 135675f74fbSSatoshi Sahara * Print form to choose diff view type 136675f74fbSSatoshi Sahara * the dropdown is to be added through JavaScript, see lib/scripts/media.js 1372db397b2SSatoshi Sahara * 138675f74fbSSatoshi Sahara * @param int $l_rev revision timestamp of left side 139675f74fbSSatoshi Sahara * @param int $r_rev revision timestamp of right side 1402db397b2SSatoshi Sahara */ 141675f74fbSSatoshi Sahara protected function showDiffViewSelector($l_rev, $r_rev) 1422db397b2SSatoshi Sahara { 1432db397b2SSatoshi Sahara $form = new Form([ 1442db397b2SSatoshi Sahara 'id' => 'mediamanager__form_diffview', 1452db397b2SSatoshi Sahara 'action' => media_managerURL([], '&'), 1462db397b2SSatoshi Sahara 'method' => 'get', 1472db397b2SSatoshi Sahara 'class' => 'diffView', 1482db397b2SSatoshi Sahara ]); 1492db397b2SSatoshi Sahara $form->addTagOpen('div')->addClass('no'); 1502db397b2SSatoshi Sahara $form->setHiddenField('sectok', null); 1512db397b2SSatoshi Sahara $form->setHiddenField('mediado', 'diff'); 15258c5cb81SSatoshi Sahara $form->setHiddenField('rev2[0]', $l_rev ?: 'current'); 15358c5cb81SSatoshi Sahara $form->setHiddenField('rev2[1]', $r_rev ?: 'current'); 1542db397b2SSatoshi Sahara $form->addTagClose('div'); 1552db397b2SSatoshi Sahara echo $form->toHTML(); 1562db397b2SSatoshi Sahara } 1572db397b2SSatoshi Sahara 158675f74fbSSatoshi Sahara /** 159675f74fbSSatoshi Sahara * Prints two images side by side 160675f74fbSSatoshi Sahara * and slider 161675f74fbSSatoshi Sahara * 162675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 163675f74fbSSatoshi Sahara * 164675f74fbSSatoshi Sahara * @param int $l_rev revision timestamp, or empty string 165675f74fbSSatoshi Sahara * @param int $r_rev revision timestamp, or empty string 166675f74fbSSatoshi Sahara * @param array $l_size array with width and height 167675f74fbSSatoshi Sahara * @param array $r_size array with width and height 168*309aaee5SSatoshi Sahara * @param string $type diff view type: opacity or portions 169675f74fbSSatoshi Sahara */ 170675f74fbSSatoshi Sahara protected function showImageDiff($l_rev, $r_rev, $l_size, $r_size, $type = null) 171675f74fbSSatoshi Sahara { 172675f74fbSSatoshi Sahara if (!isset($type)) { 173675f74fbSSatoshi Sahara $type = $this->preference['difftype']; 174675f74fbSSatoshi Sahara } 175675f74fbSSatoshi Sahara 176675f74fbSSatoshi Sahara // adjust image width, right side (newer) has priority 177675f74fbSSatoshi Sahara if ($l_size != $r_size) { 178675f74fbSSatoshi Sahara if ($r_size[0] > $l_size[0]) { 179675f74fbSSatoshi Sahara $l_size = $r_size; 1802db397b2SSatoshi Sahara } 1812db397b2SSatoshi Sahara } 1822db397b2SSatoshi Sahara 183675f74fbSSatoshi Sahara $l_src = ml($this->id, ['rev' => $l_rev, 'h' => $l_size[1], 'w' => $l_size[0]]); 184675f74fbSSatoshi Sahara $r_src = ml($this->id, ['rev' => $r_rev, 'h' => $l_size[1], 'w' => $l_size[0]]); 185675f74fbSSatoshi Sahara 186675f74fbSSatoshi Sahara // slider 187675f74fbSSatoshi Sahara echo '<div class="slider" style="max-width: '.($l_size[0]-20).'px;" ></div>'; 188675f74fbSSatoshi Sahara 189675f74fbSSatoshi Sahara // two images in divs 190675f74fbSSatoshi Sahara echo '<div class="imageDiff '.$type.'">'; 191675f74fbSSatoshi Sahara echo '<div class="image1" style="max-width: '.$l_size[0].'px;">'; 192675f74fbSSatoshi Sahara echo '<img src="'.$l_src.'" alt="" />'; 193675f74fbSSatoshi Sahara echo '</div>'; 194675f74fbSSatoshi Sahara echo '<div class="image2" style="max-width: '.$l_size[0].'px;">'; 195675f74fbSSatoshi Sahara echo '<img src="'.$r_src.'" alt="" />'; 196675f74fbSSatoshi Sahara echo '</div>'; 197675f74fbSSatoshi Sahara echo '</div>'; 198675f74fbSSatoshi Sahara } 199675f74fbSSatoshi Sahara 200675f74fbSSatoshi Sahara /** 201675f74fbSSatoshi Sahara * Shows difference between two revisions of media file 202675f74fbSSatoshi Sahara * 203675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 204675f74fbSSatoshi Sahara * 205675f74fbSSatoshi Sahara * @param string|int $l_rev revision timestamp, or empty string 206675f74fbSSatoshi Sahara * @param string|int $r_rev revision timestamp, or empty string 207675f74fbSSatoshi Sahara * @param JpegMeta $l_meta 208675f74fbSSatoshi Sahara * @param JpegMeta $r_meta 209675f74fbSSatoshi Sahara * @param int $auth permission level 210675f74fbSSatoshi Sahara */ 211675f74fbSSatoshi Sahara protected function showFileDiff($l_rev, $r_rev, $l_meta, $r_meta, $auth) 212675f74fbSSatoshi Sahara { 2138068440fSSatoshi Sahara list($l_head, $r_head) = $this->buildDiffHead($l_rev, $r_rev); 2142db397b2SSatoshi Sahara 2152db397b2SSatoshi Sahara echo '<div class="table">'; 2162db397b2SSatoshi Sahara echo '<table>'; 2172db397b2SSatoshi Sahara echo '<tr>'; 2182db397b2SSatoshi Sahara echo '<th>'. $l_head .'</th>'; 2192db397b2SSatoshi Sahara echo '<th>'. $r_head .'</th>'; 220675f74fbSSatoshi Sahara echo '</tr>'; 2212db397b2SSatoshi Sahara 2222db397b2SSatoshi Sahara echo '<tr class="image">'; 2232db397b2SSatoshi Sahara echo '<td>'; 224675f74fbSSatoshi Sahara media_preview($this->id, $auth, $l_rev, $l_meta); // $auth not used in media_preview()? 2252db397b2SSatoshi Sahara echo '</td>'; 2262db397b2SSatoshi Sahara 2272db397b2SSatoshi Sahara echo '<td>'; 228675f74fbSSatoshi Sahara media_preview($this->id, $auth, $r_rev, $r_meta); 2292db397b2SSatoshi Sahara echo '</td>'; 230675f74fbSSatoshi Sahara echo '</tr>'; 2312db397b2SSatoshi Sahara 2322db397b2SSatoshi Sahara echo '<tr class="actions">'; 2332db397b2SSatoshi Sahara echo '<td>'; 234675f74fbSSatoshi Sahara media_preview_buttons($this->id, $auth, $l_rev); // $auth used in media_preview_buttons() 2352db397b2SSatoshi Sahara echo '</td>'; 2362db397b2SSatoshi Sahara 2372db397b2SSatoshi Sahara echo '<td>'; 238675f74fbSSatoshi Sahara media_preview_buttons($this->id, $auth, $r_rev); 2392db397b2SSatoshi Sahara echo '</td>'; 240675f74fbSSatoshi Sahara echo '</tr>'; 2412db397b2SSatoshi Sahara 2422db397b2SSatoshi Sahara $l_tags = media_file_tags($l_meta); 2432db397b2SSatoshi Sahara $r_tags = media_file_tags($r_meta); 2442db397b2SSatoshi Sahara // FIXME r_tags-only stuff 2452db397b2SSatoshi Sahara foreach ($l_tags as $key => $l_tag) { 2462db397b2SSatoshi Sahara if ($l_tag['value'] != $r_tags[$key]['value']) { 2472db397b2SSatoshi Sahara $r_tags[$key]['highlighted'] = true; 2482db397b2SSatoshi Sahara $l_tags[$key]['highlighted'] = true; 2492db397b2SSatoshi Sahara } elseif (!$l_tag['value'] || !$r_tags[$key]['value']) { 2502db397b2SSatoshi Sahara unset($r_tags[$key]); 2512db397b2SSatoshi Sahara unset($l_tags[$key]); 2522db397b2SSatoshi Sahara } 2532db397b2SSatoshi Sahara } 2542db397b2SSatoshi Sahara 2552db397b2SSatoshi Sahara echo '<tr>'; 2562db397b2SSatoshi Sahara foreach (array($l_tags, $r_tags) as $tags) { 257675f74fbSSatoshi Sahara echo '<td>'; 2582db397b2SSatoshi Sahara 2592db397b2SSatoshi Sahara echo '<dl class="img_tags">'; 2602db397b2SSatoshi Sahara foreach ($tags as $tag) { 2612db397b2SSatoshi Sahara $value = cleanText($tag['value']); 2622db397b2SSatoshi Sahara if (!$value) $value = '-'; 2632db397b2SSatoshi Sahara echo '<dt>'.$lang[$tag['tag'][1]].'</dt>'; 2642db397b2SSatoshi Sahara echo '<dd>'; 2652db397b2SSatoshi Sahara if ($tag['highlighted']) echo '<strong>'; 2662db397b2SSatoshi Sahara if ($tag['tag'][2] == 'date') { 2672db397b2SSatoshi Sahara echo dformat($value); 2682db397b2SSatoshi Sahara } else { 2692db397b2SSatoshi Sahara echo hsc($value); 2702db397b2SSatoshi Sahara } 2712db397b2SSatoshi Sahara if ($tag['highlighted']) echo '</strong>'; 2722db397b2SSatoshi Sahara echo '</dd>'; 2732db397b2SSatoshi Sahara } 274675f74fbSSatoshi Sahara echo '</dl>'; 2752db397b2SSatoshi Sahara 2762db397b2SSatoshi Sahara echo '</td>'; 2772db397b2SSatoshi Sahara } 278675f74fbSSatoshi Sahara echo '</tr>'; 2792db397b2SSatoshi Sahara 280675f74fbSSatoshi Sahara echo '</table>'; 281675f74fbSSatoshi Sahara echo '</div>'; 28263ab9afeSSatoshi Sahara } 28363ab9afeSSatoshi Sahara 28463ab9afeSSatoshi Sahara} 285