182c064c1SAndreas Gohr<?php 2d6d97f60SAnna Dabrowska 382c064c1SAndreas Gohr/** 482c064c1SAndreas Gohr * DokuWiki Plugin struct (Action Component) 582c064c1SAndreas Gohr * 682c064c1SAndreas Gohr * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html 782c064c1SAndreas Gohr * @author Andreas Gohr, Michael Große <dokuwiki@cosmocode.de> 882c064c1SAndreas Gohr */ 982c064c1SAndreas Gohr 10*7234bfb1Ssplitbrainuse dokuwiki\Extension\ActionPlugin; 11*7234bfb1Ssplitbrainuse dokuwiki\Extension\EventHandler; 12*7234bfb1Ssplitbrainuse dokuwiki\Extension\Event; 1323f770edSAnna Dabrowskause dokuwiki\plugin\struct\meta\Schema; 1423f770edSAnna Dabrowska 1582c064c1SAndreas Gohr/** 1682c064c1SAndreas Gohr * Class action_plugin_struct_output 1782c064c1SAndreas Gohr * 1882c064c1SAndreas Gohr * This action component handles the automatic output of all schema data that has been assigned 1982c064c1SAndreas Gohr * to the current page by appending the appropriate instruction to the handler calls. 2082c064c1SAndreas Gohr * 2182c064c1SAndreas Gohr * The real output creation is done within the syntax component 2282c064c1SAndreas Gohr * @see syntax_plugin_struct_output 2382c064c1SAndreas Gohr */ 24*7234bfb1Ssplitbrainclass action_plugin_struct_output extends ActionPlugin 25d6d97f60SAnna Dabrowska{ 2617a3a578SAndreas Gohr protected const DW2PDF_PLACEHOLDER_PREFIX = 'PLUGIN_STRUCT'; 273851b2fbSAnna Dabrowska 2882c064c1SAndreas Gohr /** 2982c064c1SAndreas Gohr * Registers a callback function for a given event 3082c064c1SAndreas Gohr * 3182c064c1SAndreas Gohr * @param Doku_Event_Handler $controller DokuWiki's event controller object 3282c064c1SAndreas Gohr * @return void 3382c064c1SAndreas Gohr */ 34*7234bfb1Ssplitbrain public function register(EventHandler $controller) 35d6d97f60SAnna Dabrowska { 36748e747fSAnna Dabrowska $controller->register_hook('PARSER_HANDLER_DONE', 'AFTER', $this, 'handleOutput'); 37748e747fSAnna Dabrowska $controller->register_hook('PLUGIN_DW2PDF_REPLACE', 'BEFORE', $this, 'replaceDw2pdf'); 38748e747fSAnna Dabrowska $controller->register_hook('PLUGIN_DW2PDF_REPLACE', 'AFTER', $this, 'cleanupDw2pdf'); 3982c064c1SAndreas Gohr } 4082c064c1SAndreas Gohr 4182c064c1SAndreas Gohr /** 4282c064c1SAndreas Gohr * Appends the instruction to render our syntax output component to each page 4328b818ceSAndreas Gohr * after the first found headline or the very begining if no headline was found 4482c064c1SAndreas Gohr * 4582c064c1SAndreas Gohr * @param Doku_Event $event 4682c064c1SAndreas Gohr * @param $param 4782c064c1SAndreas Gohr */ 48*7234bfb1Ssplitbrain public function handleOutput(Event $event, $param) 49d6d97f60SAnna Dabrowska { 500e4a3e7cSMichael Große global $ID; 5102481400SAndreas Gohr if (!page_exists($ID)) return; 52e6a2e26bSAnna Dabrowska 53c2ad3895SAnna Dabrowska $pos = 0; 548a30dd7dSFrieder Schrempf $ins = -1; 558a30dd7dSFrieder Schrempf 56e6a2e26bSAnna Dabrowska // display struct data at the bottom? 57e6a2e26bSAnna Dabrowska if ($this->getConf('bottomoutput')) { 58c2ad3895SAnna Dabrowska $ins = count($event->data->calls); 598a30dd7dSFrieder Schrempf } elseif (!$this->getConf('topoutput')) { 6028b818ceSAndreas Gohr foreach ($event->data->calls as $num => $call) { 6128b818ceSAndreas Gohr // try to find the first header 6228b818ceSAndreas Gohr if ($call[0] == 'header') { 6328b818ceSAndreas Gohr $pos = $call[2]; 6428b818ceSAndreas Gohr $ins = $num; 6528b818ceSAndreas Gohr break; 6628b818ceSAndreas Gohr } 6782c064c1SAndreas Gohr 6828b818ceSAndreas Gohr // abort when after we looked at the first 150 bytes 699007da58SMichael Große if (isset($call[3]) && $call[3] > 150) { 7028b818ceSAndreas Gohr break; 7128b818ceSAndreas Gohr } 7228b818ceSAndreas Gohr } 73c2ad3895SAnna Dabrowska } 7428b818ceSAndreas Gohr 7528b818ceSAndreas Gohr // insert our own call after the found position 7628b818ceSAndreas Gohr array_splice( 7728b818ceSAndreas Gohr $event->data->calls, 7828b818ceSAndreas Gohr $ins + 1, 7928b818ceSAndreas Gohr 0, 80*7234bfb1Ssplitbrain [['plugin', ['struct_output', ['pos' => $pos], DOKU_LEXER_SPECIAL, ''], $pos]] 8182c064c1SAndreas Gohr ); 8282c064c1SAndreas Gohr } 8382c064c1SAndreas Gohr 843851b2fbSAnna Dabrowska /** 853851b2fbSAnna Dabrowska * If the page has a schema assigned, add its struct data 863851b2fbSAnna Dabrowska * to dw2pdf's template replacements 873851b2fbSAnna Dabrowska * 883851b2fbSAnna Dabrowska * @param Doku_Event $event 893851b2fbSAnna Dabrowska * @param $param 903851b2fbSAnna Dabrowska */ 91*7234bfb1Ssplitbrain public function replaceDw2pdf(Event $event, $param) 923851b2fbSAnna Dabrowska { 933851b2fbSAnna Dabrowska if (!$event->data['id'] || !page_exists($event->data['id'])) return; 943851b2fbSAnna Dabrowska 95d4897163SAnna Dabrowska global $REV; 96d4897163SAnna Dabrowska $rev = $REV ?: time(); 97d4897163SAnna Dabrowska 983851b2fbSAnna Dabrowska /** @var helper_plugin_struct $helper */ 993851b2fbSAnna Dabrowska $helper = plugin_load('helper', 'struct'); 100d4897163SAnna Dabrowska $data = $helper->getData($event->data['id'], null, $rev); 1013851b2fbSAnna Dabrowska 1023851b2fbSAnna Dabrowska if (!$data) return; 1033851b2fbSAnna Dabrowska 1043851b2fbSAnna Dabrowska foreach ($data as $schema => $fields) { 10523f770edSAnna Dabrowska $schemaObject = new Schema($schema); 1063851b2fbSAnna Dabrowska foreach ($fields as $field => $value) { 10723f770edSAnna Dabrowska // format fields 10823f770edSAnna Dabrowska $col = $schemaObject->findColumn($field); 10923f770edSAnna Dabrowska if (is_a($col->getType(), '\dokuwiki\plugin\struct\types\Date')) { 11023f770edSAnna Dabrowska $format = $col->getType()->getConfig()['format']; 11123f770edSAnna Dabrowska $value = date($format, strtotime($value)); 11223f770edSAnna Dabrowska } 11323f770edSAnna Dabrowska 1143851b2fbSAnna Dabrowska $placeholder = sprintf('@%s_%s_%s@', self::DW2PDF_PLACEHOLDER_PREFIX, $schema, $field); 1153851b2fbSAnna Dabrowska $event->data['replace'][$placeholder] = is_array($value) ? implode(', ', $value) : $value; 1163851b2fbSAnna Dabrowska } 1173851b2fbSAnna Dabrowska } 1183851b2fbSAnna Dabrowska } 1193851b2fbSAnna Dabrowska 1203851b2fbSAnna Dabrowska /** 1213851b2fbSAnna Dabrowska * Remove struct placeholders still present after replacement. 1223851b2fbSAnna Dabrowska * Requested data was not found. 1233851b2fbSAnna Dabrowska * 1243851b2fbSAnna Dabrowska * @param Doku_Event $event 1253851b2fbSAnna Dabrowska * @param $param 1263851b2fbSAnna Dabrowska */ 127*7234bfb1Ssplitbrain public function cleanupDw2pdf(Event $event, $param) 1283851b2fbSAnna Dabrowska { 1293851b2fbSAnna Dabrowska $pattern = '~@' . self::DW2PDF_PLACEHOLDER_PREFIX . '_[^@]+?@~'; 1303851b2fbSAnna Dabrowska $event->data['content'] = preg_replace($pattern, '', $event->data['content']); 1313851b2fbSAnna Dabrowska } 13282c064c1SAndreas Gohr} 13382c064c1SAndreas Gohr 13482c064c1SAndreas Gohr// vim:ts=4:sw=4:et: 135