X-Git-Url: https://git.harvie.cz/?a=blobdiff_plain;f=syntax.php;h=6c920737740b3b804c6d1cce5e2a8450241a4878;hb=3aaf5eeedbd3c4d718955628e74d392756633dfc;hp=442d45f360c302f8b444be0559a51b926b984ec7;hpb=34612ed6f43b1714c084992ad8de5c464b48f529;p=mirrors%2FDokuWiki-Plugin-SVGEdit.git diff --git a/syntax.php b/syntax.php index 442d45f..6c92073 100755 --- a/syntax.php +++ b/syntax.php @@ -48,32 +48,49 @@ class syntax_plugin_svgedit extends DokuWiki_Syntax_Plugin { return array($type, $match); } - function render($format, &$renderer, $data) { - if ($format!='xhtml') return; + function svg_base64_encode($svg) { //create base64 encoded svg for use as svglink in svg_format_embed + return 'data:image/svg+xml;base64,'.base64_encode($svg).'" type="image/svg+xml'; + } + + function svg_format_embed($svglink, $alt, $svg_parameters) { //create xhtml code for svg embeding global $ID; - $is_webkit= preg_match('/webkit/', strtolower($_SERVER['HTTP_USER_AGENT']) ); // dirty, but fast /n3k/ + //use object tag for stupid browsers (like firefox) - ugly (relies on browser identification) + $is_webkit= preg_match('/webkit/', strtolower($_SERVER['HTTP_USER_AGENT'])); if ($is_webkit) - $svgtag='<'.$svgtag.'="'.$svglink.'" alt="'.$alt.'" type="image/svg+xml" />'."
"; + } + + function render($format, &$renderer, $data) { + if ($format!='xhtml') return; + global $ID; + + $svg_wiki_page = trim(substr($data[1], 6, -2)); //name of wiki page containing SVG image + + //detect image size for stupid browsers (like firefox) - ugly (fails if svg does not contain information about it's size) + $svg_dimensions = ''; + preg_match('/width="[0-9]+" height="[0-9]+"/', $data[1].rawWiki($svg_wiki_page), $_); + if(isset($_[0])) $svg_dimensions = $_[0]; + if($data[0]===''.$svgtag.$svgenc.'" alt="svg-image@'.$ID.'" />'."
"; + $svgenc = $this->svg_base64_encode($data[1]); + $renderer->doc .= $this->svg_format_embed($svgenc, 'svg-image@'.$ID, $svg_dimensions); return true; } if($data[0]==='{{sv') { - $data[1] = trim(substr($data[1], 6, -2)); - $svgenc = exportlink($data[1],'svg'); - $renderer->doc .= ''.$svgtag.$svgenc.'" alt="image:'.htmlspecialchars($data[1]).'" type="image/svg+xml"/>
'; - $renderer->doc .= html_wikilink($data[1],'svg@'.$data[1]); + $svglink = exportlink($svg_wiki_page,'svg'); + $renderer->doc .= $this->svg_format_embed($svglink, 'image:'.htmlspecialchars($svg_wiki_page), $svg_dimensions); + $renderer->doc .= html_wikilink($svg_wiki_page,'svg@'.$svg_wiki_page); return true; } if($data[0]==='{{SV') { - $data[1] = trim(substr($data[1], 6, -2)); - $svgenc = 'data:image/svg+xml;base64,'.base64_encode(rawWiki($data[1])).'" type="image/svg+xml'; - $renderer->doc .= ''.$svgtag.$svgenc.'" alt="image:'.htmlspecialchars($data[1]).'" />
'; - $renderer->doc .= html_wikilink($data[1],'SVG@'.$data[1]); + $svgenc = $this->svg_base64_encode(rawWiki($svg_wiki_page)); + $renderer->doc .= $this->svg_format_embed($svgenc, 'image:'.htmlspecialchars($svg_wiki_page), $svg_dimensions); + $renderer->doc .= html_wikilink($svg_wiki_page,'SVG@'.$svg_wiki_page); return true; } }