mirror of
https://github.com/idanoo/GoScrobble.git
synced 2024-11-22 16:35:14 +00:00
2559 lines
57 KiB
JavaScript
2559 lines
57 KiB
JavaScript
'use strict';
|
|
|
|
// http://www.w3.org/TR/SVG11/intro.html#Definitions
|
|
exports.elemsGroups = {
|
|
animation: ['animate', 'animateColor', 'animateMotion', 'animateTransform', 'set'],
|
|
descriptive: ['desc', 'metadata', 'title'],
|
|
shape: ['circle', 'ellipse', 'line', 'path', 'polygon', 'polyline', 'rect'],
|
|
structural: ['defs', 'g', 'svg', 'symbol', 'use'],
|
|
paintServer: ['solidColor', 'linearGradient', 'radialGradient', 'meshGradient', 'pattern', 'hatch'],
|
|
nonRendering: ['linearGradient', 'radialGradient', 'pattern', 'clipPath', 'mask', 'marker', 'symbol', 'filter', 'solidColor'],
|
|
container: ['a', 'defs', 'g', 'marker', 'mask', 'missing-glyph', 'pattern', 'svg', 'switch', 'symbol', 'foreignObject'],
|
|
textContent: ['altGlyph', 'altGlyphDef', 'altGlyphItem', 'glyph', 'glyphRef', 'textPath', 'text', 'tref', 'tspan'],
|
|
textContentChild: ['altGlyph', 'textPath', 'tref', 'tspan'],
|
|
lightSource: ['feDiffuseLighting', 'feSpecularLighting', 'feDistantLight', 'fePointLight', 'feSpotLight'],
|
|
filterPrimitive: ['feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite', 'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap', 'feFlood', 'feGaussianBlur', 'feImage', 'feMerge', 'feMorphology', 'feOffset', 'feSpecularLighting', 'feTile', 'feTurbulence']
|
|
};
|
|
|
|
exports.pathElems = ['path', 'glyph', 'missing-glyph'];
|
|
|
|
// http://www.w3.org/TR/SVG11/intro.html#Definitions
|
|
exports.attrsGroups = {
|
|
animationAddition: ['additive', 'accumulate'],
|
|
animationAttributeTarget: ['attributeType', 'attributeName'],
|
|
animationEvent: ['onbegin', 'onend', 'onrepeat', 'onload'],
|
|
animationTiming: ['begin', 'dur', 'end', 'min', 'max', 'restart', 'repeatCount', 'repeatDur', 'fill'],
|
|
animationValue: ['calcMode', 'values', 'keyTimes', 'keySplines', 'from', 'to', 'by'],
|
|
conditionalProcessing: ['requiredFeatures', 'requiredExtensions', 'systemLanguage'],
|
|
core: ['id', 'tabindex', 'xml:base', 'xml:lang', 'xml:space'],
|
|
graphicalEvent: ['onfocusin', 'onfocusout', 'onactivate', 'onclick', 'onmousedown', 'onmouseup', 'onmouseover', 'onmousemove', 'onmouseout', 'onload'],
|
|
presentation: [
|
|
'alignment-baseline',
|
|
'baseline-shift',
|
|
'clip',
|
|
'clip-path',
|
|
'clip-rule',
|
|
'color',
|
|
'color-interpolation',
|
|
'color-interpolation-filters',
|
|
'color-profile',
|
|
'color-rendering',
|
|
'cursor',
|
|
'direction',
|
|
'display',
|
|
'dominant-baseline',
|
|
'enable-background',
|
|
'fill',
|
|
'fill-opacity',
|
|
'fill-rule',
|
|
'filter',
|
|
'flood-color',
|
|
'flood-opacity',
|
|
'font-family',
|
|
'font-size',
|
|
'font-size-adjust',
|
|
'font-stretch',
|
|
'font-style',
|
|
'font-variant',
|
|
'font-weight',
|
|
'glyph-orientation-horizontal',
|
|
'glyph-orientation-vertical',
|
|
'image-rendering',
|
|
'letter-spacing',
|
|
'lighting-color',
|
|
'marker-end',
|
|
'marker-mid',
|
|
'marker-start',
|
|
'mask',
|
|
'opacity',
|
|
'overflow',
|
|
'paint-order',
|
|
'pointer-events',
|
|
'shape-rendering',
|
|
'stop-color',
|
|
'stop-opacity',
|
|
'stroke',
|
|
'stroke-dasharray',
|
|
'stroke-dashoffset',
|
|
'stroke-linecap',
|
|
'stroke-linejoin',
|
|
'stroke-miterlimit',
|
|
'stroke-opacity',
|
|
'stroke-width',
|
|
'text-anchor',
|
|
'text-decoration',
|
|
'text-overflow',
|
|
'text-rendering',
|
|
'transform',
|
|
'unicode-bidi',
|
|
'vector-effect',
|
|
'visibility',
|
|
'word-spacing',
|
|
'writing-mode'
|
|
],
|
|
xlink: ['xlink:href', 'xlink:show', 'xlink:actuate', 'xlink:type', 'xlink:role', 'xlink:arcrole', 'xlink:title'],
|
|
documentEvent: ['onunload', 'onabort', 'onerror', 'onresize', 'onscroll', 'onzoom'],
|
|
filterPrimitive: ['x', 'y', 'width', 'height', 'result'],
|
|
transferFunction: ['type', 'tableValues', 'slope', 'intercept', 'amplitude', 'exponent', 'offset']
|
|
};
|
|
|
|
exports.attrsGroupsDefaults = {
|
|
core: {'xml:space': 'preserve'},
|
|
filterPrimitive: {x: '0', y: '0', width: '100%', height: '100%'},
|
|
presentation: {
|
|
clip: 'auto',
|
|
'clip-path': 'none',
|
|
'clip-rule': 'nonzero',
|
|
mask: 'none',
|
|
opacity: '1',
|
|
'stop-color': '#000',
|
|
'stop-opacity': '1',
|
|
'fill-opacity': '1',
|
|
'fill-rule': 'nonzero',
|
|
fill: '#000',
|
|
stroke: 'none',
|
|
'stroke-width': '1',
|
|
'stroke-linecap': 'butt',
|
|
'stroke-linejoin': 'miter',
|
|
'stroke-miterlimit': '4',
|
|
'stroke-dasharray': 'none',
|
|
'stroke-dashoffset': '0',
|
|
'stroke-opacity': '1',
|
|
'paint-order': 'normal',
|
|
'vector-effect': 'none',
|
|
display: 'inline',
|
|
visibility: 'visible',
|
|
'marker-start': 'none',
|
|
'marker-mid': 'none',
|
|
'marker-end': 'none',
|
|
'color-interpolation': 'sRGB',
|
|
'color-interpolation-filters': 'linearRGB',
|
|
'color-rendering': 'auto',
|
|
'shape-rendering': 'auto',
|
|
'text-rendering': 'auto',
|
|
'image-rendering': 'auto',
|
|
'font-style': 'normal',
|
|
'font-variant': 'normal',
|
|
'font-weight': 'normal',
|
|
'font-stretch': 'normal',
|
|
'font-size': 'medium',
|
|
'font-size-adjust': 'none',
|
|
kerning: 'auto',
|
|
'letter-spacing': 'normal',
|
|
'word-spacing': 'normal',
|
|
'text-decoration': 'none',
|
|
'text-anchor': 'start',
|
|
'text-overflow': 'clip',
|
|
'writing-mode': 'lr-tb',
|
|
'glyph-orientation-vertical': 'auto',
|
|
'glyph-orientation-horizontal': '0deg',
|
|
direction: 'ltr',
|
|
'unicode-bidi': 'normal',
|
|
'dominant-baseline': 'auto',
|
|
'alignment-baseline': 'baseline',
|
|
'baseline-shift': 'baseline'
|
|
},
|
|
transferFunction: {slope: '1', intercept: '0', amplitude: '1', exponent: '1', offset: '0'}
|
|
};
|
|
|
|
// http://www.w3.org/TR/SVG11/eltindex.html
|
|
exports.elems = {
|
|
a: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'target'
|
|
],
|
|
defaults: {
|
|
target: '_self'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
altGlyph: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'x',
|
|
'y',
|
|
'dx',
|
|
'dy',
|
|
'glyphRef',
|
|
'format',
|
|
'rotate'
|
|
]
|
|
},
|
|
altGlyphDef: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
content: [
|
|
'glyphRef'
|
|
]
|
|
},
|
|
altGlyphItem: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
content: [
|
|
'glyphRef',
|
|
'altGlyphItem'
|
|
]
|
|
},
|
|
animate: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'animationAddition',
|
|
'animationAttributeTarget',
|
|
'animationEvent',
|
|
'animationTiming',
|
|
'animationValue',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
animateColor: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'animationEvent',
|
|
'xlink',
|
|
'animationAttributeTarget',
|
|
'animationTiming',
|
|
'animationValue',
|
|
'animationAddition',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
animateMotion: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'animationEvent',
|
|
'xlink',
|
|
'animationTiming',
|
|
'animationValue',
|
|
'animationAddition'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'path',
|
|
'keyPoints',
|
|
'rotate',
|
|
'origin'
|
|
],
|
|
defaults: {
|
|
'rotate': '0'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'mpath'
|
|
]
|
|
},
|
|
animateTransform: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'animationEvent',
|
|
'xlink',
|
|
'animationAttributeTarget',
|
|
'animationTiming',
|
|
'animationValue',
|
|
'animationAddition'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'type'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
circle: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'cx',
|
|
'cy',
|
|
'r'
|
|
],
|
|
defaults: {
|
|
cx: '0',
|
|
cy: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
clipPath: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'clipPathUnits'
|
|
],
|
|
defaults: {
|
|
clipPathUnits: 'userSpaceOnUse'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape'
|
|
],
|
|
content: [
|
|
'text',
|
|
'use'
|
|
]
|
|
},
|
|
'color-profile': {
|
|
attrsGroups: [
|
|
'core',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'local',
|
|
'name',
|
|
'rendering-intent'
|
|
],
|
|
defaults: {
|
|
name: 'sRGB',
|
|
'rendering-intent': 'auto'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
cursor: {
|
|
attrsGroups: [
|
|
'core',
|
|
'conditionalProcessing',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'x',
|
|
'y'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
defs: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
desc: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
]
|
|
},
|
|
ellipse: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'cx',
|
|
'cy',
|
|
'rx',
|
|
'ry'
|
|
],
|
|
defaults: {
|
|
cx: '0',
|
|
cy: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
feBlend: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
// TODO: in - 'If no value is provided and this is the first filter primitive,
|
|
// then this filter primitive will use SourceGraphic as its input'
|
|
'in',
|
|
'in2',
|
|
'mode'
|
|
],
|
|
defaults: {
|
|
mode: 'normal'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feColorMatrix: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'type',
|
|
'values'
|
|
],
|
|
defaults: {
|
|
type: 'matrix'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feComponentTransfer: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in'
|
|
],
|
|
content: [
|
|
'feFuncA',
|
|
'feFuncB',
|
|
'feFuncG',
|
|
'feFuncR'
|
|
]
|
|
},
|
|
feComposite: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'in2',
|
|
'operator',
|
|
'k1',
|
|
'k2',
|
|
'k3',
|
|
'k4'
|
|
],
|
|
defaults: {
|
|
operator: 'over',
|
|
k1: '0',
|
|
k2: '0',
|
|
k3: '0',
|
|
k4: '0'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feConvolveMatrix: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'order',
|
|
'kernelMatrix',
|
|
// TODO: divisor - 'The default value is the sum of all values in kernelMatrix,
|
|
// with the exception that if the sum is zero, then the divisor is set to 1'
|
|
'divisor',
|
|
'bias',
|
|
// TODO: targetX - 'By default, the convolution matrix is centered in X over each
|
|
// pixel of the input image (i.e., targetX = floor ( orderX / 2 ))'
|
|
'targetX',
|
|
'targetY',
|
|
'edgeMode',
|
|
// TODO: kernelUnitLength - 'The first number is the <dx> value. The second number
|
|
// is the <dy> value. If the <dy> value is not specified, it defaults to the same value as <dx>'
|
|
'kernelUnitLength',
|
|
'preserveAlpha'
|
|
],
|
|
defaults: {
|
|
order: '3',
|
|
bias: '0',
|
|
edgeMode: 'duplicate',
|
|
preserveAlpha: 'false'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feDiffuseLighting: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'surfaceScale',
|
|
'diffuseConstant',
|
|
'kernelUnitLength'
|
|
],
|
|
defaults: {
|
|
surfaceScale: '1',
|
|
diffuseConstant: '1'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
// TODO: 'exactly one light source element, in any order'
|
|
'feDistantLight',
|
|
'fePointLight',
|
|
'feSpotLight'
|
|
]
|
|
},
|
|
feDisplacementMap: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'in2',
|
|
'scale',
|
|
'xChannelSelector',
|
|
'yChannelSelector'
|
|
],
|
|
defaults: {
|
|
scale: '0',
|
|
xChannelSelector: 'A',
|
|
yChannelSelector: 'A'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feDistantLight: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'azimuth',
|
|
'elevation'
|
|
],
|
|
defaults: {
|
|
azimuth: '0',
|
|
elevation: '0'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feFlood: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'animateColor',
|
|
'set'
|
|
]
|
|
},
|
|
feFuncA: {
|
|
attrsGroups: [
|
|
'core',
|
|
'transferFunction'
|
|
],
|
|
content: [
|
|
'set',
|
|
'animate'
|
|
]
|
|
},
|
|
feFuncB: {
|
|
attrsGroups: [
|
|
'core',
|
|
'transferFunction'
|
|
],
|
|
content: [
|
|
'set',
|
|
'animate'
|
|
]
|
|
},
|
|
feFuncG: {
|
|
attrsGroups: [
|
|
'core',
|
|
'transferFunction'
|
|
],
|
|
content: [
|
|
'set',
|
|
'animate'
|
|
]
|
|
},
|
|
feFuncR: {
|
|
attrsGroups: [
|
|
'core',
|
|
'transferFunction'
|
|
],
|
|
content: [
|
|
'set',
|
|
'animate'
|
|
]
|
|
},
|
|
feGaussianBlur: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'stdDeviation'
|
|
],
|
|
defaults: {
|
|
stdDeviation: '0'
|
|
},
|
|
content: [
|
|
'set',
|
|
'animate'
|
|
]
|
|
},
|
|
feImage: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'preserveAspectRatio',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
preserveAspectRatio: 'xMidYMid meet'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'animateTransform',
|
|
'set'
|
|
]
|
|
},
|
|
feMerge: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
],
|
|
content: [
|
|
'feMergeNode'
|
|
]
|
|
},
|
|
feMergeNode: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'in'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feMorphology: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'operator',
|
|
'radius'
|
|
],
|
|
defaults: {
|
|
operator: 'erode',
|
|
radius: '0'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feOffset: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'dx',
|
|
'dy'
|
|
],
|
|
defaults: {
|
|
dx: '0',
|
|
dy: '0'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
fePointLight: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'x',
|
|
'y',
|
|
'z'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0',
|
|
z: '0'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feSpecularLighting: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in',
|
|
'surfaceScale',
|
|
'specularConstant',
|
|
'specularExponent',
|
|
'kernelUnitLength'
|
|
],
|
|
defaults: {
|
|
surfaceScale: '1',
|
|
specularConstant: '1',
|
|
specularExponent: '1'
|
|
},
|
|
contentGroups: [
|
|
'descriptive',
|
|
// TODO: exactly one 'light source element'
|
|
'lightSource'
|
|
]
|
|
},
|
|
feSpotLight: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'x',
|
|
'y',
|
|
'z',
|
|
'pointsAtX',
|
|
'pointsAtY',
|
|
'pointsAtZ',
|
|
'specularExponent',
|
|
'limitingConeAngle'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0',
|
|
z: '0',
|
|
pointsAtX: '0',
|
|
pointsAtY: '0',
|
|
pointsAtZ: '0',
|
|
specularExponent: '1'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feTile: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'in'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
feTurbulence: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'filterPrimitive'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'baseFrequency',
|
|
'numOctaves',
|
|
'seed',
|
|
'stitchTiles',
|
|
'type'
|
|
],
|
|
defaults: {
|
|
baseFrequency: '0',
|
|
numOctaves: '1',
|
|
seed: '0',
|
|
stitchTiles: 'noStitch',
|
|
type: 'turbulence'
|
|
},
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
filter: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'filterRes',
|
|
'filterUnits',
|
|
'primitiveUnits',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
primitiveUnits: 'userSpaceOnUse',
|
|
x: '-10%',
|
|
y: '-10%',
|
|
width: '120%',
|
|
height: '120%'
|
|
},
|
|
contentGroups: [
|
|
'descriptive',
|
|
'filterPrimitive'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'set'
|
|
]
|
|
},
|
|
font: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'horiz-origin-x',
|
|
'horiz-origin-y',
|
|
'horiz-adv-x',
|
|
'vert-origin-x',
|
|
'vert-origin-y',
|
|
'vert-adv-y'
|
|
],
|
|
defaults: {
|
|
'horiz-origin-x': '0',
|
|
'horiz-origin-y': '0'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'font-face',
|
|
'glyph',
|
|
'hkern',
|
|
'missing-glyph',
|
|
'vkern'
|
|
]
|
|
},
|
|
'font-face': {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'font-family',
|
|
'font-style',
|
|
'font-variant',
|
|
'font-weight',
|
|
'font-stretch',
|
|
'font-size',
|
|
'unicode-range',
|
|
'units-per-em',
|
|
'panose-1',
|
|
'stemv',
|
|
'stemh',
|
|
'slope',
|
|
'cap-height',
|
|
'x-height',
|
|
'accent-height',
|
|
'ascent',
|
|
'descent',
|
|
'widths',
|
|
'bbox',
|
|
'ideographic',
|
|
'alphabetic',
|
|
'mathematical',
|
|
'hanging',
|
|
'v-ideographic',
|
|
'v-alphabetic',
|
|
'v-mathematical',
|
|
'v-hanging',
|
|
'underline-position',
|
|
'underline-thickness',
|
|
'strikethrough-position',
|
|
'strikethrough-thickness',
|
|
'overline-position',
|
|
'overline-thickness'
|
|
],
|
|
defaults: {
|
|
'font-style': 'all',
|
|
'font-variant': 'normal',
|
|
'font-weight': 'all',
|
|
'font-stretch': 'normal',
|
|
'unicode-range': 'U+0-10FFFF',
|
|
'units-per-em': '1000',
|
|
'panose-1': '0 0 0 0 0 0 0 0 0 0',
|
|
'slope': '0'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
// TODO: "at most one 'font-face-src' element"
|
|
'font-face-src'
|
|
]
|
|
},
|
|
// TODO: empty content
|
|
'font-face-format': {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'string'
|
|
]
|
|
},
|
|
'font-face-name': {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'name'
|
|
]
|
|
},
|
|
'font-face-src': {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
content: [
|
|
'font-face-name',
|
|
'font-face-uri'
|
|
]
|
|
},
|
|
'font-face-uri': {
|
|
attrsGroups: [
|
|
'core',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
content: [
|
|
'font-face-format'
|
|
]
|
|
},
|
|
foreignObject: {
|
|
attrsGroups: [
|
|
'core',
|
|
'conditionalProcessing',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height'
|
|
],
|
|
defaults: {
|
|
x: 0,
|
|
y: 0
|
|
}
|
|
},
|
|
g: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
glyph: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'd',
|
|
'horiz-adv-x',
|
|
'vert-origin-x',
|
|
'vert-origin-y',
|
|
'vert-adv-y',
|
|
'unicode',
|
|
'glyph-name',
|
|
'orientation',
|
|
'arabic-form',
|
|
'lang'
|
|
],
|
|
defaults: {
|
|
'arabic-form': 'initial'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
],
|
|
},
|
|
glyphRef: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'd',
|
|
'horiz-adv-x',
|
|
'vert-origin-x',
|
|
'vert-origin-y',
|
|
'vert-adv-y'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
hatch: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'x',
|
|
'y',
|
|
'pitch',
|
|
'rotate',
|
|
'hatchUnits',
|
|
'hatchContentUnits',
|
|
'transform'
|
|
],
|
|
defaults: {
|
|
hatchUnits: 'objectBoundingBox',
|
|
hatchContentUnits: 'userSpaceOnUse',
|
|
x: '0',
|
|
y: '0',
|
|
pitch: '0',
|
|
rotate: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'hatchPath'
|
|
]
|
|
},
|
|
hatchPath: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'd',
|
|
'offset'
|
|
],
|
|
defaults: {
|
|
offset: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
hkern: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'u1',
|
|
'g1',
|
|
'u2',
|
|
'g2',
|
|
'k'
|
|
]
|
|
},
|
|
image: {
|
|
attrsGroups: [
|
|
'core',
|
|
'conditionalProcessing',
|
|
'graphicalEvent',
|
|
'xlink',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'preserveAspectRatio',
|
|
'transform',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0',
|
|
preserveAspectRatio: 'xMidYMid meet'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
line: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'x1',
|
|
'y1',
|
|
'x2',
|
|
'y2'
|
|
],
|
|
defaults: {
|
|
x1: '0',
|
|
y1: '0',
|
|
x2: '0',
|
|
y2: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
linearGradient: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'x1',
|
|
'y1',
|
|
'x2',
|
|
'y2',
|
|
'gradientUnits',
|
|
'gradientTransform',
|
|
'spreadMethod',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
x1: '0',
|
|
y1: '0',
|
|
x2: '100%',
|
|
y2: '0',
|
|
spreadMethod: 'pad'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'animateTransform',
|
|
'set',
|
|
'stop'
|
|
]
|
|
},
|
|
marker: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'viewBox',
|
|
'preserveAspectRatio',
|
|
'refX',
|
|
'refY',
|
|
'markerUnits',
|
|
'markerWidth',
|
|
'markerHeight',
|
|
'orient'
|
|
],
|
|
defaults: {
|
|
markerUnits: 'strokeWidth',
|
|
refX: '0',
|
|
refY: '0',
|
|
markerWidth: '3',
|
|
markerHeight: '3'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
mask: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'maskUnits',
|
|
'maskContentUnits'
|
|
],
|
|
defaults: {
|
|
maskUnits: 'objectBoundingBox',
|
|
maskContentUnits: 'userSpaceOnUse',
|
|
x: '-10%',
|
|
y: '-10%',
|
|
width: '120%',
|
|
height: '120%'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
metadata: {
|
|
attrsGroups: [
|
|
'core'
|
|
]
|
|
},
|
|
'missing-glyph': {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'd',
|
|
'horiz-adv-x',
|
|
'vert-origin-x',
|
|
'vert-origin-y',
|
|
'vert-adv-y'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
mpath: {
|
|
attrsGroups: [
|
|
'core',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
path: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'd',
|
|
'pathLength'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
pattern: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'viewBox',
|
|
'preserveAspectRatio',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'patternUnits',
|
|
'patternContentUnits',
|
|
'patternTransform',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
patternUnits: 'objectBoundingBox',
|
|
patternContentUnits: 'userSpaceOnUse',
|
|
x: '0',
|
|
y: '0',
|
|
width: '0',
|
|
height: '0',
|
|
preserveAspectRatio: 'xMidYMid meet'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'paintServer',
|
|
'shape',
|
|
'structural'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
polygon: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'points'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
polyline: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'points'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
radialGradient: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'cx',
|
|
'cy',
|
|
'r',
|
|
'fx',
|
|
'fy',
|
|
'fr',
|
|
'gradientUnits',
|
|
'gradientTransform',
|
|
'spreadMethod',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
gradientUnits: 'objectBoundingBox',
|
|
cx: '50%',
|
|
cy: '50%',
|
|
r: '50%'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'animateTransform',
|
|
'set',
|
|
'stop'
|
|
]
|
|
},
|
|
meshGradient: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'x',
|
|
'y',
|
|
'gradientUnits',
|
|
'transform'
|
|
],
|
|
contentGroups: [
|
|
'descriptive',
|
|
'paintServer',
|
|
'animation',
|
|
],
|
|
content: [
|
|
'meshRow'
|
|
]
|
|
},
|
|
meshRow: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'meshPatch'
|
|
]
|
|
},
|
|
meshPatch: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'stop'
|
|
]
|
|
},
|
|
rect: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'rx',
|
|
'ry'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
script: {
|
|
attrsGroups: [
|
|
'core',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'type',
|
|
'href',
|
|
'xlink:href'
|
|
]
|
|
},
|
|
set: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'animation',
|
|
'xlink',
|
|
'animationAttributeTarget',
|
|
'animationTiming',
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'to'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
solidColor: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
],
|
|
contentGroups: [
|
|
'paintServer'
|
|
]
|
|
},
|
|
stop: {
|
|
attrsGroups: [
|
|
'core',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'offset',
|
|
'path'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'animateColor',
|
|
'set'
|
|
]
|
|
},
|
|
style: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'type',
|
|
'media',
|
|
'title'
|
|
],
|
|
defaults: {
|
|
type: 'text/css'
|
|
}
|
|
},
|
|
svg: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'documentEvent',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'viewBox',
|
|
'preserveAspectRatio',
|
|
'zoomAndPan',
|
|
'version',
|
|
'baseProfile',
|
|
'contentScriptType',
|
|
'contentStyleType'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0',
|
|
width: '100%',
|
|
height: '100%',
|
|
preserveAspectRatio: 'xMidYMid meet',
|
|
zoomAndPan: 'magnify',
|
|
version: '1.1',
|
|
baseProfile: 'none',
|
|
contentScriptType: 'application/ecmascript',
|
|
contentStyleType: 'text/css'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
switch: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform'
|
|
],
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape'
|
|
],
|
|
content: [
|
|
'a',
|
|
'foreignObject',
|
|
'g',
|
|
'image',
|
|
'svg',
|
|
'switch',
|
|
'text',
|
|
'use'
|
|
]
|
|
},
|
|
symbol: {
|
|
attrsGroups: [
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'preserveAspectRatio',
|
|
'viewBox',
|
|
'refX',
|
|
'refY'
|
|
],
|
|
defaults: {
|
|
refX: 0,
|
|
refY: 0
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'shape',
|
|
'structural',
|
|
'paintServer'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyphDef',
|
|
'clipPath',
|
|
'color-profile',
|
|
'cursor',
|
|
'filter',
|
|
'font',
|
|
'font-face',
|
|
'foreignObject',
|
|
'image',
|
|
'marker',
|
|
'mask',
|
|
'pattern',
|
|
'script',
|
|
'style',
|
|
'switch',
|
|
'text',
|
|
'view'
|
|
]
|
|
},
|
|
text: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'lengthAdjust',
|
|
'x',
|
|
'y',
|
|
'dx',
|
|
'dy',
|
|
'rotate',
|
|
'textLength'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0',
|
|
lengthAdjust: 'spacing'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive',
|
|
'textContentChild'
|
|
],
|
|
content: [
|
|
'a'
|
|
]
|
|
},
|
|
textPath: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'href',
|
|
'xlink:href',
|
|
'startOffset',
|
|
'method',
|
|
'spacing',
|
|
'd'
|
|
],
|
|
defaults: {
|
|
startOffset: '0',
|
|
method: 'align',
|
|
spacing: 'exact'
|
|
},
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyph',
|
|
'animate',
|
|
'animateColor',
|
|
'set',
|
|
'tref',
|
|
'tspan'
|
|
]
|
|
},
|
|
title: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style'
|
|
]
|
|
},
|
|
tref: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'animate',
|
|
'animateColor',
|
|
'set'
|
|
]
|
|
},
|
|
tspan: {
|
|
attrsGroups: [
|
|
'conditionalProcessing',
|
|
'core',
|
|
'graphicalEvent',
|
|
'presentation'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'x',
|
|
'y',
|
|
'dx',
|
|
'dy',
|
|
'rotate',
|
|
'textLength',
|
|
'lengthAdjust'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
],
|
|
content: [
|
|
'a',
|
|
'altGlyph',
|
|
'animate',
|
|
'animateColor',
|
|
'set',
|
|
'tref',
|
|
'tspan'
|
|
]
|
|
},
|
|
use: {
|
|
attrsGroups: [
|
|
'core',
|
|
'conditionalProcessing',
|
|
'graphicalEvent',
|
|
'presentation',
|
|
'xlink'
|
|
],
|
|
attrs: [
|
|
'class',
|
|
'style',
|
|
'externalResourcesRequired',
|
|
'transform',
|
|
'x',
|
|
'y',
|
|
'width',
|
|
'height',
|
|
'href',
|
|
'xlink:href'
|
|
],
|
|
defaults: {
|
|
x: '0',
|
|
y: '0'
|
|
},
|
|
contentGroups: [
|
|
'animation',
|
|
'descriptive'
|
|
]
|
|
},
|
|
view: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'externalResourcesRequired',
|
|
'viewBox',
|
|
'preserveAspectRatio',
|
|
'zoomAndPan',
|
|
'viewTarget'
|
|
],
|
|
contentGroups: [
|
|
'descriptive'
|
|
]
|
|
},
|
|
vkern: {
|
|
attrsGroups: [
|
|
'core'
|
|
],
|
|
attrs: [
|
|
'u1',
|
|
'g1',
|
|
'u2',
|
|
'g2',
|
|
'k'
|
|
]
|
|
}
|
|
};
|
|
|
|
// http://wiki.inkscape.org/wiki/index.php/Inkscape-specific_XML_attributes
|
|
exports.editorNamespaces = [
|
|
'http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd',
|
|
'http://inkscape.sourceforge.net/DTD/sodipodi-0.dtd',
|
|
'http://www.inkscape.org/namespaces/inkscape',
|
|
'http://www.bohemiancoding.com/sketch/ns',
|
|
'http://ns.adobe.com/AdobeIllustrator/10.0/',
|
|
'http://ns.adobe.com/Graphs/1.0/',
|
|
'http://ns.adobe.com/AdobeSVGViewerExtensions/3.0/',
|
|
'http://ns.adobe.com/Variables/1.0/',
|
|
'http://ns.adobe.com/SaveForWeb/1.0/',
|
|
'http://ns.adobe.com/Extensibility/1.0/',
|
|
'http://ns.adobe.com/Flows/1.0/',
|
|
'http://ns.adobe.com/ImageReplacement/1.0/',
|
|
'http://ns.adobe.com/GenericCustomNamespace/1.0/',
|
|
'http://ns.adobe.com/XPath/1.0/',
|
|
'http://schemas.microsoft.com/visio/2003/SVGExtensions/',
|
|
'http://taptrix.com/vectorillustrator/svg_extensions',
|
|
'http://www.figma.com/figma/ns',
|
|
'http://purl.org/dc/elements/1.1/',
|
|
'http://creativecommons.org/ns#',
|
|
'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
|
'http://www.serif.com/',
|
|
'http://www.vector.evaxdesign.sk'
|
|
];
|
|
|
|
// http://www.w3.org/TR/SVG11/linking.html#processingIRI
|
|
exports.referencesProps = [
|
|
'clip-path',
|
|
'color-profile',
|
|
'fill',
|
|
'filter',
|
|
'marker-start',
|
|
'marker-mid',
|
|
'marker-end',
|
|
'mask',
|
|
'stroke',
|
|
'style'
|
|
];
|
|
|
|
// http://www.w3.org/TR/SVG11/propidx.html
|
|
exports.inheritableAttrs = [
|
|
'clip-rule',
|
|
'color',
|
|
'color-interpolation',
|
|
'color-interpolation-filters',
|
|
'color-profile',
|
|
'color-rendering',
|
|
'cursor',
|
|
'direction',
|
|
'dominant-baseline',
|
|
'fill',
|
|
'fill-opacity',
|
|
'fill-rule',
|
|
'font',
|
|
'font-family',
|
|
'font-size',
|
|
'font-size-adjust',
|
|
'font-stretch',
|
|
'font-style',
|
|
'font-variant',
|
|
'font-weight',
|
|
'glyph-orientation-horizontal',
|
|
'glyph-orientation-vertical',
|
|
'image-rendering',
|
|
'letter-spacing',
|
|
'marker',
|
|
'marker-end',
|
|
'marker-mid',
|
|
'marker-start',
|
|
'paint-order',
|
|
'pointer-events',
|
|
'shape-rendering',
|
|
'stroke',
|
|
'stroke-dasharray',
|
|
'stroke-dashoffset',
|
|
'stroke-linecap',
|
|
'stroke-linejoin',
|
|
'stroke-miterlimit',
|
|
'stroke-opacity',
|
|
'stroke-width',
|
|
'text-anchor',
|
|
'text-rendering',
|
|
'transform',
|
|
'visibility',
|
|
'word-spacing',
|
|
'writing-mode'
|
|
];
|
|
|
|
exports.presentationNonInheritableGroupAttrs = [
|
|
'display',
|
|
'clip-path',
|
|
'filter',
|
|
'mask',
|
|
'opacity',
|
|
'text-decoration',
|
|
'transform',
|
|
'unicode-bidi',
|
|
'visibility'
|
|
];
|
|
|
|
// http://www.w3.org/TR/SVG11/single-page.html#types-ColorKeywords
|
|
exports.colorsNames = {
|
|
'aliceblue': '#f0f8ff',
|
|
'antiquewhite': '#faebd7',
|
|
'aqua': '#0ff',
|
|
'aquamarine': '#7fffd4',
|
|
'azure': '#f0ffff',
|
|
'beige': '#f5f5dc',
|
|
'bisque': '#ffe4c4',
|
|
'black': '#000',
|
|
'blanchedalmond': '#ffebcd',
|
|
'blue': '#00f',
|
|
'blueviolet': '#8a2be2',
|
|
'brown': '#a52a2a',
|
|
'burlywood': '#deb887',
|
|
'cadetblue': '#5f9ea0',
|
|
'chartreuse': '#7fff00',
|
|
'chocolate': '#d2691e',
|
|
'coral': '#ff7f50',
|
|
'cornflowerblue': '#6495ed',
|
|
'cornsilk': '#fff8dc',
|
|
'crimson': '#dc143c',
|
|
'cyan': '#0ff',
|
|
'darkblue': '#00008b',
|
|
'darkcyan': '#008b8b',
|
|
'darkgoldenrod': '#b8860b',
|
|
'darkgray': '#a9a9a9',
|
|
'darkgreen': '#006400',
|
|
'darkgrey': '#a9a9a9',
|
|
'darkkhaki': '#bdb76b',
|
|
'darkmagenta': '#8b008b',
|
|
'darkolivegreen': '#556b2f',
|
|
'darkorange': '#ff8c00',
|
|
'darkorchid': '#9932cc',
|
|
'darkred': '#8b0000',
|
|
'darksalmon': '#e9967a',
|
|
'darkseagreen': '#8fbc8f',
|
|
'darkslateblue': '#483d8b',
|
|
'darkslategray': '#2f4f4f',
|
|
'darkslategrey': '#2f4f4f',
|
|
'darkturquoise': '#00ced1',
|
|
'darkviolet': '#9400d3',
|
|
'deeppink': '#ff1493',
|
|
'deepskyblue': '#00bfff',
|
|
'dimgray': '#696969',
|
|
'dimgrey': '#696969',
|
|
'dodgerblue': '#1e90ff',
|
|
'firebrick': '#b22222',
|
|
'floralwhite': '#fffaf0',
|
|
'forestgreen': '#228b22',
|
|
'fuchsia': '#f0f',
|
|
'gainsboro': '#dcdcdc',
|
|
'ghostwhite': '#f8f8ff',
|
|
'gold': '#ffd700',
|
|
'goldenrod': '#daa520',
|
|
'gray': '#808080',
|
|
'green': '#008000',
|
|
'greenyellow': '#adff2f',
|
|
'grey': '#808080',
|
|
'honeydew': '#f0fff0',
|
|
'hotpink': '#ff69b4',
|
|
'indianred': '#cd5c5c',
|
|
'indigo': '#4b0082',
|
|
'ivory': '#fffff0',
|
|
'khaki': '#f0e68c',
|
|
'lavender': '#e6e6fa',
|
|
'lavenderblush': '#fff0f5',
|
|
'lawngreen': '#7cfc00',
|
|
'lemonchiffon': '#fffacd',
|
|
'lightblue': '#add8e6',
|
|
'lightcoral': '#f08080',
|
|
'lightcyan': '#e0ffff',
|
|
'lightgoldenrodyellow': '#fafad2',
|
|
'lightgray': '#d3d3d3',
|
|
'lightgreen': '#90ee90',
|
|
'lightgrey': '#d3d3d3',
|
|
'lightpink': '#ffb6c1',
|
|
'lightsalmon': '#ffa07a',
|
|
'lightseagreen': '#20b2aa',
|
|
'lightskyblue': '#87cefa',
|
|
'lightslategray': '#789',
|
|
'lightslategrey': '#789',
|
|
'lightsteelblue': '#b0c4de',
|
|
'lightyellow': '#ffffe0',
|
|
'lime': '#0f0',
|
|
'limegreen': '#32cd32',
|
|
'linen': '#faf0e6',
|
|
'magenta': '#f0f',
|
|
'maroon': '#800000',
|
|
'mediumaquamarine': '#66cdaa',
|
|
'mediumblue': '#0000cd',
|
|
'mediumorchid': '#ba55d3',
|
|
'mediumpurple': '#9370db',
|
|
'mediumseagreen': '#3cb371',
|
|
'mediumslateblue': '#7b68ee',
|
|
'mediumspringgreen': '#00fa9a',
|
|
'mediumturquoise': '#48d1cc',
|
|
'mediumvioletred': '#c71585',
|
|
'midnightblue': '#191970',
|
|
'mintcream': '#f5fffa',
|
|
'mistyrose': '#ffe4e1',
|
|
'moccasin': '#ffe4b5',
|
|
'navajowhite': '#ffdead',
|
|
'navy': '#000080',
|
|
'oldlace': '#fdf5e6',
|
|
'olive': '#808000',
|
|
'olivedrab': '#6b8e23',
|
|
'orange': '#ffa500',
|
|
'orangered': '#ff4500',
|
|
'orchid': '#da70d6',
|
|
'palegoldenrod': '#eee8aa',
|
|
'palegreen': '#98fb98',
|
|
'paleturquoise': '#afeeee',
|
|
'palevioletred': '#db7093',
|
|
'papayawhip': '#ffefd5',
|
|
'peachpuff': '#ffdab9',
|
|
'peru': '#cd853f',
|
|
'pink': '#ffc0cb',
|
|
'plum': '#dda0dd',
|
|
'powderblue': '#b0e0e6',
|
|
'purple': '#800080',
|
|
'rebeccapurple': '#639',
|
|
'red': '#f00',
|
|
'rosybrown': '#bc8f8f',
|
|
'royalblue': '#4169e1',
|
|
'saddlebrown': '#8b4513',
|
|
'salmon': '#fa8072',
|
|
'sandybrown': '#f4a460',
|
|
'seagreen': '#2e8b57',
|
|
'seashell': '#fff5ee',
|
|
'sienna': '#a0522d',
|
|
'silver': '#c0c0c0',
|
|
'skyblue': '#87ceeb',
|
|
'slateblue': '#6a5acd',
|
|
'slategray': '#708090',
|
|
'slategrey': '#708090',
|
|
'snow': '#fffafa',
|
|
'springgreen': '#00ff7f',
|
|
'steelblue': '#4682b4',
|
|
'tan': '#d2b48c',
|
|
'teal': '#008080',
|
|
'thistle': '#d8bfd8',
|
|
'tomato': '#ff6347',
|
|
'turquoise': '#40e0d0',
|
|
'violet': '#ee82ee',
|
|
'wheat': '#f5deb3',
|
|
'white': '#fff',
|
|
'whitesmoke': '#f5f5f5',
|
|
'yellow': '#ff0',
|
|
'yellowgreen': '#9acd32'
|
|
};
|
|
|
|
exports.colorsShortNames = {
|
|
'#f0ffff': 'azure',
|
|
'#f5f5dc': 'beige',
|
|
'#ffe4c4': 'bisque',
|
|
'#a52a2a': 'brown',
|
|
'#ff7f50': 'coral',
|
|
'#ffd700': 'gold',
|
|
'#808080': 'gray',
|
|
'#008000': 'green',
|
|
'#4b0082': 'indigo',
|
|
'#fffff0': 'ivory',
|
|
'#f0e68c': 'khaki',
|
|
'#faf0e6': 'linen',
|
|
'#800000': 'maroon',
|
|
'#000080': 'navy',
|
|
'#808000': 'olive',
|
|
'#ffa500': 'orange',
|
|
'#da70d6': 'orchid',
|
|
'#cd853f': 'peru',
|
|
'#ffc0cb': 'pink',
|
|
'#dda0dd': 'plum',
|
|
'#800080': 'purple',
|
|
'#f00': 'red',
|
|
'#ff0000': 'red',
|
|
'#fa8072': 'salmon',
|
|
'#a0522d': 'sienna',
|
|
'#c0c0c0': 'silver',
|
|
'#fffafa': 'snow',
|
|
'#d2b48c': 'tan',
|
|
'#008080': 'teal',
|
|
'#ff6347': 'tomato',
|
|
'#ee82ee': 'violet',
|
|
'#f5deb3': 'wheat'
|
|
};
|
|
|
|
// http://www.w3.org/TR/SVG11/single-page.html#types-DataTypeColor
|
|
exports.colorsProps = [
|
|
'color', 'fill', 'stroke', 'stop-color', 'flood-color', 'lighting-color'
|
|
];
|