108ca4f85Sgerardnico<?php 208ca4f85Sgerardnico 308ca4f85Sgerardnicouse ComboStrap\Analytics; 4a6bf47aaSNickeauuse ComboStrap\Identity; 508ca4f85Sgerardnicouse ComboStrap\LogUtility; 68aa9d0e6Sgerardnicouse ComboStrap\Message; 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'); 168aa9d0e6Sgerardnicorequire_once(__DIR__ . '/../class/Message.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"; 365f891b7eSNickeau /** 375f891b7eSNickeau * Disable the message totally 385f891b7eSNickeau */ 395f891b7eSNickeau const CONF_DISABLE_QUALITY_MONITORING = "disableDynamicQualityMonitoring"; 40aa3cb38fSgerardnico 41eee76a3dSgerardnico /** 42eee76a3dSgerardnico * Key in the frontmatter that disable the message 43eee76a3dSgerardnico */ 44eee76a3dSgerardnico const DISABLE_INDICATOR = "dynamic_quality_monitoring"; 45eee76a3dSgerardnico 4608ca4f85Sgerardnico 4708ca4f85Sgerardnico function __construct() 4808ca4f85Sgerardnico { 4908ca4f85Sgerardnico // enable direct access to language strings 5008ca4f85Sgerardnico // ie $this->lang 5108ca4f85Sgerardnico $this->setupLocale(); 5208ca4f85Sgerardnico } 5308ca4f85Sgerardnico 5408ca4f85Sgerardnico 5508ca4f85Sgerardnico function register(Doku_Event_Handler $controller) 5608ca4f85Sgerardnico { 5708ca4f85Sgerardnico 585f891b7eSNickeau if(!$this->getConf(self::CONF_DISABLE_QUALITY_MONITORING)) { 5908ca4f85Sgerardnico $controller->register_hook( 6008ca4f85Sgerardnico 'TPL_ACT_RENDER', 6108ca4f85Sgerardnico 'BEFORE', 6208ca4f85Sgerardnico $this, 6308ca4f85Sgerardnico '_displayQualityMessage', 6408ca4f85Sgerardnico array() 6508ca4f85Sgerardnico ); 665f891b7eSNickeau } 6708ca4f85Sgerardnico 6808ca4f85Sgerardnico 6908ca4f85Sgerardnico } 7008ca4f85Sgerardnico 7108ca4f85Sgerardnico 7208ca4f85Sgerardnico /** 7308ca4f85Sgerardnico * Main function; dispatches the visual comment actions 7408ca4f85Sgerardnico * @param $event Doku_Event 7508ca4f85Sgerardnico */ 7608ca4f85Sgerardnico function _displayQualityMessage(&$event, $param) 7708ca4f85Sgerardnico { 7808ca4f85Sgerardnico if ($event->data == 'show') { 79d262537cSgerardnico 80d262537cSgerardnico /** 81d262537cSgerardnico * Quality is just for the writers 82d262537cSgerardnico */ 83a6bf47aaSNickeau if (!Identity::isWriter()) { 84d262537cSgerardnico return; 85d262537cSgerardnico } 86d262537cSgerardnico 87ef295d81Sgerardnico $note = $this->createQualityNote(PluginUtility::getPageId(), $this); 88d262537cSgerardnico if ($note != null) { 89531e725cSNickeau ptln($note->toHtml()); 90d262537cSgerardnico } 91d262537cSgerardnico } 92d262537cSgerardnico 93d262537cSgerardnico } 94d262537cSgerardnico 95d262537cSgerardnico /** 96d262537cSgerardnico * @param $pageId 97d262537cSgerardnico * @param $plugin - Plugin 988aa9d0e6Sgerardnico * @return Message|null 99d262537cSgerardnico */ 100ef295d81Sgerardnico static public function createQualityNote($pageId, $plugin) 101d262537cSgerardnico { 102*85e82846SNickeau $page = Page::createPageFromId($pageId); 103aa3cb38fSgerardnico 104531e725cSNickeau if ($page->isSlot()) { 105aa3cb38fSgerardnico return null; 106aa3cb38fSgerardnico } 1079b9e6d1fSgerardnico 108eee76a3dSgerardnico if (!$page->isQualityMonitored()) { 109eee76a3dSgerardnico return null; 110eee76a3dSgerardnico } 111eee76a3dSgerardnico 112*85e82846SNickeau if ($page->exists()) { 11308ca4f85Sgerardnico $analytics = $page->getAnalyticsFromFs(); 114aa3cb38fSgerardnico $rules = $analytics[Analytics::QUALITY][Analytics::RULES]; 11508ca4f85Sgerardnico 116e68157ebSgerardnico 117e68157ebSgerardnico /** 118e68157ebSgerardnico * We may got null 119e68157ebSgerardnico * array_key_exists() expects parameter 2 to be array, 120e68157ebSgerardnico * null given in /opt/www/datacadamia.com/lib/plugins/combo/action/qualitymessage.php on line 113 121e68157ebSgerardnico */ 122e68157ebSgerardnico if ($rules==null){ 123e68157ebSgerardnico return null; 124e68157ebSgerardnico } 125e68157ebSgerardnico 126aa3cb38fSgerardnico /** 127aa3cb38fSgerardnico * If there is no info, nothing to show 128aa3cb38fSgerardnico */ 129aa3cb38fSgerardnico if (!array_key_exists(Analytics::INFO, $rules)) { 130aa3cb38fSgerardnico return null; 131aa3cb38fSgerardnico } 132aa3cb38fSgerardnico 133aa3cb38fSgerardnico /** 134aa3cb38fSgerardnico * The error info 135aa3cb38fSgerardnico */ 136aa3cb38fSgerardnico $qualityInfoRules = $rules[Analytics::INFO]; 137aa3cb38fSgerardnico 138aa3cb38fSgerardnico /** 139aa3cb38fSgerardnico * Excluding the excluded rules 140aa3cb38fSgerardnico */ 141aa3cb38fSgerardnico global $conf; 142aa3cb38fSgerardnico $excludedRulesConf = $conf['plugin'][PluginUtility::PLUGIN_BASE_NAME][self::CONF_EXCLUDED_QUALITY_RULES_FROM_DYNAMIC_MONITORING]; 143aa3cb38fSgerardnico $excludedRules = preg_split("/,/", $excludedRulesConf); 144aa3cb38fSgerardnico foreach ($excludedRules as $excludedRule) { 145aa3cb38fSgerardnico if (array_key_exists($excludedRule, $qualityInfoRules)) { 146aa3cb38fSgerardnico unset($qualityInfoRules[$excludedRule]); 14708ca4f85Sgerardnico } 14808ca4f85Sgerardnico } 14908ca4f85Sgerardnico 15008ca4f85Sgerardnico if (sizeof($qualityInfoRules) > 0) { 15108ca4f85Sgerardnico 15208ca4f85Sgerardnico $qualityScore = $analytics[Analytics::QUALITY][renderer_plugin_combo_analytics::SCORING][renderer_plugin_combo_analytics::SCORE]; 1538aa9d0e6Sgerardnico $message = new Message($plugin); 154d262537cSgerardnico $message->addContent("<p>Well played, you got a " . PluginUtility::getUrl("quality:score", "quality score") . " of {$qualityScore} !</p>"); 155722648eaSgerardnico if ($page->isLowQualityPage()) { 156722648eaSgerardnico $analytics = $page->getAnalyticsFromFs(true); 157722648eaSgerardnico $mandatoryFailedRules = $analytics[Analytics::QUALITY][Analytics::FAILED_MANDATORY_RULES]; 158722648eaSgerardnico $rulesUrl = PluginUtility::getUrl("quality:rule", "rules"); 159722648eaSgerardnico $lqPageUrl = PluginUtility::getUrl("low_quality_page", "low quality page"); 160722648eaSgerardnico $message->addContent("<div class='alert alert-info'>This is a {$lqPageUrl} because it has failed the following mandatory {$rulesUrl}:"); 161722648eaSgerardnico $message->addContent("<ul style='margin-bottom: 0'>"); 162fa5961eaSgerardnico /** 163fa5961eaSgerardnico * A low quality page should have 164fa5961eaSgerardnico * failed mandatory rules 165fa5961eaSgerardnico * but due to the asycn nature, sometimes 166fa5961eaSgerardnico * we don't have an array 167fa5961eaSgerardnico */ 168fa5961eaSgerardnico if (is_array($mandatoryFailedRules)) { 169722648eaSgerardnico foreach ($mandatoryFailedRules as $mandatoryFailedRule) { 170ef295d81Sgerardnico $message->addContent("<li>" . PluginUtility::getUrl("quality:rule#list", $mandatoryFailedRule) . "</li>"); 171722648eaSgerardnico } 172fa5961eaSgerardnico } 173722648eaSgerardnico $message->addContent("</ul>"); 174722648eaSgerardnico $message->addContent("</div>"); 175722648eaSgerardnico } 17608ca4f85Sgerardnico $message->addContent("<p>You can still win a couple of points.</p>"); 17708ca4f85Sgerardnico $message->addContent("<ul>"); 17808ca4f85Sgerardnico foreach ($qualityInfoRules as $qualityRule => $qualityInfo) { 17908ca4f85Sgerardnico $message->addContent("<li>"); 18008ca4f85Sgerardnico $message->addContent($qualityInfo); 18108ca4f85Sgerardnico $message->addContent("</li>"); 18208ca4f85Sgerardnico } 18308ca4f85Sgerardnico $message->addContent("</ul>"); 18408ca4f85Sgerardnico 185d262537cSgerardnico $message->setSignatureCanonical("quality:dynamic_monitoring"); 186d262537cSgerardnico $message->setSignatureName("Quality Dynamic Monitoring Feature"); 1878aa9d0e6Sgerardnico $message->setType(Message::TYPE_CLASSIC); 18808ca4f85Sgerardnico $message->setClass(self::QUALITY_BOX_CLASS); 189d262537cSgerardnico return $message; 19008ca4f85Sgerardnico 19108ca4f85Sgerardnico 19208ca4f85Sgerardnico } 19308ca4f85Sgerardnico } 194d262537cSgerardnico return null; 19508ca4f85Sgerardnico } 19608ca4f85Sgerardnico 19708ca4f85Sgerardnico 19808ca4f85Sgerardnico} 199