1007225e5Sgerardnico<?php 2007225e5Sgerardnico 3007225e5Sgerardnico 4007225e5Sgerardnico// must be run within Dokuwiki 5007225e5Sgerardnicouse ComboStrap\PluginUtility; 6007225e5Sgerardnico 7007225e5Sgerardnicoif (!defined('DOKU_INC')) die(); 8007225e5Sgerardnico 9007225e5Sgerardnico/** 10007225e5Sgerardnico * Class syntax_plugin_combo_note 11007225e5Sgerardnico * Implementation of a note 12007225e5Sgerardnico * called an alert in <a href="https://getbootstrap.com/docs/4.0/components/alerts/">bootstrap</a> 13007225e5Sgerardnico */ 14007225e5Sgerardnicoclass syntax_plugin_combo_note extends DokuWiki_Syntax_Plugin 15007225e5Sgerardnico{ 16007225e5Sgerardnico 17007225e5Sgerardnico const TAG = "note"; 18007225e5Sgerardnico 19007225e5Sgerardnico /** 20007225e5Sgerardnico * Syntax Type. 21007225e5Sgerardnico * 22007225e5Sgerardnico * Needs to return one of the mode types defined in $PARSER_MODES in parser.php 23007225e5Sgerardnico * @see DokuWiki_Syntax_Plugin::getType() 24007225e5Sgerardnico */ 25007225e5Sgerardnico function getType() 26007225e5Sgerardnico { 27007225e5Sgerardnico return 'container'; 28007225e5Sgerardnico } 29007225e5Sgerardnico 30007225e5Sgerardnico /** 31007225e5Sgerardnico * How Dokuwiki will add P element 32007225e5Sgerardnico * 33007225e5Sgerardnico * * 'normal' - The plugin can be used inside paragraphs 34007225e5Sgerardnico * * 'block' - Open paragraphs need to be closed before plugin output - block should not be inside paragraphs 35007225e5Sgerardnico * * 'stack' - Special case. Plugin wraps other paragraphs. - Stacks can contain paragraphs 36007225e5Sgerardnico * 37007225e5Sgerardnico * @see DokuWiki_Syntax_Plugin::getPType() 38007225e5Sgerardnico */ 39007225e5Sgerardnico function getPType() 40007225e5Sgerardnico { 41007225e5Sgerardnico return 'block'; 42007225e5Sgerardnico } 43007225e5Sgerardnico 44007225e5Sgerardnico /** 45007225e5Sgerardnico * @return array 46007225e5Sgerardnico * Allow which kind of plugin inside 47007225e5Sgerardnico * 485f891b7eSNickeau * ************************ 495f891b7eSNickeau * This function has no effect because {@link SyntaxPlugin::accepts()} is used 505f891b7eSNickeau * ************************ 51007225e5Sgerardnico */ 52007225e5Sgerardnico function getAllowedTypes() 53007225e5Sgerardnico { 54007225e5Sgerardnico return array('container', 'formatting', 'substition', 'protected', 'disabled', 'paragraphs'); 55007225e5Sgerardnico } 56007225e5Sgerardnico 575f891b7eSNickeau 58007225e5Sgerardnico function getSort() 59007225e5Sgerardnico { 60007225e5Sgerardnico return 201; 61007225e5Sgerardnico } 62007225e5Sgerardnico 635f891b7eSNickeau public function accepts($mode) 645f891b7eSNickeau { 655f891b7eSNickeau /** 665f891b7eSNickeau * header mode is disable to take over 675f891b7eSNickeau * and replace it with {@link syntax_plugin_combo_title} 685f891b7eSNickeau */ 695f891b7eSNickeau if ($mode == "header") { 705f891b7eSNickeau return false; 715f891b7eSNickeau } 725f891b7eSNickeau /** 735f891b7eSNickeau * If preformatted is disable, we does not accept it 745f891b7eSNickeau */ 755f891b7eSNickeau if (!$this->getConf(syntax_plugin_combo_preformatted::CONF_PREFORMATTED_ENABLE)) { 765f891b7eSNickeau return PluginUtility::disablePreformatted($mode); 775f891b7eSNickeau } else { 785f891b7eSNickeau return true; 795f891b7eSNickeau } 805f891b7eSNickeau } 815f891b7eSNickeau 825f891b7eSNickeau 83007225e5Sgerardnico function connectTo($mode) 84007225e5Sgerardnico { 85007225e5Sgerardnico 86007225e5Sgerardnico $pattern = PluginUtility::getContainerTagPattern(self::TAG); 87007225e5Sgerardnico $this->Lexer->addEntryPattern($pattern, $mode, PluginUtility::getModeForComponent($this->getPluginComponent())); 88007225e5Sgerardnico } 89007225e5Sgerardnico 90007225e5Sgerardnico 91007225e5Sgerardnico function postConnect() 92007225e5Sgerardnico { 93007225e5Sgerardnico 94007225e5Sgerardnico $this->Lexer->addExitPattern('</' . self::TAG . '>', PluginUtility::getModeForComponent($this->getPluginComponent())); 95007225e5Sgerardnico 96007225e5Sgerardnico } 97007225e5Sgerardnico 98007225e5Sgerardnico function handle($match, $state, $pos, Doku_Handler $handler) 99007225e5Sgerardnico { 100007225e5Sgerardnico 101007225e5Sgerardnico switch ($state) { 102007225e5Sgerardnico 103007225e5Sgerardnico case DOKU_LEXER_ENTER : 104007225e5Sgerardnico $defaultAttributes = array("type" => "info"); 105007225e5Sgerardnico $inlineAttributes = PluginUtility::getTagAttributes($match); 106007225e5Sgerardnico $attributes = PluginUtility::mergeAttributes($inlineAttributes, $defaultAttributes); 107*32b85071SNickeau return array( 108*32b85071SNickeau PluginUtility::STATE => $state, 109*32b85071SNickeau PluginUtility::ATTRIBUTES => $attributes 110*32b85071SNickeau ); 111007225e5Sgerardnico 112007225e5Sgerardnico case DOKU_LEXER_UNMATCHED : 113*32b85071SNickeau return PluginUtility::handleAndReturnUnmatchedData(self::TAG, $match, $handler); 114007225e5Sgerardnico 115007225e5Sgerardnico case DOKU_LEXER_EXIT : 116007225e5Sgerardnico 117007225e5Sgerardnico // Important otherwise we don't get an exit in the render 118*32b85071SNickeau return array( 119*32b85071SNickeau PluginUtility::STATE => $state 120*32b85071SNickeau ); 121007225e5Sgerardnico 122007225e5Sgerardnico 123007225e5Sgerardnico } 124007225e5Sgerardnico return array(); 125007225e5Sgerardnico 126007225e5Sgerardnico } 127007225e5Sgerardnico 128007225e5Sgerardnico /** 129007225e5Sgerardnico * Render the output 130007225e5Sgerardnico * @param string $format 131007225e5Sgerardnico * @param Doku_Renderer $renderer 132007225e5Sgerardnico * @param array $data - what the function handle() return'ed 133007225e5Sgerardnico * @return boolean - rendered correctly? (however, returned value is not used at the moment) 134007225e5Sgerardnico * @see DokuWiki_Syntax_Plugin::render() 135007225e5Sgerardnico * 136007225e5Sgerardnico * 137007225e5Sgerardnico */ 138007225e5Sgerardnico function render($format, Doku_Renderer $renderer, $data) 139007225e5Sgerardnico { 140007225e5Sgerardnico if ($format == 'xhtml') { 141007225e5Sgerardnico 142007225e5Sgerardnico /** @var Doku_Renderer_xhtml $renderer */ 143*32b85071SNickeau $state = $data[PluginUtility::STATE]; 144007225e5Sgerardnico switch ($state) { 145007225e5Sgerardnico case DOKU_LEXER_ENTER : 146*32b85071SNickeau $attributes = $data[PluginUtility::ATTRIBUTES]; 147007225e5Sgerardnico $classValue = "alert"; 148007225e5Sgerardnico $type = $attributes["type"]; 149007225e5Sgerardnico // Switch for the color 150007225e5Sgerardnico switch ($type) { 151007225e5Sgerardnico case "important": 152007225e5Sgerardnico $type = "warning"; 153007225e5Sgerardnico break; 154007225e5Sgerardnico case "warning": 155007225e5Sgerardnico $type = "danger"; 156007225e5Sgerardnico break; 157007225e5Sgerardnico } 158007225e5Sgerardnico 159007225e5Sgerardnico if ($type != "tip") { 160007225e5Sgerardnico $classValue .= " alert-" . $type; 161007225e5Sgerardnico } else { 162007225e5Sgerardnico // There is no alert-tip color 163007225e5Sgerardnico // base color was background color and we have modified the luminance 164007225e5Sgerardnico if (!array_key_exists("color", $attributes)) { 165007225e5Sgerardnico $attributes["color"] = "#6c6400"; // lum - 51 166007225e5Sgerardnico } 167007225e5Sgerardnico if (!array_key_exists("border-color", $attributes)) { 168007225e5Sgerardnico $attributes["border-color"] = "#FFF78c"; // lum - 186 169007225e5Sgerardnico } 170007225e5Sgerardnico if (!array_key_exists("background-color", $attributes)) { 171007225e5Sgerardnico $attributes["background-color"] = "#fff79f"; // lum - 195 172007225e5Sgerardnico } 173007225e5Sgerardnico } 174007225e5Sgerardnico 175007225e5Sgerardnico if (array_key_exists("class", $attributes)) { 176007225e5Sgerardnico $attributes["class"] .= " {$classValue}"; 177007225e5Sgerardnico } else { 178007225e5Sgerardnico $attributes["class"] = "{$classValue}"; 179007225e5Sgerardnico } 180007225e5Sgerardnico 181007225e5Sgerardnico $renderer->doc .= '<div ' . PluginUtility::array2HTMLAttributes($attributes) . ' role="note">'; 182007225e5Sgerardnico break; 183007225e5Sgerardnico 184007225e5Sgerardnico case DOKU_LEXER_UNMATCHED : 185*32b85071SNickeau $renderer->doc .= PluginUtility::renderUnmatched($data); 186007225e5Sgerardnico break; 187007225e5Sgerardnico 188007225e5Sgerardnico case DOKU_LEXER_EXIT : 189007225e5Sgerardnico $renderer->doc .= '</div>'; 190007225e5Sgerardnico break; 191007225e5Sgerardnico } 192007225e5Sgerardnico return true; 193007225e5Sgerardnico } 194007225e5Sgerardnico 195007225e5Sgerardnico // unsupported $mode 196007225e5Sgerardnico return false; 197007225e5Sgerardnico } 198007225e5Sgerardnico 199007225e5Sgerardnico 200007225e5Sgerardnico} 201007225e5Sgerardnico 202