11794c5faSDominik Eckelmann<?php 21794c5faSDominik Eckelmann 31794c5faSDominik Eckelmannif(!defined('DOKU_INC')) die(); 41794c5faSDominik Eckelmann 51794c5faSDominik Eckelmannclass action_plugin_publish_banner extends DokuWiki_Action_Plugin { 61794c5faSDominik Eckelmann 7248339c4SDominik Eckelmann /** 8248339c4SDominik Eckelmann * @var helper_plugin_publish 9248339c4SDominik Eckelmann */ 101794c5faSDominik Eckelmann private $hlp; 111794c5faSDominik Eckelmann 121794c5faSDominik Eckelmann function __construct() { 131794c5faSDominik Eckelmann $this->hlp = plugin_load('helper','publish'); 141794c5faSDominik Eckelmann } 151794c5faSDominik Eckelmann 16c2a737a8SDominik Eckelmann function register(Doku_Event_Handler &$controller) { 171794c5faSDominik Eckelmann $controller->register_hook('TPL_ACT_RENDER', 'BEFORE', $this, 'handle_display_banner', array()); 181794c5faSDominik Eckelmann } 191794c5faSDominik Eckelmann 201794c5faSDominik Eckelmann function handle_display_banner(&$event, $param) { 211794c5faSDominik Eckelmann global $INFO; 221794c5faSDominik Eckelmann 23*d9258364SDominik Eckelmann if (!$this->hlp->isActive()) { 241794c5faSDominik Eckelmann return; 251794c5faSDominik Eckelmann } 261794c5faSDominik Eckelmann 271794c5faSDominik Eckelmann if ($event->data != 'show') { 281794c5faSDominik Eckelmann return; 291794c5faSDominik Eckelmann } 301794c5faSDominik Eckelmann 311794c5faSDominik Eckelmann if (!$INFO['exists']) { 321794c5faSDominik Eckelmann return; 331794c5faSDominik Eckelmann } 341794c5faSDominik Eckelmann 351794c5faSDominik Eckelmann $meta = $INFO['meta']; 361794c5faSDominik Eckelmann 371794c5faSDominik Eckelmann if (!$meta['approval']) { 381794c5faSDominik Eckelmann $meta['approval'] = array(); 391794c5faSDominik Eckelmann } 401794c5faSDominik Eckelmann 412391ef60SAndreas Gohr if($INFO['perm'] <= AUTH_READ && $this->getConf('hidereaderbanner')){ 422391ef60SAndreas Gohr return; 432391ef60SAndreas Gohr } 441794c5faSDominik Eckelmann 451794c5faSDominik Eckelmann $this->showBanner(); 461794c5faSDominik Eckelmann return; 471794c5faSDominik Eckelmann } 481794c5faSDominik Eckelmann 491794c5faSDominik Eckelmann function difflink($id, $rev1, $rev2) { 501794c5faSDominik Eckelmann if($rev1 == $rev2) { return ''; } 511794c5faSDominik Eckelmann return '<a href="' . wl($id, 'rev2[]=' . $rev1 . '&rev2[]=' . $rev2 . '&do[diff]=1') . 521794c5faSDominik Eckelmann '" class="approved_diff_link">' . 531794c5faSDominik Eckelmann '<img src="'.DOKU_BASE.'lib/images/diff.png" class="approved_diff_link" alt="Diff" />' . 541794c5faSDominik Eckelmann '</a>'; 551794c5faSDominik Eckelmann } 561794c5faSDominik Eckelmann 571794c5faSDominik Eckelmann function showBanner() { 581794c5faSDominik Eckelmann if ($this->hlp->isCurrentRevisionApproved()) { 591794c5faSDominik Eckelmann $class = 'approved_yes'; 601794c5faSDominik Eckelmann } else { 612b00c146SDominik Eckelmann if ($this->hlp->isHiddenForUser()) { 62e9bf2be1SDominik Eckelmann return; 63e9bf2be1SDominik Eckelmann } 641794c5faSDominik Eckelmann $class = 'approved_no'; 651794c5faSDominik Eckelmann } 661794c5faSDominik Eckelmann 671794c5faSDominik Eckelmann printf('<div class="approval %s">', $class); 681794c5faSDominik Eckelmann $this->showLatestDraftIfNewer(); 691794c5faSDominik Eckelmann $this->showLatestApprovedVersion(); 701794c5faSDominik Eckelmann $this->showDraft(); 711794c5faSDominik Eckelmann $this->showApproved(); 721794c5faSDominik Eckelmann $this->showPreviousApproved(); 731794c5faSDominik Eckelmann 741794c5faSDominik Eckelmann $this->showApproveAction(); 752b00c146SDominik Eckelmann $this->showInternalNote(); 761794c5faSDominik Eckelmann 771794c5faSDominik Eckelmann echo '</div>'; 781794c5faSDominik Eckelmann } 791794c5faSDominik Eckelmann 802b00c146SDominik Eckelmann function showInternalNote() { 812b00c146SDominik Eckelmann $note = trim($this->getConf('internal note')); 822b00c146SDominik Eckelmann if ($note === '') { 832b00c146SDominik Eckelmann return; 842b00c146SDominik Eckelmann } 852b00c146SDominik Eckelmann if (!$this->hlp->isHidden()) { 862b00c146SDominik Eckelmann return; 872b00c146SDominik Eckelmann } 882b00c146SDominik Eckelmann 892b00c146SDominik Eckelmann printf('<span>%s</span>', hsc($note)); 902b00c146SDominik Eckelmann } 912b00c146SDominik Eckelmann 921794c5faSDominik Eckelmann function showLatestDraftIfNewer() { 931794c5faSDominik Eckelmann global $ID; 941794c5faSDominik Eckelmann $revision = $this->hlp->getRevision(); 951794c5faSDominik Eckelmann $latestRevision = $this->hlp->getLastestRevision(); 961794c5faSDominik Eckelmann 971794c5faSDominik Eckelmann if ($revision >= $latestRevision) { 981794c5faSDominik Eckelmann return; 991794c5faSDominik Eckelmann } 1001794c5faSDominik Eckelmann if ($this->hlp->isRevisionApproved($latestRevision)) { 1011794c5faSDominik Eckelmann return; 1021794c5faSDominik Eckelmann } 1031794c5faSDominik Eckelmann 1041794c5faSDominik Eckelmann echo '<span class="approval_latest_draft">'; 1051794c5faSDominik Eckelmann printf($this->getLang('apr_recent_draft'), wl($ID, 'force_rev=1')); 1061794c5faSDominik Eckelmann echo $this->difflink($ID, null, $revision) . '</span>'; 1071794c5faSDominik Eckelmann } 1081794c5faSDominik Eckelmann 1091794c5faSDominik Eckelmann function showLatestApprovedVersion() { 1101794c5faSDominik Eckelmann global $ID; 1111794c5faSDominik Eckelmann $revision = $this->hlp->getRevision(); 1121794c5faSDominik Eckelmann $latestApprovedRevision = $this->hlp->getLatestApprovedRevision(); 1131794c5faSDominik Eckelmann 1141794c5faSDominik Eckelmann if ($latestApprovedRevision <= $revision) { 1151794c5faSDominik Eckelmann return; 1161794c5faSDominik Eckelmann } 1171794c5faSDominik Eckelmann 1181794c5faSDominik Eckelmann $latestRevision = $this->hlp->getLastestRevision(); 1191794c5faSDominik Eckelmann if ($latestApprovedRevision == $latestRevision) { 1201794c5faSDominik Eckelmann //$latestApprovedRevision = ''; 1211794c5faSDominik Eckelmann } 1221794c5faSDominik Eckelmann echo '<span class="approval_outdated">'; 1231794c5faSDominik Eckelmann printf($this->getLang('apr_outdated'), wl($ID, 'rev=' . $latestApprovedRevision)); 1241794c5faSDominik Eckelmann echo $this->difflink($ID, $latestApprovedRevision, $revision) . '</span>'; 1251794c5faSDominik Eckelmann } 1261794c5faSDominik Eckelmann 1271794c5faSDominik Eckelmann function showDraft() { 1281794c5faSDominik Eckelmann $revision = $this->hlp->getRevision(); 1291794c5faSDominik Eckelmann 1301794c5faSDominik Eckelmann if ($this->hlp->isCurrentRevisionApproved()) { 1311794c5faSDominik Eckelmann return; 1321794c5faSDominik Eckelmann } 1331794c5faSDominik Eckelmann 1341794c5faSDominik Eckelmann $approvals = $this->hlp->getApprovalsOnRevision($this->hlp->getRevision()); 1351794c5faSDominik Eckelmann $approvalCount = count($approvals); 1361794c5faSDominik Eckelmann 1371794c5faSDominik Eckelmann echo '<span class="approval_draft">'; 1381794c5faSDominik Eckelmann printf($this->getLang('apr_draft'), '<span class="approval_date">' . dformat($revision) . '</span>'); 1391794c5faSDominik Eckelmann echo '<br />'; 1401794c5faSDominik Eckelmann printf(' ' . $this->getLang('approvals'), $approvalCount, $this->getConf('number_of_approved')); 1411794c5faSDominik Eckelmann if ($approvalCount != 0) { 1421794c5faSDominik Eckelmann printf(' ' . $this->getLang('approved by'), implode(', ', $this->hlp->getApprovers())); 1431794c5faSDominik Eckelmann } 1441794c5faSDominik Eckelmann echo '</span>'; 1451794c5faSDominik Eckelmann } 1461794c5faSDominik Eckelmann 1471794c5faSDominik Eckelmann function showApproved() { 1481794c5faSDominik Eckelmann if (!$this->hlp->isCurrentRevisionApproved()) { 1491794c5faSDominik Eckelmann return; 1501794c5faSDominik Eckelmann } 1511794c5faSDominik Eckelmann 1521794c5faSDominik Eckelmann echo '<span class="approval_approved">'; 1531794c5faSDominik Eckelmann printf($this->getLang('apr_approved'), 1541794c5faSDominik Eckelmann '<span class="approval_date">' . dformat($this->hlp->getApprovalDate()) . '</span>', 1551794c5faSDominik Eckelmann implode(', ', $this->hlp->getApprovers())); 1561794c5faSDominik Eckelmann echo '</span>'; 1571794c5faSDominik Eckelmann } 1581794c5faSDominik Eckelmann 1591794c5faSDominik Eckelmann function showPreviousApproved() { 1601794c5faSDominik Eckelmann global $ID; 1611794c5faSDominik Eckelmann $previousApproved = $this->hlp->getPreviousApprovedRevision(); 1621794c5faSDominik Eckelmann if (!$previousApproved) { 1631794c5faSDominik Eckelmann return; 1641794c5faSDominik Eckelmann } 1651794c5faSDominik Eckelmann echo '<span class="approval_previous">'; 1661794c5faSDominik Eckelmann printf($this->getLang('apr_previous'), 1671794c5faSDominik Eckelmann wl($ID, 'rev=' . $previousApproved), 1681794c5faSDominik Eckelmann dformat($previousApproved)); 1691794c5faSDominik Eckelmann echo $this->difflink($ID, $previousApproved, $this->hlp->getRevision()) . '</span>'; 1701794c5faSDominik Eckelmann } 1711794c5faSDominik Eckelmann 1721794c5faSDominik Eckelmann private function showApproveAction() { 1731794c5faSDominik Eckelmann global $ID; 1741794c5faSDominik Eckelmann global $REV; 1751794c5faSDominik Eckelmann global $USERINFO; 1761794c5faSDominik Eckelmann if (!$this->hlp->canApprove()) { 1771794c5faSDominik Eckelmann return; 1781794c5faSDominik Eckelmann } 1791794c5faSDominik Eckelmann 1801794c5faSDominik Eckelmann $approvals = $this->hlp->getApprovalsOnRevision($this->hlp->getRevision()); 1811794c5faSDominik Eckelmann foreach ($approvals as $approve) { 1821794c5faSDominik Eckelmann if ($approve[1] == $_SERVER['REMOTE_USER']) { 1831794c5faSDominik Eckelmann return; 1841794c5faSDominik Eckelmann } 1851794c5faSDominik Eckelmann if ($approve[1] == $USERINFO['mail']) { 1861794c5faSDominik Eckelmann return; 1871794c5faSDominik Eckelmann } 1881794c5faSDominik Eckelmann } 1891794c5faSDominik Eckelmann 1901794c5faSDominik Eckelmann echo '<span class="approval_action">'; 1911794c5faSDominik Eckelmann echo '<a href="' . wl($ID, array('rev' => $REV, 'publish_approve'=>1)) . '">'; 1921794c5faSDominik Eckelmann echo $this->getLang('approve action'); 1931794c5faSDominik Eckelmann echo '</a>'; 1941794c5faSDominik Eckelmann echo '</span> '; 1951794c5faSDominik Eckelmann } 1961794c5faSDominik Eckelmann} 197