svg-path-commander 2.0.10 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/.eslintrc.cjs +1 -0
  2. package/README.md +4 -4
  3. package/dist/svg-path-commander.cjs +1 -1
  4. package/dist/svg-path-commander.cjs.map +1 -1
  5. package/dist/svg-path-commander.d.ts +137 -30
  6. package/dist/svg-path-commander.js +1 -1
  7. package/dist/svg-path-commander.js.map +1 -1
  8. package/dist/svg-path-commander.mjs +868 -698
  9. package/dist/svg-path-commander.mjs.map +1 -1
  10. package/package.json +20 -22
  11. package/src/convert/pathToAbsolute.ts +1 -1
  12. package/src/convert/pathToCurve.ts +1 -1
  13. package/src/convert/pathToRelative.ts +1 -1
  14. package/src/index.ts +30 -26
  15. package/src/interface.ts +32 -32
  16. package/src/math/arcTools.ts +217 -0
  17. package/src/math/bezier.ts +261 -0
  18. package/src/math/cubicTools.ts +81 -0
  19. package/src/math/lineTools.ts +52 -0
  20. package/src/math/quadTools.ts +79 -0
  21. package/src/parser/isMoveCommand.ts +17 -0
  22. package/src/parser/parsePathString.ts +1 -1
  23. package/src/parser/scanSegment.ts +12 -3
  24. package/src/process/normalizePath.ts +1 -1
  25. package/src/process/replaceArc.ts +52 -0
  26. package/src/process/splitPath.ts +1 -1
  27. package/src/process/transformPath.ts +14 -34
  28. package/src/types.ts +5 -0
  29. package/src/util/distanceEpsilon.ts +3 -0
  30. package/src/util/getClosestPoint.ts +1 -1
  31. package/src/util/getPathBBox.ts +4 -3
  32. package/src/util/getPointAtLength.ts +3 -3
  33. package/src/util/getPropertiesAtLength.ts +2 -1
  34. package/src/util/getPropertiesAtPoint.ts +4 -1
  35. package/src/util/getTotalLength.ts +2 -2
  36. package/src/util/isPointInStroke.ts +2 -1
  37. package/src/util/pathFactory.ts +130 -0
  38. package/src/util/shapeToPathArray.ts +8 -4
  39. package/test/class.test.ts +501 -0
  40. package/test/fixtures/getMarkup.ts +17 -0
  41. package/{cypress → test}/fixtures/shapes.js +18 -18
  42. package/{cypress → test}/fixtures/simpleShapes.js +6 -6
  43. package/test/static.test.ts +304 -0
  44. package/tsconfig.json +9 -4
  45. package/{vite.config.ts → vite.config.mts} +10 -1
  46. package/vitest.config-ui.mts +26 -0
  47. package/vitest.config.mts +26 -0
  48. package/cypress/e2e/svg-path-commander.spec.ts +0 -868
  49. package/cypress/plugins/esbuild-istanbul.ts +0 -50
  50. package/cypress/plugins/tsCompile.ts +0 -34
  51. package/cypress/support/commands.ts +0 -37
  52. package/cypress/support/e2e.ts +0 -21
  53. package/cypress/test.html +0 -36
  54. package/src/util/pathLengthFactory.ts +0 -114
  55. package/src/util/segmentArcFactory.ts +0 -219
  56. package/src/util/segmentCubicFactory.ts +0 -114
  57. package/src/util/segmentLineFactory.ts +0 -45
  58. package/src/util/segmentQuadFactory.ts +0 -109
  59. /package/{cypress/fixtures/shapeObjects.js → test/fixtures/shapeObjects.ts} +0 -0
@@ -1,49 +1,49 @@
1
1
  import CSSMatrix$1 from '@thednp/dommatrix';
2
2
 
