1257dd7f8SAndreas Gohr<?php 2d6d97f60SAnna Dabrowska 3257dd7f8SAndreas Gohr/** 4257dd7f8SAndreas Gohr * DokuWiki Plugin struct (Syntax Component) 5257dd7f8SAndreas Gohr * 6257dd7f8SAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 7257dd7f8SAndreas Gohr * @author Andreas Gohr, Michael Große <dokuwiki@cosmocode.de> 8257dd7f8SAndreas Gohr */ 9257dd7f8SAndreas Gohr 10f411d872SAndreas Gohruse dokuwiki\plugin\struct\meta\AccessTable; 11ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\Assignments; 127cbcfbdbSAndreas Gohruse dokuwiki\plugin\struct\meta\StructException; 13257dd7f8SAndreas Gohr 14d6d97f60SAnna Dabrowskaclass syntax_plugin_struct_output extends DokuWiki_Syntax_Plugin 15d6d97f60SAnna Dabrowska{ 1687050b53SMichael Grosse 1787050b53SMichael Grosse protected $hasBeenRendered = false; 1887050b53SMichael Grosse 197938ca48SAndreas Gohr const XHTML_OPEN = '<div id="plugin__struct_output">'; 207938ca48SAndreas Gohr const XHTML_CLOSE = '</div>'; 217938ca48SAndreas Gohr 22257dd7f8SAndreas Gohr /** 23979b16f8SAndreas Gohr * Regexp to check on which actions the struct data may be rendered 24979b16f8SAndreas Gohr */ 25979b16f8SAndreas Gohr const WHITELIST_ACTIONS = '/^(show|export_.*)$/'; 26979b16f8SAndreas Gohr 27979b16f8SAndreas Gohr /** 28257dd7f8SAndreas Gohr * @return string Syntax mode type 29257dd7f8SAndreas Gohr */ 30d6d97f60SAnna Dabrowska public function getType() 31d6d97f60SAnna Dabrowska { 32257dd7f8SAndreas Gohr return 'substition'; 33257dd7f8SAndreas Gohr } 34da30fdd3SAndreas Gohr 35257dd7f8SAndreas Gohr /** 36257dd7f8SAndreas Gohr * @return string Paragraph type 37257dd7f8SAndreas Gohr */ 38d6d97f60SAnna Dabrowska public function getPType() 39d6d97f60SAnna Dabrowska { 40257dd7f8SAndreas Gohr return 'block'; 41257dd7f8SAndreas Gohr } 42da30fdd3SAndreas Gohr 43257dd7f8SAndreas Gohr /** 44257dd7f8SAndreas Gohr * @return int Sort order - Low numbers go before high numbers 45257dd7f8SAndreas Gohr */ 46d6d97f60SAnna Dabrowska public function getSort() 47d6d97f60SAnna Dabrowska { 48257dd7f8SAndreas Gohr return 155; 49257dd7f8SAndreas Gohr } 50257dd7f8SAndreas Gohr 51257dd7f8SAndreas Gohr /** 52257dd7f8SAndreas Gohr * Connect lookup pattern to lexer. 53257dd7f8SAndreas Gohr * 5482c064c1SAndreas Gohr * We do not connect any pattern here, because the call to this plugin is not 5582c064c1SAndreas Gohr * triggered from syntax but our action component 5682c064c1SAndreas Gohr * 5782c064c1SAndreas Gohr * @asee action_plugin_struct_output 58257dd7f8SAndreas Gohr * @param string $mode Parser mode 59257dd7f8SAndreas Gohr */ 60d6d97f60SAnna Dabrowska public function connectTo($mode) 61d6d97f60SAnna Dabrowska { 62257dd7f8SAndreas Gohr } 63257dd7f8SAndreas Gohr 64257dd7f8SAndreas Gohr /** 65257dd7f8SAndreas Gohr * Handle matches of the struct syntax 66257dd7f8SAndreas Gohr * 67257dd7f8SAndreas Gohr * @param string $match The match of the syntax 68257dd7f8SAndreas Gohr * @param int $state The state of the handler 69257dd7f8SAndreas Gohr * @param int $pos The position in the document 70257dd7f8SAndreas Gohr * @param Doku_Handler $handler The handler 71257dd7f8SAndreas Gohr * @return array Data for the renderer 72257dd7f8SAndreas Gohr */ 73d6d97f60SAnna Dabrowska public function handle($match, $state, $pos, Doku_Handler $handler) 74d6d97f60SAnna Dabrowska { 7582c064c1SAndreas Gohr // this is never called 7682c064c1SAndreas Gohr return array(); 77257dd7f8SAndreas Gohr } 78257dd7f8SAndreas Gohr 79257dd7f8SAndreas Gohr /** 8082c064c1SAndreas Gohr * Render schema data 81257dd7f8SAndreas Gohr * 82564e138bSAnna Dabrowska * Currently completely renderer agnostic 8382c064c1SAndreas Gohr * 8434ea6e10SAnna Dabrowska * @param string $format Renderer format 8534ea6e10SAnna Dabrowska * @param Doku_Renderer $renderer The renderer 86257dd7f8SAndreas Gohr * @param array $data The data from the handler() function 87257dd7f8SAndreas Gohr * @return bool If rendering was successful. 88257dd7f8SAndreas Gohr */ 8934ea6e10SAnna Dabrowska public function render($format, Doku_Renderer $renderer, $data) 90d6d97f60SAnna Dabrowska { 910e4a3e7cSMichael Große global $ACT; 92257dd7f8SAndreas Gohr global $ID; 9382c064c1SAndreas Gohr global $INFO; 94257dd7f8SAndreas Gohr global $REV; 95bdefb930SAnna Dabrowska 9634ea6e10SAnna Dabrowska foreach (helper_plugin_struct::BLACKLIST_RENDERER as $blacklisted) { 9734ea6e10SAnna Dabrowska if ($renderer instanceof $blacklisted) { 980e4a3e7cSMichael Große return true; 990e4a3e7cSMichael Große } 100bdefb930SAnna Dabrowska } 10182c064c1SAndreas Gohr if ($ID != $INFO['id']) return true; 1022f1a213bSAndreas Gohr if (!$INFO['exists']) return true; 10387050b53SMichael Grosse if ($this->hasBeenRendered) return true; 104979b16f8SAndreas Gohr if (!preg_match(self::WHITELIST_ACTIONS, act_clean($ACT))) return true; 10587050b53SMichael Grosse 10687050b53SMichael Grosse // do not render the output twice on the same page, e.g. when another page has been included 10787050b53SMichael Grosse $this->hasBeenRendered = true; 1087cbcfbdbSAndreas Gohr try { 109025cb9daSAndreas Gohr $assignments = Assignments::getInstance(); 1107cbcfbdbSAndreas Gohr } catch (StructException $e) { 1117cbcfbdbSAndreas Gohr return false; 1127cbcfbdbSAndreas Gohr } 113257dd7f8SAndreas Gohr $tables = $assignments->getPageAssignments($ID); 114257dd7f8SAndreas Gohr if (!$tables) return true; 115257dd7f8SAndreas Gohr 11634ea6e10SAnna Dabrowska if ($format == 'xhtml') $renderer->doc .= self::XHTML_OPEN; 1175a1eab78SAndreas Gohr 1187938ca48SAndreas Gohr $hasdata = false; 119257dd7f8SAndreas Gohr foreach ($tables as $table) { 120a28d6152SAndreas Gohr try { 1214cd5cc28SAnna Dabrowska $schemadata = AccessTable::getPageAccess($table, $ID, (int)$REV); 122a28d6152SAndreas Gohr } catch (StructException $ignored) { 123a28d6152SAndreas Gohr continue; // no such schema at this revision 124a28d6152SAndreas Gohr } 125b1ab837dSFrieder Schrempf 126b1ab837dSFrieder Schrempf $rendercontext = array( 127b1ab837dSFrieder Schrempf 'renderer' => $renderer, 128b1ab837dSFrieder Schrempf 'format' => $format, 129b1ab837dSFrieder Schrempf 'meta' => p_get_metadata($ID), 130b1ab837dSFrieder Schrempf 'schemadata' => $schemadata, 131b1ab837dSFrieder Schrempf 'hasdata' => &$hasdata 132b1ab837dSFrieder Schrempf ); 133b1ab837dSFrieder Schrempf 134*2dbe71f8SAnna Dabrowska $event = new \Doku_Event( 135b1ab837dSFrieder Schrempf 'PLUGIN_STRUCT_RENDER_SCHEMA_DATA', 136*2dbe71f8SAnna Dabrowska $rendercontext 137b1ab837dSFrieder Schrempf ); 138*2dbe71f8SAnna Dabrowska $event->trigger([$this, 'renderSchemaData']); 139b1ab837dSFrieder Schrempf } 140b1ab837dSFrieder Schrempf 141b1ab837dSFrieder Schrempf if ($format == 'xhtml') $renderer->doc .= self::XHTML_CLOSE; 142b1ab837dSFrieder Schrempf 143b1ab837dSFrieder Schrempf // if no data has been output, remove empty wrapper again 144b1ab837dSFrieder Schrempf if ($format == 'xhtml' && !$hasdata) { 145b1ab837dSFrieder Schrempf $renderer->doc = substr($renderer->doc, 0, -1 * strlen(self::XHTML_OPEN . self::XHTML_CLOSE)); 146b1ab837dSFrieder Schrempf } 147b1ab837dSFrieder Schrempf 148b1ab837dSFrieder Schrempf return true; 149b1ab837dSFrieder Schrempf } 150b1ab837dSFrieder Schrempf 151b1ab837dSFrieder Schrempf /** 152b1ab837dSFrieder Schrempf * Default schema data rendering (simple table view) 153b1ab837dSFrieder Schrempf * 154b1ab837dSFrieder Schrempf * @param array The render context including renderer and data 155b1ab837dSFrieder Schrempf */ 156b1ab837dSFrieder Schrempf public function renderSchemaData($rendercontext) 157b1ab837dSFrieder Schrempf { 158b1ab837dSFrieder Schrempf $schemadata = $rendercontext['schemadata']; 159b1ab837dSFrieder Schrempf $renderer = $rendercontext['renderer']; 160b1ab837dSFrieder Schrempf $format = $rendercontext['format']; 161b1ab837dSFrieder Schrempf 1620dd23cefSAndreas Gohr $schemadata->optionSkipEmpty(true); 1630dd23cefSAndreas Gohr $data = $schemadata->getData(); 164b1ab837dSFrieder Schrempf if (!count($data)) 165b1ab837dSFrieder Schrempf return; 166b1ab837dSFrieder Schrempf 167b1ab837dSFrieder Schrempf $rendercontext['hasdata'] = true; 168257dd7f8SAndreas Gohr 16934ea6e10SAnna Dabrowska $renderer->table_open(); 17034ea6e10SAnna Dabrowska $renderer->tablethead_open(); 17134ea6e10SAnna Dabrowska $renderer->tablerow_open(); 17234ea6e10SAnna Dabrowska $renderer->tableheader_open(2); 17334ea6e10SAnna Dabrowska $renderer->cdata($schemadata->getSchema()->getTranslatedLabel()); 17434ea6e10SAnna Dabrowska $renderer->tableheader_close(); 17534ea6e10SAnna Dabrowska $renderer->tablerow_close(); 17634ea6e10SAnna Dabrowska $renderer->tablethead_close(); 177da30fdd3SAndreas Gohr 17834ea6e10SAnna Dabrowska $renderer->tabletbody_open(); 179257dd7f8SAndreas Gohr foreach ($data as $field) { 18034ea6e10SAnna Dabrowska $renderer->tablerow_open(); 18134ea6e10SAnna Dabrowska $renderer->tableheader_open(); 18234ea6e10SAnna Dabrowska $renderer->cdata($field->getColumn()->getTranslatedLabel()); 18334ea6e10SAnna Dabrowska $renderer->tableheader_close(); 18434ea6e10SAnna Dabrowska $renderer->tablecell_open(); 18534ea6e10SAnna Dabrowska if ($format == 'xhtml') { 18634ea6e10SAnna Dabrowska $renderer->doc = substr($renderer->doc, 0, -1) . 187748e747fSAnna Dabrowska ' data-struct="' . hsc($field->getColumn()->getFullQualifiedLabel()) . 188748e747fSAnna Dabrowska '">'; 18925852712SAndreas Gohr } 19034ea6e10SAnna Dabrowska $field->render($renderer, $format); 19134ea6e10SAnna Dabrowska $renderer->tablecell_close(); 19234ea6e10SAnna Dabrowska $renderer->tablerow_close(); 193257dd7f8SAndreas Gohr } 19434ea6e10SAnna Dabrowska $renderer->tabletbody_close(); 19534ea6e10SAnna Dabrowska $renderer->table_close(); 196da30fdd3SAndreas Gohr } 197257dd7f8SAndreas Gohr} 198257dd7f8SAndreas Gohr 199257dd7f8SAndreas Gohr// vim:ts=4:sw=4:et: 200