1<?php 2 3use dokuwiki\plugin\diagrams\Diagrams; 4 5/** 6 * Class syntax_plugin_diagrams 7 */ 8class syntax_plugin_diagrams_mediafile extends DokuWiki_Syntax_Plugin 9{ 10 11 /** 12 * @inheritdoc 13 */ 14 public function getType() 15 { 16 return 'substition'; 17 } 18 19 /** 20 * @inheritdoc 21 */ 22 public function getSort() 23 { 24 return 319; 25 } 26 27 /** 28 * @inheritdoc 29 */ 30 public function connectTo($mode) 31 { 32 // only register if mediafile mode is enabled 33 if (!($this->getConf('mode') & Diagrams::MODE_MEDIA)) return; 34 35 // grab all SVG images 36 $this->Lexer->addSpecialPattern('\{\{[^\}]+(?:\.svg)[^\}]*?\}\}',$mode,'plugin_diagrams_mediafile'); 37 } 38 39 /** 40 * Parse SVG syntax into media data 41 * 42 * @param string $match 43 * @param int $state 44 * @param int $pos 45 * @param Doku_Handler $handler 46 * @return array|bool 47 */ 48 public function handle($match, $state, $pos, Doku_Handler $handler) 49 { 50 $data = Doku_Handler_Parse_Media($match); 51 52 /** @var helper_plugin_diagrams $helper */ 53 $helper = plugin_load('helper', 'diagrams'); 54 if (!$data['type'] == 'internalmedia' || !$helper->isDiagramFile(mediaFN($data['src']))) { 55 // This is not a local diagrams file, but some other SVG media file 56 $handler->media($match, $state, $pos); 57 return false; 58 } 59 60 $data['url'] = ml($data['src'], ['cache' => 'nocache'], true, '&'); 61 return $data; 62 } 63 64 /** 65 * Handle rewrites made by the move plugin 66 * 67 * @param string $match 68 * @param int $state 69 * @param int $pos 70 * @param string $plugin 71 * @param helper_plugin_move_handler $handler 72 * @return void 73 */ 74 public function handleMove($match, $state, $pos, $plugin, $handler) 75 { 76 if ($plugin !== 'diagrams_mediafile') return; 77 78 $handler->media($match, $state, $pos); 79 } 80 81 /** 82 * Render the diagram SVG as <object> instead of <img> to allow links, 83 * except when rendering to a PDF 84 * 85 * @param string $format 86 * @param Doku_Renderer $renderer 87 * @param array $data 88 * @return bool 89 */ 90 public function render($format, Doku_Renderer $renderer, $data) 91 { 92 if ($format === 'metadata') { 93 $renderer->internalmedia($data['src']); 94 return true; 95 } 96 if ($format !== 'xhtml') { 97 return false; 98 } 99 100 $baseAttributes = [ 101 'class' => 'media', 102 'width' => $data['width'] ?: '', 103 'height' => $data['height'] ?: '', 104 'title' => $data['title'] ?: '', 105 ]; 106 107 108 if (is_a($renderer, 'renderer_plugin_dw2pdf')) { 109 $imageAttributes = $baseAttributes; 110 $imageAttributes['align'] = $data['align']; 111 $imageAttributes['src'] = $data['url']; 112 $renderer->doc .= '<img ' . buildAttributes($imageAttributes) . '/>'; 113 } else { 114 $wrapperAttributes = $baseAttributes; 115 $wrapperAttributes['class'] .= ' diagrams-svg-wrapper media' . $data['align']; 116 117 $imageAttributes = []; 118 $imageAttributes['class'] = 'diagrams-svg'; 119 $imageAttributes['data'] = $data['url']; 120 $imageAttributes['data-id'] = cleanID($data['src']); 121 $imageAttributes['type'] = 'image/svg+xml'; 122 $imageAttributes['data-pos'] = $data['pos'] ?: ''; 123 $imageAttributes['data-len'] = $data['len'] ?: ''; 124 125 $image = sprintf('<object %s></object>', buildAttributes($imageAttributes, true)); 126 $wrapper = sprintf('<div %s>%s</div>', buildAttributes($wrapperAttributes, true), $image); 127 $renderer->doc .= $wrapper; 128 } 129 130 return true; 131 } 132} 133