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 76*ef295d81Sgerardnico $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 */ 89*ef295d81Sgerardnico static public function createQualityNote($pageId, $plugin) 90d262537cSgerardnico { 91d262537cSgerardnico $page = new Page($pageId); 92aa3cb38fSgerardnico 93aa3cb38fSgerardnico if ($page->isBar()) { 94aa3cb38fSgerardnico return null; 95aa3cb38fSgerardnico } 96d262537cSgerardnico if ($page->existInFs()) { 9708ca4f85Sgerardnico $analytics = $page->getAnalyticsFromFs(); 98aa3cb38fSgerardnico $rules = $analytics[Analytics::QUALITY][Analytics::RULES]; 9908ca4f85Sgerardnico 100aa3cb38fSgerardnico /** 101aa3cb38fSgerardnico * If there is no info, nothing to show 102aa3cb38fSgerardnico */ 103aa3cb38fSgerardnico if (!array_key_exists(Analytics::INFO, $rules)) { 104aa3cb38fSgerardnico return null; 105aa3cb38fSgerardnico } 106aa3cb38fSgerardnico 107aa3cb38fSgerardnico /** 108aa3cb38fSgerardnico * The error info 109aa3cb38fSgerardnico */ 110aa3cb38fSgerardnico $qualityInfoRules = $rules[Analytics::INFO]; 111aa3cb38fSgerardnico 112aa3cb38fSgerardnico /** 113aa3cb38fSgerardnico * Excluding the excluded rules 114aa3cb38fSgerardnico */ 115aa3cb38fSgerardnico global $conf; 116aa3cb38fSgerardnico $excludedRulesConf = $conf['plugin'][PluginUtility::PLUGIN_BASE_NAME][self::CONF_EXCLUDED_QUALITY_RULES_FROM_DYNAMIC_MONITORING]; 117aa3cb38fSgerardnico $excludedRules = preg_split("/,/", $excludedRulesConf); 118aa3cb38fSgerardnico foreach ($excludedRules as $excludedRule) { 119aa3cb38fSgerardnico if (array_key_exists($excludedRule, $qualityInfoRules)) { 120aa3cb38fSgerardnico unset($qualityInfoRules[$excludedRule]); 12108ca4f85Sgerardnico } 12208ca4f85Sgerardnico } 12308ca4f85Sgerardnico 12408ca4f85Sgerardnico if (sizeof($qualityInfoRules) > 0) { 12508ca4f85Sgerardnico 12608ca4f85Sgerardnico $qualityScore = $analytics[Analytics::QUALITY][renderer_plugin_combo_analytics::SCORING][renderer_plugin_combo_analytics::SCORE]; 127d262537cSgerardnico $message = new Note($plugin); 128d262537cSgerardnico $message->addContent("<p>Well played, you got a " . PluginUtility::getUrl("quality:score", "quality score") . " of {$qualityScore} !</p>"); 129722648eaSgerardnico if ($page->isLowQualityPage()) { 130722648eaSgerardnico $analytics = $page->getAnalyticsFromFs(true); 131722648eaSgerardnico $mandatoryFailedRules = $analytics[Analytics::QUALITY][Analytics::FAILED_MANDATORY_RULES]; 132722648eaSgerardnico $rulesUrl = PluginUtility::getUrl("quality:rule", "rules"); 133722648eaSgerardnico $lqPageUrl = PluginUtility::getUrl("low_quality_page", "low quality page"); 134722648eaSgerardnico $message->addContent("<div class='alert alert-info'>This is a {$lqPageUrl} because it has failed the following mandatory {$rulesUrl}:"); 135722648eaSgerardnico $message->addContent("<ul style='margin-bottom: 0'>"); 136*ef295d81Sgerardnico 137722648eaSgerardnico foreach ($mandatoryFailedRules as $mandatoryFailedRule) { 138*ef295d81Sgerardnico $message->addContent("<li>".PluginUtility::getUrl("quality:rule#list", $mandatoryFailedRule)."</li>"); 139722648eaSgerardnico } 140722648eaSgerardnico $message->addContent("</ul>"); 141722648eaSgerardnico $message->addContent("</div>"); 142722648eaSgerardnico } 14308ca4f85Sgerardnico $message->addContent("<p>You can still win a couple of points.</p>"); 14408ca4f85Sgerardnico $message->addContent("<ul>"); 14508ca4f85Sgerardnico foreach ($qualityInfoRules as $qualityRule => $qualityInfo) { 14608ca4f85Sgerardnico $message->addContent("<li>"); 14708ca4f85Sgerardnico $message->addContent($qualityInfo); 14808ca4f85Sgerardnico $message->addContent("</li>"); 14908ca4f85Sgerardnico } 15008ca4f85Sgerardnico $message->addContent("</ul>"); 15108ca4f85Sgerardnico 152d262537cSgerardnico $message->setSignatureCanonical("quality:dynamic_monitoring"); 153d262537cSgerardnico $message->setSignatureName("Quality Dynamic Monitoring Feature"); 154d262537cSgerardnico $message->setType(Note::TYPE_CLASSIC); 15508ca4f85Sgerardnico $message->setClass(self::QUALITY_BOX_CLASS); 156d262537cSgerardnico return $message; 15708ca4f85Sgerardnico 15808ca4f85Sgerardnico 15908ca4f85Sgerardnico } 16008ca4f85Sgerardnico } 161d262537cSgerardnico return null; 16208ca4f85Sgerardnico } 16308ca4f85Sgerardnico 16408ca4f85Sgerardnico 16508ca4f85Sgerardnico} 166