xref: /template/strap/action/qualitymessage.php (revision 9b9e6d1fd4c31e9d70c96490a12e4d7445d392eb)
108ca4f85Sgerardnico<?php
208ca4f85Sgerardnico
308ca4f85Sgerardnicouse ComboStrap\Analytics;
4d262537cSgerardnicouse ComboStrap\Auth;
508ca4f85Sgerardnicouse ComboStrap\LogUtility;
6d262537cSgerardnicouse ComboStrap\Note;
708ca4f85Sgerardnicouse ComboStrap\Page;
808ca4f85Sgerardnicouse ComboStrap\PagesIndex;
908ca4f85Sgerardnicouse ComboStrap\PluginUtility;
1008ca4f85Sgerardnico
1108ca4f85Sgerardnicoif (!defined('DOKU_INC')) die();
1208ca4f85Sgerardnicoif (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN', DOKU_INC . 'lib/plugins/');
1308ca4f85Sgerardnico
1408ca4f85Sgerardnico
1508ca4f85Sgerardnicorequire_once(__DIR__ . '/../class/Page.php');
16d262537cSgerardnicorequire_once(__DIR__ . '/../class/Note.php');
1708ca4f85Sgerardnico
1808ca4f85Sgerardnico/**
1908ca4f85Sgerardnico *
2008ca4f85Sgerardnico * Show a quality message
2108ca4f85Sgerardnico *
2208ca4f85Sgerardnico *
2308ca4f85Sgerardnico *
2408ca4f85Sgerardnico */
2508ca4f85Sgerardnicoclass action_plugin_combo_qualitymessage extends DokuWiki_Action_Plugin
2608ca4f85Sgerardnico{
2708ca4f85Sgerardnico
2808ca4f85Sgerardnico    // a class can not start with a number
2908ca4f85Sgerardnico    const QUALITY_BOX_CLASS = "quality-message";
3008ca4f85Sgerardnico
31aa3cb38fSgerardnico    /**
32aa3cb38fSgerardnico     * The quality rules that will not show
33aa3cb38fSgerardnico     * up in the messages
34aa3cb38fSgerardnico     */
35aa3cb38fSgerardnico    const CONF_EXCLUDED_QUALITY_RULES_FROM_DYNAMIC_MONITORING = "excludedQualityRulesFromDynamicMonitoring";
36aa3cb38fSgerardnico
3708ca4f85Sgerardnico
3808ca4f85Sgerardnico    function __construct()
3908ca4f85Sgerardnico    {
4008ca4f85Sgerardnico        // enable direct access to language strings
4108ca4f85Sgerardnico        // ie $this->lang
4208ca4f85Sgerardnico        $this->setupLocale();
4308ca4f85Sgerardnico    }
4408ca4f85Sgerardnico
4508ca4f85Sgerardnico
4608ca4f85Sgerardnico    function register(Doku_Event_Handler $controller)
4708ca4f85Sgerardnico    {
4808ca4f85Sgerardnico
4908ca4f85Sgerardnico        $controller->register_hook(
5008ca4f85Sgerardnico            'TPL_ACT_RENDER',
5108ca4f85Sgerardnico            'BEFORE',
5208ca4f85Sgerardnico            $this,
5308ca4f85Sgerardnico            '_displayQualityMessage',
5408ca4f85Sgerardnico            array()
5508ca4f85Sgerardnico        );
5608ca4f85Sgerardnico
5708ca4f85Sgerardnico
5808ca4f85Sgerardnico    }
5908ca4f85Sgerardnico
6008ca4f85Sgerardnico
6108ca4f85Sgerardnico    /**
6208ca4f85Sgerardnico     * Main function; dispatches the visual comment actions
6308ca4f85Sgerardnico     * @param   $event Doku_Event
6408ca4f85Sgerardnico     */
6508ca4f85Sgerardnico    function _displayQualityMessage(&$event, $param)
6608ca4f85Sgerardnico    {
6708ca4f85Sgerardnico        if ($event->data == 'show') {
68d262537cSgerardnico
69d262537cSgerardnico            /**
70d262537cSgerardnico             * Quality is just for the writers
71d262537cSgerardnico             */
72d262537cSgerardnico            if (!Auth::isWriter()) {
73d262537cSgerardnico                return;
74d262537cSgerardnico            }
75d262537cSgerardnico
76ef295d81Sgerardnico            $note = $this->createQualityNote(PluginUtility::getPageId(), $this);
77d262537cSgerardnico            if ($note != null) {
78d262537cSgerardnico                ptln($note->getHtml());
79d262537cSgerardnico            }
80d262537cSgerardnico        }
81d262537cSgerardnico
82d262537cSgerardnico    }
83d262537cSgerardnico
84d262537cSgerardnico    /**
85d262537cSgerardnico     * @param $pageId
86d262537cSgerardnico     * @param $plugin - Plugin
87d262537cSgerardnico     * @return Note|null
88d262537cSgerardnico     */
89ef295d81Sgerardnico    static public function createQualityNote($pageId, $plugin)
90d262537cSgerardnico    {
91d262537cSgerardnico        $page = new Page($pageId);
92aa3cb38fSgerardnico
93aa3cb38fSgerardnico        if ($page->isBar()) {
94aa3cb38fSgerardnico            return null;
95aa3cb38fSgerardnico        }
96*9b9e6d1fSgerardnico
97d262537cSgerardnico        if ($page->existInFs()) {
9808ca4f85Sgerardnico            $analytics = $page->getAnalyticsFromFs();
99aa3cb38fSgerardnico            $rules = $analytics[Analytics::QUALITY][Analytics::RULES];
10008ca4f85Sgerardnico
101aa3cb38fSgerardnico            /**
102aa3cb38fSgerardnico             * If there is no info, nothing to show
103aa3cb38fSgerardnico             */
104aa3cb38fSgerardnico            if (!array_key_exists(Analytics::INFO, $rules)) {
105aa3cb38fSgerardnico                return null;
106aa3cb38fSgerardnico            }
107aa3cb38fSgerardnico
108aa3cb38fSgerardnico            /**
109aa3cb38fSgerardnico             * The error info
110aa3cb38fSgerardnico             */
111aa3cb38fSgerardnico            $qualityInfoRules = $rules[Analytics::INFO];
112aa3cb38fSgerardnico
113aa3cb38fSgerardnico            /**
114aa3cb38fSgerardnico             * Excluding the excluded rules
115aa3cb38fSgerardnico             */
116aa3cb38fSgerardnico            global $conf;
117aa3cb38fSgerardnico            $excludedRulesConf = $conf['plugin'][PluginUtility::PLUGIN_BASE_NAME][self::CONF_EXCLUDED_QUALITY_RULES_FROM_DYNAMIC_MONITORING];
118aa3cb38fSgerardnico            $excludedRules = preg_split("/,/", $excludedRulesConf);
119aa3cb38fSgerardnico            foreach ($excludedRules as $excludedRule) {
120aa3cb38fSgerardnico                if (array_key_exists($excludedRule, $qualityInfoRules)) {
121aa3cb38fSgerardnico                    unset($qualityInfoRules[$excludedRule]);
12208ca4f85Sgerardnico                }
12308ca4f85Sgerardnico            }
12408ca4f85Sgerardnico
12508ca4f85Sgerardnico            if (sizeof($qualityInfoRules) > 0) {
12608ca4f85Sgerardnico
12708ca4f85Sgerardnico                $qualityScore = $analytics[Analytics::QUALITY][renderer_plugin_combo_analytics::SCORING][renderer_plugin_combo_analytics::SCORE];
128d262537cSgerardnico                $message = new Note($plugin);
129d262537cSgerardnico                $message->addContent("<p>Well played, you got a " . PluginUtility::getUrl("quality:score", "quality score") . " of {$qualityScore} !</p>");
130722648eaSgerardnico                if ($page->isLowQualityPage()) {
131722648eaSgerardnico                    $analytics = $page->getAnalyticsFromFs(true);
132722648eaSgerardnico                    $mandatoryFailedRules = $analytics[Analytics::QUALITY][Analytics::FAILED_MANDATORY_RULES];
133722648eaSgerardnico                    $rulesUrl = PluginUtility::getUrl("quality:rule", "rules");
134722648eaSgerardnico                    $lqPageUrl = PluginUtility::getUrl("low_quality_page", "low quality page");
135722648eaSgerardnico                    $message->addContent("<div class='alert alert-info'>This is a {$lqPageUrl} because it has failed the following mandatory {$rulesUrl}:");
136722648eaSgerardnico                    $message->addContent("<ul style='margin-bottom: 0'>");
137ef295d81Sgerardnico
138722648eaSgerardnico                    foreach ($mandatoryFailedRules as $mandatoryFailedRule) {
139ef295d81Sgerardnico                        $message->addContent("<li>".PluginUtility::getUrl("quality:rule#list", $mandatoryFailedRule)."</li>");
140722648eaSgerardnico                    }
141722648eaSgerardnico                    $message->addContent("</ul>");
142722648eaSgerardnico                    $message->addContent("</div>");
143722648eaSgerardnico                }
14408ca4f85Sgerardnico                $message->addContent("<p>You can still win a couple of points.</p>");
14508ca4f85Sgerardnico                $message->addContent("<ul>");
14608ca4f85Sgerardnico                foreach ($qualityInfoRules as $qualityRule => $qualityInfo) {
14708ca4f85Sgerardnico                    $message->addContent("<li>");
14808ca4f85Sgerardnico                    $message->addContent($qualityInfo);
14908ca4f85Sgerardnico                    $message->addContent("</li>");
15008ca4f85Sgerardnico                }
15108ca4f85Sgerardnico                $message->addContent("</ul>");
15208ca4f85Sgerardnico
153d262537cSgerardnico                $message->setSignatureCanonical("quality:dynamic_monitoring");
154d262537cSgerardnico                $message->setSignatureName("Quality Dynamic Monitoring Feature");
155d262537cSgerardnico                $message->setType(Note::TYPE_CLASSIC);
15608ca4f85Sgerardnico                $message->setClass(self::QUALITY_BOX_CLASS);
157d262537cSgerardnico                return $message;
15808ca4f85Sgerardnico
15908ca4f85Sgerardnico
16008ca4f85Sgerardnico            }
16108ca4f85Sgerardnico        }
162d262537cSgerardnico        return null;
16308ca4f85Sgerardnico    }
16408ca4f85Sgerardnico
16508ca4f85Sgerardnico
16608ca4f85Sgerardnico}
167