xref: /plugin/publish/action/banner.php (revision d925836499a451841905892e9450b59427c1ea5a)
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