xref: /template/strap/action/qualitymessage.php (revision 722648ea66ebf5492a297f883b2890d60f7e9bfa)
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
3108ca4f85Sgerardnico
3208ca4f85Sgerardnico    function __construct()
3308ca4f85Sgerardnico    {
3408ca4f85Sgerardnico        // enable direct access to language strings
3508ca4f85Sgerardnico        // ie $this->lang
3608ca4f85Sgerardnico        $this->setupLocale();
3708ca4f85Sgerardnico    }
3808ca4f85Sgerardnico
3908ca4f85Sgerardnico
4008ca4f85Sgerardnico    function register(Doku_Event_Handler $controller)
4108ca4f85Sgerardnico    {
4208ca4f85Sgerardnico
4308ca4f85Sgerardnico        $controller->register_hook(
4408ca4f85Sgerardnico            'TPL_ACT_RENDER',
4508ca4f85Sgerardnico            'BEFORE',
4608ca4f85Sgerardnico            $this,
4708ca4f85Sgerardnico            '_displayQualityMessage',
4808ca4f85Sgerardnico            array()
4908ca4f85Sgerardnico        );
5008ca4f85Sgerardnico
5108ca4f85Sgerardnico
5208ca4f85Sgerardnico    }
5308ca4f85Sgerardnico
5408ca4f85Sgerardnico
5508ca4f85Sgerardnico    /**
5608ca4f85Sgerardnico     * Main function; dispatches the visual comment actions
5708ca4f85Sgerardnico     * @param   $event Doku_Event
5808ca4f85Sgerardnico     */
5908ca4f85Sgerardnico    function _displayQualityMessage(&$event, $param)
6008ca4f85Sgerardnico    {
6108ca4f85Sgerardnico        if ($event->data == 'show') {
62d262537cSgerardnico
63d262537cSgerardnico            /**
64d262537cSgerardnico             * Quality is just for the writers
65d262537cSgerardnico             */
66d262537cSgerardnico            if (!Auth::isWriter()) {
67d262537cSgerardnico                return;
68d262537cSgerardnico            }
69d262537cSgerardnico
70d262537cSgerardnico            $note = $this->getQualityNote(PluginUtility::getPageId(), $this);
71d262537cSgerardnico            if ($note != null) {
72d262537cSgerardnico                ptln($note->getHtml());
73d262537cSgerardnico            }
74d262537cSgerardnico        }
75d262537cSgerardnico
76d262537cSgerardnico    }
77d262537cSgerardnico
78d262537cSgerardnico    /**
79d262537cSgerardnico     * @param $pageId
80d262537cSgerardnico     * @param $plugin - Plugin
81d262537cSgerardnico     * @return Note|null
82d262537cSgerardnico     */
83d262537cSgerardnico    static public function getQualityNote($pageId, $plugin)
84d262537cSgerardnico    {
85d262537cSgerardnico        $page = new Page($pageId);
86d262537cSgerardnico        if ($page->existInFs()) {
8708ca4f85Sgerardnico            $analytics = $page->getAnalyticsFromFs();
8808ca4f85Sgerardnico            $qualityInfoRules = $analytics[Analytics::QUALITY][Analytics::RULES][Analytics::INFO];
8908ca4f85Sgerardnico
9008ca4f85Sgerardnico            // Excluded rules
9108ca4f85Sgerardnico            $excludedRules = array(
9208ca4f85Sgerardnico                renderer_plugin_combo_analytics::RULE_AVERAGE_WORDS_BY_SECTION_MIN,
9308ca4f85Sgerardnico                renderer_plugin_combo_analytics::RULE_AVERAGE_WORDS_BY_SECTION_MAX
9408ca4f85Sgerardnico            );
9508ca4f85Sgerardnico            foreach ($excludedRules as $filter) {
9608ca4f85Sgerardnico                if (array_key_exists($filter, $qualityInfoRules)) {
9708ca4f85Sgerardnico                    unset($qualityInfoRules[$filter]);
9808ca4f85Sgerardnico                }
9908ca4f85Sgerardnico            }
10008ca4f85Sgerardnico
10108ca4f85Sgerardnico            if (sizeof($qualityInfoRules) > 0) {
10208ca4f85Sgerardnico
10308ca4f85Sgerardnico                $qualityScore = $analytics[Analytics::QUALITY][renderer_plugin_combo_analytics::SCORING][renderer_plugin_combo_analytics::SCORE];
104d262537cSgerardnico                $message = new Note($plugin);
105d262537cSgerardnico                $message->addContent("<p>Well played, you got a " . PluginUtility::getUrl("quality:score", "quality score") . " of {$qualityScore} !</p>");
106*722648eaSgerardnico                if ($page->isLowQualityPage()) {
107*722648eaSgerardnico                    $analytics = $page->getAnalyticsFromFs(true);
108*722648eaSgerardnico                    $mandatoryFailedRules = $analytics[Analytics::QUALITY][Analytics::FAILED_MANDATORY_RULES];
109*722648eaSgerardnico                    $rulesUrl = PluginUtility::getUrl("quality:rule", "rules");
110*722648eaSgerardnico                    $lqPageUrl = PluginUtility::getUrl("low_quality_page", "low quality page");
111*722648eaSgerardnico                    $message->addContent("<div class='alert alert-info'>This is a {$lqPageUrl} because it has failed the following mandatory {$rulesUrl}:");
112*722648eaSgerardnico                    $message->addContent("<ul style='margin-bottom: 0'>");
113*722648eaSgerardnico                    foreach ($mandatoryFailedRules as $mandatoryFailedRule){
114*722648eaSgerardnico                        $message->addContent("<li>{$mandatoryFailedRule}</li>");
115*722648eaSgerardnico                    }
116*722648eaSgerardnico                    $message->addContent("</ul>");
117*722648eaSgerardnico                    $message->addContent("</div>");
118*722648eaSgerardnico                }
11908ca4f85Sgerardnico                $message->addContent("<p>You can still win a couple of points.</p>");
12008ca4f85Sgerardnico                $message->addContent("<ul>");
12108ca4f85Sgerardnico                foreach ($qualityInfoRules as $qualityRule => $qualityInfo) {
12208ca4f85Sgerardnico                    $message->addContent("<li>");
12308ca4f85Sgerardnico                    $message->addContent($qualityInfo);
12408ca4f85Sgerardnico                    $message->addContent("</li>");
12508ca4f85Sgerardnico                }
12608ca4f85Sgerardnico                $message->addContent("</ul>");
12708ca4f85Sgerardnico
128d262537cSgerardnico                $message->setSignatureCanonical("quality:dynamic_monitoring");
129d262537cSgerardnico                $message->setSignatureName("Quality Dynamic Monitoring Feature");
130d262537cSgerardnico                $message->setType(Note::TYPE_CLASSIC);
13108ca4f85Sgerardnico                $message->setClass(self::QUALITY_BOX_CLASS);
132d262537cSgerardnico                return $message;
13308ca4f85Sgerardnico
13408ca4f85Sgerardnico
13508ca4f85Sgerardnico            }
13608ca4f85Sgerardnico        }
137d262537cSgerardnico        return null;
13808ca4f85Sgerardnico    }
13908ca4f85Sgerardnico
14008ca4f85Sgerardnico
14108ca4f85Sgerardnico}
142