PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` 'use strict'; const { visit } = require('../lib/xast.js'); exports.type = 'visitor'; exports.name = 'cleanupEnableBackground'; exports.active = true; exports.description = 'remove or cleanup enable-background attribute when possible'; /** * Remove or cleanup enable-background attr which coincides with a width/height box. * * @see https://www.w3.org/TR/SVG11/filters.html#EnableBackgroundProperty * * @example * * ⬇ * * * @author Kir Belevich * * @type {import('../lib/types').Plugin} */ exports.fn = (root) => { const regEnableBackground = /^new\s0\s0\s([-+]?\d*\.?\d+([eE][-+]?\d+)?)\s([-+]?\d*\.?\d+([eE][-+]?\d+)?)$/; let hasFilter = false; visit(root, { element: { enter: (node) => { if (node.name === 'filter') { hasFilter = true; } }, }, }); return { element: { enter: (node) => { if (node.attributes['enable-background'] == null) { return; } if (hasFilter) { if ( (node.name === 'svg' || node.name === 'mask' || node.name === 'pattern') && node.attributes.width != null && node.attributes.height != null ) { const match = node.attributes['enable-background'].match(regEnableBackground); if ( match != null && node.attributes.width === match[1] && node.attributes.height === match[3] ) { if (node.name === 'svg') { delete node.attributes['enable-background']; } else { node.attributes['enable-background'] = 'new'; } } } } else { //we don't need 'enable-background' if we have no filters delete node.attributes['enable-background']; } }, }, }; };