3
- export interface SegmentProperties {
3
+ export type SegmentProperties = {
4
4
  segment: PathSegment;
5
5
  index: number;
6
6
  length: number;
7
7
  lengthAtSegment: number;
8
8
  [key: string]: any;
9
- }
10
- export interface PointProperties {
9
+ };
10
+ export type PointProperties = {
11
11
  closest: {
12
12
  x: number;
13
13
  y: number;
14
14
  };
15
15
  distance: number;
16
16
  segment?: SegmentProperties;
17
- }
18
- export interface LineAttr {
17
+ };
18
+ export type LineAttr = {
19
19
  type: "line";
20
20
  x1: number;
21
21
  y1: number;
22
22
  x2: number;
23
23
  y2: number;
24
24
  [key: string]: string | number;
25
- }
26
- export interface PolyAttr {
25
+ };
26
+ export type PolyAttr = {
27
27
  type: "polygon" | "polyline";
28
28
  points: string;
29
29
  [key: string]: string | number;
30
- }
31
- export interface CircleAttr {
30
+ };
31
+ export type CircleAttr = {
32
32
  type: "circle";
33
33
  cx: number;
34
34
  cy: number;
35
35
  r: number;
36
36
  [key: string]: string | number;
37
- }
38
- export interface EllipseAttr {
37
+ };
38
+ export type EllipseAttr = {
39
39
  type: "ellipse";
40
40
  cx: number;
41
41
  cy: number;
42
42
  rx: number;
43
43
  ry?: number;
44
44
  [key: string]: string | number | undefined;
45
- }
46
- export interface RectAttr {
45
+ };
46
+ export type RectAttr = {
47
47
  type: "rect";
48
48
  width: number;
49
49
  height: number;
@@ -52,13 +52,49 @@ export interface RectAttr {
52
52
  rx?: number;
53
53
  ry?: number;
54
54
  [key: string]: string | number | undefined;
55
- }
56
- export interface GlyphAttr {
55
+ };
56
+ export type GlyphAttr = {
57
57
  type: "glyph";
58
58
  d: string;
59
59
  [key: string]: string | number;
60
- }
61
- export interface PathBBox {
60
+ };
61
+ export type ShapeParams = {
62
+ line: [
63
+ "x1",
64
+ "y1",
65
+ "x2",
66
+ "y2"
67
+ ];
68
+ circle: [
69
+ "cx",
70
+ "cy",
71
+ "r"
72
+ ];
73
+ ellipse: [
74
+ "cx",
75
+ "cy",
76
+ "rx",
77
+ "ry"
78
+ ];
79
+ rect: [
80
+ "width",
81
+ "height",
82
+ "x",
83
+ "y",
84
+ "rx",
85
+ "ry"
86
+ ];
87
+ polygon: [
88
+ "points"
89
+ ];
90
+ polyline: [
91
+ "points"
92
+ ];
93
+ glyph: [
94
+ "d"
95
+ ];
96
+ };
97
+ export type PathBBox = {
62
98
  width: number;
63
99
  height: number;
64
100
  x: number;
@@ -68,8 +104,28 @@ export interface PathBBox {
68
104
  cx: number;
69
105
  cy: number;
70
106
  cz: number;
71
- }
72
- export interface LengthFactory {
107
+ };
108
+ export type SegmentLimits = {
109
+ min: {
110
+ x: number;
111
+ y: number;
112
+ };
113
+ max: {
114
+ x: number;
115
+ y: number;
116
+ };
117
+ };
118
+ export type ParserParams = {
119
+ x1: number;
120
+ y1: number;
121
+ x2: number;
122
+ y2: number;
123
+ x: number;
124
+ y: number;
125
+ qx: number | null;
126
+ qy: number | null;
127
+ };
128
+ export type LengthFactory = {
73
129
  length: number;
74
130
  point: {
75
131
  x: number;
@@ -83,18 +139,32 @@ export interface LengthFactory {
83
139
  x: number;
84
140
  y: number;
85
141
  };
86
- }
87
- export interface Options {
142
+ };
143
+ export type Options = {
88
144
  round: "auto" | "off" | number;
89
145
  origin: number[];
90
- }
91
- export interface TransformObject {
146
+ };
147
+ export type PathTransform = {
148
+ s: PathSegment;
149
+ c: string;
150
+ x: number;
151
+ y: number;
152
+ };
153
+ export type TransformObject = {
92
154
  translate: number | number[];
93
155
  rotate: number | number[];
94
156
  scale: number | number[];
95
157
  skew: number | number[];
96
158
  origin: number[];
97
- }
159
+ };
160
+ export type TransformProps = keyof TransformObject;
161
+ export type TransformEntries = [
162
+ TransformProps,
163
+ TransformObject[TransformProps]
164
+ ][];
165
+ export type SpaceNumber = 5760 | 6158 | 8192 | 8193 | 8194 | 8195 | 8196 | 8197 | 8198 | 8199 | 8200 | 8201 | 8202 | 8239 | 8287 | 12288 | 65279 | 10 | 13 | 8232 | 8233 | 32 | 9 | 11 | 12 | 160 | 5760;
166
+ export type PathCommandNumber = 109 | 122 | 108 | 104 | 118 | 99 | 115 | 113 | 116 | 97;
167
+ export type DigitNumber = 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57;
98
168
  export type MCommand = "M";
99
169
  export type mCommand = "m";
100
170
  export type LCommand = "L";
@@ -115,6 +185,9 @@ export type TCommand = "T";
115
185
  export type tCommand = "t";
116
186
  export type ACommand = "A";
117
187
  export type aCommand = "a";
188
+ export type AbsoluteCommand = MCommand | LCommand | VCommand | HCommand | ZCommand | CCommand | SCommand | QCommand | TCommand | ACommand;
189
+ export type RelativeCommand = mCommand | lCommand | vCommand | hCommand | zCommand | cCommand | sCommand | qCommand | tCommand | aCommand;
190
+ export type PathCommand = AbsoluteCommand | RelativeCommand;
118
191
  export type MSegment = [
119
192
  MCommand,
120
193
  number,
@@ -244,6 +317,7 @@ export type aSegment = [
244
317
  ];
245
318
  export type ArcSegment = ASegment | aSegment;
246
319
  export type PathSegment = MoveSegment | LineSegment | VertLineSegment | HorLineSegment | CloseSegment | CubicSegment | ShortCubicSegment | QuadSegment | ShortQuadSegment | ArcSegment;
320
+ export type ShortSegment = VertLineSegment | HorLineSegment | ShortCubicSegment | ShortQuadSegment | CloseSegment;
247
321
  export type AbsoluteSegment = MSegment | LSegment | VSegment | HSegment | CSegment | SSegment | QSegment | TSegment | ASegment | ZSegment;
248
322
  export type RelativeSegment = mSegment | lSegment | vSegment | hSegment | cSegment | sSegment | qSegment | tSegment | aSegment | zSegment;
249
323
  export type NormalSegment = MSegment | LSegment | CSegment | QSegment | ASegment | ZSegment;
@@ -267,7 +341,17 @@ export type CurveArray = [
267
341
  MSegment,
268
342
  ...CSegment[]
269
343
  ];
344
+ export type PolygonArray = [
345
+ MSegment,
346
+ ...LSegment[],
347
+ ZSegment
348
+ ];
349
+ export type PolylineArray = [
350
+ MSegment,
351
+ ...LSegment[]
352
+ ];
270
353
  export type ShapeTypes = SVGPolylineElement | SVGPolygonElement | SVGLineElement | SVGEllipseElement | SVGCircleElement | SVGRectElement;
354
+ export type ShapeTags = "line" | "polyline" | "polygon" | "ellipse" | "circle" | "rect" | "glyph";
271
355
  export type ShapeOps = LineAttr | PolyAttr | PolyAttr | EllipseAttr | CircleAttr | RectAttr | GlyphAttr;
272
356
  export type TransformObjectValues = Partial<TransformObject> & {
273
357
  origin: [
@@ -276,6 +360,10 @@ export type TransformObjectValues = Partial<TransformObject> & {
276
360
  number
277
361
  ];
278
362
  };
363
+ export type Point = {
364
+ x: number;
365
+ y: number;
366
+ };
279
367
  /**
280
368
  * Creates a new SVGPathCommander instance with the following properties:
281
369
  * * segments: `pathArray`
@@ -284,12 +372,12 @@ export type TransformObjectValues = Partial<TransformObject> & {
284
372
  *
285
373
  * @class
286
374
  * @author thednp <https://github.com/thednp/svg-path-commander>
287
- * @returns {SVGPathCommander} a new SVGPathCommander instance
375
+ * @returns a new SVGPathCommander instance
288
376
  */
289
377
  declare class SVGPathCommander {
290
378
  static CSSMatrix: typeof CSSMatrix$1;
291
379
  static getSVGMatrix: (transform: TransformObjectValues) => CSSMatrix$1;
292
- static getPathBBox: (path?: PathArray | string) => PathBBox;
380
+ static getPathBBox: (path: PathArray | string) => PathBBox;
293
381
  static getPathArea: (path: PathArray) => number;
294
382
  static getTotalLength: (pathInput: string | PathArray) => number;
295
383
  static getDrawDirection: (path: string | PathArray) => boolean;
@@ -297,7 +385,23 @@ declare class SVGPathCommander {
297
385
  x: number;
298
386
  y: number;
299
387
  };
300
- static pathLengthFactory: (pathInput: string | PathArray, distance?: number) => LengthFactory;
388
+ static pathFactory: (pathInput: string | PathArray, distance?: number) => {
389
+ point: {
390
+ x: number;
391
+ y: number;
392
+ };
393
+ length: number;
394
+ readonly bbox: {
395
+ min: {
396
+ x: number;
397
+ y: number;
398
+ };
399
+ max: {
400
+ x: number;
401
+ y: number;
402
+ };
403
+ };
404
+ };
301
405
  static getPropertiesAtLength: (pathInput: string | PathArray, distance?: number) => SegmentProperties;
302
406
  static getPropertiesAtPoint: (pathInput: string | PathArray, point: {
303
407
  x: number;
@@ -334,7 +438,7 @@ declare class SVGPathCommander {
334
438
  static isCurveArray: (path: unknown) => path is CurveArray;
335
439
  static isNormalizedArray: (path: unknown) => path is NormalArray;
336
440
  static shapeToPath: (element: ShapeTypes | ShapeOps, replace?: boolean, ownerDocument?: Document) => SVGPathElement | false;
337
- static shapeToPathArray: (element: ShapeTypes | ShapeOps, ownerDocument?: Document) => PathArray | false;
441
+ static shapeToPathArray: (element: ShapeTypes | ShapeOps, ownerDocument?: Document) => false | PathArray;
338
442
  static parsePathString: (pathInput: string | PathArray) => PathArray;
339
443
  static roundPath: (path: PathArray, roundOption?: number | "off") => PathArray;
340
444
  static splitPath: (pathInput: PathArray) => PathArray[];
@@ -342,6 +446,7 @@ declare class SVGPathCommander {
342
446
  CubicSegment,
343
447
  CubicSegment
344
448
  ];
449
+ static replaceArc: (pathInput: PathArray | string) => PathArray;
345
450
  static optimizePath: (pathInput: PathArray, round: "off" | number) => PathArray;
346
451
  static reverseCurve: (path: CurveArray) => CurveArray;
347
452
  static reversePath: (pathInput: PathArray) => PathArray;
@@ -360,10 +465,12 @@ declare class SVGPathCommander {
360
465
  ];
361
466
  /**
362
467
  * @constructor
363
- * @param {string} pathValue the path string
364
- * @param {any} config instance options
468
+ * @param pathValue the path string
469
+ * @param config instance options
365
470
  */
366
471
  constructor(pathValue: string, config?: Partial<Options>);
472
+ get bbox(): PathBBox;
473
+ get length(): number;
367
474
  /**
368
475
  * Returns the path bounding box, equivalent to native `path.getBBox()`.
369
476
  *
@@ -1,2 +1,2 @@
1
- var SVGPathCommander=function(){"use strict";var je=Object.defineProperty;var ze=(k,P,$)=>P in k?je(k,P,{enumerable:!0,configurable:!0,writable:!0,value:$}):k[P]=$;var w=(k,P,$)=>ze(k,typeof P!="symbol"?P+"":P,$);const k={origin:[0,0,0],round:4},P="SVGPathCommander Error",$={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0},Ct=e=>{let t=e.pathValue[e.segmentStart],n=t.toLowerCase();const{data:r}=e;for(;r.length>=$[n]&&(n==="m"&&r.length>2?(e.segments.push([t,...r.splice(0,2)]),n="l",t=t==="m"?"l":"L"):e.segments.push([t,...r.splice(0,$[n])]),!!$[n]););},te=e=>{const{index:t,pathValue:n}=e,r=n.charCodeAt(t);if(r===48){e.param=0,e.index+=1;return}if(r===49){e.param=1,e.index+=1;return}e.err=`${P}: invalid Arc flag "${n[t]}", expecting 0 or 1 at index ${t}`},Z=e=>e>=48&&e<=57,X="Invalid path value",ee=e=>{const{max:t,pathValue:n,index:r}=e;let s=r,i=!1,o=!1,l=!1,a=!1,c;if(s>=t){e.err=`${P}: ${X} at index ${s}, "pathValue" is missing param`;return}if(c=n.charCodeAt(s),(c===43||c===45)&&(s+=1,c=n.charCodeAt(s)),!Z(c)&&c!==46){e.err=`${P}: ${X} at index ${s}, "${n[s]}" is not a number`;return}if(c!==46){if(i=c===48,s+=1,c=n.charCodeAt(s),i&&s<t&&c&&Z(c)){e.err=`${P}: ${X} at index ${r}, "${n[r]}" illegal number`;return}for(;s<t&&Z(n.charCodeAt(s));)s+=1,o=!0;c=n.charCodeAt(s)}if(c===46){for(a=!0,s+=1;Z(n.charCodeAt(s));)s+=1,l=!0;c=n.charCodeAt(s)}if(c===101||c===69){if(a&&!o&&!l){e.err=`${P}: ${X} at index ${s}, "${n[s]}" invalid float exponent`;return}if(s+=1,c=n.charCodeAt(s),(c===43||c===45)&&(s+=1),s<t&&Z(n.charCodeAt(s)))for(;s<t&&Z(n.charCodeAt(s));)s+=1;else{e.err=`${P}: ${X} at index ${s}, "${n[s]}" invalid integer exponent`;return}}e.index=s,e.param=+e.pathValue.slice(r,s)},ne=e=>[5760,6158,8192,8193,8194,8195,8196,8197,8198,8199,8200,8201,8202,8239,8287,12288,65279,10,13,8232,8233,32,9,11,12,160].includes(e),B=e=>{const{pathValue:t,max:n}=e;for(;e.index<n&&ne(t.charCodeAt(e.index));)e.index+=1},se=e=>{switch(e|32){case 109:case 122:case 108:case 104:case 118:case 99:case 115:case 113:case 116:case 97:return!0;default:return!1}},re=e=>Z(e)||e===43||e===45||e===46,ie=e=>(e|32)===97,Tt=e=>{const{max:t,pathValue:n,index:r}=e,s=n.charCodeAt(r),i=$[n[r].toLowerCase()];if(e.segmentStart=r,!se(s)){e.err=`${P}: ${X} "${n[r]}" is not a path command`;return}if(e.index+=1,B(e),e.data=[],!i){Ct(e);return}for(;;){for(let o=i;o>0;o-=1){if(ie(s)&&(o===3||o===4)?te(e):ee(e),e.err.length)return;e.data.push(e.param),B(e),e.index<t&&n.charCodeAt(e.index)===44&&(e.index+=1,B(e))}if(e.index>=e.max||!re(n.charCodeAt(e.index)))break}Ct(e)};class Lt{constructor(t){this.segments=[],this.pathValue=t,this.max=t.length,this.index=0,this.param=0,this.segmentStart=0,this.data=[],this.err=""}}const J=e=>Array.isArray(e)&&e.every(t=>{const n=t[0].toLowerCase();return $[n]===t.length-1&&"achlmqstvz".includes(n)&&t.slice(1).every(Number.isFinite)})&&e.length>0,F=e=>{if(J(e))return[...e];const t=new Lt(e);for(B(t);t.index<t.max&&!t.err.length;)Tt(t);if(t.err&&t.err.length)throw TypeError(t.err);return t.segments},oe=e=>{const t=e.length;let n=-1,r,s=e[t-1],i=0;for(;++n<t;)r=s,s=e[n],i+=r[1]*s[0]-r[0]*s[1];return i/2},V=(e,t)=>Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1])),ce=e=>e.reduce((t,n,r)=>r?t+V(e[r-1],n):0,0);var ae=Object.defineProperty,le=(e,t,n)=>t in e?ae(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,T=(e,t,n)=>le(e,typeof t!="symbol"?t+"":t,n);const me={a:1,b:0,c:0,d:1,e:0,f:0,m11:1,m12:0,m13:0,m14:0,m21:0,m22:1,m23:0,m24:0,m31:0,m32:0,m33:1,m34:0,m41:0,m42:0,m43:0,m44:1,is2D:!0,isIdentity:!0},St=e=>(e instanceof Float64Array||e instanceof Float32Array||Array.isArray(e)&&e.every(t=>typeof t=="number"))&&[6,16].some(t=>e.length===t),kt=e=>e instanceof DOMMatrix||e instanceof v||typeof e=="object"&&Object.keys(me).every(t=>e&&t in e),U=e=>{const t=new v,n=Array.from(e);if(!St(n))throw TypeError(`CSSMatrix: "${n.join(",")}" must be an array with 6/16 numbers.`);if(n.length===16){const[r,s,i,o,l,a,c,m,u,y,g,f,h,x,p,b]=n;t.m11=r,t.a=r,t.m21=l,t.c=l,t.m31=u,t.m41=h,t.e=h,t.m12=s,t.b=s,t.m22=a,t.d=a,t.m32=y,t.m42=x,t.f=x,t.m13=i,t.m23=c,t.m33=g,t.m43=p,t.m14=o,t.m24=m,t.m34=f,t.m44=b}else if(n.length===6){const[r,s,i,o,l,a]=n;t.m11=r,t.a=r,t.m12=s,t.b=s,t.m21=i,t.c=i,t.m22=o,t.d=o,t.m41=l,t.e=l,t.m42=a,t.f=a}return t},$t=e=>{if(kt(e))return U([e.m11,e.m12,e.m13,e.m14,e.m21,e.m22,e.m23,e.m24,e.m31,e.m32,e.m33,e.m34,e.m41,e.m42,e.m43,e.m44]);throw TypeError(`CSSMatrix: "${JSON.stringify(e)}" is not a DOMMatrix / CSSMatrix / JSON compatible object.`)},qt=e=>{if(typeof e!="string")throw TypeError(`CSSMatrix: "${JSON.stringify(e)}" is not a string.`);const t=String(e).replace(/\s/g,"");let n=new v;const r=`CSSMatrix: invalid transform string "${e}"`;return t.split(")").filter(s=>s).forEach(s=>{const[i,o]=s.split("(");if(!o)throw TypeError(r);const l=o.split(",").map(f=>f.includes("rad")?parseFloat(f)*(180/Math.PI):parseFloat(f)),[a,c,m,u]=l,y=[a,c,m],g=[a,c,m,u];if(i==="perspective"&&a&&[c,m].every(f=>f===void 0))n.m34=-1/a;else if(i.includes("matrix")&&[6,16].includes(l.length)&&l.every(f=>!Number.isNaN(+f))){const f=l.map(h=>Math.abs(h)<1e-6?0:h);n=n.multiply(U(f))}else if(i==="translate3d"&&y.every(f=>!Number.isNaN(+f)))n=n.translate(a,c,m);else if(i==="translate"&&a&&m===void 0)n=n.translate(a,c||0,0);else if(i==="rotate3d"&&g.every(f=>!Number.isNaN(+f))&&u)n=n.rotateAxisAngle(a,c,m,u);else if(i==="rotate"&&a&&[c,m].every(f=>f===void 0))n=n.rotate(0,0,a);else if(i==="scale3d"&&y.every(f=>!Number.isNaN(+f))&&y.some(f=>f!==1))n=n.scale(a,c,m);else if(i==="scale"&&!Number.isNaN(a)&&a!==1&&m===void 0){const f=Number.isNaN(+c)?a:c;n=n.scale(a,f,1)}else if(i==="skew"&&(a||!Number.isNaN(a)&&c)&&m===void 0)n=n.skew(a,c||0);else if(["translate","rotate","scale","skew"].some(f=>i.includes(f))&&/[XYZ]/.test(i)&&a&&[c,m].every(f=>f===void 0))if(i==="skewX"||i==="skewY")n=n[i](a);else{const f=i.replace(/[XYZ]/,""),h=i.replace(f,""),x=["X","Y","Z"].indexOf(h),p=f==="scale"?1:0,b=[x===0?a:p,x===1?a:p,x===2?a:p];n=n[f](...b)}else throw TypeError(r)}),n},gt=(e,t)=>t?[e.a,e.b,e.c,e.d,e.e,e.f]:[e.m11,e.m12,e.m13,e.m14,e.m21,e.m22,e.m23,e.m24,e.m31,e.m32,e.m33,e.m34,e.m41,e.m42,e.m43,e.m44],Ot=(e,t,n)=>{const r=new v;return r.m41=e,r.e=e,r.m42=t,r.f=t,r.m43=n,r},Et=(e,t,n)=>{const r=new v,s=Math.PI/180,i=e*s,o=t*s,l=n*s,a=Math.cos(i),c=-Math.sin(i),m=Math.cos(o),u=-Math.sin(o),y=Math.cos(l),g=-Math.sin(l),f=m*y,h=-m*g;r.m11=f,r.a=f,r.m12=h,r.b=h,r.m13=u;const x=c*u*y+a*g;r.m21=x,r.c=x;const p=a*y-c*u*g;return r.m22=p,r.d=p,r.m23=-c*m,r.m31=c*g-a*u*y,r.m32=c*y+a*u*g,r.m33=a*m,r},jt=(e,t,n,r)=>{const s=new v,i=Math.sqrt(e*e+t*t+n*n);if(i===0)return s;const o=e/i,l=t/i,a=n/i,c=r*(Math.PI/360),m=Math.sin(c),u=Math.cos(c),y=m*m,g=o*o,f=l*l,h=a*a,x=1-2*(f+h)*y;s.m11=x,s.a=x;const p=2*(o*l*y+a*m*u);s.m12=p,s.b=p,s.m13=2*(o*a*y-l*m*u);const b=2*(l*o*y-a*m*u);s.m21=b,s.c=b;const A=1-2*(h+g)*y;return s.m22=A,s.d=A,s.m23=2*(l*a*y+o*m*u),s.m31=2*(a*o*y+l*m*u),s.m32=2*(a*l*y-o*m*u),s.m33=1-2*(g+f)*y,s},zt=(e,t,n)=>{const r=new v;return r.m11=e,r.a=e,r.m22=t,r.d=t,r.m33=n,r},et=(e,t)=>{const n=new v;if(e){const r=e*Math.PI/180,s=Math.tan(r);n.m21=s,n.c=s}if(t){const r=t*Math.PI/180,s=Math.tan(r);n.m12=s,n.b=s}return n},It=e=>et(e,0),Dt=e=>et(0,e),O=(e,t)=>{const n=t.m11*e.m11+t.m12*e.m21+t.m13*e.m31+t.m14*e.m41,r=t.m11*e.m12+t.m12*e.m22+t.m13*e.m32+t.m14*e.m42,s=t.m11*e.m13+t.m12*e.m23+t.m13*e.m33+t.m14*e.m43,i=t.m11*e.m14+t.m12*e.m24+t.m13*e.m34+t.m14*e.m44,o=t.m21*e.m11+t.m22*e.m21+t.m23*e.m31+t.m24*e.m41,l=t.m21*e.m12+t.m22*e.m22+t.m23*e.m32+t.m24*e.m42,a=t.m21*e.m13+t.m22*e.m23+t.m23*e.m33+t.m24*e.m43,c=t.m21*e.m14+t.m22*e.m24+t.m23*e.m34+t.m24*e.m44,m=t.m31*e.m11+t.m32*e.m21+t.m33*e.m31+t.m34*e.m41,u=t.m31*e.m12+t.m32*e.m22+t.m33*e.m32+t.m34*e.m42,y=t.m31*e.m13+t.m32*e.m23+t.m33*e.m33+t.m34*e.m43,g=t.m31*e.m14+t.m32*e.m24+t.m33*e.m34+t.m34*e.m44,f=t.m41*e.m11+t.m42*e.m21+t.m43*e.m31+t.m44*e.m41,h=t.m41*e.m12+t.m42*e.m22+t.m43*e.m32+t.m44*e.m42,x=t.m41*e.m13+t.m42*e.m23+t.m43*e.m33+t.m44*e.m43,p=t.m41*e.m14+t.m42*e.m24+t.m43*e.m34+t.m44*e.m44;return U([n,r,s,i,o,l,a,c,m,u,y,g,f,h,x,p])};class v{constructor(t){return this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0,this.m11=1,this.m12=0,this.m13=0,this.m14=0,this.m21=0,this.m22=1,this.m23=0,this.m24=0,this.m31=0,this.m32=0,this.m33=1,this.m34=0,this.m41=0,this.m42=0,this.m43=0,this.m44=1,t?this.setMatrixValue(t):this}get isIdentity(){return this.m11===1&&this.m12===0&&this.m13===0&&this.m14===0&&this.m21===0&&this.m22===1&&this.m23===0&&this.m24===0&&this.m31===0&&this.m32===0&&this.m33===1&&this.m34===0&&this.m41===0&&this.m42===0&&this.m43===0&&this.m44===1}get is2D(){return this.m31===0&&this.m32===0&&this.m33===1&&this.m34===0&&this.m43===0&&this.m44===1}setMatrixValue(t){return typeof t=="string"&&t.length&&t!=="none"?qt(t):Array.isArray(t)||t instanceof Float64Array||t instanceof Float32Array?U(t):typeof t=="object"?$t(t):this}toFloat32Array(t){return Float32Array.from(gt(this,t))}toFloat64Array(t){return Float64Array.from(gt(this,t))}toString(){const{is2D:t}=this,n=this.toFloat64Array(t).join(", ");return`${t?"matrix":"matrix3d"}(${n})`}toJSON(){const{is2D:t,isIdentity:n}=this;return{...this,is2D:t,isIdentity:n}}multiply(t){return O(this,t)}translate(t,n,r){const s=t;let i=n,o=r;return typeof i>"u"&&(i=0),typeof o>"u"&&(o=0),O(this,Ot(s,i,o))}scale(t,n,r){const s=t;let i=n,o=r;return typeof i>"u"&&(i=t),typeof o>"u"&&(o=1),O(this,zt(s,i,o))}rotate(t,n,r){let s=t,i=n||0,o=r||0;return typeof t=="number"&&typeof n>"u"&&typeof r>"u"&&(o=s,s=0,i=0),O(this,Et(s,i,o))}rotateAxisAngle(t,n,r,s){if([t,n,r,s].some(i=>Number.isNaN(+i)))throw new TypeError("CSSMatrix: expecting 4 values");return O(this,jt(t,n,r,s))}skewX(t){return O(this,It(t))}skewY(t){return O(this,Dt(t))}skew(t,n){return O(this,et(t,n))}transformPoint(t){const n=this.m11*t.x+this.m21*t.y+this.m31*t.z+this.m41*t.w,r=this.m12*t.x+this.m22*t.y+this.m32*t.z+this.m42*t.w,s=this.m13*t.x+this.m23*t.y+this.m33*t.z+this.m43*t.w,i=this.m14*t.x+this.m24*t.y+this.m34*t.z+this.m44*t.w;return t instanceof DOMPoint?new DOMPoint(n,r,s,i):{x:n,y:r,z:s,w:i}}}T(v,"Translate",Ot),T(v,"Rotate",Et),T(v,"RotateAxisAngle",jt),T(v,"Scale",zt),T(v,"SkewX",It),T(v,"SkewY",Dt),T(v,"Skew",et),T(v,"Multiply",O),T(v,"fromArray",U),T(v,"fromMatrix",$t),T(v,"fromString",qt),T(v,"toArray",gt),T(v,"isCompatibleArray",St),T(v,"isCompatibleObject",kt);const xt=e=>J(e)&&e.every(([t])=>t===t.toUpperCase()),Q=e=>{if(xt(e))return[...e];const t=F(e);let n=0,r=0,s=0,i=0;return t.map(o=>{const l=o.slice(1).map(Number),[a]=o,c=a.toUpperCase();if(a==="M")return[n,r]=l,s=n,i=r,["M",n,r];let m=[];if(a!==c)if(c==="A")m=[c,l[0],l[1],l[2],l[3],l[4],l[5]+n,l[6]+r];else if(c==="V")m=[c,l[0]+r];else if(c==="H")m=[c,l[0]+n];else{const u=l.map((y,g)=>y+(g%2?r:n));m=[c,...u]}else m=[c,...l];return c==="Z"?(n=s,r=i):c==="H"?[,n]=m:c==="V"?[,r]=m:([n,r]=m.slice(-2),c==="M"&&(s=n,i=r)),m})},he=(e,t)=>{const[n]=e,{x1:r,y1:s,x2:i,y2:o}=t,l=e.slice(1).map(Number);let a=e;if("TQ".includes(n)||(t.qx=null,t.qy=null),n==="H")a=["L",e[1],s];else if(n==="V")a=["L",r,e[1]];else if(n==="S"){const c=r*2-i,m=s*2-o;t.x1=c,t.y1=m,a=["C",c,m,...l]}else if(n==="T"){const c=r*2-(t.qx?t.qx:0),m=s*2-(t.qy?t.qy:0);t.qx=c,t.qy=m,a=["Q",c,m,...l]}else if(n==="Q"){const[c,m]=l;t.qx=c,t.qy=m}return a},pt=e=>xt(e)&&e.every(([t])=>"ACLMQZ".includes(t)),nt={x1:0,y1:0,x2:0,y2:0,x:0,y:0,qx:null,qy:null},I=e=>{if(pt(e))return[...e];const t=Q(e),n={...nt},r=t.length;for(let s=0;s<r;s+=1){t[s],t[s]=he(t[s],n);const i=t[s],o=i.length;n.x1=+i[o-2],n.y1=+i[o-1],n.x2=+i[o-4]||n.x1,n.y2=+i[o-3]||n.y1}return t},E=(e,t,n)=>{const[r,s]=e,[i,o]=t;return[r+(i-r)*n,s+(o-s)*n]},bt=(e,t,n,r,s)=>{const i=V([e,t],[n,r]);let o={x:0,y:0};if(typeof s=="number")if(s<=0)o={x:e,y:t};else if(s>=i)o={x:n,y:r};else{const[l,a]=E([e,t],[n,r],s/i);o={x:l,y:a}}return{length:i,point:o,min:{x:Math.min(e,n),y:Math.min(t,r)},max:{x:Math.max(e,n),y:Math.max(t,r)}}},Zt=(e,t)=>{const{x:n,y:r}=e,{x:s,y:i}=t,o=n*s+r*i,l=Math.sqrt((n**2+r**2)*(s**2+i**2));return(n*i-r*s<0?-1:1)*Math.acos(o/l)},ue=(e,t,n,r,s,i,o,l,a,c)=>{const{abs:m,sin:u,cos:y,sqrt:g,PI:f}=Math;let h=m(n),x=m(r);const b=(s%360+360)%360*(f/180);if(e===l&&t===a)return{x:e,y:t};if(h===0||x===0)return bt(e,t,l,a,c).point;const A=(e-l)/2,d=(t-a)/2,M={x:y(b)*A+u(b)*d,y:-u(b)*A+y(b)*d},L=M.x**2/h**2+M.y**2/x**2;L>1&&(h*=g(L),x*=g(L));const D=h**2*x**2-h**2*M.y**2-x**2*M.x**2,_=h**2*M.y**2+x**2*M.x**2;let Y=D/_;Y=Y<0?0:Y;const ht=(i!==o?1:-1)*g(Y),q={x:ht*(h*M.y/x),y:ht*(-(x*M.x)/h)},ut={x:y(b)*q.x-u(b)*q.y+(e+l)/2,y:u(b)*q.x+y(b)*q.y+(t+a)/2},W={x:(M.x-q.x)/h,y:(M.y-q.y)/x},ft=Zt({x:1,y:0},W),yt={x:(-M.x-q.x)/h,y:(-M.y-q.y)/x};let j=Zt(W,yt);!o&&j>0?j-=2*f:o&&j<0&&(j+=2*f),j%=2*f;const z=ft+j*c,G=h*y(z),tt=x*u(z);return{x:y(b)*G-u(b)*tt+ut.x,y:u(b)*G+y(b)*tt+ut.y}},fe=(e,t,n,r,s,i,o,l,a,c)=>{const m=typeof c=="number";let u=e,y=t,g=0,f=[u,y,g],h=[u,y],x=0,p={x:0,y:0},b=[{x:u,y}];m&&c<=0&&(p={x:u,y});const A=300;for(let d=0;d<=A;d+=1){if(x=d/A,{x:u,y}=ue(e,t,n,r,s,i,o,l,a,x),b=[...b,{x:u,y}],g+=V(h,[u,y]),h=[u,y],m&&g>c&&c>f[2]){const M=(g-c)/(g-f[2]);p={x:h[0]*(1-M)+f[0]*M,y:h[1]*(1-M)+f[1]*M}}f=[u,y,g]}return m&&c>=g&&(p={x:l,y:a}),{length:g,point:p,min:{x:Math.min(...b.map(d=>d.x)),y:Math.min(...b.map(d=>d.y))},max:{x:Math.max(...b.map(d=>d.x)),y:Math.max(...b.map(d=>d.y))}}},ye=(e,t,n,r,s,i,o,l,a)=>{const c=1-a;return{x:c**3*e+3*c**2*a*n+3*c*a**2*s+a**3*o,y:c**3*t+3*c**2*a*r+3*c*a**2*i+a**3*l}},ge=(e,t,n,r,s,i,o,l,a)=>{const c=typeof a=="number";let m=e,u=t,y=0,g=[m,u,y],f=[m,u],h=0,x={x:0,y:0},p=[{x:m,y:u}];c&&a<=0&&(x={x:m,y:u});const b=300;for(let A=0;A<=b;A+=1){if(h=A/b,{x:m,y:u}=ye(e,t,n,r,s,i,o,l,h),p=[...p,{x:m,y:u}],y+=V(f,[m,u]),f=[m,u],c&&y>a&&a>g[2]){const d=(y-a)/(y-g[2]);x={x:f[0]*(1-d)+g[0]*d,y:f[1]*(1-d)+g[1]*d}}g=[m,u,y]}return c&&a>=y&&(x={x:o,y:l}),{length:y,point:x,min:{x:Math.min(...p.map(A=>A.x)),y:Math.min(...p.map(A=>A.y))},max:{x:Math.max(...p.map(A=>A.x)),y:Math.max(...p.map(A=>A.y))}}},xe=(e,t,n,r,s,i,o)=>{const l=1-o;return{x:l**2*e+2*l*o*n+o**2*s,y:l**2*t+2*l*o*r+o**2*i}},pe=(e,t,n,r,s,i,o)=>{const l=typeof o=="number";let a=e,c=t,m=0,u=[a,c,m],y=[a,c],g=0,f={x:0,y:0},h=[{x:a,y:c}];l&&o<=0&&(f={x:a,y:c});const x=300;for(let p=0;p<=x;p+=1){if(g=p/x,{x:a,y:c}=xe(e,t,n,r,s,i,g),h=[...h,{x:a,y:c}],m+=V(y,[a,c]),y=[a,c],l&&m>o&&o>u[2]){const b=(m-o)/(m-u[2]);f={x:y[0]*(1-b)+u[0]*b,y:y[1]*(1-b)+u[1]*b}}u=[a,c,m]}return l&&o>=m&&(f={x:s,y:i}),{length:m,point:f,min:{x:Math.min(...h.map(p=>p.x)),y:Math.min(...h.map(p=>p.y))},max:{x:Math.max(...h.map(p=>p.x)),y:Math.max(...h.map(p=>p.y))}}},st=(e,t)=>{const n=I(e),r=typeof t=="number";let s,i=[],o,l=0,a=0,c=0,m=0,u,y=[],g=[],f=0,h={x:0,y:0},x=h,p=h,b=h,A=0;for(let d=0,M=n.length;d<M;d+=1)u=n[d],[o]=u,s=o==="M",i=s?i:[l,a,...u.slice(1)],s?([,c,m]=u,h={x:c,y:m},x=h,f=0,r&&t<.001&&(b=h)):o==="L"?{length:f,min:h,max:x,point:p}=bt(...i,(t||0)-A):o==="A"?{length:f,min:h,max:x,point:p}=fe(...i,(t||0)-A):o==="C"?{length:f,min:h,max:x,point:p}=ge(...i,(t||0)-A):o==="Q"?{length:f,min:h,max:x,point:p}=pe(...i,(t||0)-A):o==="Z"&&(i=[l,a,c,m],{length:f,min:h,max:x,point:p}=bt(...i,(t||0)-A)),r&&A<t&&A+f>=t&&(b=p),g=[...g,x],y=[...y,h],A+=f,[l,a]=o!=="Z"?u.slice(-2):[c,m];return r&&t>=A&&(b={x:l,y:a}),{length:A,point:b,min:{x:Math.min(...y.map(d=>d.x)),y:Math.min(...y.map(d=>d.y))},max:{x:Math.max(...g.map(d=>d.x)),y:Math.max(...g.map(d=>d.y))}}},Ft=e=>{if(!e)return{x:0,y:0,width:0,height:0,x2:0,y2:0,cx:0,cy:0,cz:0};const{min:{x:t,y:n},max:{x:r,y:s}}=st(e),i=r-t,o=s-n;return{width:i,height:o,x:t,y:n,x2:r,y2:s,cx:t+i/2,cy:n+o/2,cz:Math.max(i,o)+Math.min(i,o)/2}},dt=(e,t,n)=>{if(e[n].length>7){e[n].shift();const r=e[n];let s=n;for(;r.length;)t[n]="A",e.splice(s+=1,0,["C",...r.splice(0,6)]);e.splice(n,1)}},Rt=e=>pt(e)&&e.every(([t])=>"MC".includes(t)),rt=(e,t,n)=>{const r=e*Math.cos(n)-t*Math.sin(n),s=e*Math.sin(n)+t*Math.cos(n);return{x:r,y:s}},Xt=(e,t,n,r,s,i,o,l,a,c)=>{let m=e,u=t,y=n,g=r,f=l,h=a;const x=Math.PI*120/180,p=Math.PI/180*(+s||0);let b=[],A,d,M,L,D;if(c)[d,M,L,D]=c;else{A=rt(m,u,-p),m=A.x,u=A.y,A=rt(f,h,-p),f=A.x,h=A.y;const C=(m-f)/2,S=(u-h)/2;let R=C*C/(y*y)+S*S/(g*g);R>1&&(R=Math.sqrt(R),y*=R,g*=R);const vt=y*y,Pt=g*g,Gt=(i===o?-1:1)*Math.sqrt(Math.abs((vt*Pt-vt*S*S-Pt*C*C)/(vt*S*S+Pt*C*C)));L=Gt*y*S/g+(m+f)/2,D=Gt*-g*C/y+(u+h)/2,d=Math.asin(((u-D)/g*10**9>>0)/10**9),M=Math.asin(((h-D)/g*10**9>>0)/10**9),d=m<L?Math.PI-d:d,M=f<L?Math.PI-M:M,d<0&&(d=Math.PI*2+d),M<0&&(M=Math.PI*2+M),o&&d>M&&(d-=Math.PI*2),!o&&M>d&&(M-=Math.PI*2)}let _=M-d;if(Math.abs(_)>x){const C=M,S=f,R=h;M=d+x*(o&&M>d?1:-1),f=L+y*Math.cos(M),h=D+g*Math.sin(M),b=Xt(f,h,y,g,s,0,o,S,R,[M,C,L,D])}_=M-d;const Y=Math.cos(d),ht=Math.sin(d),q=Math.cos(M),ut=Math.sin(M),W=Math.tan(_/4),ft=4/3*y*W,yt=4/3*g*W,j=[m,u],z=[m+ft*ht,u-yt*Y],G=[f+ft*ut,h-yt*q],tt=[f,h];if(z[0]=2*j[0]-z[0],z[1]=2*j[1]-z[1],c)return[...z,...G,...tt,...b];b=[...z,...G,...tt,...b];const wt=[];for(let C=0,S=b.length;C<S;C+=1)wt[C]=C%2?rt(b[C-1],b[C],p).y:rt(b[C],b[C+1],p).x;return wt},be=(e,t,n,r,s,i)=>{const o=.3333333333333333,l=2/3;return[o*e+l*n,o*t+l*r,o*s+l*n,o*i+l*r,s,i]},Qt=(e,t,n,r)=>{const s=E([e,t],[n,r],.3333333333333333),i=E([e,t],[n,r],2/3);return[...s,...i,n,r]},it=(e,t)=>{const[n]=e,r=e.slice(1).map(Number),[s,i]=r;let o;const{x1:l,y1:a,x:c,y:m}=t;return"TQ".includes(n)||(t.qx=null,t.qy=null),n==="M"?(t.x=s,t.y=i,e):n==="A"?(o=[l,a,...r],["C",...Xt(...o)]):n==="Q"?(t.qx=s,t.qy=i,o=[l,a,...r],["C",...be(...o)]):n==="L"?["C",...Qt(l,a,s,i)]:n==="Z"?["C",...Qt(l,a,c,m)]:e},ot=e=>{if(Rt(e))return[...e];const t=I(e),n={...nt},r=[];let s="",i=t.length;for(let o=0;o<i;o+=1){[s]=t[o],r[o]=s,t[o]=it(t[o],n),dt(t,r,o),i=t.length;const l=t[o],a=l.length;n.x1=+l[a-2],n.y1=+l[a-1],n.x2=+l[a-4]||n.x1,n.y2=+l[a-3]||n.y1}return t},de=(e,t,n,r,s,i,o,l)=>3*((l-t)*(n+s)-(o-e)*(r+i)+r*(e-s)-n*(t-i)+l*(s+e/3)-o*(i+t/3))/20,Ht=e=>{let t=0,n=0,r=0;return ot(e).map(s=>{switch(s[0]){case"M":return[,t,n]=s,0;default:return r=de(t,n,...s.slice(1)),[t,n]=s.slice(-2),r}}).reduce((s,i)=>s+i,0)},H=e=>st(e).length,Me=e=>Ht(ot(e))>=0,K=(e,t)=>st(e,t).point,Mt=(e,t)=>{const n=F(e);let r=[...n],s=H(r),i=r.length-1,o=0,l=0,a=n[0];const[c,m]=a.slice(-2),u={x:c,y:m};if(i<=0||!t||!Number.isFinite(t))return{segment:a,index:0,length:l,point:u,lengthAtSegment:o};if(t>=s)return r=n.slice(0,-1),o=H(r),l=s-o,{segment:n[i],index:i,length:l,lengthAtSegment:o};const y=[];for(;i>0;)a=r[i],r=r.slice(0,-1),o=H(r),l=s-o,s=o,y.push({segment:a,index:i,length:l,lengthAtSegment:o}),i-=1;return y.find(({lengthAtSegment:g})=>g<=t)},ct=(e,t)=>{const n=F(e),r=I(n),s=H(n),i=d=>{const M=d.x-t.x,L=d.y-t.y;return M*M+L*L};let o=8,l,a={x:0,y:0},c=0,m=0,u=1/0;for(let d=0;d<=s;d+=o)l=K(r,d),c=i(l),c<u&&(a=l,m=d,u=c);o/=2;let y,g,f=0,h=0,x=0,p=0;for(;o>.5;)f=m-o,y=K(r,f),x=i(y),h=m+o,g=K(r,h),p=i(g),f>=0&&x<u?(a=y,m=f,u=x):h<=s&&p<u?(a=g,m=h,u=p):o/=2;const b=Mt(n,m),A=Math.sqrt(u);return{closest:a,distance:A,segment:b}},Ae=(e,t)=>ct(e,t).closest,Ne=(e,t)=>ct(e,t).segment,we=(e,t)=>Mt(e,t).segment,ve=(e,t)=>{const{distance:n}=ct(e,t);return Math.abs(n)<.001},Yt=e=>{if(typeof e!="string"||!e.length)return!1;const t=new Lt(e);for(B(t);t.index<t.max&&!t.err.length;)Tt(t);return!t.err.length&&"mM".includes(t.segments[0][0])},Bt=e=>J(e)&&e.slice(1).every(([t])=>t===t.toLowerCase()),at={line:["x1","y1","x2","y2"],circle:["cx","cy","r"],ellipse:["cx","cy","rx","ry"],rect:["width","height","x","y","rx","ry"],polygon:["points"],polyline:["points"],glyph:["d"]},Pe=e=>{let{x1:t,y1:n,x2:r,y2:s}=e;return[t,n,r,s]=[t,n,r,s].map(i=>+i),[["M",t,n],["L",r,s]]},Ce=e=>{const t=[],n=(e.points||"").trim().split(/[\s|,]/).map(s=>+s);let r=0;for(;r<n.length;)t.push([r?"L":"M",n[r],n[r+1]]),r+=2;return e.type==="polygon"?[...t,["z"]]:t},Te=e=>{let{cx:t,cy:n,r}=e;return[t,n,r]=[t,n,r].map(s=>+s),[["M",t-r,n],["a",r,r,0,1,0,2*r,0],["a",r,r,0,1,0,-2*r,0]]},Le=e=>{let{cx:t,cy:n}=e,r=e.rx||0,s=e.ry||r;return[t,n,r,s]=[t,n,r,s].map(i=>+i),[["M",t-r,n],["a",r,s,0,1,0,2*r,0],["a",r,s,0,1,0,-2*r,0]]},Se=e=>{const t=+e.x||0,n=+e.y||0,r=+e.width,s=+e.height;let i=+(e.rx||0),o=+(e.ry||i);return i||o?(i*2>r&&(i-=(i*2-r)/2),o*2>s&&(o-=(o*2-s)/2),[["M",t+i,n],["h",r-i*2],["s",i,0,i,o],["v",s-o*2],["s",0,o,-i,o],["h",-r+i*2],["s",-i,0,-i,-o],["v",-s+o*2],["s",0,-o,i,-o]]):[["M",t,n],["h",r],["v",s],["H",t],["Z"]]},Jt=(e,t)=>{const r=(t||document).defaultView||window,s=Object.keys(at),i=e instanceof r.SVGElement,o=i?e.tagName:null;if(o&&[...s,"path"].every(u=>o!==u))throw TypeError(`${P}: "${o}" is not SVGElement`);const l=i?o:e.type,a=at[l],c={type:l};i?a.forEach(u=>{c[u]=e.getAttribute(u)}):Object.assign(c,e);let m=[];return l==="circle"?m=Te(c):l==="ellipse"?m=Le(c):["polyline","polygon"].includes(l)?m=Ce(c):l==="rect"?m=Se(c):l==="line"?m=Pe(c):["glyph","path"].includes(l)&&(m=F(i?e.getAttribute("d")||"":e.d||"")),J(m)&&m.length?m:!1},lt=(e,t)=>{let{round:n}=k;if(t==="off"||n==="off")return[...e];n=typeof t=="number"&&t>=0?t:n;const r=typeof n=="number"&&n>=1?10**n:1;return e.map(s=>{const i=s.slice(1).map(Number).map(o=>n?Math.round(o*r)/r:Math.round(o));return[s[0],...i]})},At=(e,t)=>lt(e,t).map(n=>n[0]+n.slice(1).join(" ")).join(""),ke=(e,t,n)=>{const r=n||document,s=r.defaultView||window,i=Object.keys(at),o=e instanceof s.SVGElement,l=o?e.tagName:null;if(l==="path")throw TypeError(`${P}: "${l}" is already SVGPathElement`);if(l&&i.every(h=>l!==h))throw TypeError(`${P}: "${l}" is not SVGElement`);const a=r.createElementNS("http://www.w3.org/2000/svg","path"),c=o?l:e.type,m=at[c],u={type:c},y=k.round,g=Jt(e,r),f=g&&g.length?At(g,y):"";return o?(m.forEach(h=>{u[h]=e.getAttribute(h)}),Object.values(e.attributes).forEach(({name:h,value:x})=>{m.includes(h)||a.setAttribute(h,x)})):(Object.assign(u,e),Object.keys(u).forEach(h=>{!m.includes(h)&&h!=="type"&&a.setAttribute(h.replace(/[A-Z]/g,x=>`-${x.toLowerCase()}`),u[h])})),Yt(f)?(a.setAttribute("d",f),t&&o&&(e.before(a,e),e.remove()),a):!1},Vt=e=>{const t=[];let n,r=-1;return e.forEach(s=>{s[0]==="M"?(n=[s],r+=1):n=[...n,s],t[r]=n}),t},Ut=e=>{let t=new v;const{origin:n}=e,[r,s]=n,{translate:i}=e,{rotate:o}=e,{skew:l}=e,{scale:a}=e;return Array.isArray(i)&&i.length>=2&&i.every(c=>!Number.isNaN(+c))&&i.some(c=>c!==0)?t=t.translate(...i):typeof i=="number"&&!Number.isNaN(i)&&(t=t.translate(i)),(o||l||a)&&(t=t.translate(r,s),Array.isArray(o)&&o.length>=2&&o.every(c=>!Number.isNaN(+c))&&o.some(c=>c!==0)?t=t.rotate(...o):typeof o=="number"&&!Number.isNaN(o)&&(t=t.rotate(o)),Array.isArray(l)&&l.length===2&&l.every(c=>!Number.isNaN(+c))&&l.some(c=>c!==0)?(t=l[0]?t.skewX(l[0]):t,t=l[1]?t.skewY(l[1]):t):typeof l=="number"&&!Number.isNaN(l)&&(t=t.skewX(l)),Array.isArray(a)&&a.length>=2&&a.every(c=>!Number.isNaN(+c))&&a.some(c=>c!==1)?t=t.scale(...a):typeof a=="number"&&!Number.isNaN(a)&&(t=t.scale(a)),t=t.translate(-r,-s)),t},Nt=e=>{if(Bt(e))return[...e];const t=F(e);let n=0,r=0,s=0,i=0;return t.map(o=>{const l=o.slice(1).map(Number),[a]=o,c=a.toLowerCase();if(a==="M")return[n,r]=l,s=n,i=r,["M",n,r];let m=[];if(a!==c)if(c==="a")m=[c,l[0],l[1],l[2],l[3],l[4],l[5]-n,l[6]-r];else if(c==="v")m=[c,l[0]-r];else if(c==="h")m=[c,l[0]-n];else{const y=l.map((g,f)=>g-(f%2?r:n));m=[c,...y]}else a==="m"&&(s=l[0]+n,i=l[1]+r),m=[c,...l];const u=m.length;return c==="z"?(n=s,r=i):c==="h"?n+=m[1]:c==="v"?r+=m[1]:(n+=m[u-2],r+=m[u-1]),m})},$e=(e,t,n,r)=>{const[s]=e,i=p=>Math.round(p*10**4)/10**4,o=e.slice(1).map(p=>+p),l=t.slice(1).map(p=>+p),{x1:a,y1:c,x2:m,y2:u,x:y,y:g}=n;let f=e;const[h,x]=l.slice(-2);if("TQ".includes(s)||(n.qx=null,n.qy=null),["V","H","S","T","Z"].includes(s))f=[s,...o];else if(s==="L")i(y)===i(h)?f=["V",x]:i(g)===i(x)&&(f=["H",h]);else if(s==="C"){const[p,b]=l;"CS".includes(r)&&(i(p)===i(a*2-m)&&i(b)===i(c*2-u)||i(a)===i(m*2-y)&&i(c)===i(u*2-g))&&(f=["S",...l.slice(-4)]),n.x1=p,n.y1=b}else if(s==="Q"){const[p,b]=l;n.qx=p,n.qy=b,"QT".includes(r)&&(i(p)===i(a*2-m)&&i(b)===i(c*2-u)||i(a)===i(m*2-y)&&i(c)===i(u*2-g))&&(f=["T",...l.slice(-2)])}return f},Kt=(e,t)=>{const n=Q(e),r=I(n),s={...nt},i=[],o=n.length;let l="",a="",c=0,m=0,u=0,y=0;for(let h=0;h<o;h+=1){[l]=n[h],i[h]=l,h&&(a=i[h-1]),n[h]=$e(n[h],r[h],s,a);const x=n[h],p=x.length;switch(s.x1=+x[p-2],s.y1=+x[p-1],s.x2=+x[p-4]||s.x1,s.y2=+x[p-3]||s.y1,l){case"Z":c=u,m=y;break;case"H":[,c]=x;break;case"V":[,m]=x;break;default:[c,m]=x.slice(-2).map(Number),l==="M"&&(u=c,y=m)}s.x=c,s.y=m}const g=lt(n,t),f=lt(Nt(n),t);return g.map((h,x)=>x?h.join("").length<f[x].join("").length?h:f[x]:h)},qe=e=>{const t=e.slice(1).map((n,r,s)=>r?[...s[r-1].slice(-2),...n.slice(1)]:[...e[0].slice(1),...n.slice(1)]).map(n=>n.map((r,s)=>n[n.length-s-2*(1-s%2)])).reverse();return[["M",...t[0].slice(0,2)],...t.map(n=>["C",...n.slice(2)])]},mt=e=>{const t=Q(e),n=t.slice(-1)[0][0]==="Z",r=I(t).map((s,i)=>{const[o,l]=s.slice(-2).map(Number);return{seg:t[i],n:s,c:t[i][0],x:o,y:l}}).map((s,i,o)=>{const l=s.seg,a=s.n,c=i&&o[i-1],m=o[i+1],u=s.c,y=o.length,g=i?o[i-1].x:o[y-1].x,f=i?o[i-1].y:o[y-1].y;let h=[];switch(u){case"M":h=n?["Z"]:[u,g,f];break;case"A":h=[u,...l.slice(1,-3),l[5]===1?0:1,g,f];break;case"C":m&&m.c==="S"?h=["S",l[1],l[2],g,f]:h=[u,l[3],l[4],l[1],l[2],g,f];break;case"S":c&&"CS".includes(c.c)&&(!m||m.c!=="S")?h=["C",a[3],a[4],a[1],a[2],g,f]:h=[u,a[1],a[2],g,f];break;case"Q":m&&m.c==="T"?h=["T",g,f]:h=[u,...l.slice(1,-2),g,f];break;case"T":c&&"QT".includes(c.c)&&(!m||m.c!=="T")?h=["Q",a[1],a[2],g,f]:h=[u,g,f];break;case"Z":h=["M",g,f];break;case"H":h=[u,g];break;case"V":h=[u,f];break;default:h=[u,...l.slice(1,-2),g,f]}return h});return n?r.reverse():[r[0],...r.slice(1).reverse()]},Oe=(e,t)=>{let n=v.Translate(...t.slice(0,-1));return[,,,n.m44]=t,n=e.multiply(n),[n.m41,n.m42,n.m43,n.m44]},_t=(e,t,n)=>{const[r,s,i]=n,[o,l,a]=Oe(e,[...t,0,1]),c=o-r,m=l-s,u=a-i;return[c*(Math.abs(i)/Math.abs(u)||1)+r,m*(Math.abs(i)/Math.abs(u)||1)+s]},Wt=(e,t)=>{let n=0,r=0,s,i,o,l,a,c;const m=Q(e),u=t&&Object.keys(t);if(!t||u&&!u.length)return[...m];const y=I(m);if(!t.origin){const{origin:M}=k;Object.assign(t,{origin:M})}const g=Ut(t),{origin:f}=t,h={...nt};let x=[],p=0,b="",A=[];const d=[];if(!g.isIdentity){for(s=0,o=m.length;s<o;s+=1){x=m[s],m[s]&&([b]=x),d[s]=b,b==="A"&&(x=it(y[s],h),m[s]=it(y[s],h),dt(m,d,s),y[s]=it(y[s],h),dt(y,d,s),o=Math.max(m.length,y.length)),x=y[s],p=x.length,h.x1=+x[p-2],h.y1=+x[p-1],h.x2=+x[p-4]||h.x1,h.y2=+x[p-3]||h.y1;const M={s:m[s],c:m[s][0],x:h.x1,y:h.y1};A=[...A,M]}return A.map(M=>{if(b=M.c,x=M.s,b==="L"||b==="H"||b==="V")return[a,c]=_t(g,[M.x,M.y],f),n!==a&&r!==c?x=["L",a,c]:r===c?x=["H",a]:n===a&&(x=["V",c]),n=a,r=c,x;for(i=1,l=x.length;i<l;i+=2)[n,r]=_t(g,[+x[i],+x[i+1]],f),x[i]=n,x[i+1]=r;return x})}return[...m]},Ee=e=>{const n=e.slice(0,2),r=e.slice(2,4),s=e.slice(4,6),i=e.slice(6,8),o=E(n,r,.5),l=E(r,s,.5),a=E(s,i,.5),c=E(o,l,.5),m=E(l,a,.5),u=E(c,m,.5);return[["C",...o,...c,...u],["C",...m,...a,...i]]};class N{constructor(t,n){const r=n||{},s=typeof t>"u";if(s||!t.length)throw TypeError(`${P}: "pathValue" is ${s?"undefined":"empty"}`);const i=F(t);this.segments=i;const{width:o,height:l,cx:a,cy:c,cz:m}=this.getBBox(),{round:u,origin:y}=r;let g;if(u==="auto"){const h=`${Math.floor(Math.max(o,l))}`.length;g=h>=4?0:4-h}else Number.isInteger(u)||u==="off"?g=u:g=k.round;let f;if(Array.isArray(y)&&y.length>=2){const[h,x,p]=y.map(Number);f=[Number.isNaN(h)?a:h,Number.isNaN(x)?c:x,Number.isNaN(p)?m:p]}else f=[a,c,m];return this.round=g,this.origin=f,this}getBBox(){return Ft(this.segments)}getTotalLength(){return H(this.segments)}getPointAtLength(t){return K(this.segments,t)}toAbsolute(){const{segments:t}=this;return this.segments=Q(t),this}toRelative(){const{segments:t}=this;return this.segments=Nt(t),this}toCurve(){const{segments:t}=this;return this.segments=ot(t),this}reverse(t){this.toAbsolute();const{segments:n}=this,r=Vt(n),s=r.length>1?r:!1,i=s?[...s].map((l,a)=>t?a?mt(l):[...l]:mt(l)):[...n];let o=[];return s?o=i.flat(1):o=t?n:mt(n),this.segments=[...o],this}normalize(){const{segments:t}=this;return this.segments=I(t),this}optimize(){const{segments:t}=this;return this.segments=Kt(t,this.round),this}transform(t){if(!t||typeof t!="object"||typeof t=="object"&&!["translate","rotate","skew","scale"].some(a=>a in t))return this;const{segments:n,origin:[r,s,i]}=this,o={};for(const[a,c]of Object.entries(t))a==="skew"&&Array.isArray(c)||(a==="rotate"||a==="translate"||a==="origin"||a==="scale")&&Array.isArray(c)?o[a]=c.map(Number):a!=="origin"&&typeof Number(c)=="number"&&(o[a]=Number(c));const{origin:l}=o;if(Array.isArray(l)&&l.length>=2){const[a,c,m]=l.map(Number);o.origin=[Number.isNaN(a)?r:a,Number.isNaN(c)?s:c,m||i]}else o.origin=[r,s,i];return this.segments=Wt(n,o),this}flipX(){return this.transform({rotate:[0,180,0]}),this}flipY(){return this.transform({rotate:[180,0,0]}),this}toString(){return At(this.segments,this.round)}}return w(N,"CSSMatrix",v),w(N,"getSVGMatrix",Ut),w(N,"getPathBBox",Ft),w(N,"getPathArea",Ht),w(N,"getTotalLength",H),w(N,"getDrawDirection",Me),w(N,"getPointAtLength",K),w(N,"pathLengthFactory",st),w(N,"getPropertiesAtLength",Mt),w(N,"getPropertiesAtPoint",ct),w(N,"polygonLength",ce),w(N,"polygonArea",oe),w(N,"getClosestPoint",Ae),w(N,"getSegmentOfPoint",Ne),w(N,"getSegmentAtLength",we),w(N,"isPointInStroke",ve),w(N,"isValidPath",Yt),w(N,"isPathArray",J),w(N,"isAbsoluteArray",xt),w(N,"isRelativeArray",Bt),w(N,"isCurveArray",Rt),w(N,"isNormalizedArray",pt),w(N,"shapeToPath",ke),w(N,"shapeToPathArray",Jt),w(N,"parsePathString",F),w(N,"roundPath",lt),w(N,"splitPath",Vt),w(N,"splitCubic",Ee),w(N,"optimizePath",Kt),w(N,"reverseCurve",qe),w(N,"reversePath",mt),w(N,"normalizePath",I),w(N,"transformPath",Wt),w(N,"pathToAbsolute",Q),w(N,"pathToRelative",Nt),w(N,"pathToCurve",ot),w(N,"pathToString",At),N}();
1
+ var SVGPathCommander=function(){"use strict";var Ue=Object.defineProperty;var Ve=(S,A,q)=>A in S?Ue(S,A,{enumerable:!0,configurable:!0,writable:!0,value:q}):S[A]=q;var N=(S,A,q)=>Ve(S,typeof A!="symbol"?A+"":A,q);const S={origin:[0,0,0],round:4},A="SVGPathCommander Error",q={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0},Tt=e=>{let t=e.pathValue[e.segmentStart],n=t.toLowerCase();const{data:s}=e;for(;s.length>=q[n]&&(n==="m"&&s.length>2?(e.segments.push([t,...s.splice(0,2)]),n="l",t=t==="m"?"l":"L"):e.segments.push([t,...s.splice(0,q[n])]),!!q[n]););},oe=e=>{const{index:t,pathValue:n}=e,s=n.charCodeAt(t);if(s===48){e.param=0,e.index+=1;return}if(s===49){e.param=1,e.index+=1;return}e.err=`${A}: invalid Arc flag "${n[t]}", expecting 0 or 1 at index ${t}`},X=e=>e>=48&&e<=57,Z="Invalid path value",ce=e=>{const{max:t,pathValue:n,index:s}=e;let r=s,i=!1,o=!1,c=!1,a=!1,l;if(r>=t){e.err=`${A}: ${Z} at index ${r}, "pathValue" is missing param`;return}if(l=n.charCodeAt(r),(l===43||l===45)&&(r+=1,l=n.charCodeAt(r)),!X(l)&&l!==46){e.err=`${A}: ${Z} at index ${r}, "${n[r]}" is not a number`;return}if(l!==46){if(i=l===48,r+=1,l=n.charCodeAt(r),i&&r<t&&l&&X(l)){e.err=`${A}: ${Z} at index ${s}, "${n[s]}" illegal number`;return}for(;r<t&&X(n.charCodeAt(r));)r+=1,o=!0;l=n.charCodeAt(r)}if(l===46){for(a=!0,r+=1;X(n.charCodeAt(r));)r+=1,c=!0;l=n.charCodeAt(r)}if(l===101||l===69){if(a&&!o&&!c){e.err=`${A}: ${Z} at index ${r}, "${n[r]}" invalid float exponent`;return}if(r+=1,l=n.charCodeAt(r),(l===43||l===45)&&(r+=1),r<t&&X(n.charCodeAt(r)))for(;r<t&&X(n.charCodeAt(r));)r+=1;else{e.err=`${A}: ${Z} at index ${r}, "${n[r]}" invalid integer exponent`;return}}e.index=r,e.param=+e.pathValue.slice(s,r)},le=e=>[5760,6158,8192,8193,8194,8195,8196,8197,8198,8199,8200,8201,8202,8239,8287,12288,65279,10,13,8232,8233,32,9,11,12,160].includes(e),_=e=>{const{pathValue:t,max:n}=e;for(;e.index<n&&le(t.charCodeAt(e.index));)e.index+=1},ae=e=>{switch(e|32){case 109:case 122:case 108:case 104:case 118:case 99:case 115:case 113:case 116:case 97:return!0;default:return!1}},me=e=>X(e)||e===43||e===45||e===46,he=e=>(e|32)===97,ue=e=>{switch(e|32){case 109:case 77:return!0;default:return!1}},Lt=e=>{var a;const{max:t,pathValue:n,index:s,segments:r}=e,i=n.charCodeAt(s),o=q[n[s].toLowerCase()];if(e.segmentStart=s,!ae(i)){e.err=`${A}: ${Z} "${n[s]}" is not a path command at index ${s}`;return}const c=r[r.length-1];if(!ue(i)&&((a=c==null?void 0:c[0])==null?void 0:a.toLocaleLowerCase())==="z"){e.err=`${A}: ${Z} "${n[s]}" is not a MoveTo path command at index ${s}`;return}if(e.index+=1,_(e),e.data=[],!o){Tt(e);return}for(;;){for(let l=o;l>0;l-=1){if(he(i)&&(l===3||l===4)?oe(e):ce(e),e.err.length)return;e.data.push(e.param),_(e),e.index<t&&n.charCodeAt(e.index)===44&&(e.index+=1,_(e))}if(e.index>=e.max||!me(n.charCodeAt(e.index)))break}Tt(e)};class $t{constructor(t){this.segments=[],this.pathValue=t,this.max=t.length,this.index=0,this.param=0,this.segmentStart=0,this.data=[],this.err=""}}const K=e=>Array.isArray(e)&&e.every(t=>{const n=t[0].toLowerCase();return q[n]===t.length-1&&"achlmqstvz".includes(n)&&t.slice(1).every(Number.isFinite)})&&e.length>0,Y=e=>{if(K(e))return e.slice(0);const t=new $t(e);for(_(t);t.index<t.max&&!t.err.length;)Lt(t);if(t.err&&t.err.length)throw TypeError(t.err);return t.segments},fe=e=>{const t=e.length;let n=-1,s,r=e[t-1],i=0;for(;++n<t;)s=r,r=e[n],i+=s[1]*r[0]-s[0]*r[1];return i/2},kt=(e,t)=>Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1])),ge=e=>e.reduce((t,n,s)=>s?t+kt(e[s-1],n):0,0);var ye=Object.defineProperty,xe=(e,t,n)=>t in e?ye(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,T=(e,t,n)=>xe(e,typeof t!="symbol"?t+"":t,n);const pe={a:1,b:0,c:0,d:1,e:0,f:0,m11:1,m12:0,m13:0,m14:0,m21:0,m22:1,m23:0,m24:0,m31:0,m32:0,m33:1,m34:0,m41:0,m42:0,m43:0,m44:1,is2D:!0,isIdentity:!0},St=e=>(e instanceof Float64Array||e instanceof Float32Array||Array.isArray(e)&&e.every(t=>typeof t=="number"))&&[6,16].some(t=>e.length===t),qt=e=>e instanceof DOMMatrix||e instanceof P||typeof e=="object"&&Object.keys(pe).every(t=>e&&t in e),U=e=>{const t=new P,n=Array.from(e);if(!St(n))throw TypeError(`CSSMatrix: "${n.join(",")}" must be an array with 6/16 numbers.`);if(n.length===16){const[s,r,i,o,c,a,l,m,u,y,x,f,h,g,p,b]=n;t.m11=s,t.a=s,t.m21=c,t.c=c,t.m31=u,t.m41=h,t.e=h,t.m12=r,t.b=r,t.m22=a,t.d=a,t.m32=y,t.m42=g,t.f=g,t.m13=i,t.m23=l,t.m33=x,t.m43=p,t.m14=o,t.m24=m,t.m34=f,t.m44=b}else if(n.length===6){const[s,r,i,o,c,a]=n;t.m11=s,t.a=s,t.m12=r,t.b=r,t.m21=i,t.c=i,t.m22=o,t.d=o,t.m41=c,t.e=c,t.m42=a,t.f=a}return t},Et=e=>{if(qt(e))return U([e.m11,e.m12,e.m13,e.m14,e.m21,e.m22,e.m23,e.m24,e.m31,e.m32,e.m33,e.m34,e.m41,e.m42,e.m43,e.m44]);throw TypeError(`CSSMatrix: "${JSON.stringify(e)}" is not a DOMMatrix / CSSMatrix / JSON compatible object.`)},zt=e=>{if(typeof e!="string")throw TypeError(`CSSMatrix: "${JSON.stringify(e)}" is not a string.`);const t=String(e).replace(/\s/g,"");let n=new P;const s=`CSSMatrix: invalid transform string "${e}"`;return t.split(")").filter(r=>r).forEach(r=>{const[i,o]=r.split("(");if(!o)throw TypeError(s);const c=o.split(",").map(f=>f.includes("rad")?parseFloat(f)*(180/Math.PI):parseFloat(f)),[a,l,m,u]=c,y=[a,l,m],x=[a,l,m,u];if(i==="perspective"&&a&&[l,m].every(f=>f===void 0))n.m34=-1/a;else if(i.includes("matrix")&&[6,16].includes(c.length)&&c.every(f=>!Number.isNaN(+f))){const f=c.map(h=>Math.abs(h)<1e-6?0:h);n=n.multiply(U(f))}else if(i==="translate3d"&&y.every(f=>!Number.isNaN(+f)))n=n.translate(a,l,m);else if(i==="translate"&&a&&m===void 0)n=n.translate(a,l||0,0);else if(i==="rotate3d"&&x.every(f=>!Number.isNaN(+f))&&u)n=n.rotateAxisAngle(a,l,m,u);else if(i==="rotate"&&a&&[l,m].every(f=>f===void 0))n=n.rotate(0,0,a);else if(i==="scale3d"&&y.every(f=>!Number.isNaN(+f))&&y.some(f=>f!==1))n=n.scale(a,l,m);else if(i==="scale"&&!Number.isNaN(a)&&a!==1&&m===void 0){const f=Number.isNaN(+l)?a:l;n=n.scale(a,f,1)}else if(i==="skew"&&(a||!Number.isNaN(a)&&l)&&m===void 0)n=n.skew(a,l||0);else if(["translate","rotate","scale","skew"].some(f=>i.includes(f))&&/[XYZ]/.test(i)&&a&&[l,m].every(f=>f===void 0))if(i==="skewX"||i==="skewY")n=n[i](a);else{const f=i.replace(/[XYZ]/,""),h=i.replace(f,""),g=["X","Y","Z"].indexOf(h),p=f==="scale"?1:0,b=[g===0?a:p,g===1?a:p,g===2?a:p];n=n[f](...b)}else throw TypeError(s)}),n},pt=(e,t)=>t?[e.a,e.b,e.c,e.d,e.e,e.f]:[e.m11,e.m12,e.m13,e.m14,e.m21,e.m22,e.m23,e.m24,e.m31,e.m32,e.m33,e.m34,e.m41,e.m42,e.m43,e.m44],Ot=(e,t,n)=>{const s=new P;return s.m41=e,s.e=e,s.m42=t,s.f=t,s.m43=n,s},jt=(e,t,n)=>{const s=new P,r=Math.PI/180,i=e*r,o=t*r,c=n*r,a=Math.cos(i),l=-Math.sin(i),m=Math.cos(o),u=-Math.sin(o),y=Math.cos(c),x=-Math.sin(c),f=m*y,h=-m*x;s.m11=f,s.a=f,s.m12=h,s.b=h,s.m13=u;const g=l*u*y+a*x;s.m21=g,s.c=g;const p=a*y-l*u*x;return s.m22=p,s.d=p,s.m23=-l*m,s.m31=l*x-a*u*y,s.m32=l*y+a*u*x,s.m33=a*m,s},It=(e,t,n,s)=>{const r=new P,i=Math.sqrt(e*e+t*t+n*n);if(i===0)return r;const o=e/i,c=t/i,a=n/i,l=s*(Math.PI/360),m=Math.sin(l),u=Math.cos(l),y=m*m,x=o*o,f=c*c,h=a*a,g=1-2*(f+h)*y;r.m11=g,r.a=g;const p=2*(o*c*y+a*m*u);r.m12=p,r.b=p,r.m13=2*(o*a*y-c*m*u);const b=2*(c*o*y-a*m*u);r.m21=b,r.c=b;const v=1-2*(h+x)*y;return r.m22=v,r.d=v,r.m23=2*(c*a*y+o*m*u),r.m31=2*(a*o*y+c*m*u),r.m32=2*(a*c*y-o*m*u),r.m33=1-2*(x+f)*y,r},Dt=(e,t,n)=>{const s=new P;return s.m11=e,s.a=e,s.m22=t,s.d=t,s.m33=n,s},st=(e,t)=>{const n=new P;if(e){const s=e*Math.PI/180,r=Math.tan(s);n.m21=r,n.c=r}if(t){const s=t*Math.PI/180,r=Math.tan(s);n.m12=r,n.b=r}return n},Rt=e=>st(e,0),Xt=e=>st(0,e),O=(e,t)=>{const n=t.m11*e.m11+t.m12*e.m21+t.m13*e.m31+t.m14*e.m41,s=t.m11*e.m12+t.m12*e.m22+t.m13*e.m32+t.m14*e.m42,r=t.m11*e.m13+t.m12*e.m23+t.m13*e.m33+t.m14*e.m43,i=t.m11*e.m14+t.m12*e.m24+t.m13*e.m34+t.m14*e.m44,o=t.m21*e.m11+t.m22*e.m21+t.m23*e.m31+t.m24*e.m41,c=t.m21*e.m12+t.m22*e.m22+t.m23*e.m32+t.m24*e.m42,a=t.m21*e.m13+t.m22*e.m23+t.m23*e.m33+t.m24*e.m43,l=t.m21*e.m14+t.m22*e.m24+t.m23*e.m34+t.m24*e.m44,m=t.m31*e.m11+t.m32*e.m21+t.m33*e.m31+t.m34*e.m41,u=t.m31*e.m12+t.m32*e.m22+t.m33*e.m32+t.m34*e.m42,y=t.m31*e.m13+t.m32*e.m23+t.m33*e.m33+t.m34*e.m43,x=t.m31*e.m14+t.m32*e.m24+t.m33*e.m34+t.m34*e.m44,f=t.m41*e.m11+t.m42*e.m21+t.m43*e.m31+t.m44*e.m41,h=t.m41*e.m12+t.m42*e.m22+t.m43*e.m32+t.m44*e.m42,g=t.m41*e.m13+t.m42*e.m23+t.m43*e.m33+t.m44*e.m43,p=t.m41*e.m14+t.m42*e.m24+t.m43*e.m34+t.m44*e.m44;return U([n,s,r,i,o,c,a,l,m,u,y,x,f,h,g,p])};class P{constructor(t){return this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0,this.m11=1,this.m12=0,this.m13=0,this.m14=0,this.m21=0,this.m22=1,this.m23=0,this.m24=0,this.m31=0,this.m32=0,this.m33=1,this.m34=0,this.m41=0,this.m42=0,this.m43=0,this.m44=1,t?this.setMatrixValue(t):this}get isIdentity(){return this.m11===1&&this.m12===0&&this.m13===0&&this.m14===0&&this.m21===0&&this.m22===1&&this.m23===0&&this.m24===0&&this.m31===0&&this.m32===0&&this.m33===1&&this.m34===0&&this.m41===0&&this.m42===0&&this.m43===0&&this.m44===1}get is2D(){return this.m31===0&&this.m32===0&&this.m33===1&&this.m34===0&&this.m43===0&&this.m44===1}setMatrixValue(t){return typeof t=="string"&&t.length&&t!=="none"?zt(t):Array.isArray(t)||t instanceof Float64Array||t instanceof Float32Array?U(t):typeof t=="object"?Et(t):this}toFloat32Array(t){return Float32Array.from(pt(this,t))}toFloat64Array(t){return Float64Array.from(pt(this,t))}toString(){const{is2D:t}=this,n=this.toFloat64Array(t).join(", ");return`${t?"matrix":"matrix3d"}(${n})`}toJSON(){const{is2D:t,isIdentity:n}=this;return{...this,is2D:t,isIdentity:n}}multiply(t){return O(this,t)}translate(t,n,s){const r=t;let i=n,o=s;return typeof i>"u"&&(i=0),typeof o>"u"&&(o=0),O(this,Ot(r,i,o))}scale(t,n,s){const r=t;let i=n,o=s;return typeof i>"u"&&(i=t),typeof o>"u"&&(o=1),O(this,Dt(r,i,o))}rotate(t,n,s){let r=t,i=n||0,o=s||0;return typeof t=="number"&&typeof n>"u"&&typeof s>"u"&&(o=r,r=0,i=0),O(this,jt(r,i,o))}rotateAxisAngle(t,n,s,r){if([t,n,s,r].some(i=>Number.isNaN(+i)))throw new TypeError("CSSMatrix: expecting 4 values");return O(this,It(t,n,s,r))}skewX(t){return O(this,Rt(t))}skewY(t){return O(this,Xt(t))}skew(t,n){return O(this,st(t,n))}transformPoint(t){const n=this.m11*t.x+this.m21*t.y+this.m31*t.z+this.m41*t.w,s=this.m12*t.x+this.m22*t.y+this.m32*t.z+this.m42*t.w,r=this.m13*t.x+this.m23*t.y+this.m33*t.z+this.m43*t.w,i=this.m14*t.x+this.m24*t.y+this.m34*t.z+this.m44*t.w;return t instanceof DOMPoint?new DOMPoint(n,s,r,i):{x:n,y:s,z:r,w:i}}}T(P,"Translate",Ot),T(P,"Rotate",jt),T(P,"RotateAxisAngle",It),T(P,"Scale",Dt),T(P,"SkewX",Rt),T(P,"SkewY",Xt),T(P,"Skew",st),T(P,"Multiply",O),T(P,"fromArray",U),T(P,"fromMatrix",Et),T(P,"fromString",zt),T(P,"toArray",pt),T(P,"isCompatibleArray",St),T(P,"isCompatibleObject",qt);const rt=e=>K(e)&&e.every(([t])=>t===t.toUpperCase()),H=e=>{if(rt(e))return e.slice(0);const t=Y(e);let n=0,s=0,r=0,i=0;return t.map(o=>{const c=o.slice(1).map(Number),[a]=o,l=a.toUpperCase();if(a==="M")return[n,s]=c,r=n,i=s,["M",n,s];let m=[];if(a!==l)if(l==="A")m=[l,c[0],c[1],c[2],c[3],c[4],c[5]+n,c[6]+s];else if(l==="V")m=[l,c[0]+s];else if(l==="H")m=[l,c[0]+n];else{const u=c.map((y,x)=>y+(x%2?s:n));m=[l,...u]}else m=[l,...c];return l==="Z"?(n=r,s=i):l==="H"?[,n]=m:l==="V"?[,s]=m:([n,s]=m.slice(-2),l==="M"&&(r=n,i=s)),m})},be=(e,t)=>{const[n]=e,{x1:s,y1:r,x2:i,y2:o}=t,c=e.slice(1).map(Number);let a=e;if("TQ".includes(n)||(t.qx=null,t.qy=null),n==="H")a=["L",e[1],r];else if(n==="V")a=["L",s,e[1]];else if(n==="S"){const l=s*2-i,m=r*2-o;t.x1=l,t.y1=m,a=["C",l,m,...c]}else if(n==="T"){const l=s*2-(t.qx?t.qx:0),m=r*2-(t.qy?t.qy:0);t.qx=l,t.qy=m,a=["Q",l,m,...c]}else if(n==="Q"){const[l,m]=c;t.qx=l,t.qy=m}return a},it=e=>rt(e)&&e.every(([t])=>"ACLMQZ".includes(t)),V={x1:0,y1:0,x2:0,y2:0,x:0,y:0,qx:null,qy:null},j=e=>{if(it(e))return e.slice(0);const t=H(e),n={...V},s=t.length;for(let r=0;r<s;r+=1){t[r],t[r]=be(t[r],n);const i=t[r],o=i.length;n.x1=+i[o-2],n.y1=+i[o-1],n.x2=+i[o-4]||n.x1,n.y2=+i[o-3]||n.y1}return t},I=(e,t,n)=>{const[s,r]=e,[i,o]=t;return[s+(i-s)*n,r+(o-r)*n]},bt=(e,t,n,s,r)=>{const{min:i,max:o}=Math;let c={x:0,y:0};const a=()=>kt([e,t],[n,s]);if(typeof r=="number"){const l=a();if(r<=0)c={x:e,y:t};else if(r>=l)c={x:n,y:s};else{const[m,u]=I([e,t],[n,s],r/l);c={x:m,y:u}}}return{point:c,get length(){return a()},get bbox(){return{min:{x:i(e,n),y:i(t,s)},max:{x:o(e,n),y:o(t,s)}}}}},de=(e,t,n)=>{const s=n/2,r=Math.sin(s),i=Math.cos(s),o=e**2*r**2,c=t**2*i**2,a=Math.sqrt(o+c)*n;return Math.abs(a)},Me=(e,t,n,s,r,i,o)=>{const{cos:c,sin:a,min:l,max:m}=Math,u=c(r),y=a(r),x=v=>e+n*c(v)*u-s*a(v)*y,f=v=>t+s*a(v)*u+n*c(v)*y,h=x(i),g=f(i),p=x(o),b=f(o);return{min:{x:l(h,p),y:l(g,b)},max:{x:m(h,p),y:m(g,b)}}},Zt=(e,t)=>{const{x:n,y:s}=e,{x:r,y:i}=t,o=n*r+s*i,c=Math.sqrt((n**2+s**2)*(r**2+i**2));return(n*i-s*r<0?-1:1)*Math.acos(o/c)},Ne=(e,t,n,s,r,i,o,c,a,l)=>{const{abs:m,sin:u,cos:y,sqrt:x,PI:f}=Math;let h=m(n),g=m(s);const b=(r%360+360)%360*(f/180);if(e===c&&t===a)return{point:{x:c,y:a},length:0,bbox:{min:{x:c,y:a},max:{x:c,y:a}}};if(h===0||g===0)return bt(e,t,c,a,l);const v=(e-c)/2,M=(t-a)/2,w={x:y(b)*v+u(b)*M,y:-u(b)*v+y(b)*M},L=w.x**2/h**2+w.y**2/g**2;L>1&&(h*=x(L),g*=x(L));const D=h**2*g**2-h**2*w.y**2-g**2*w.x**2,G=h**2*w.y**2+g**2*w.x**2;let J=D/G;J=J<0?0:J;const gt=(i!==o?1:-1)*x(J),E={x:gt*(h*w.y/g),y:gt*(-(g*w.x)/h)},Q={x:y(b)*E.x-u(b)*E.y+(e+c)/2,y:u(b)*E.x+y(b)*E.y+(t+a)/2},tt={x:(w.x-E.x)/h,y:(w.y-E.y)/g},R=Zt({x:1,y:0},tt),yt={x:(-w.x-E.x)/h,y:(-w.y-E.y)/g};let $=Zt(tt,yt);!o&&$>0?$-=2*f:o&&$<0&&($+=2*f),$%=2*f;const z=R+$*(l||0),xt=R+$,et=h*y(z),nt=g*u(z);return{point:{x:y(b)*et-u(b)*nt+Q.x,y:u(b)*et+y(b)*nt+Q.y},center:Q,angle:z,startAngle:R,endAngle:xt,radiusX:h,radiusY:g,get length(){return de(h,g,$)},get bbox(){return Me(Q.x,Q.y,h,g,b,R,R+$)}}},we={x:0,y:0},Yt=[-.06405689286260563,.06405689286260563,-.1911188674736163,.1911188674736163,-.3150426796961634,.3150426796961634,-.4337935076260451,.4337935076260451,-.5454214713888396,.5454214713888396,-.6480936519369755,.6480936519369755,-.7401241915785544,.7401241915785544,-.820001985973903,.820001985973903,-.8864155270044011,.8864155270044011,-.9382745520027328,.9382745520027328,-.9747285559713095,.9747285559713095,-.9951872199970213,.9951872199970213],ve=[.12793819534675216,.12793819534675216,.1258374563468283,.1258374563468283,.12167047292780339,.12167047292780339,.1155056680537256,.1155056680537256,.10744427011596563,.10744427011596563,.09761865210411388,.09761865210411388,.08619016153195327,.08619016153195327,.0733464814110803,.0733464814110803,.05929858491543678,.05929858491543678,.04427743881741981,.04427743881741981,.028531388628933663,.028531388628933663,.0123412297999872,.0123412297999872],Pe=e=>{const t=[];for(let n=e,s=n.length,r=s-1;s>1;s-=1,r-=1){const i=[];for(let o=0;o<r;o+=1)i.push({x:r*(n[o+1].x-n[o].x),y:r*(n[o+1].y-n[o].y),t:0});t.push(i),n=i}return t},Ae=(e,t)=>{if(t===0)return e[0].t=0,e[0];const n=e.length-1;if(t===1)return e[n].t=1,e[n];const s=1-t;let r=e;if(n===0)return e[0].t=t,e[0];if(n===1)return{x:s*r[0].x+t*r[1].x,y:s*r[0].y+t*r[1].y,t};const i=s*s,o=t*t;let c=0,a=0,l=0,m=0;return n===2?(r=[r[0],r[1],r[2],we],c=i,a=s*t*2,l=o):n===3&&(c=i*s,a=i*t*3,l=s*o*3,m=t*o),{x:c*r[0].x+a*r[1].x+l*r[2].x+m*r[3].x,y:c*r[0].y+a*r[1].y+l*r[2].y+m*r[3].y,t}},Ce=(e,t)=>{const n=e(t),s=n.x*n.x+n.y*n.y;return Math.sqrt(s)},Te=e=>{const n=Yt.length;let s=0;for(let r=0,i;r<n;r++)i=.5*Yt[r]+.5,s+=ve[r]*Ce(e,i);return .5*s},Qt=e=>{const t=[];for(let s=0,r=e.length,i=2;s<r;s+=i)t.push({x:e[s],y:e[s+1]});const n=Pe(t);return Te(s=>Ae(n[0],s))},Le=1e-8,dt=e=>{const t=Math.min(e[0],e[2]),n=Math.max(e[0],e[2]);if(e[1]>=e[0]?e[2]>=e[1]:e[2]<=e[1])return[t,n];const s=(e[0]*e[2]-e[1]*e[1])/(e[0]-2*e[1]+e[2]);return s<t?[s,n]:[t,s]},Ft=e=>{const t=e[0]-3*e[1]+3*e[2]-e[3];if(Math.abs(t)<Le)return e[0]===e[3]&&e[0]===e[1]?[e[0],e[3]]:dt([e[0],-.5*e[0]+1.5*e[1],e[0]-3*e[1]+3*e[2]]);const n=-e[0]*e[2]+e[0]*e[3]-e[1]*e[2]-e[1]*e[3]+e[1]*e[1]+e[2]*e[2];if(n<=0)return[Math.min(e[0],e[3]),Math.max(e[0],e[3])];const s=Math.sqrt(n);let r=Math.min(e[0],e[3]),i=Math.max(e[0],e[3]);const o=e[0]-2*e[1]+e[2];for(let c=(o+s)/t,a=1;a<=2;c=(o-s)/t,a++)if(c>0&&c<1){const l=e[0]*(1-c)*(1-c)*(1-c)+e[1]*3*(1-c)*(1-c)*c+e[2]*3*(1-c)*c*c+e[3]*c*c*c;l<r&&(r=l),l>i&&(i=l)}return[r,i]},$e=([e,t,n,s,r,i,o,c],a)=>{const l=1-a;return{x:l**3*e+3*l**2*a*n+3*l*a**2*r+a**3*o,y:l**3*t+3*l**2*a*s+3*l*a**2*i+a**3*c}},ke=(e,t,n,s,r,i,o,c,a)=>{const l=typeof a=="number";let m={x:e,y:t};const u=()=>Qt([e,t,n,s,r,i,o,c]);if(l){const y=u();a<=0||(a>=y?m={x:o,y:c}:m=$e([e,t,n,s,r,i,o,c],a/y))}return{point:m,get length(){return u()},get bbox(){const y=Ft([e,n,r,o]),x=Ft([t,s,i,c]);return{min:{x:y[0],y:x[0]},max:{x:y[1],y:x[1]}}}}},Se=([e,t,n,s,r,i],o)=>{const c=1-o;return{x:c**2*e+2*c*o*n+o**2*r,y:c**2*t+2*c*o*s+o**2*i}},qe=(e,t,n,s,r,i,o)=>{const c=typeof o=="number";let a={x:e,y:t};const l=()=>Qt([e,t,n,s,r,i]);if(c){const m=l();o<=0||(o>=m?a={x:r,y:i}:a=Se([e,t,n,s,r,i],o/m))}return{point:a,get length(){return l()},get bbox(){const m=dt([e,n,r]),u=dt([t,s,i]);return{min:{x:m[0],y:u[0]},max:{x:m[1],y:u[1]}}}}},Mt=1e-5,ot=(e,t)=>{const n=j(e),s=typeof t=="number";let r=!1,i=[],o="M",c=0,a=0,l=0,m=0,u=n[0];const y=[],x=[];let f={x:0,y:0},h={x:0,y:0},g=f,p=0,b={point:{x:0,y:0},length:0,bbox:{min:{x:0,y:0},max:{x:0,y:0}}};for(let v=0,M=n.length;v<M;v+=1)u=n[v],[o]=u,r=o==="M",i=r?i:[c,a,...u.slice(1)],s&&t<Mt&&(g=f),r?([,l,m]=u,f={x:l,y:m},h={x:l,y:m},b={point:f,length:0,bbox:{min:f,max:h}}):o==="L"?b=bt(...i,s?t-p:void 0):o==="A"?b=Ne(...i,s?t-p:void 0):o==="C"?b=ke(...i,s?t-p:void 0):o==="Q"?b=qe(...i,s?t-p:void 0):o==="Z"&&(i=[c,a,l,m],b=bt(...i,s?t-p:void 0)),s&&p<t&&p+b.length>=t&&(g=b.point),y.push(b.bbox.min),x.push(b.bbox.max),p+=b.length,[c,a]=o!=="Z"?u.slice(-2):[l,m];return s&&t>p-Mt&&(g={x:c,y:a}),{point:g,length:p,get bbox(){return{min:{x:Math.min(...y.map(v=>v.x)),y:Math.min(...y.map(v=>v.y))},max:{x:Math.max(...x.map(v=>v.x)),y:Math.max(...x.map(v=>v.y))}}}}},Ht=e=>{if(!e)return{x:0,y:0,width:0,height:0,x2:0,y2:0,cx:0,cy:0,cz:0};const t=ot(e),{min:{x:n,y:s},max:{x:r,y:i}}=t.bbox,o=r-n,c=i-s;return{width:o,height:c,x:n,y:s,x2:r,y2:i,cx:n+o/2,cy:s+c/2,cz:Math.max(o,c)+Math.min(o,c)/2}},Nt=(e,t,n)=>{if(e[n].length>7){e[n].shift();const s=e[n];let r=n;for(;s.length;)t[n]="A",e.splice(r+=1,0,["C",...s.splice(0,6)]);e.splice(n,1)}},Bt=e=>it(e)&&e.every(([t])=>"MC".includes(t)),ct=(e,t,n)=>{const s=e*Math.cos(n)-t*Math.sin(n),r=e*Math.sin(n)+t*Math.cos(n);return{x:s,y:r}},Jt=(e,t,n,s,r,i,o,c,a,l)=>{let m=e,u=t,y=n,x=s,f=c,h=a;const g=Math.PI*120/180,p=Math.PI/180*(+r||0);let b=[],v,M,w,L,D;if(l)[M,w,L,D]=l;else{v=ct(m,u,-p),m=v.x,u=v.y,v=ct(f,h,-p),f=v.x,h=v.y;const C=(m-f)/2,k=(u-h)/2;let F=C*C/(y*y)+k*k/(x*x);F>1&&(F=Math.sqrt(F),y*=F,x*=F);const At=y*y,Ct=x*x,ie=(i===o?-1:1)*Math.sqrt(Math.abs((At*Ct-At*k*k-Ct*C*C)/(At*k*k+Ct*C*C)));L=ie*y*k/x+(m+f)/2,D=ie*-x*C/y+(u+h)/2,M=Math.asin(((u-D)/x*10**9>>0)/10**9),w=Math.asin(((h-D)/x*10**9>>0)/10**9),M=m<L?Math.PI-M:M,w=f<L?Math.PI-w:w,M<0&&(M=Math.PI*2+M),w<0&&(w=Math.PI*2+w),o&&M>w&&(M-=Math.PI*2),!o&&w>M&&(w-=Math.PI*2)}let G=w-M;if(Math.abs(G)>g){const C=w,k=f,F=h;w=M+g*(o&&w>M?1:-1),f=L+y*Math.cos(w),h=D+x*Math.sin(w),b=Jt(f,h,y,x,r,0,o,k,F,[w,C,L,D])}G=w-M;const J=Math.cos(M),gt=Math.sin(M),E=Math.cos(w),Q=Math.sin(w),tt=Math.tan(G/4),R=4/3*y*tt,yt=4/3*x*tt,$=[m,u],z=[m+R*gt,u-yt*J],xt=[f+R*Q,h-yt*E],et=[f,h];if(z[0]=2*$[0]-z[0],z[1]=2*$[1]-z[1],l)return[...z,...xt,...et,...b];b=[...z,...xt,...et,...b];const nt=[];for(let C=0,k=b.length;C<k;C+=1)nt[C]=C%2?ct(b[C-1],b[C],p).y:ct(b[C],b[C+1],p).x;return nt},Ee=(e,t,n,s,r,i)=>{const o=.3333333333333333,c=2/3;return[o*e+c*n,o*t+c*s,o*r+c*n,o*i+c*s,r,i]},_t=(e,t,n,s)=>{const r=I([e,t],[n,s],.3333333333333333),i=I([e,t],[n,s],2/3);return[...r,...i,n,s]},lt=(e,t)=>{const[n]=e,s=e.slice(1).map(Number),[r,i]=s;let o;const{x1:c,y1:a,x:l,y:m}=t;return"TQ".includes(n)||(t.qx=null,t.qy=null),n==="M"?(t.x=r,t.y=i,e):n==="A"?(o=[c,a,...s],["C",...Jt(...o)]):n==="Q"?(t.qx=r,t.qy=i,o=[c,a,...s],["C",...Ee(...o)]):n==="L"?["C",..._t(c,a,r,i)]:n==="Z"?["C",..._t(c,a,l,m)]:e},at=e=>{if(Bt(e))return e.slice(0);const t=j(e),n={...V},s=[];let r="",i=t.length;for(let o=0;o<i;o+=1){[r]=t[o],s[o]=r,t[o]=lt(t[o],n),Nt(t,s,o),i=t.length;const c=t[o],a=c.length;n.x1=+c[a-2],n.y1=+c[a-1],n.x2=+c[a-4]||n.x1,n.y2=+c[a-3]||n.y1}return t},ze=(e,t,n,s,r,i,o,c)=>3*((c-t)*(n+r)-(o-e)*(s+i)+s*(e-r)-n*(t-i)+c*(r+e/3)-o*(i+t/3))/20,Kt=e=>{let t=0,n=0,s=0;return at(e).map(r=>{switch(r[0]){case"M":return[,t,n]=r,0;default:return s=ze(t,n,...r.slice(1)),[t,n]=r.slice(-2),s}}).reduce((r,i)=>r+i,0)},B=e=>ot(e).length,Oe=e=>Kt(at(e))>=0,W=(e,t)=>ot(e,t).point,wt=(e,t)=>{const n=Y(e);let s=n.slice(0),r=B(s),i=s.length-1,o=0,c=0,a=n[0];const[l,m]=a.slice(-2),u={x:l,y:m};if(i<=0||!t||!Number.isFinite(t))return{segment:a,index:0,length:c,point:u,lengthAtSegment:o};if(t>=r)return s=n.slice(0,-1),o=B(s),c=r-o,{segment:n[i],index:i,length:c,lengthAtSegment:o};const y=[];for(;i>0;)a=s[i],s=s.slice(0,-1),o=B(s),c=r-o,r=o,y.push({segment:a,index:i,length:c,lengthAtSegment:o}),i-=1;return y.find(({lengthAtSegment:x})=>x<=t)},mt=(e,t)=>{const n=Y(e),s=j(n),r=B(n),i=M=>{const w=M.x-t.x,L=M.y-t.y;return w*w+L*L};let o=8,c,a={x:0,y:0},l=0,m=0,u=1/0;for(let M=0;M<=r;M+=o)c=W(s,M),l=i(c),l<u&&(a=c,m=M,u=l);o/=2;let y,x,f=0,h=0,g=0,p=0;for(;o>1e-6&&(f=m-o,y=W(s,f),g=i(y),h=m+o,x=W(s,h),p=i(x),f>=0&&g<u?(a=y,m=f,u=g):h<=r&&p<u?(a=x,m=h,u=p):o/=2,!(o<1e-5)););const b=wt(n,m),v=Math.sqrt(u);return{closest:a,distance:v,segment:b}},je=(e,t)=>mt(e,t).closest,Ie=(e,t)=>mt(e,t).segment,De=(e,t)=>wt(e,t).segment,Re=(e,t)=>{const{distance:n}=mt(e,t);return Math.abs(n)<Mt},Ut=e=>{if(typeof e!="string"||!e.length)return!1;const t=new $t(e);for(_(t);t.index<t.max&&!t.err.length;)Lt(t);return!t.err.length&&"mM".includes(t.segments[0][0])},Vt=e=>K(e)&&e.slice(1).every(([t])=>t===t.toLowerCase()),ht={line:["x1","y1","x2","y2"],circle:["cx","cy","r"],ellipse:["cx","cy","rx","ry"],rect:["width","height","x","y","rx","ry"],polygon:["points"],polyline:["points"],glyph:["d"]},Xe=e=>{let{x1:t,y1:n,x2:s,y2:r}=e;return[t,n,s,r]=[t,n,s,r].map(i=>+i),[["M",t,n],["L",s,r]]},Ze=e=>{const t=[],n=(e.points||"").trim().split(/[\s|,]/).map(r=>+r);let s=0;for(;s<n.length;)t.push([s?"L":"M",n[s],n[s+1]]),s+=2;return e.type==="polygon"?[...t,["z"]]:t},Ye=e=>{let{cx:t,cy:n,r:s}=e;return[t,n,s]=[t,n,s].map(r=>+r),[["M",t-s,n],["a",s,s,0,1,0,2*s,0],["a",s,s,0,1,0,-2*s,0]]},Qe=e=>{let{cx:t,cy:n}=e,s=e.rx||0,r=e.ry||s;return[t,n,s,r]=[t,n,s,r].map(i=>+i),[["M",t-s,n],["a",s,r,0,1,0,2*s,0],["a",s,r,0,1,0,-2*s,0]]},Fe=e=>{const t=+e.x||0,n=+e.y||0,s=+e.width,r=+e.height;let i=+(e.rx||0),o=+(e.ry||i);return i||o?(i*2>s&&(i-=(i*2-s)/2),o*2>r&&(o-=(o*2-r)/2),[["M",t+i,n],["h",s-i*2],["s",i,0,i,o],["v",r-o*2],["s",0,o,-i,o],["h",-s+i*2],["s",-i,0,-i,-o],["v",-r+o*2],["s",0,-o,i,-o]]):[["M",t,n],["h",s],["v",r],["H",t],["Z"]]},Wt=(e,t)=>{const s=(t||document).defaultView||window,r=Object.keys(ht),i=e instanceof s.SVGElement,o=i?e.tagName:null;if(o&&[...r,"path"].every(u=>o!==u))throw TypeError(`${A}: "${o}" is not SVGElement`);const c=i?o:e.type,a=ht[c],l={type:c};i?a.forEach(u=>{l[u]=e.getAttribute(u)}):Object.assign(l,e);let m=[];return c==="circle"?m=Ye(l):c==="ellipse"?m=Qe(l):["polyline","polygon"].includes(c)?m=Ze(l):c==="rect"?m=Fe(l):c==="line"?m=Xe(l):["glyph","path"].includes(c)&&(m=Y(i?e.getAttribute("d")||"":e.d||"")),K(m)&&m.length?m:!1},ut=(e,t)=>{let{round:n}=S;if(t==="off"||n==="off")return[...e];n=typeof t=="number"&&t>=0?t:n;const s=typeof n=="number"&&n>=1?10**n:1;return e.map(r=>{const i=r.slice(1).map(Number).map(o=>n?Math.round(o*s)/s:Math.round(o));return[r[0],...i]})},vt=(e,t)=>ut(e,t).map(n=>n[0]+n.slice(1).join(" ")).join(""),He=(e,t,n)=>{const s=n||document,r=s.defaultView||window,i=Object.keys(ht),o=e instanceof r.SVGElement,c=o?e.tagName:null;if(c==="path")throw TypeError(`${A}: "${c}" is already SVGPathElement`);if(c&&i.every(h=>c!==h))throw TypeError(`${A}: "${c}" is not SVGElement`);const a=s.createElementNS("http://www.w3.org/2000/svg","path"),l=o?c:e.type,m=ht[l],u={type:l},y=S.round,x=Wt(e,s),f=x&&x.length?vt(x,y):"";return o?(m.forEach(h=>{u[h]=e.getAttribute(h)}),Object.values(e.attributes).forEach(({name:h,value:g})=>{m.includes(h)||a.setAttribute(h,g)})):(Object.assign(u,e),Object.keys(u).forEach(h=>{!m.includes(h)&&h!=="type"&&a.setAttribute(h.replace(/[A-Z]/g,g=>`-${g.toLowerCase()}`),u[h])})),Ut(f)?(a.setAttribute("d",f),t&&o&&(e.before(a,e),e.remove()),a):!1},Gt=e=>{const t=[];let n,s=-1;return e.forEach(r=>{r[0]==="M"?(n=[r],s+=1):n.push(r),t[s]=n}),t},te=e=>{let t=new P;const{origin:n}=e,[s,r]=n,{translate:i}=e,{rotate:o}=e,{skew:c}=e,{scale:a}=e;return Array.isArray(i)&&i.length>=2&&i.every(l=>!Number.isNaN(+l))&&i.some(l=>l!==0)?t=t.translate(...i):typeof i=="number"&&!Number.isNaN(i)&&(t=t.translate(i)),(o||c||a)&&(t=t.translate(s,r),Array.isArray(o)&&o.length>=2&&o.every(l=>!Number.isNaN(+l))&&o.some(l=>l!==0)?t=t.rotate(...o):typeof o=="number"&&!Number.isNaN(o)&&(t=t.rotate(o)),Array.isArray(c)&&c.length===2&&c.every(l=>!Number.isNaN(+l))&&c.some(l=>l!==0)?(t=c[0]?t.skewX(c[0]):t,t=c[1]?t.skewY(c[1]):t):typeof c=="number"&&!Number.isNaN(c)&&(t=t.skewX(c)),Array.isArray(a)&&a.length>=2&&a.every(l=>!Number.isNaN(+l))&&a.some(l=>l!==1)?t=t.scale(...a):typeof a=="number"&&!Number.isNaN(a)&&(t=t.scale(a)),t=t.translate(-s,-r)),t},Pt=e=>{if(Vt(e))return e.slice(0);const t=Y(e);let n=0,s=0,r=0,i=0;return t.map(o=>{const c=o.slice(1).map(Number),[a]=o,l=a.toLowerCase();if(a==="M")return[n,s]=c,r=n,i=s,["M",n,s];let m=[];if(a!==l)if(l==="a")m=[l,c[0],c[1],c[2],c[3],c[4],c[5]-n,c[6]-s];else if(l==="v")m=[l,c[0]-s];else if(l==="h")m=[l,c[0]-n];else{const y=c.map((x,f)=>x-(f%2?s:n));m=[l,...y]}else a==="m"&&(r=c[0]+n,i=c[1]+s),m=[l,...c];const u=m.length;return l==="z"?(n=r,s=i):l==="h"?n+=m[1]:l==="v"?s+=m[1]:(n+=m[u-2],s+=m[u-1]),m})},Be=(e,t,n,s)=>{const[r]=e,i=p=>Math.round(p*10**4)/10**4,o=e.slice(1).map(p=>+p),c=t.slice(1).map(p=>+p),{x1:a,y1:l,x2:m,y2:u,x:y,y:x}=n;let f=e;const[h,g]=c.slice(-2);if("TQ".includes(r)||(n.qx=null,n.qy=null),["V","H","S","T","Z"].includes(r))f=[r,...o];else if(r==="L")i(y)===i(h)?f=["V",g]:i(x)===i(g)&&(f=["H",h]);else if(r==="C"){const[p,b]=c;"CS".includes(s)&&(i(p)===i(a*2-m)&&i(b)===i(l*2-u)||i(a)===i(m*2-y)&&i(l)===i(u*2-x))&&(f=["S",...c.slice(-4)]),n.x1=p,n.y1=b}else if(r==="Q"){const[p,b]=c;n.qx=p,n.qy=b,"QT".includes(s)&&(i(p)===i(a*2-m)&&i(b)===i(l*2-u)||i(a)===i(m*2-y)&&i(l)===i(u*2-x))&&(f=["T",...c.slice(-2)])}return f},ee=(e,t)=>{const n=H(e),s=j(n),r={...V},i=[],o=n.length;let c="",a="",l=0,m=0,u=0,y=0;for(let h=0;h<o;h+=1){[c]=n[h],i[h]=c,h&&(a=i[h-1]),n[h]=Be(n[h],s[h],r,a);const g=n[h],p=g.length;switch(r.x1=+g[p-2],r.y1=+g[p-1],r.x2=+g[p-4]||r.x1,r.y2=+g[p-3]||r.y1,c){case"Z":l=u,m=y;break;case"H":[,l]=g;break;case"V":[,m]=g;break;default:[l,m]=g.slice(-2).map(Number),c==="M"&&(u=l,y=m)}r.x=l,r.y=m}const x=ut(n,t),f=ut(Pt(n),t);return x.map((h,g)=>g?h.join("").length<f[g].join("").length?h:f[g]:h)},Je=e=>{const t=e.slice(1).map((n,s,r)=>s?[...r[s-1].slice(-2),...n.slice(1)]:[...e[0].slice(1),...n.slice(1)]).map(n=>n.map((s,r)=>n[n.length-r-2*(1-r%2)])).reverse();return[["M",...t[0].slice(0,2)],...t.map(n=>["C",...n.slice(2)])]},ft=e=>{const t=H(e),n=t.slice(-1)[0][0]==="Z",s=j(t).map((r,i)=>{const[o,c]=r.slice(-2).map(Number);return{seg:t[i],n:r,c:t[i][0],x:o,y:c}}).map((r,i,o)=>{const c=r.seg,a=r.n,l=i&&o[i-1],m=o[i+1],u=r.c,y=o.length,x=i?o[i-1].x:o[y-1].x,f=i?o[i-1].y:o[y-1].y;let h=[];switch(u){case"M":h=n?["Z"]:[u,x,f];break;case"A":h=[u,...c.slice(1,-3),c[5]===1?0:1,x,f];break;case"C":m&&m.c==="S"?h=["S",c[1],c[2],x,f]:h=[u,c[3],c[4],c[1],c[2],x,f];break;case"S":l&&"CS".includes(l.c)&&(!m||m.c!=="S")?h=["C",a[3],a[4],a[1],a[2],x,f]:h=[u,a[1],a[2],x,f];break;case"Q":m&&m.c==="T"?h=["T",x,f]:h=[u,...c.slice(1,-2),x,f];break;case"T":l&&"QT".includes(l.c)&&(!m||m.c!=="T")?h=["Q",a[1],a[2],x,f]:h=[u,x,f];break;case"Z":h=["M",x,f];break;case"H":h=[u,x];break;case"V":h=[u,f];break;default:h=[u,...c.slice(1,-2),x,f]}return h});return n?s.reverse():[s[0],...s.slice(1).reverse()]},_e=(e,t)=>{let n=P.Translate(...t.slice(0,-1));return[,,,n.m44]=t,n=e.multiply(n),[n.m41,n.m42,n.m43,n.m44]},ne=(e,t,n)=>{const[s,r,i]=n,[o,c,a]=_e(e,[...t,0,1]),l=o-s,m=c-r,u=a-i;return[l*(Math.abs(i)/Math.abs(u)||1)+s,m*(Math.abs(i)/Math.abs(u)||1)+r]},se=e=>{const t=rt(e)?e:H(e),n=it(t)?t:j(t),s={...V},r=[];let i=[],o=0,c="";const a=[];let l=0,m=t.length;for(l=0;l<m;l+=1)t[l]&&([c]=t[l]),r[l]=c,c==="A"&&(i=lt(n[l],s),t[l]=lt(n[l],s),Nt(t,r,l),n[l]=lt(n[l],s),Nt(n,r,l),m=Math.max(t.length,n.length)),i=n[l],o=i.length,s.x1=+i[o-2],s.y1=+i[o-1],s.x2=+i[o-4]||s.x1,s.y2=+i[o-3]||s.y1,a.push(t[l]);return a},re=(e,t)=>{let n=0,s=0,r,i,o,c,a,l;const m=se(e),u=t&&Object.keys(t);if(!t||u&&!u.length)return m.slice(0);const y=j(m);if(!t.origin){const{origin:M}=S;Object.assign(t,{origin:M})}const x=te(t),{origin:f}=t,h={...V};let g=[],p=0,b="";const v=[];if(!x.isIdentity){for(r=0,o=m.length;r<o;r+=1){g=y[r],p=g.length,h.x1=+g[p-2],h.y1=+g[p-1],h.x2=+g[p-4]||h.x1,h.y2=+g[p-3]||h.y1;const M={s:m[r],c:m[r][0],x:h.x1,y:h.y1};v.push(M)}return v.map(M=>{if(b=M.c,g=M.s,b==="L"||b==="H"||b==="V")return[a,l]=ne(x,[M.x,M.y],f),n!==a&&s!==l?g=["L",a,l]:s===l?g=["H",a]:n===a&&(g=["V",l]),n=a,s=l,g;for(i=1,c=g.length;i<c;i+=2)[n,s]=ne(x,[+g[i],+g[i+1]],f),g[i]=n,g[i+1]=s;return g})}return m.slice(0)},Ke=e=>{const n=e.slice(0,2),s=e.slice(2,4),r=e.slice(4,6),i=e.slice(6,8),o=I(n,s,.5),c=I(s,r,.5),a=I(r,i,.5),l=I(o,c,.5),m=I(c,a,.5),u=I(l,m,.5);return[["C",...o,...l,...u],["C",...m,...a,...i]]};class d{constructor(t,n){const s=n||{},r=typeof t>"u";if(r||!t.length)throw TypeError(`${A}: "pathValue" is ${r?"undefined":"empty"}`);const i=Y(t);this.segments=i;const{width:o,height:c,cx:a,cy:l,cz:m}=this.bbox,{round:u,origin:y}=s;let x;if(u==="auto"){const h=`${Math.floor(Math.max(o,c))}`.length;x=h>=4?0:4-h}else Number.isInteger(u)||u==="off"?x=u:x=S.round;let f=[a,l,m];if(Array.isArray(y)&&y.length>=2){const[h,g,p]=y.map(Number);f=[Number.isNaN(h)?a:h,Number.isNaN(g)?l:g,Number.isNaN(p)?m:p]}return this.round=x,this.origin=f,this}get bbox(){return Ht(this.segments)}get length(){return B(this.segments)}getBBox(){return this.bbox}getTotalLength(){return this.length}getPointAtLength(t){return W(this.segments,t)}toAbsolute(){const{segments:t}=this;return this.segments=H(t),this}toRelative(){const{segments:t}=this;return this.segments=Pt(t),this}toCurve(){const{segments:t}=this;return this.segments=at(t),this}reverse(t){this.toAbsolute();const{segments:n}=this,s=Gt(n),r=s.length>1?s:!1,i=r?r.map((c,a)=>t?a?ft(c):c.slice(0):ft(c)):n.slice(0);let o=[];return r?o=i.flat(1):o=t?n:ft(n),this.segments=o.slice(0),this}normalize(){const{segments:t}=this;return this.segments=j(t),this}optimize(){const{segments:t}=this;return this.segments=ee(t,this.round),this}transform(t){if(!t||typeof t!="object"||typeof t=="object"&&!["translate","rotate","skew","scale"].some(a=>a in t))return this;const{segments:n,origin:[s,r,i]}=this,o={};for(const[a,l]of Object.entries(t))a==="skew"&&Array.isArray(l)||(a==="rotate"||a==="translate"||a==="origin"||a==="scale")&&Array.isArray(l)?o[a]=l.map(Number):a!=="origin"&&typeof Number(l)=="number"&&(o[a]=Number(l));const{origin:c}=o;if(Array.isArray(c)&&c.length>=2){const[a,l,m]=c.map(Number);o.origin=[Number.isNaN(a)?s:a,Number.isNaN(l)?r:l,m||i]}else o.origin=[s,r,i];return this.segments=re(n,o),this}flipX(){return this.transform({rotate:[0,180,0]}),this}flipY(){return this.transform({rotate:[180,0,0]}),this}toString(){return vt(this.segments,this.round)}}return N(d,"CSSMatrix",P),N(d,"getSVGMatrix",te),N(d,"getPathBBox",Ht),N(d,"getPathArea",Kt),N(d,"getTotalLength",B),N(d,"getDrawDirection",Oe),N(d,"getPointAtLength",W),N(d,"pathFactory",ot),N(d,"getPropertiesAtLength",wt),N(d,"getPropertiesAtPoint",mt),N(d,"polygonLength",ge),N(d,"polygonArea",fe),N(d,"getClosestPoint",je),N(d,"getSegmentOfPoint",Ie),N(d,"getSegmentAtLength",De),N(d,"isPointInStroke",Re),N(d,"isValidPath",Ut),N(d,"isPathArray",K),N(d,"isAbsoluteArray",rt),N(d,"isRelativeArray",Vt),N(d,"isCurveArray",Bt),N(d,"isNormalizedArray",it),N(d,"shapeToPath",He),N(d,"shapeToPathArray",Wt),N(d,"parsePathString",Y),N(d,"roundPath",ut),N(d,"splitPath",Gt),N(d,"splitCubic",Ke),N(d,"replaceArc",se),N(d,"optimizePath",ee),N(d,"reverseCurve",Je),N(d,"reversePath",ft),N(d,"normalizePath",j),N(d,"transformPath",re),N(d,"pathToAbsolute",H),N(d,"pathToRelative",Pt),N(d,"pathToCurve",at),N(d,"pathToString",vt),d}();
2
2
  //# sourceMappingURL=svg-path-commander.js.map