xref: /plugin/struct/syntax/table.php (revision 25ed0c0dbf1e045a4e27c1c3a21e99786851c54d)
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