X-Git-Url: http://git.harvie.cz/?a=blobdiff_plain;f=syntax.php;h=17224c66d18444f94afaee935b32fe74807db8ea;hb=32165dccbbcfae3d9a883bfe935bfc733ac17382;hp=2d9e69e05ff645099c6c2306f0e28b9ec9c13d5e;hpb=b3a6ad9d8ae6d6a835ceab584a3ad870b9d7caa9;p=mirrors%2FDokuWiki-Plugin-SVGEdit.git
diff --git a/syntax.php b/syntax.php
index 2d9e69e..17224c6 100755
--- a/syntax.php
+++ b/syntax.php
@@ -48,28 +48,50 @@ class syntax_plugin_svgedit extends DokuWiki_Syntax_Plugin {
return array($type, $match);
}
+ function format_svg_embed($svglink, $alt) {
+ global $ID;
+
+ //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];
+
+ //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='img src';
+ else
+ $svgtag='object '.$svg_dimensions.' data';
+
+ return '<'.$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
+
+
+
+
if($data[0]==='
'."
";
+ $svglink = 'data:image/svg+xml;base64,'.base64_encode($data[1]).'" type="image/svg+xml';
+ $renderer->doc .= $this->format_svg_embed($svglink, 'svg-image@'.$ID);
return true;
}
if($data[0]==='{{sv') {
- $data[1] = trim(substr($data[1], 6, -2));
- $svgenc = exportlink($data[1],'svg');
- $renderer->doc .= '![image:'.htmlspecialchars($data[1]).']('.$svgenc.')
';
- //$renderer->doc .= '
'; //scrollbars on webkit :-(
- $renderer->doc .= html_wikilink($data[1],'svg@'.$data[1]);
+ $svglink = exportlink($svg_wiki_page,'svg');
+ $renderer->doc .= $this->format_svg_embed($svglink, 'image:'.htmlspecialchars($svg_wiki_page));
+ //$renderer->doc .= ''.$svgtag.$svglink.'" alt="image:'.htmlspecialchars($svg_wiki_page).'" type="image/svg+xml"/>
';
+ $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 .= '![image:'.htmlspecialchars($data[1]).']('.$svgenc.')
';
- $renderer->doc .= html_wikilink($data[1],'SVG@'.$data[1]);
+ $svglink = 'data:image/svg+xml;base64,'.base64_encode(rawWiki($svg_wiki_page)).'" type="image/svg+xml';
+ $renderer->doc .= $this->format_svg_embed($svglink, 'image:'.htmlspecialchars($svg_wiki_page));
+ //$renderer->doc .= ''.$svgtag.$svglink.'" alt="image:'.htmlspecialchars($svg_wiki_page).'" />
';
+ $renderer->doc .= html_wikilink($svg_wiki_page,'SVG@'.$svg_wiki_page);
return true;
}
}