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; 24*e71e09a6SSatoshi Sahara $this->item = 'media'; 25edb50e6aSSatoshi Sahara 26295564cdSSatoshi Sahara // init preference 27edb50e6aSSatoshi Sahara $this->preference['fromAjax'] = false; // see doluwiki\Ajax::callMediadiff() 28edb50e6aSSatoshi Sahara $this->preference['showIntro'] = false; 2991e70b5fSSatoshi Sahara $this->preference['difftype'] = 'both'; // media diff view type: both, opacity or portions 308068440fSSatoshi Sahara 318068440fSSatoshi Sahara $this->setChangeLog(); 328068440fSSatoshi Sahara } 338068440fSSatoshi Sahara 348068440fSSatoshi Sahara /** @inheritdoc */ 358068440fSSatoshi Sahara protected function setChangeLog() 368068440fSSatoshi Sahara { 378068440fSSatoshi Sahara $this->changelog = new MediaChangeLog($this->id); 3863ab9afeSSatoshi Sahara } 3963ab9afeSSatoshi Sahara 40b4b4c5c6SSatoshi Sahara /** @inheritdoc */ 41b4b4c5c6SSatoshi Sahara protected function preProcess() 42b4b4c5c6SSatoshi Sahara { 43b4b4c5c6SSatoshi Sahara parent::preProcess(); 44b4b4c5c6SSatoshi Sahara if (!isset($this->old_rev, $this->new_rev)) { 45b4b4c5c6SSatoshi Sahara // no revision was given, compare previous to current 468068440fSSatoshi Sahara $revs = $this->changelog->getRevisions(0, 1); 47b4b4c5c6SSatoshi Sahara $this->old_rev = file_exists(mediaFN($this->id, $revs[0])) ? $revs[0] : ''; 48b4b4c5c6SSatoshi Sahara $this->new_rev = ''; 49b4b4c5c6SSatoshi Sahara } 50b4b4c5c6SSatoshi Sahara } 51b4b4c5c6SSatoshi Sahara 5263ab9afeSSatoshi Sahara /** 5363ab9afeSSatoshi Sahara * Shows difference between two revisions of media 54675f74fbSSatoshi Sahara * 55675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 5663ab9afeSSatoshi Sahara */ 57309aaee5SSatoshi Sahara public function show() 5863ab9afeSSatoshi Sahara { 59675f74fbSSatoshi Sahara global $conf; 60675f74fbSSatoshi Sahara 6163ab9afeSSatoshi Sahara $ns = getNS($this->id); 6263ab9afeSSatoshi Sahara $auth = auth_quickaclcheck("$ns:*"); 63675f74fbSSatoshi Sahara 64675f74fbSSatoshi Sahara if ($auth < AUTH_READ || !$this->id || !$conf['mediarevisions']) return ''; 65675f74fbSSatoshi Sahara 66675f74fbSSatoshi Sahara // determine left and right revision 6748d75c00SSatoshi Sahara if (!isset($this->old_rev, $this->new_rev)) $this->preProcess(); 68b4b4c5c6SSatoshi Sahara [$l_rev, $r_rev] = [$this->old_rev, $this->new_rev]; 69675f74fbSSatoshi Sahara 70675f74fbSSatoshi Sahara // prepare event data 71675f74fbSSatoshi Sahara // NOTE: MEDIA_DIFF event does not found in DokuWiki Event List? 72675f74fbSSatoshi Sahara $data = array(); 73675f74fbSSatoshi Sahara $data[0] = $this->id; 74675f74fbSSatoshi Sahara $data[1] = $l_rev; 75675f74fbSSatoshi Sahara $data[2] = $r_rev; 76675f74fbSSatoshi Sahara $data[3] = $ns; 77675f74fbSSatoshi Sahara $data[4] = $auth; // permission level 78675f74fbSSatoshi Sahara $data[5] = $this->preference['fromAjax']; 79675f74fbSSatoshi Sahara 80675f74fbSSatoshi Sahara // trigger event 81675f74fbSSatoshi Sahara Event::createAndTrigger('MEDIA_DIFF', $data, null, false); 82675f74fbSSatoshi Sahara 83675f74fbSSatoshi Sahara if (is_array($data) && count($data) === 6) { 84675f74fbSSatoshi Sahara $this->id = $data[0]; 85675f74fbSSatoshi Sahara $l_rev = $data[1]; 86675f74fbSSatoshi Sahara $r_rev = $data[2]; 87675f74fbSSatoshi Sahara $ns = $data[3]; 88675f74fbSSatoshi Sahara $auth = $data[4]; 89675f74fbSSatoshi Sahara $this->preference['fromAjax'] = $data[5]; 90675f74fbSSatoshi Sahara } else { 91675f74fbSSatoshi Sahara return ''; 92675f74fbSSatoshi Sahara } 93675f74fbSSatoshi Sahara 94675f74fbSSatoshi Sahara $l_meta = new \JpegMeta(mediaFN($this->id, $l_rev)); 95675f74fbSSatoshi Sahara $r_meta = new \JpegMeta(mediaFN($this->id, $r_rev)); 96675f74fbSSatoshi Sahara 97675f74fbSSatoshi Sahara $is_img = preg_match('/\.(jpe?g|gif|png)$/', $this->id); 98675f74fbSSatoshi Sahara if ($is_img) { 99675f74fbSSatoshi Sahara // get image width and height for the mediamanager preview panel 100675f74fbSSatoshi Sahara $l_size = media_image_preview_size($this->id, $l_rev, $l_meta); 101675f74fbSSatoshi Sahara $r_size = media_image_preview_size($this->id, $r_rev, $r_meta); 102675f74fbSSatoshi Sahara // re-check image, ensure minimum image width for showImageDiff() 103675f74fbSSatoshi Sahara $is_img = ($l_size && $r_size && ($l_size[0] >= 30 || $r_size[0] >= 30)); 104675f74fbSSatoshi Sahara } 105675f74fbSSatoshi Sahara 106675f74fbSSatoshi Sahara // determine requested diff view type 107309aaee5SSatoshi Sahara if (!$is_img) { 108309aaee5SSatoshi Sahara $this->preference['difftype'] = 'both'; 109309aaee5SSatoshi Sahara } 110675f74fbSSatoshi Sahara 111675f74fbSSatoshi Sahara // display intro 112675f74fbSSatoshi Sahara if ($this->preference['showIntro']) echo p_locale_xhtml('diff'); 113675f74fbSSatoshi Sahara 114675f74fbSSatoshi Sahara // print form to choose diff view type 115675f74fbSSatoshi Sahara if ($is_img && !$this->preference['fromAjax']) { 11691e70b5fSSatoshi Sahara $this->showDiffViewSelector(); 117675f74fbSSatoshi Sahara echo '<div id="mediamanager__diff" >'; 118675f74fbSSatoshi Sahara } 119675f74fbSSatoshi Sahara 120309aaee5SSatoshi Sahara switch ($this->preference['difftype']) { 121675f74fbSSatoshi Sahara case 'opacity': 122675f74fbSSatoshi Sahara case 'portions': 123675f74fbSSatoshi Sahara $this->showImageDiff($l_rev, $r_rev, $l_size, $r_size, $difftype); 124675f74fbSSatoshi Sahara break; 125675f74fbSSatoshi Sahara case 'both': 126675f74fbSSatoshi Sahara default: 127675f74fbSSatoshi Sahara $this->showFileDiff($l_rev, $r_rev, $l_meta, $r_meta, $auth); 128675f74fbSSatoshi Sahara break; 129675f74fbSSatoshi Sahara } 130675f74fbSSatoshi Sahara 131675f74fbSSatoshi Sahara if ($is_img && !$this->preference['fromAjax']) { 132675f74fbSSatoshi Sahara echo '</div>'; 133675f74fbSSatoshi Sahara } 1342db397b2SSatoshi Sahara } 1352db397b2SSatoshi Sahara 1362db397b2SSatoshi Sahara /** 137675f74fbSSatoshi Sahara * Print form to choose diff view type 138675f74fbSSatoshi Sahara * the dropdown is to be added through JavaScript, see lib/scripts/media.js 1392db397b2SSatoshi Sahara */ 14091e70b5fSSatoshi Sahara protected function showDiffViewSelector() 1412db397b2SSatoshi Sahara { 14291e70b5fSSatoshi Sahara echo '<div class="diffoptions group">'; 14391e70b5fSSatoshi Sahara 1442db397b2SSatoshi Sahara $form = new Form([ 1452db397b2SSatoshi Sahara 'id' => 'mediamanager__form_diffview', 1462db397b2SSatoshi Sahara 'action' => media_managerURL([], '&'), 1472db397b2SSatoshi Sahara 'method' => 'get', 1482db397b2SSatoshi Sahara 'class' => 'diffView', 1492db397b2SSatoshi Sahara ]); 1502db397b2SSatoshi Sahara $form->addTagOpen('div')->addClass('no'); 1512db397b2SSatoshi Sahara $form->setHiddenField('sectok', null); 1522db397b2SSatoshi Sahara $form->setHiddenField('mediado', 'diff'); 15391e70b5fSSatoshi Sahara $form->setHiddenField('rev2[0]', $this->old_rev ?: 'current'); 15491e70b5fSSatoshi Sahara $form->setHiddenField('rev2[1]', $this->new_rev ?: 'current'); 1552db397b2SSatoshi Sahara $form->addTagClose('div'); 1562db397b2SSatoshi Sahara echo $form->toHTML(); 15791e70b5fSSatoshi Sahara 15891e70b5fSSatoshi Sahara echo '</div>'; // .diffoptions 1592db397b2SSatoshi Sahara } 1602db397b2SSatoshi Sahara 161675f74fbSSatoshi Sahara /** 162675f74fbSSatoshi Sahara * Prints two images side by side 163675f74fbSSatoshi Sahara * and slider 164675f74fbSSatoshi Sahara * 165675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 166675f74fbSSatoshi Sahara * 167295564cdSSatoshi Sahara * @param string|int $l_rev revision timestamp, or empty string 168295564cdSSatoshi Sahara * @param string|int $r_rev revision timestamp, or empty string 169675f74fbSSatoshi Sahara * @param array $l_size array with width and height 170675f74fbSSatoshi Sahara * @param array $r_size array with width and height 171309aaee5SSatoshi Sahara * @param string $type diff view type: opacity or portions 172675f74fbSSatoshi Sahara */ 173675f74fbSSatoshi Sahara protected function showImageDiff($l_rev, $r_rev, $l_size, $r_size, $type = null) 174675f74fbSSatoshi Sahara { 175675f74fbSSatoshi Sahara if (!isset($type)) { 176675f74fbSSatoshi Sahara $type = $this->preference['difftype']; 177675f74fbSSatoshi Sahara } 178675f74fbSSatoshi Sahara 179675f74fbSSatoshi Sahara // adjust image width, right side (newer) has priority 180675f74fbSSatoshi Sahara if ($l_size != $r_size) { 181675f74fbSSatoshi Sahara if ($r_size[0] > $l_size[0]) { 182675f74fbSSatoshi Sahara $l_size = $r_size; 1832db397b2SSatoshi Sahara } 1842db397b2SSatoshi Sahara } 1852db397b2SSatoshi Sahara 186675f74fbSSatoshi Sahara $l_src = ml($this->id, ['rev' => $l_rev, 'h' => $l_size[1], 'w' => $l_size[0]]); 187675f74fbSSatoshi Sahara $r_src = ml($this->id, ['rev' => $r_rev, 'h' => $l_size[1], 'w' => $l_size[0]]); 188675f74fbSSatoshi Sahara 189675f74fbSSatoshi Sahara // slider 190675f74fbSSatoshi Sahara echo '<div class="slider" style="max-width: '.($l_size[0]-20).'px;" ></div>'; 191675f74fbSSatoshi Sahara 192675f74fbSSatoshi Sahara // two images in divs 193675f74fbSSatoshi Sahara echo '<div class="imageDiff '.$type.'">'; 194675f74fbSSatoshi Sahara echo '<div class="image1" style="max-width: '.$l_size[0].'px;">'; 195675f74fbSSatoshi Sahara echo '<img src="'.$l_src.'" alt="" />'; 196675f74fbSSatoshi Sahara echo '</div>'; 197675f74fbSSatoshi Sahara echo '<div class="image2" style="max-width: '.$l_size[0].'px;">'; 198675f74fbSSatoshi Sahara echo '<img src="'.$r_src.'" alt="" />'; 199675f74fbSSatoshi Sahara echo '</div>'; 200675f74fbSSatoshi Sahara echo '</div>'; 201675f74fbSSatoshi Sahara } 202675f74fbSSatoshi Sahara 203675f74fbSSatoshi Sahara /** 204675f74fbSSatoshi Sahara * Shows difference between two revisions of media file 205675f74fbSSatoshi Sahara * 206675f74fbSSatoshi Sahara * @author Kate Arzamastseva <pshns@ukr.net> 207675f74fbSSatoshi Sahara * 208675f74fbSSatoshi Sahara * @param string|int $l_rev revision timestamp, or empty string 209675f74fbSSatoshi Sahara * @param string|int $r_rev revision timestamp, or empty string 210675f74fbSSatoshi Sahara * @param JpegMeta $l_meta 211675f74fbSSatoshi Sahara * @param JpegMeta $r_meta 212675f74fbSSatoshi Sahara * @param int $auth permission level 213675f74fbSSatoshi Sahara */ 214675f74fbSSatoshi Sahara protected function showFileDiff($l_rev, $r_rev, $l_meta, $r_meta, $auth) 215675f74fbSSatoshi Sahara { 2168068440fSSatoshi Sahara list($l_head, $r_head) = $this->buildDiffHead($l_rev, $r_rev); 2172db397b2SSatoshi Sahara 2182db397b2SSatoshi Sahara echo '<div class="table">'; 2192db397b2SSatoshi Sahara echo '<table>'; 2202db397b2SSatoshi Sahara echo '<tr>'; 2212db397b2SSatoshi Sahara echo '<th>'. $l_head .'</th>'; 2222db397b2SSatoshi Sahara echo '<th>'. $r_head .'</th>'; 223675f74fbSSatoshi Sahara echo '</tr>'; 2242db397b2SSatoshi Sahara 2252db397b2SSatoshi Sahara echo '<tr class="image">'; 2262db397b2SSatoshi Sahara echo '<td>'; 227675f74fbSSatoshi Sahara media_preview($this->id, $auth, $l_rev, $l_meta); // $auth not used in media_preview()? 2282db397b2SSatoshi Sahara echo '</td>'; 2292db397b2SSatoshi Sahara 2302db397b2SSatoshi Sahara echo '<td>'; 231675f74fbSSatoshi Sahara media_preview($this->id, $auth, $r_rev, $r_meta); 2322db397b2SSatoshi Sahara echo '</td>'; 233675f74fbSSatoshi Sahara echo '</tr>'; 2342db397b2SSatoshi Sahara 2352db397b2SSatoshi Sahara echo '<tr class="actions">'; 2362db397b2SSatoshi Sahara echo '<td>'; 237675f74fbSSatoshi Sahara media_preview_buttons($this->id, $auth, $l_rev); // $auth used in media_preview_buttons() 2382db397b2SSatoshi Sahara echo '</td>'; 2392db397b2SSatoshi Sahara 2402db397b2SSatoshi Sahara echo '<td>'; 241675f74fbSSatoshi Sahara media_preview_buttons($this->id, $auth, $r_rev); 2422db397b2SSatoshi Sahara echo '</td>'; 243675f74fbSSatoshi Sahara echo '</tr>'; 2442db397b2SSatoshi Sahara 2452db397b2SSatoshi Sahara $l_tags = media_file_tags($l_meta); 2462db397b2SSatoshi Sahara $r_tags = media_file_tags($r_meta); 2472db397b2SSatoshi Sahara // FIXME r_tags-only stuff 2482db397b2SSatoshi Sahara foreach ($l_tags as $key => $l_tag) { 2492db397b2SSatoshi Sahara if ($l_tag['value'] != $r_tags[$key]['value']) { 2502db397b2SSatoshi Sahara $r_tags[$key]['highlighted'] = true; 2512db397b2SSatoshi Sahara $l_tags[$key]['highlighted'] = true; 2522db397b2SSatoshi Sahara } elseif (!$l_tag['value'] || !$r_tags[$key]['value']) { 2532db397b2SSatoshi Sahara unset($r_tags[$key]); 2542db397b2SSatoshi Sahara unset($l_tags[$key]); 2552db397b2SSatoshi Sahara } 2562db397b2SSatoshi Sahara } 2572db397b2SSatoshi Sahara 2582db397b2SSatoshi Sahara echo '<tr>'; 2592db397b2SSatoshi Sahara foreach (array($l_tags, $r_tags) as $tags) { 260675f74fbSSatoshi Sahara echo '<td>'; 2612db397b2SSatoshi Sahara 2622db397b2SSatoshi Sahara echo '<dl class="img_tags">'; 2632db397b2SSatoshi Sahara foreach ($tags as $tag) { 2642db397b2SSatoshi Sahara $value = cleanText($tag['value']); 2652db397b2SSatoshi Sahara if (!$value) $value = '-'; 2662db397b2SSatoshi Sahara echo '<dt>'.$lang[$tag['tag'][1]].'</dt>'; 2672db397b2SSatoshi Sahara echo '<dd>'; 2682db397b2SSatoshi Sahara if ($tag['highlighted']) echo '<strong>'; 2692db397b2SSatoshi Sahara if ($tag['tag'][2] == 'date') { 2702db397b2SSatoshi Sahara echo dformat($value); 2712db397b2SSatoshi Sahara } else { 2722db397b2SSatoshi Sahara echo hsc($value); 2732db397b2SSatoshi Sahara } 2742db397b2SSatoshi Sahara if ($tag['highlighted']) echo '</strong>'; 2752db397b2SSatoshi Sahara echo '</dd>'; 2762db397b2SSatoshi Sahara } 277675f74fbSSatoshi Sahara echo '</dl>'; 2782db397b2SSatoshi Sahara 2792db397b2SSatoshi Sahara echo '</td>'; 2802db397b2SSatoshi Sahara } 281675f74fbSSatoshi Sahara echo '</tr>'; 2822db397b2SSatoshi Sahara 283675f74fbSSatoshi Sahara echo '</table>'; 284675f74fbSSatoshi Sahara echo '</div>'; 28563ab9afeSSatoshi Sahara } 28663ab9afeSSatoshi Sahara 28763ab9afeSSatoshi Sahara} 288