svgo
svgo copied to clipboard
"Viewer does not support full SVG 1.1" added to image during optimization
Describe the bug
When I run an SVG 1.1 document through svgo (version 2.2.1 installed via yarn global
), I get the text "Viewer does not support full SVG 1.1" added to the bottom of the image. I don't see anything else wrong with the image. Checking the output SVG source shows that the text is added by svgo, not the viewer.
To Reproduce Steps to reproduce the behavior:
- Use diagrams.net / draw.io to create a simple diagram.
- Export the image to SVG with default settings.
- Run
svgo my.svg -o my2.svg
- View the resulting image.
Expected behavior
Assuming that the warning is legitimate, I would expect it to either appear on stdout or else to fail processing and be on stderr. Showing up silently on the output image was unexpected.
Screenshots
data:image/s3,"s3://crabby-images/8b06c/8b06c61c9da388c9b40b8cc42c35130fafe71a63" alt="image"
Desktop (please complete the following information):
- SVGO Version - 2.2.1
- NodeJs Version - 15.10.0
- OS: MacOS Catalina 10.15.7
Hi, could you please submit svg file here?
Alright, I see the problem
Good deal - do you still need that SVG file?
You can submit one in case service will be unavailable
If useful, here is SVG with the problem: https://raw.githubusercontent.com/vincentbernat/vincent.bernat.ch/fcdf778c74bd9717552e323abaef2a73982c5d8a/content/media/images/rsync-remote-remote.svg
For anyone else hitting this problem:
draw.io graphs are generated with this piece of code:
<switch>
<g requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"/>
<a transform="translate(0,-5)" xlink:href="[https://www.diagrams.net/doc/faq/svg-export-text-problems](view-source:https://www.diagrams.net/doc/faq/svg-export-text-problems)" target="_blank">
<text text-anchor="middle" font-size="10px" x="50%" y="100%">Viewer does not support full SVG 1.1</text>
</a>
</switch>
And SVGO's removeEmptyContainers
plugin strips out the g
tag, making the message appear unconditionally.
The workaround, until that plugin deals with this case, is to disable it through config. I.e.:
module.exports = {
plugins: [
{
name: 'preset-default',
params: {
overrides: {
removeEmptyContainers: false,
},
},
},
],
};
This seems easy to fix: check if parentNode tag is switch and don't remove the container if it is.
This seems easy to fix: check if parentNode tag is switch and don't remove the container if it is.
Thanks for investigating this and opening a PR. I'll review it soon and get it merged. Just writing a note for how to approach this.
I was checking if we should really skip if the parent is a <switch>
, or if instead we should only skip if any of the requiredFeatures
, requiredExtensions
, or systemLanguage
attributes are present.
Indeed, I think the best solution is to check if the parent is a <switch>
though, as it is valid for a <switch>
to contain an empty <g/>
with no attributes, which will render nothing. Removing that would affect the rendering of the SVG.
It could also be worth updating Remove Hidden Elements to delete the <switch>
entirely if the first node doesn't contain a conditional attribute and is a non-rendering element. I'll look into this separately, though.