1549a0837SAndreas Gohr<?php 261356325SAnna Dabrowska 3549a0837SAndreas Gohr/** 4549a0837SAndreas Gohr * DokuWiki Plugin struct (Syntax Component) 5549a0837SAndreas Gohr * 6549a0837SAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 7549a0837SAndreas Gohr * @author Andreas Gohr, Michael Große <dokuwiki@cosmocode.de> 8549a0837SAndreas Gohr */ 9549a0837SAndreas Gohr 10ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\AggregationTable; 11ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\ConfigParser; 12ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\SearchConfig; 13ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\StructException; 1415929be2SAndreas Gohr 1561356325SAnna Dabrowskaclass syntax_plugin_struct_table extends DokuWiki_Syntax_Plugin 1661356325SAnna Dabrowska{ 173f2a8309SAndreas Gohr /** @var string which class to use for output */ 183f2a8309SAndreas Gohr protected $tableclass = AggregationTable::class; 193f2a8309SAndreas Gohr 20549a0837SAndreas Gohr /** 21549a0837SAndreas Gohr * @return string Syntax mode type 22549a0837SAndreas Gohr */ 2361356325SAnna Dabrowska public function getType() 2461356325SAnna Dabrowska { 2515929be2SAndreas Gohr return 'substition'; 26549a0837SAndreas Gohr } 273f2a8309SAndreas Gohr 28549a0837SAndreas Gohr /** 29549a0837SAndreas Gohr * @return string Paragraph type 30549a0837SAndreas Gohr */ 3161356325SAnna Dabrowska public function getPType() 3261356325SAnna Dabrowska { 3315929be2SAndreas Gohr return 'block'; 34549a0837SAndreas Gohr } 353f2a8309SAndreas Gohr 36549a0837SAndreas Gohr /** 37549a0837SAndreas Gohr * @return int Sort order - Low numbers go before high numbers 38549a0837SAndreas Gohr */ 3961356325SAnna Dabrowska public function getSort() 4061356325SAnna Dabrowska { 415511bd5bSAndreas Gohr return 155; 42549a0837SAndreas Gohr } 43549a0837SAndreas Gohr 44549a0837SAndreas Gohr /** 45549a0837SAndreas Gohr * Connect lookup pattern to lexer. 46549a0837SAndreas Gohr * 47549a0837SAndreas Gohr * @param string $mode Parser mode 48549a0837SAndreas Gohr */ 4961356325SAnna Dabrowska public function connectTo($mode) 5061356325SAnna Dabrowska { 515511bd5bSAndreas Gohr $this->Lexer->addSpecialPattern('----+ *struct table *-+\n.*?\n----+', $mode, 'plugin_struct_table'); 52549a0837SAndreas Gohr } 53549a0837SAndreas Gohr 54549a0837SAndreas Gohr /** 55549a0837SAndreas Gohr * Handle matches of the struct syntax 56549a0837SAndreas Gohr * 57549a0837SAndreas Gohr * @param string $match The match of the syntax 58549a0837SAndreas Gohr * @param int $state The state of the handler 59549a0837SAndreas Gohr * @param int $pos The position in the document 60549a0837SAndreas Gohr * @param Doku_Handler $handler The handler 61549a0837SAndreas Gohr * @return array Data for the renderer 62549a0837SAndreas Gohr */ 6361356325SAnna Dabrowska public function handle($match, $state, $pos, Doku_Handler $handler) 6461356325SAnna Dabrowska { 65bd363da9SAndreas Gohr global $conf; 66549a0837SAndreas Gohr 675511bd5bSAndreas Gohr $lines = explode("\n", $match); 685511bd5bSAndreas Gohr array_shift($lines); 695511bd5bSAndreas Gohr array_pop($lines); 705511bd5bSAndreas Gohr 715511bd5bSAndreas Gohr try { 725511bd5bSAndreas Gohr $parser = new ConfigParser($lines); 730659dc64SMichael Grosse $config = $parser->getConfig(); 740659dc64SMichael Grosse return $config; 755511bd5bSAndreas Gohr } catch (StructException $e) { 765511bd5bSAndreas Gohr msg($e->getMessage(), -1, $e->getLine(), $e->getFile()); 77bd363da9SAndreas Gohr if ($conf['allowdebug']) msg('<pre>' . hsc($e->getTraceAsString()) . '</pre>', -1); 785511bd5bSAndreas Gohr return null; 795511bd5bSAndreas Gohr } 80549a0837SAndreas Gohr } 81549a0837SAndreas Gohr 82549a0837SAndreas Gohr /** 83549a0837SAndreas Gohr * Render xhtml output or metadata 84549a0837SAndreas Gohr * 8534ea6e10SAnna Dabrowska * @param string $format Renderer mode (supported modes: xhtml) 86549a0837SAndreas Gohr * @param Doku_Renderer $renderer The renderer 8730bf61e6SAndreas Gohr * @param array $config The parsed config data from the handler() function 88549a0837SAndreas Gohr * @return bool If rendering was successful. 89549a0837SAndreas Gohr */ 9030bf61e6SAndreas Gohr public function render($format, Doku_Renderer $renderer, $config) 9161356325SAnna Dabrowska { 9206fee43aSMichael Grosse global $INFO; 93bd363da9SAndreas Gohr global $conf; 9429877279SMichael Große 9530bf61e6SAndreas Gohr if (!$config) return false; 9630bf61e6SAndreas Gohr $config = $this->addTypeFilter($config); // add type specific filters 9730bf61e6SAndreas Gohr 98*25ed0c0dSAndreas Gohr // always use the main page's ID @todo might make sense as utility method somewhere 99*25ed0c0dSAndreas Gohr if($INFO !== null) { 100*25ed0c0dSAndreas Gohr $mainId = $INFO['id']; 101*25ed0c0dSAndreas Gohr } else { 102*25ed0c0dSAndreas Gohr $mainId = getID(); 103*25ed0c0dSAndreas Gohr } 104*25ed0c0dSAndreas Gohr 10515929be2SAndreas Gohr try { 10630bf61e6SAndreas Gohr $search = new SearchConfig($config); 10734ea6e10SAnna Dabrowska if ($format === 'struct_csv') { 1086ce83f43SAndreas Gohr // no pagination in export 1096ce83f43SAndreas Gohr $search->setLimit(0); 1106ce83f43SAndreas Gohr $search->setOffset(0); 1116ce83f43SAndreas Gohr } 1126ce83f43SAndreas Gohr 1133f2a8309SAndreas Gohr /** @var AggregationTable $table */ 114*25ed0c0dSAndreas Gohr $table = new $this->tableclass($mainId, $format, $renderer, $search); 11507993756SAndreas Gohr $table->render(); 11616b7d914SAndreas Gohr 11734ea6e10SAnna Dabrowska if ($format === 'metadata') { 11816b7d914SAndreas Gohr /** @var Doku_Renderer_metadata $renderer */ 11916b7d914SAndreas Gohr $renderer->meta['plugin']['struct']['hasaggregation'] = $search->getCacheFlag(); 12016b7d914SAndreas Gohr } 1215511bd5bSAndreas Gohr } catch (StructException $e) { 12215929be2SAndreas Gohr msg($e->getMessage(), -1, $e->getLine(), $e->getFile()); 123bd363da9SAndreas Gohr if ($conf['allowdebug']) msg('<pre>' . hsc($e->getTraceAsString()) . '</pre>', -1); 12415929be2SAndreas Gohr } 12515929be2SAndreas Gohr 126549a0837SAndreas Gohr return true; 127549a0837SAndreas Gohr } 1280ceefd5cSAnna Dabrowska 1290ceefd5cSAnna Dabrowska /** 130c797933dSAnna Dabrowska * Filter based on primary key columns, applicable in child classes 1310ceefd5cSAnna Dabrowska * 1320ceefd5cSAnna Dabrowska * @param array $config 1330ceefd5cSAnna Dabrowska * @return array 1340ceefd5cSAnna Dabrowska */ 1350ceefd5cSAnna Dabrowska protected function addTypeFilter($config) 1360ceefd5cSAnna Dabrowska { 1370ceefd5cSAnna Dabrowska return $config; 1380ceefd5cSAnna Dabrowska } 139549a0837SAndreas Gohr} 140