svg-path-commander 2.1.1 → 2.1.3
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.
- package/README.md +2 -2
- package/dist/svg-path-commander.cjs +1 -1
- package/dist/svg-path-commander.cjs.map +1 -1
- package/dist/svg-path-commander.d.ts +188 -19
- package/dist/svg-path-commander.js +1 -1
- package/dist/svg-path-commander.js.map +1 -1
- package/dist/svg-path-commander.mjs +1170 -982
- package/dist/svg-path-commander.mjs.map +1 -1
- package/package.json +7 -7
- package/src/convert/pathToAbsolute.ts +2 -31
- package/src/convert/pathToCurve.ts +13 -27
- package/src/convert/pathToRelative.ts +2 -47
- package/src/convert/pathToString.ts +40 -7
- package/src/index.ts +132 -39
- package/src/interface.ts +2 -1
- package/src/math/arcTools.ts +70 -76
- package/src/math/bezier.ts +41 -33
- package/src/math/cubicTools.ts +15 -14
- package/src/math/distanceSquareRoot.ts +1 -1
- package/src/math/lineTools.ts +8 -14
- package/src/math/polygonTools.ts +48 -0
- package/src/math/quadTools.ts +12 -12
- package/src/math/rotateVector.ts +3 -2
- package/src/math/roundTo.ts +7 -0
- package/src/parser/finalizeSegment.ts +11 -7
- package/src/parser/parsePathString.ts +2 -3
- package/src/parser/pathParser.ts +1 -1
- package/src/process/absolutizeSegment.ts +38 -29
- package/src/process/arcToCubic.ts +2 -2
- package/src/process/iterate.ts +41 -16
- package/src/process/lineToCubic.ts +1 -1
- package/src/process/normalizePath.ts +14 -31
- package/src/process/normalizeSegment.ts +53 -15
- package/src/process/optimizePath.ts +39 -60
- package/src/process/projection2d.ts +2 -2
- package/src/process/relativizeSegment.ts +36 -34
- package/src/process/reverseCurve.ts +8 -5
- package/src/process/reversePath.ts +87 -74
- package/src/process/roundPath.ts +14 -8
- package/src/process/roundSegment.ts +9 -0
- package/src/process/segmentToCubic.ts +9 -7
- package/src/process/shortenSegment.ts +24 -32
- package/src/process/splitCubic.ts +2 -2
- package/src/process/transformPath.ts +43 -44
- package/src/types.ts +7 -11
- package/src/util/getPathArea.ts +2 -2
- package/src/util/getPathBBox.ts +111 -55
- package/src/util/getPointAtLength.ts +51 -49
- package/src/util/getPropertiesAtLength.ts +4 -5
- package/src/util/getPropertiesAtPoint.ts +5 -5
- package/src/util/getTotalLength.ts +94 -44
- package/test/class.test.ts +4 -0
- package/test/fixtures/shapes.js +5 -5
- package/test/fixtures/simpleShapes.js +12 -0
- package/test/static.test.ts +18 -12
- package/vitest.config-ui.mts +5 -0
- package/vitest.config.mts +5 -0
- package/src/math/polygonArea.ts +0 -29
- package/src/math/polygonLength.ts +0 -22
package/README.md
CHANGED
|
@@ -7,8 +7,8 @@
|
|
|
7
7
|
[](https://www.typescriptlang.org/)
|
|
8
8
|
[](https://prettier.io/)
|
|
9
9
|
[](https://github.com/eslint)
|
|
10
|
-
[](https://vitest.dev/)
|
|
11
|
+
[](https://vitejs.dev/)
|
|
12
12
|
|
|
13
13
|

|
|
14
14
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var he=Object.defineProperty;var fe=(e,t,n)=>t in e?he(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var N=(e,t,n)=>fe(e,typeof t!="symbol"?t+"":t,n);const st={origin:[0,0,0],round:4},E="SVGPathCommander Error",tt={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0},$t=e=>{let t=e.pathValue[e.segmentStart],n=t.toLowerCase();const{data:r}=e;for(;r.length>=tt[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,tt[n])]),!!tt[n]););},ye=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=`${E}: invalid Arc flag "${n[t]}", expecting 0 or 1 at index ${t}`},F=e=>e>=48&&e<=57,U="Invalid path value",ge=e=>{const{max:t,pathValue:n,index:r}=e;let s=r,i=!1,o=!1,c=!1,l=!1,a;if(s>=t){e.err=`${E}: ${U} at index ${s}, "pathValue" is missing param`;return}if(a=n.charCodeAt(s),(a===43||a===45)&&(s+=1,a=n.charCodeAt(s)),!F(a)&&a!==46){e.err=`${E}: ${U} at index ${s}, "${n[s]}" is not a number`;return}if(a!==46){if(i=a===48,s+=1,a=n.charCodeAt(s),i&&s<t&&a&&F(a)){e.err=`${E}: ${U} at index ${r}, "${n[r]}" illegal number`;return}for(;s<t&&F(n.charCodeAt(s));)s+=1,o=!0;a=n.charCodeAt(s)}if(a===46){for(l=!0,s+=1;F(n.charCodeAt(s));)s+=1,c=!0;a=n.charCodeAt(s)}if(a===101||a===69){if(l&&!o&&!c){e.err=`${E}: ${U} at index ${s}, "${n[s]}" invalid float exponent`;return}if(s+=1,a=n.charCodeAt(s),(a===43||a===45)&&(s+=1),s<t&&F(n.charCodeAt(s)))for(;s<t&&F(n.charCodeAt(s));)s+=1;else{e.err=`${E}: ${U} at index ${s}, "${n[s]}" invalid integer exponent`;return}}e.index=s,e.param=+e.pathValue.slice(r,s)},xe=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),et=e=>{const{pathValue:t,max:n}=e;for(;e.index<n&&xe(t.charCodeAt(e.index));)e.index+=1},pe=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}},de=e=>F(e)||e===43||e===45||e===46,Me=e=>(e|32)===97,be=e=>{switch(e|32){case 109:case 77:return!0;default:return!1}},Qt=e=>{var l;const{max:t,pathValue:n,index:r,segments:s}=e,i=n.charCodeAt(r),o=tt[n[r].toLowerCase()];if(e.segmentStart=r,!pe(i)){e.err=`${E}: ${U} "${n[r]}" is not a path command at index ${r}`;return}const c=s[s.length-1];if(!be(i)&&((l=c==null?void 0:c[0])==null?void 0:l.toLocaleLowerCase())==="z"){e.err=`${E}: ${U} "${n[r]}" is not a MoveTo path command at index ${r}`;return}if(e.index+=1,et(e),e.data=[],!o){$t(e);return}for(;;){for(let a=o;a>0;a-=1){if(Me(i)&&(a===3||a===4)?ye(e):ge(e),e.err.length)return;e.data.push(e.param),et(e),e.index<t&&n.charCodeAt(e.index)===44&&(e.index+=1,et(e))}if(e.index>=e.max||!de(n.charCodeAt(e.index)))break}$t(e)};class Xt{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 q=e=>{if(typeof e!="string")return e.slice(0);const t=new Xt(e);for(et(t);t.index<t.max&&!t.err.length;)Qt(t);if(t!=null&&t.err.length)throw TypeError(t.err);return t.segments},we=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},Pt=(e,t)=>Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1])),Ne=e=>e.reduce((t,n,r)=>r?t+Pt(e[r-1],n):0,0);var Ae=Object.defineProperty,Ce=(e,t,n)=>t in e?Ae(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,k=(e,t,n)=>Ce(e,typeof t!="symbol"?t+"":t,n);const ve={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},Bt=e=>(e instanceof Float64Array||e instanceof Float32Array||Array.isArray(e)&&e.every(t=>typeof t=="number"))&&[6,16].some(t=>e.length===t),Yt=e=>e instanceof DOMMatrix||e instanceof v||typeof e=="object"&&Object.keys(ve).every(t=>e&&t in e),it=e=>{const t=new v,n=Array.from(e);if(!Bt(n))throw TypeError(`CSSMatrix: "${n.join(",")}" must be an array with 6/16 numbers.`);if(n.length===16){const[r,s,i,o,c,l,a,m,u,g,f,h,y,x,p,d]=n;t.m11=r,t.a=r,t.m21=c,t.c=c,t.m31=u,t.m41=y,t.e=y,t.m12=s,t.b=s,t.m22=l,t.d=l,t.m32=g,t.m42=x,t.f=x,t.m13=i,t.m23=a,t.m33=f,t.m43=p,t.m14=o,t.m24=m,t.m34=h,t.m44=d}else if(n.length===6){const[r,s,i,o,c,l]=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=c,t.e=c,t.m42=l,t.f=l}return t},Ht=e=>{if(Yt(e))return it([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.`)},Ft=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 c=o.split(",").map(h=>h.includes("rad")?parseFloat(h)*(180/Math.PI):parseFloat(h)),[l,a,m,u]=c,g=[l,a,m],f=[l,a,m,u];if(i==="perspective"&&l&&[a,m].every(h=>h===void 0))n.m34=-1/l;else if(i.includes("matrix")&&[6,16].includes(c.length)&&c.every(h=>!Number.isNaN(+h))){const h=c.map(y=>Math.abs(y)<1e-6?0:y);n=n.multiply(it(h))}else if(i==="translate3d"&&g.every(h=>!Number.isNaN(+h)))n=n.translate(l,a,m);else if(i==="translate"&&l&&m===void 0)n=n.translate(l,a||0,0);else if(i==="rotate3d"&&f.every(h=>!Number.isNaN(+h))&&u)n=n.rotateAxisAngle(l,a,m,u);else if(i==="rotate"&&l&&[a,m].every(h=>h===void 0))n=n.rotate(0,0,l);else if(i==="scale3d"&&g.every(h=>!Number.isNaN(+h))&&g.some(h=>h!==1))n=n.scale(l,a,m);else if(i==="scale"&&!Number.isNaN(l)&&l!==1&&m===void 0){const h=Number.isNaN(+a)?l:a;n=n.scale(l,h,1)}else if(i==="skew"&&(l||!Number.isNaN(l)&&a)&&m===void 0)n=n.skew(l,a||0);else if(["translate","rotate","scale","skew"].some(h=>i.includes(h))&&/[XYZ]/.test(i)&&l&&[a,m].every(h=>h===void 0))if(i==="skewX"||i==="skewY")n=n[i](l);else{const h=i.replace(/[XYZ]/,""),y=i.replace(h,""),x=["X","Y","Z"].indexOf(y),p=h==="scale"?1:0,d=[x===0?l:p,x===1?l:p,x===2?l:p];n=n[h](...d)}else throw TypeError(r)}),n},wt=(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],Ut=(e,t,n)=>{const r=new v;return r.m41=e,r.e=e,r.m42=t,r.f=t,r.m43=n,r},Vt=(e,t,n)=>{const r=new v,s=Math.PI/180,i=e*s,o=t*s,c=n*s,l=Math.cos(i),a=-Math.sin(i),m=Math.cos(o),u=-Math.sin(o),g=Math.cos(c),f=-Math.sin(c),h=m*g,y=-m*f;r.m11=h,r.a=h,r.m12=y,r.b=y,r.m13=u;const x=a*u*g+l*f;r.m21=x,r.c=x;const p=l*g-a*u*f;return r.m22=p,r.d=p,r.m23=-a*m,r.m31=a*f-l*u*g,r.m32=a*g+l*u*f,r.m33=l*m,r},_t=(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,c=t/i,l=n/i,a=r*(Math.PI/360),m=Math.sin(a),u=Math.cos(a),g=m*m,f=o*o,h=c*c,y=l*l,x=1-2*(h+y)*g;s.m11=x,s.a=x;const p=2*(o*c*g+l*m*u);s.m12=p,s.b=p,s.m13=2*(o*l*g-c*m*u);const d=2*(c*o*g-l*m*u);s.m21=d,s.c=d;const C=1-2*(y+f)*g;return s.m22=C,s.d=C,s.m23=2*(c*l*g+o*m*u),s.m31=2*(l*o*g+c*m*u),s.m32=2*(l*c*g-o*m*u),s.m33=1-2*(f+h)*g,s},Jt=(e,t,n)=>{const r=new v;return r.m11=e,r.a=e,r.m22=t,r.d=t,r.m33=n,r},yt=(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},Kt=e=>yt(e,0),Wt=e=>yt(0,e),j=(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,c=t.m21*e.m12+t.m22*e.m22+t.m23*e.m32+t.m24*e.m42,l=t.m21*e.m13+t.m22*e.m23+t.m23*e.m33+t.m24*e.m43,a=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,g=t.m31*e.m13+t.m32*e.m23+t.m33*e.m33+t.m34*e.m43,f=t.m31*e.m14+t.m32*e.m24+t.m33*e.m34+t.m34*e.m44,h=t.m41*e.m11+t.m42*e.m21+t.m43*e.m31+t.m44*e.m41,y=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 it([n,r,s,i,o,c,l,a,m,u,g,f,h,y,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"?Ft(t):Array.isArray(t)||t instanceof Float64Array||t instanceof Float32Array?it(t):typeof t=="object"?Ht(t):this}toFloat32Array(t){return Float32Array.from(wt(this,t))}toFloat64Array(t){return Float64Array.from(wt(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 j(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),j(this,Ut(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),j(this,Jt(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),j(this,Vt(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 j(this,_t(t,n,r,s))}skewX(t){return j(this,Kt(t))}skewY(t){return j(this,Wt(t))}skew(t,n){return j(this,yt(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}}}k(v,"Translate",Ut),k(v,"Rotate",Vt),k(v,"RotateAxisAngle",_t),k(v,"Scale",Jt),k(v,"SkewX",Kt),k(v,"SkewY",Wt),k(v,"Skew",yt),k(v,"Multiply",j),k(v,"fromArray",it),k(v,"fromMatrix",Ht),k(v,"fromString",Ft),k(v,"toArray",wt),k(v,"isCompatibleArray",Bt),k(v,"isCompatibleObject",Yt);const gt={x1:0,y1:0,x2:0,y2:0,x:0,y:0,qx:null,qy:null},D=(e,t)=>{const n={...gt};let r=e.length,s;for(let i=0;i<r;i+=1){s=e[i];const o=t(s,n,i);e[i]=o,o[0]==="C"&&(r=e.length),s=e[i];const c=s.length;n.x1=+s[c-2],n.y1=+s[c-1],n.x2=+s[c-4]||n.x1,n.y2=+s[c-3]||n.y1}return e},V=(e,t)=>{const[n]=e,{x:r,y:s}=t,i=e.slice(1).map(Number),o=n.toUpperCase();if(!(o===n)){if(o==="A")return[o,i[0],i[1],i[2],i[3],i[4],i[5]+r,i[6]+s];if(o==="V")return[o,i[0]+s];if(o==="H")return[o,i[0]+r];{const l=i.map((a,m)=>a+(m%2?s:r));return[o,...l]}}return e},G=(e,t)=>{const[n]=e,{x1:r,y1:s,x2:i,y2:o}=t,c=e.slice(1).map(Number);if("TQ".includes(n)||(t.qx=null,t.qy=null),n==="H")return["L",e[1],s];if(n==="V")return["L",r,e[1]];if(n==="S"){const l=r*2-i,a=s*2-o;return t.x1=l,t.y1=a,["C",l,a,...c]}else if(n==="T"){const l=r*2-(t.qx?t.qx:0),a=s*2-(t.qy?t.qy:0);return t.qx=l,t.qy=a,["Q",l,a,...c]}else if(n==="Q"){const[l,a]=c;t.qx=l,t.qy=a}return e},R=(e,t,n)=>{const[r,s]=e,[i,o]=t;return[r+(i-r)*n,s+(o-s)*n]},at=(e,t,n,r)=>Pt([e,t],[n,r]),Gt=(e,t,n,r,s)=>{const i=Pt([e,t],[n,r]);let o={x:e,y:t};if(typeof s=="number")if(s<=0)o={x:e,y:t};else if(s>=i)o={x:n,y:r};else{const[c,l]=R([e,t],[n,r],s/i);o={x:c,y:l}}return o},kt=(e,t,n,r)=>{const{min:s,max:i}=Math;return{min:{x:s(e,n),y:s(t,r)},max:{x:i(e,n),y:i(t,r)}}},te=(e,t,n)=>{const r=n/2,s=Math.sin(r),i=Math.cos(r),o=e**2*s**2,c=t**2*i**2,l=Math.sqrt(o+c)*n;return Math.abs(l)},K=(e,t,n,r,s,i)=>{const o=Math.cos(i),c=Math.sin(i),l=r*Math.cos(e),a=s*Math.sin(e);return{x:t+o*l-c*a,y:n+c*l+o*a}},qt=(e,t)=>{const{x:n,y:r}=e,{x:s,y:i}=t,o=n*s+r*i,c=Math.sqrt((n**2+r**2)*(s**2+i**2));return(n*i-r*s<0?-1:1)*Math.acos(o/c)},Lt=(e,t,n,r,s,i,o,c,l)=>{const{abs:a,sin:m,cos:u,sqrt:g,PI:f}=Math;let h=a(n),y=a(r);const p=(s%360+360)%360*(f/180);if(e===c&&t===l)return{rx:h,ry:y,startAngle:0,endAngle:0,center:{x:c,y:l}};if(h===0||y===0)return{rx:h,ry:y,startAngle:0,endAngle:0,center:{x:c,y:l}};const d=(e-c)/2,C=(t-l)/2,M={x:u(p)*d+m(p)*C,y:-m(p)*d+u(p)*C},b=M.x**2/h**2+M.y**2/y**2;b>1&&(h*=g(b),y*=g(b));const w=h**2*y**2-h**2*M.y**2-y**2*M.x**2,T=h**2*M.y**2+y**2*M.x**2;let P=w/T;P=P<0?0:P;const $=(i!==o?1:-1)*g(P),S={x:$*(h*M.y/y),y:$*(-(y*M.x)/h)},_={x:u(p)*S.x-m(p)*S.y+(e+c)/2,y:m(p)*S.x+u(p)*S.y+(t+l)/2},X={x:(M.x-S.x)/h,y:(M.y-S.y)/y},Q=qt({x:1,y:0},X),B={x:(-M.x-S.x)/h,y:(-M.y-S.y)/y};let I=qt(X,B);!o&&I>0?I-=2*f:o&&I<0&&(I+=2*f),I%=2*f;const J=Q+I;return{center:_,startAngle:Q,endAngle:J,rx:h,ry:y}},ee=(e,t,n,r,s,i,o,c,l)=>{const{rx:a,ry:m,startAngle:u,endAngle:g}=Lt(e,t,n,r,s,i,o,c,l);return te(a,m,g-u)},Pe=(e,t,n,r,s,i,o,c,l,a)=>{let m={x:e,y:t};const{center:u,rx:g,ry:f,startAngle:h,endAngle:y}=Lt(e,t,n,r,s,i,o,c,l),x=te(g,f,y-h);if(typeof a=="number")if(a<=0)m={x:e,y:t};else if(a>=x)m={x:c,y:l};else{if(e===c&&t===l)return{x:c,y:l};if(g===0||f===0)return Gt(e,t,c,l,a);const{PI:p,cos:d,sin:C}=Math,M=y-h,w=(s%360+360)%360*(p/180),T=h+M*(a/x),P=g*d(T),$=f*C(T);m={x:d(w)*P-C(w)*$+u.x,y:C(w)*P+d(w)*$+u.y}}return m},Le=(e,t,n,r,s,i,o,c,l)=>{const{center:a,rx:m,ry:u,startAngle:g,endAngle:f}=Lt(e,t,n,r,s,i,o,c,l),h=f-g,y={x:c,y:l},[x,p]=[a.x,a.y],d=[y],C=s*Math.PI/180,M=Math.tan(C),b=Math.atan2(-u*M,m),w=b,T=b+Math.PI,P=Math.atan2(u,m*M),$=P+Math.PI,S=[e,c],_=[t,l],X=Math.min(...S),Q=Math.max(...S),B=Math.min(..._),I=Math.max(..._),J=f-h*.001,z=K(J,x,p,m,u,C),ot=f-h*.999,Y=K(ot,x,p,m,u,C);return(z.x>Q||Y.x>Q)&&d.push(K(w,x,p,m,u,C)),(z.x<X||Y.x<X)&&d.push(K(T,x,p,m,u,C)),(z.y<B||Y.y<B)&&d.push(K($,x,p,m,u,C)),(z.y>I||Y.y>I)&&d.push(K(P,x,p,m,u,C)),{min:{x:Math.min(...d.map(O=>O.x)),y:Math.min(...d.map(O=>O.y))},max:{x:Math.max(...d.map(O=>O.x)),y:Math.max(...d.map(O=>O.y))}}},Te={x:0,y:0},It=[-.06405689286260563,.06405689286260563,-.1911188674736163,.1911188674736163,-.3150426796961634,.3150426796961634,-.4337935076260451,.4337935076260451,-.5454214713888396,.5454214713888396,-.6480936519369755,.6480936519369755,-.7401241915785544,.7401241915785544,-.820001985973903,.820001985973903,-.8864155270044011,.8864155270044011,-.9382745520027328,.9382745520027328,-.9747285559713095,.9747285559713095,-.9951872199970213,.9951872199970213],Se=[.12793819534675216,.12793819534675216,.1258374563468283,.1258374563468283,.12167047292780339,.12167047292780339,.1155056680537256,.1155056680537256,.10744427011596563,.10744427011596563,.09761865210411388,.09761865210411388,.08619016153195327,.08619016153195327,.0733464814110803,.0733464814110803,.05929858491543678,.05929858491543678,.04427743881741981,.04427743881741981,.028531388628933663,.028531388628933663,.0123412297999872,.0123412297999872],$e=e=>{const t=[];for(let n=e,r=n.length,s=r-1;r>1;r-=1,s-=1){const i=[];for(let o=0;o<s;o+=1)i.push({x:s*(n[o+1].x-n[o].x),y:s*(n[o+1].y-n[o].y),t:0});t.push(i),n=i}return t},ke=(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 r=1-t;let s=e;if(n===0)return e[0].t=t,e[0];if(n===1)return{x:r*s[0].x+t*s[1].x,y:r*s[0].y+t*s[1].y,t};const i=r*r,o=t*t;let c=0,l=0,a=0,m=0;return n===2?(s=[s[0],s[1],s[2],Te],c=i,l=r*t*2,a=o):n===3&&(c=i*r,l=i*t*3,a=r*o*3,m=t*o),{x:c*s[0].x+l*s[1].x+a*s[2].x+m*s[3].x,y:c*s[0].y+l*s[1].y+a*s[2].y+m*s[3].y,t}},qe=(e,t)=>{const n=e(t),r=n.x*n.x+n.y*n.y;return Math.sqrt(r)},Ie=e=>{const n=It.length;let r=0;for(let s=0,i;s<n;s++)i=.5*It[s]+.5,r+=Se[s]*qe(e,i);return .5*r},xt=e=>{const t=[];for(let r=0,s=e.length,i=2;r<s;r+=i)t.push({x:e[r],y:e[r+1]});const n=$e(t);return Ie(r=>ke(n[0],r))},Ee=1e-8,Nt=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 r=(e[0]*e[2]-e[1]*e[1])/(e[0]-2*e[1]+e[2]);return r<t?[r,n]:[t,r]},Et=e=>{const t=e[0]-3*e[1]+3*e[2]-e[3];if(Math.abs(t)<Ee)return e[0]===e[3]&&e[0]===e[1]?[e[0],e[3]]:Nt([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 r=Math.sqrt(n);let s=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+r)/t,l=1;l<=2;c=(o-r)/t,l++)if(c>0&&c<1){const a=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;a<s&&(s=a),a>i&&(i=a)}return[s,i]},ze=([e,t,n,r,s,i,o,c],l)=>{const a=1-l;return{x:a**3*e+3*a**2*l*n+3*a*l**2*s+l**3*o,y:a**3*t+3*a**2*l*r+3*a*l**2*i+l**3*c}},ne=(e,t,n,r,s,i,o,c)=>xt([e,t,n,r,s,i,o,c]),Ze=(e,t,n,r,s,i,o,c,l)=>{const a=typeof l=="number";let m={x:e,y:t};if(a){const u=xt([e,t,n,r,s,i,o,c]);l<=0||(l>=u?m={x:o,y:c}:m=ze([e,t,n,r,s,i,o,c],l/u))}return m},Oe=(e,t,n,r,s,i,o,c)=>{const l=Et([e,n,s,o]),a=Et([t,r,i,c]);return{min:{x:l[0],y:a[0]},max:{x:l[1],y:a[1]}}},je=([e,t,n,r,s,i],o)=>{const c=1-o;return{x:c**2*e+2*c*o*n+o**2*s,y:c**2*t+2*c*o*r+o**2*i}},se=(e,t,n,r,s,i)=>xt([e,t,n,r,s,i]),Re=(e,t,n,r,s,i,o)=>{const c=typeof o=="number";let l={x:e,y:t};if(c){const a=xt([e,t,n,r,s,i]);o<=0||(o>=a?l={x:s,y:i}:l=je([e,t,n,r,s,i],o/a))}return l},De=(e,t,n,r,s,i)=>{const o=Nt([e,n,s]),c=Nt([t,r,i]);return{min:{x:o[0],y:c[0]},max:{x:o[1],y:c[1]}}},zt=e=>{if(!e)return{x:0,y:0,width:0,height:0,x2:0,y2:0,cx:0,cy:0,cz:0};const t=q(e);let n=[],r="M",s=0,i=0,o=0,c=0;const l=[],a=[];let m={x:s,y:i},u={x:s,y:i};D(t,(d,C)=>{const M=V(d,C),b=G(M,C);return[r]=b,n=[s,i,...b.slice(1)],r==="M"?([,o,c]=b,m={x:o,y:c},u={x:o,y:c}):r==="L"?{min:m,max:u}=kt(...n):r==="A"?{min:m,max:u}=Le(...n):r==="C"?{min:m,max:u}=Oe(...n):r==="Q"?{min:m,max:u}=De(...n):r==="Z"&&(n=[s,i,o,c],{min:m,max:u}=kt(...n)),l.push(m),a.push(u),r==="Z"?(s=o,i=c):([s,i]=b.slice(-2),r==="M"&&(o=s,c=i)),C.x=s,C.y=i,b});const g=Math.min(...l.map(d=>d.x)),f=Math.max(...a.map(d=>d.x)),h=Math.min(...l.map(d=>d.y)),y=Math.max(...a.map(d=>d.y)),x=f-g,p=y-h;return{width:x,height:p,x:g,y:h,x2:f,y2:y,cx:g+x/2,cy:h+p/2,cz:Math.max(x,p)+Math.min(x,p)/2}},ct=(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}},re=(e,t,n,r,s,i,o,c,l,a)=>{let m=e,u=t,g=n,f=r,h=c,y=l;const x=Math.PI*120/180,p=Math.PI/180*(+s||0);let d=[],C,M,b,w,T;if(a)[M,b,w,T]=a;else{C=ct(m,u,-p),m=C.x,u=C.y,C=ct(h,y,-p),h=C.x,y=C.y;const L=(m-h)/2,Z=(u-y)/2;let H=L*L/(g*g)+Z*Z/(f*f);H>1&&(H=Math.sqrt(H),g*=H,f*=H);const Mt=g*g,bt=f*f,St=(i===o?-1:1)*Math.sqrt(Math.abs((Mt*bt-Mt*Z*Z-bt*L*L)/(Mt*Z*Z+bt*L*L)));w=St*g*Z/f+(m+h)/2,T=St*-f*L/g+(u+y)/2,M=Math.asin(((u-T)/f*10**9>>0)/10**9),b=Math.asin(((y-T)/f*10**9>>0)/10**9),M=m<w?Math.PI-M:M,b=h<w?Math.PI-b:b,M<0&&(M=Math.PI*2+M),b<0&&(b=Math.PI*2+b),o&&M>b&&(M-=Math.PI*2),!o&&b>M&&(b-=Math.PI*2)}let P=b-M;if(Math.abs(P)>x){const L=b,Z=h,H=y;b=M+x*(o&&b>M?1:-1),h=w+g*Math.cos(b),y=T+f*Math.sin(b),d=re(h,y,g,f,s,0,o,Z,H,[b,L,w,T])}P=b-M;const $=Math.cos(M),S=Math.sin(M),_=Math.cos(b),X=Math.sin(b),Q=Math.tan(P/4),B=4/3*g*Q,I=4/3*f*Q,J=[m,u],z=[m+B*S,u-I*$],ot=[h+B*X,y-I*_],Y=[h,y];if(z[0]=2*J[0]-z[0],z[1]=2*J[1]-z[1],a)return[...z,...ot,...Y,...d];d=[...z,...ot,...Y,...d];const O=[];for(let L=0,Z=d.length;L<Z;L+=1)O[L]=L%2?ct(d[L-1],d[L],p).y:ct(d[L],d[L+1],p).x;return O},Qe=(e,t,n,r,s,i)=>{const o=.3333333333333333,c=2/3;return[o*e+c*n,o*t+c*r,o*s+c*n,o*i+c*r,s,i]},Zt=(e,t,n,r)=>{const s=R([e,t],[n,r],.3333333333333333),i=R([e,t],[n,r],2/3);return[...s,...i,n,r]},ie=(e,t)=>{const[n]=e,r=e.slice(1).map(Number),[s,i]=r;let o;const{x1:c,y1:l,x:a,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=[c,l,...r],["C",...re(...o)]):n==="Q"?(t.qx=s,t.qy=i,o=[c,l,...r],["C",...Qe(...o)]):n==="L"?["C",...Zt(c,l,s,i)]:n==="Z"?["C",...Zt(c,l,a,m)]:e},mt=e=>{let t=0,n=0,r=0,s=0,i="M";const o=q(e);return D(o,(c,l,a)=>{const m=V(c,l);[i]=m;const u=i.toUpperCase(),g=G(m,l);let f=ie(g,l);return f[0]==="C"&&f.length>7&&(o.splice(a+1,0,["C",...f.slice(7)]),f=f.slice(0,7)),u==="Z"?(t=r,n=s):([t,n]=f.slice(-2),u==="M"&&(r=t,s=n)),l.x=t,l.y=n,f})},Xe=(e,t,n,r,s,i,o,c)=>3*((c-t)*(n+s)-(o-e)*(r+i)+r*(e-s)-n*(t-i)+c*(s+e/3)-o*(i+t/3))/20,oe=e=>{let t=0,n=0,r=0;return mt(e).map(s=>{switch(s[0]){case"M":return[,t,n]=s,0;default:return r=Xe(t,n,...s.slice(1)),[t,n]=s.slice(-2),r}}).reduce((s,i)=>s+i,0)},W=e=>{const t=q(e);let n=!1,r=[],s="M",i=0,o=0,c=0,l=0,a=0;return D(t,(m,u)=>{const g=V(m,u),f=G(g,u);return[s]=f,n=s==="M",r=n?r:[i,o,...f.slice(1)],n?[,c,l]=m:s==="L"?a+=at(...r):s==="A"?a+=ee(...r):s==="C"?a+=ne(...r):s==="Q"?a+=se(...r):s==="Z"&&(r=[i,o,c,l],a+=at(...r)),s==="Z"?(i=c,o=l):([i,o]=f.slice(-2),n&&(c=i,l=o)),u.x=i,u.y=o,f}),a},Be=e=>oe(mt(e))>=0,At=1e-5,nt=(e,t)=>{const n=q(e);let r=!1,s=[],i="M",o=0,c=0,[l,a]=n[0].slice(1);const m=typeof t=="number";let u={x:l,y:a},g=0,f=u,h=0;return m?(t<At&&(f=u),D(n,(y,x)=>{const p=V(y,x),d=G(p,x);return[i]=d,r=i==="M",s=r?s:[o,c,...d.slice(1)],r?([,l,a]=y,u={x:l,y:a},g=0):i==="L"?(u=Gt(...s,t-h),g=at(...s)):i==="A"?(u=Pe(...s,t-h),g=ee(...s)):i==="C"?(u=Ze(...s,t-h),g=ne(...s)):i==="Q"?(u=Re(...s,t-h),g=se(...s)):i==="Z"&&(s=[o,c,l,a],u={x:l,y:a},g=at(...s)),h<t&&h+g>=t&&(f=u),h+=g,i==="Z"?(o=l,c=a):([o,c]=d.slice(-2),i==="M"&&(l=o,a=c)),x.x=o,x.y=c,d}),t>h-At&&(f={x:o,y:c}),f):u},Tt=(e,t)=>{const n=q(e);let r=n.slice(0),s=W(r),i=r.length-1,o=0,c=0,l=n[0];const[a,m]=l.slice(-2),u={x:a,y:m};if(i<=0||!t||!Number.isFinite(t))return{segment:l,index:0,length:c,point:u,lengthAtSegment:o};if(t>=s)return r=n.slice(0,-1),o=W(r),c=s-o,{segment:n[i],index:i,length:c,lengthAtSegment:o};const g=[];for(;i>0;)l=r[i],r=r.slice(0,-1),o=W(r),c=s-o,s=o,g.push({segment:l,index:i,length:c,lengthAtSegment:o}),i-=1;return g.find(({lengthAtSegment:f})=>f<=t)},rt=e=>{let t=0,n=0,r=0,s=0,i="M";return D(q(e),(o,c)=>{const l=V(o,c),a=G(l,c);[i]=a;const m=i.toUpperCase();return m==="Z"?(t=r,n=s):([t,n]=a.slice(-2),m==="M"&&(r=t,s=n)),c.x=t,c.y=n,a})},pt=(e,t)=>{const n=q(e),r=rt(n),s=W(n),i=M=>{const b=M.x-t.x,w=M.y-t.y;return b*b+w*w};let o=8,c,l={x:0,y:0},a=0,m=0,u=1/0;for(let M=0;M<=s;M+=o)c=nt(r,M),a=i(c),a<u&&(l=c,m=M,u=a);o/=2;let g,f,h=0,y=0,x=0,p=0;for(;o>1e-6&&(h=m-o,g=nt(r,h),x=i(g),y=m+o,f=nt(r,y),p=i(f),h>=0&&x<u?(l=g,m=h,u=x):y<=s&&p<u?(l=f,m=y,u=p):o/=2,!(o<1e-5)););const d=Tt(n,m),C=Math.sqrt(u);return{closest:l,distance:C,segment:d}},Ye=(e,t)=>pt(e,t).closest,He=(e,t)=>pt(e,t).segment,Fe=(e,t)=>Tt(e,t).segment,Ue=(e,t)=>{const{distance:n}=pt(e,t);return Math.abs(n)<At},ce=e=>{if(typeof e!="string"||!e.length)return!1;const t=new Xt(e);for(et(t);t.index<t.max&&!t.err.length;)Qt(t);return!t.err.length&&"mM".includes(t.segments[0][0])},dt=e=>Array.isArray(e)&&e.every(t=>{const n=t[0].toLowerCase();return tt[n]===t.length-1&&"achlmqstvz".includes(n)&&t.slice(1).every(Number.isFinite)})&&e.length>0,le=e=>dt(e)&&e.every(([t])=>t===t.toUpperCase()),Ve=e=>dt(e)&&e.slice(1).every(([t])=>t===t.toLowerCase()),ae=e=>le(e)&&e.every(([t])=>"ACLMQZ".includes(t)),_e=e=>ae(e)&&e.every(([t])=>"MC".includes(t)),ut={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"]},Je=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]]},Ke=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},We=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]]},Ge=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]]},tn=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"]]},me=(e,t)=>{const r=(t||document).defaultView||window,s=Object.keys(ut),i=e instanceof r.SVGElement,o=i?e.tagName:null;if(o&&[...s,"path"].every(u=>o!==u))throw TypeError(`${E}: "${o}" is not SVGElement`);const c=i?o:e.type,l=ut[c],a={type:c};i?l.forEach(u=>{a[u]=e.getAttribute(u)}):Object.assign(a,e);let m=[];return c==="circle"?m=We(a):c==="ellipse"?m=Ge(a):["polyline","polygon"].includes(c)?m=Ke(a):c==="rect"?m=tn(a):c==="line"?m=Je(a):["glyph","path"].includes(c)&&(m=q(i?e.getAttribute("d")||"":e.d||"")),dt(m)&&m.length?m:!1},ht=(e,t)=>{let{round:n}=st;if(t==="off"||n==="off")return e.slice(0);n=typeof t=="number"&&t>=0?t:n;const r=typeof n=="number"&&n>=1?10**n:1;return D(e,s=>{const i=s.slice(1).map(o=>n?Math.round(o*r)/r:Math.round(o));return[s[0],...i]})},Ct=(e,t)=>ht(e,t).map(n=>n[0]+n.slice(1).join(" ")).join(""),en=(e,t,n)=>{const r=n||document,s=r.defaultView||window,i=Object.keys(ut),o=e instanceof s.SVGElement,c=o?e.tagName:null;if(c==="path")throw TypeError(`${E}: "${c}" is already SVGPathElement`);if(c&&i.every(y=>c!==y))throw TypeError(`${E}: "${c}" is not SVGElement`);const l=r.createElementNS("http://www.w3.org/2000/svg","path"),a=o?c:e.type,m=ut[a],u={type:a},g=st.round,f=me(e,r),h=f&&f.length?Ct(f,g):"";return o?(m.forEach(y=>{u[y]=e.getAttribute(y)}),Object.values(e.attributes).forEach(({name:y,value:x})=>{m.includes(y)||l.setAttribute(y,x)})):(Object.assign(u,e),Object.keys(u).forEach(y=>{!m.includes(y)&&y!=="type"&&l.setAttribute(y.replace(/[A-Z]/g,x=>`-${x.toLowerCase()}`),u[y])})),ce(h)?(l.setAttribute("d",h),t&&o&&(e.before(l,e),e.remove()),l):!1},Ot=e=>{const t=[];let n,r=-1,s=0,i=0,o=0,c=0;const l={...gt};return e.forEach(a=>{const[m]=a,u=m.toUpperCase(),g=m.toLowerCase(),f=m===g,h=a.slice(1);u==="M"?(r+=1,[s,i]=h,s+=f?l.x:0,i+=f?l.y:0,o=s,c=i,n=[f?[u,o,c]:a]):(u==="Z"?(s=o,i=c):u==="H"?([,s]=a,s+=f?l.x:0):u==="V"?([,i]=a,i+=f?l.y:0):([s,i]=a.slice(-2),s+=f?l.x:0,i+=f?l.y:0),n.push(a)),l.x=s,l.y=i,t[r]=n}),t},ue=e=>{let t=new v;const{origin:n}=e,[r,s]=n,{translate:i}=e,{rotate:o}=e,{skew:c}=e,{scale:l}=e;return Array.isArray(i)&&i.length>=2&&i.every(a=>!Number.isNaN(+a))&&i.some(a=>a!==0)?t=t.translate(...i):typeof i=="number"&&!Number.isNaN(i)&&(t=t.translate(i)),(o||c||l)&&(t=t.translate(r,s),Array.isArray(o)&&o.length>=2&&o.every(a=>!Number.isNaN(+a))&&o.some(a=>a!==0)?t=t.rotate(...o):typeof o=="number"&&!Number.isNaN(o)&&(t=t.rotate(o)),Array.isArray(c)&&c.length===2&&c.every(a=>!Number.isNaN(+a))&&c.some(a=>a!==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(l)&&l.length>=2&&l.every(a=>!Number.isNaN(+a))&&l.some(a=>a!==1)?t=t.scale(...l):typeof l=="number"&&!Number.isNaN(l)&&(t=t.scale(l)),t=t.translate(-r,-s)),t},ft=e=>{let t=0,n=0,r=0,s=0,i="M";const o=q(e);return D(o,(c,l)=>{[i]=c;const a=V(c,l),m=i.toUpperCase();return m==="Z"?(t=r,n=s):m==="H"?[,t]=a:m==="V"?[,n]=a:([t,n]=a.slice(-2),m==="M"&&(r=t,s=n)),l.x=t,l.y=n,a})},nn=(e,t,n)=>{const[r]=e,{x:s,y:i}=t,o=e.slice(1).map(Number),c=r.toLowerCase();if(n===0&&r==="M")return e;if(r!==c){if(c==="a")return[c,o[0],o[1],o[2],o[3],o[4],o[5]-s,o[6]-i];if(c==="v")return[c,o[0]-i];if(c==="h")return[c,o[0]-s];{const l=o.map((a,m)=>a-(m%2?i:s));return[c,...l]}}return e},vt=e=>{let t=0,n=0,r=0,s=0,i="M";const o=q(e);return D(o,(c,l,a)=>{[i]=c;const m=nn(c,l,a),[u]=m,g=i.toUpperCase(),f=i.toLowerCase(),h=u===f;return g==="Z"?(t=r,n=s):g==="H"?([,t]=m,t+=h?l.x:0):g==="V"?([,n]=m,n+=h?l.y:0):([t,n]=m.slice(-2),t+=h?l.x:0,n+=h?l.y:0,g==="M"&&(r=t,s=n)),l.x=t,l.y=n,m})},sn=(e,t,n,r)=>{const[s]=e,i=p=>Math.round(p*10**4)/10**4,o=e.slice(1),c=t.slice(1),{x1:l,y1:a,x2:m,y2:u,x:g,y:f}=n;let h=e;const[y,x]=c.slice(-2);if("TQ".includes(s)||(n.qx=null,n.qy=null),["V","H","S","T","Z"].includes(s))h=[s,...o];else if(s==="L")i(g)===i(y)?h=["V",x]:i(f)===i(x)&&(h=["H",y]);else if(s==="C"){const[p,d]=c;"CS".includes(r)&&(i(p)===i(l*2-m)&&i(d)===i(a*2-u)||i(l)===i(m*2-g)&&i(a)===i(u*2-f))&&(h=["S",...c.slice(-4)]),n.x1=p,n.y1=d}else if(s==="Q"){const[p,d]=c;n.qx=p,n.qy=d,"QT".includes(r)&&(i(p)===i(l*2-m)&&i(d)===i(a*2-u)||i(l)===i(m*2-g)&&i(a)===i(u*2-f))&&(h=["T",...c.slice(-2)])}return h},jt=(e,t)=>{const n=ft(e),r=rt(n),s={...gt},i=[],o=n.length;let c="",l="",a=0,m=0,u=0,g=0;for(let y=0;y<o;y+=1){[c]=n[y],i[y]=c,y&&(l=i[y-1]),n[y]=sn(n[y],r[y],s,l);const x=n[y],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,c){case"Z":a=u,m=g;break;case"H":[,a]=x;break;case"V":[,m]=x;break;default:[a,m]=x.slice(-2).map(Number),c==="M"&&(u=a,g=m)}s.x=a,s.y=m}const f=ht(n,t),h=ht(vt(n),t);return f.map((y,x)=>x?y.join("").length<h[x].join("").length?y:h[x]:y)},rn=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)])]},lt=e=>{const t=ft(e),n=t.slice(-1)[0][0]==="Z",r=rt(t).map((s,i)=>{const[o,c]=s.slice(-2).map(Number);return{seg:t[i],n:s,c:t[i][0],x:o,y:c}}).map((s,i,o)=>{const c=s.seg,l=s.n,a=i&&o[i-1],m=o[i+1],u=s.c,g=o.length,f=i?o[i-1].x:o[g-1].x,h=i?o[i-1].y:o[g-1].y;let y=[];switch(u){case"M":y=n?["Z"]:[u,f,h];break;case"A":y=[u,...c.slice(1,-3),c[5]===1?0:1,f,h];break;case"C":m&&m.c==="S"?y=["S",c[1],c[2],f,h]:y=[u,c[3],c[4],c[1],c[2],f,h];break;case"S":a&&"CS".includes(a.c)&&(!m||m.c!=="S")?y=["C",l[3],l[4],l[1],l[2],f,h]:y=[u,l[1],l[2],f,h];break;case"Q":m&&m.c==="T"?y=["T",f,h]:y=[u,...c.slice(1,-2),f,h];break;case"T":a&&"QT".includes(a.c)&&(!m||m.c!=="T")?y=["Q",l[1],l[2],f,h]:y=[u,f,h];break;case"Z":y=["M",f,h];break;case"H":y=[u,f];break;case"V":y=[u,h];break;default:y=[u,...c.slice(1,-2),f,h]}return y});return n?r.reverse():[r[0],...r.slice(1).reverse()]},on=(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]},Rt=(e,t,n)=>{const[r,s,i]=n,[o,c,l]=on(e,[...t,0,1]),a=o-r,m=c-s,u=l-i;return[a*(Math.abs(i)/Math.abs(u)||1)+r,m*(Math.abs(i)/Math.abs(u)||1)+s]},Dt=(e,t)=>{let n=0,r=0,s=0,i=0,o=0,c=0,l=0,a=0,m=0,u=0,g="M";const f={...gt},h=q(e),y=t&&Object.keys(t);if(!t||y&&!y.length)return h;t.origin||Object.assign(t,{origin:st.origin});const x=t.origin,p=ue(t);return p.isIdentity?h:D(h,(d,C,M)=>{const b=V(d,f);[g]=b;let w=g==="A"?ie(b,f):["V","H"].includes(g)?G(b,f):b;const T=w[0]==="C"&&w.length>7,P=T?w.slice(0,7):w.slice(0);if(T&&(h.splice(M+1,0,["C",...w.slice(7)]),w=w.slice(0,7)),w[0]==="L"){const S=w.slice(-2);[o,c]=Rt(p,S,x),n!==o&&r!==c?w=["L",o,c]:r===c?w=["H",o]:n===o&&(w=["V",c])}else for(l=1,a=w.length;l<a;l+=2)[o,c]=Rt(p,[+w[l],+w[l+1]],x),w[l]=o,w[l+1]=c;n=o,r=c,g==="Z"?(m=s,u=i):([m,u]=P.slice(-2),g==="M"&&(s=m,i=u));const $=P.length;return f.x1=+P[$-2],f.y1=+P[$-1],f.x2=+P[$-4]||f.x1,f.y2=+P[$-3]||f.y1,f.x=m,f.y=u,w})},cn=(e,t=.5)=>{const n=t,r=e.slice(0,2),s=e.slice(2,4),i=e.slice(4,6),o=e.slice(6,8),c=R(r,s,n),l=R(s,i,n),a=R(i,o,n),m=R(c,l,n),u=R(l,a,n),g=R(m,u,n);return[["C",...c,...m,...g],["C",...u,...a,...o]]};class A{constructor(t,n){const r=n||{},s=typeof t>"u";if(s||!t.length)throw TypeError(`${E}: "pathValue" is ${s?"undefined":"empty"}`);const i=q(t);this.segments=i;const{round:o,origin:c}=r;let l;Number.isInteger(o)||o==="off"?l=o:l=st.round;let a=st.origin;if(Array.isArray(c)&&c.length>=2){const[m,u,g]=c.map(Number);a=[Number.isNaN(m)?0:m,Number.isNaN(u)?0:u,Number.isNaN(g)?0:g]}return this.round=l,this.origin=a,this}get bbox(){return zt(this.segments)}get length(){return W(this.segments)}getBBox(){return this.bbox}getTotalLength(){return this.length}getPointAtLength(t){return nt(this.segments,t)}toAbsolute(){const{segments:t}=this;return this.segments=ft(t),this}toRelative(){const{segments:t}=this;return this.segments=vt(t),this}toCurve(){const{segments:t}=this;return this.segments=mt(t),this}reverse(t){this.toAbsolute();const{segments:n}=this,r=Ot(n),s=r.length>1?r:!1,i=s?s.map((c,l)=>t?l?lt(c):c.slice(0):lt(c)):n.slice(0);let o=[];return s?o=i.flat(1):o=t?n:lt(n),this.segments=o.slice(0),this}normalize(){const{segments:t}=this;return this.segments=rt(t),this}optimize(){const{segments:t}=this;return this.segments=jt(t,this.round),this}transform(t){if(!t||typeof t!="object"||typeof t=="object"&&!["translate","rotate","skew","scale"].some(l=>l in t))return this;const{segments:n,origin:[r,s,i]}=this,o={};for(const[l,a]of Object.entries(t))l==="skew"&&Array.isArray(a)||(l==="rotate"||l==="translate"||l==="origin"||l==="scale")&&Array.isArray(a)?o[l]=a.map(Number):l!=="origin"&&typeof Number(a)=="number"&&(o[l]=Number(a));const{origin:c}=o;if(Array.isArray(c)&&c.length>=2){const[l,a,m]=c.map(Number);o.origin=[Number.isNaN(l)?r:l,Number.isNaN(a)?s:a,m||i]}else o.origin=[r,s,i];return this.segments=Dt(n,o),this}flipX(){const{cx:t,cy:n}=this.bbox;return this.transform({rotate:[0,180,0],origin:[t,n,0]}),this}flipY(){const{cx:t,cy:n}=this.bbox;return this.transform({rotate:[180,0,0],origin:[t,n,0]}),this}toString(){return Ct(this.segments,this.round)}}N(A,"CSSMatrix",v),N(A,"getSVGMatrix",ue),N(A,"getPathBBox",zt),N(A,"getPathArea",oe),N(A,"getTotalLength",W),N(A,"getDrawDirection",Be),N(A,"getPointAtLength",nt),N(A,"getPropertiesAtLength",Tt),N(A,"getPropertiesAtPoint",pt),N(A,"polygonLength",Ne),N(A,"polygonArea",we),N(A,"getClosestPoint",Ye),N(A,"getSegmentOfPoint",He),N(A,"getSegmentAtLength",Fe),N(A,"isPointInStroke",Ue),N(A,"isValidPath",ce),N(A,"isPathArray",dt),N(A,"isAbsoluteArray",le),N(A,"isRelativeArray",Ve),N(A,"isCurveArray",_e),N(A,"isNormalizedArray",ae),N(A,"shapeToPath",en),N(A,"shapeToPathArray",me),N(A,"parsePathString",q),N(A,"roundPath",ht),N(A,"splitPath",Ot),N(A,"splitCubic",cn),N(A,"optimizePath",jt),N(A,"reverseCurve",rn),N(A,"reversePath",lt),N(A,"normalizePath",rt),N(A,"transformPath",Dt),N(A,"pathToAbsolute",ft),N(A,"pathToRelative",vt),N(A,"pathToCurve",mt),N(A,"pathToString",Ct);module.exports=A;
|
|
1
|
+
"use strict";var je=Object.defineProperty;var Qe=(e,t,s)=>t in e?je(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s;var d=(e,t,s)=>Qe(e,typeof t!="symbol"?t+"":t,s);var Ze=Object.defineProperty,De=(e,t,s)=>t in e?Ze(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s,S=(e,t,s)=>De(e,typeof t!="symbol"?t+"":t,s);const Oe={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},Gt=e=>(e instanceof Float64Array||e instanceof Float32Array||Array.isArray(e)&&e.every(t=>typeof t=="number"))&&[6,16].some(t=>e.length===t),te=e=>e instanceof DOMMatrix||e instanceof T||typeof e=="object"&&Object.keys(Oe).every(t=>e&&t in e),lt=e=>{const t=new T,s=Array.from(e);if(!Gt(s))throw TypeError(`CSSMatrix: "${s.join(",")}" must be an array with 6/16 numbers.`);if(s.length===16){const[r,n,i,o,l,c,a,u,m,h,g,f,y,p,M,N]=s;t.m11=r,t.a=r,t.m21=l,t.c=l,t.m31=m,t.m41=y,t.e=y,t.m12=n,t.b=n,t.m22=c,t.d=c,t.m32=h,t.m42=p,t.f=p,t.m13=i,t.m23=a,t.m33=g,t.m43=M,t.m14=o,t.m24=u,t.m34=f,t.m44=N}else if(s.length===6){const[r,n,i,o,l,c]=s;t.m11=r,t.a=r,t.m12=n,t.b=n,t.m21=i,t.c=i,t.m22=o,t.d=o,t.m41=l,t.e=l,t.m42=c,t.f=c}return t},ee=e=>{if(te(e))return lt([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.`)},ne=e=>{if(typeof e!="string")throw TypeError(`CSSMatrix: "${JSON.stringify(e)}" is not a string.`);const t=String(e).replace(/\s/g,"");let s=new T;const r=`CSSMatrix: invalid transform string "${e}"`;return t.split(")").filter(n=>n).forEach(n=>{const[i,o]=n.split("(");if(!o)throw TypeError(r);const l=o.split(",").map(f=>f.includes("rad")?parseFloat(f)*(180/Math.PI):parseFloat(f)),[c,a,u,m]=l,h=[c,a,u],g=[c,a,u,m];if(i==="perspective"&&c&&[a,u].every(f=>f===void 0))s.m34=-1/c;else if(i.includes("matrix")&&[6,16].includes(l.length)&&l.every(f=>!Number.isNaN(+f))){const f=l.map(y=>Math.abs(y)<1e-6?0:y);s=s.multiply(lt(f))}else if(i==="translate3d"&&h.every(f=>!Number.isNaN(+f)))s=s.translate(c,a,u);else if(i==="translate"&&c&&u===void 0)s=s.translate(c,a||0,0);else if(i==="rotate3d"&&g.every(f=>!Number.isNaN(+f))&&m)s=s.rotateAxisAngle(c,a,u,m);else if(i==="rotate"&&c&&[a,u].every(f=>f===void 0))s=s.rotate(0,0,c);else if(i==="scale3d"&&h.every(f=>!Number.isNaN(+f))&&h.some(f=>f!==1))s=s.scale(c,a,u);else if(i==="scale"&&!Number.isNaN(c)&&c!==1&&u===void 0){const f=Number.isNaN(+a)?c:a;s=s.scale(c,f,1)}else if(i==="skew"&&(c||!Number.isNaN(c)&&a)&&u===void 0)s=s.skew(c,a||0);else if(["translate","rotate","scale","skew"].some(f=>i.includes(f))&&/[XYZ]/.test(i)&&c&&[a,u].every(f=>f===void 0))if(i==="skewX"||i==="skewY")s=s[i](c);else{const f=i.replace(/[XYZ]/,""),y=i.replace(f,""),p=["X","Y","Z"].indexOf(y),M=f==="scale"?1:0,N=[p===0?c:M,p===1?c:M,p===2?c:M];s=s[f](...N)}else throw TypeError(r)}),s},zt=(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],se=(e,t,s)=>{const r=new T;return r.m41=e,r.e=e,r.m42=t,r.f=t,r.m43=s,r},re=(e,t,s)=>{const r=new T,n=Math.PI/180,i=e*n,o=t*n,l=s*n,c=Math.cos(i),a=-Math.sin(i),u=Math.cos(o),m=-Math.sin(o),h=Math.cos(l),g=-Math.sin(l),f=u*h,y=-u*g;r.m11=f,r.a=f,r.m12=y,r.b=y,r.m13=m;const p=a*m*h+c*g;r.m21=p,r.c=p;const M=c*h-a*m*g;return r.m22=M,r.d=M,r.m23=-a*u,r.m31=a*g-c*m*h,r.m32=a*h+c*m*g,r.m33=c*u,r},ie=(e,t,s,r)=>{const n=new T,i=Math.sqrt(e*e+t*t+s*s);if(i===0)return n;const o=e/i,l=t/i,c=s/i,a=r*(Math.PI/360),u=Math.sin(a),m=Math.cos(a),h=u*u,g=o*o,f=l*l,y=c*c,p=1-2*(f+y)*h;n.m11=p,n.a=p;const M=2*(o*l*h+c*u*m);n.m12=M,n.b=M,n.m13=2*(o*c*h-l*u*m);const N=2*(l*o*h-c*u*m);n.m21=N,n.c=N;const x=1-2*(y+g)*h;return n.m22=x,n.d=x,n.m23=2*(l*c*h+o*u*m),n.m31=2*(c*o*h+l*u*m),n.m32=2*(c*l*h-o*u*m),n.m33=1-2*(g+f)*h,n},oe=(e,t,s)=>{const r=new T;return r.m11=e,r.a=e,r.m22=t,r.d=t,r.m33=s,r},At=(e,t)=>{const s=new T;if(e){const r=e*Math.PI/180,n=Math.tan(r);s.m21=n,s.c=n}if(t){const r=t*Math.PI/180,n=Math.tan(r);s.m12=n,s.b=n}return s},ce=e=>At(e,0),le=e=>At(0,e),_=(e,t)=>{const s=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,n=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,c=t.m21*e.m13+t.m22*e.m23+t.m23*e.m33+t.m24*e.m43,a=t.m21*e.m14+t.m22*e.m24+t.m23*e.m34+t.m24*e.m44,u=t.m31*e.m11+t.m32*e.m21+t.m33*e.m31+t.m34*e.m41,m=t.m31*e.m12+t.m32*e.m22+t.m33*e.m32+t.m34*e.m42,h=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,y=t.m41*e.m12+t.m42*e.m22+t.m43*e.m32+t.m44*e.m42,p=t.m41*e.m13+t.m42*e.m23+t.m43*e.m33+t.m44*e.m43,M=t.m41*e.m14+t.m42*e.m24+t.m43*e.m34+t.m44*e.m44;return lt([s,r,n,i,o,l,c,a,u,m,h,g,f,y,p,M])};class T{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"?ne(t):Array.isArray(t)||t instanceof Float64Array||t instanceof Float32Array?lt(t):typeof t=="object"?ee(t):this}toFloat32Array(t){return Float32Array.from(zt(this,t))}toFloat64Array(t){return Float64Array.from(zt(this,t))}toString(){const{is2D:t}=this,s=this.toFloat64Array(t).join(", ");return`${t?"matrix":"matrix3d"}(${s})`}toJSON(){const{is2D:t,isIdentity:s}=this;return{...this,is2D:t,isIdentity:s}}multiply(t){return _(this,t)}translate(t,s,r){const n=t;let i=s,o=r;return typeof i>"u"&&(i=0),typeof o>"u"&&(o=0),_(this,se(n,i,o))}scale(t,s,r){const n=t;let i=s,o=r;return typeof i>"u"&&(i=t),typeof o>"u"&&(o=1),_(this,oe(n,i,o))}rotate(t,s,r){let n=t,i=s||0,o=r||0;return typeof t=="number"&&typeof s>"u"&&typeof r>"u"&&(o=n,n=0,i=0),_(this,re(n,i,o))}rotateAxisAngle(t,s,r,n){if([t,s,r,n].some(i=>Number.isNaN(+i)))throw new TypeError("CSSMatrix: expecting 4 values");return _(this,ie(t,s,r,n))}skewX(t){return _(this,ce(t))}skewY(t){return _(this,le(t))}skew(t,s){return _(this,At(t,s))}transformPoint(t){const s=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,n=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(s,r,n,i):{x:s,y:r,z:n,w:i}}}S(T,"Translate",se),S(T,"Rotate",re),S(T,"RotateAxisAngle",ie),S(T,"Scale",oe),S(T,"SkewX",ce),S(T,"SkewY",le),S(T,"Skew",At),S(T,"Multiply",_),S(T,"fromArray",lt),S(T,"fromMatrix",ee),S(T,"fromString",ne),S(T,"toArray",zt),S(T,"isCompatibleArray",Gt),S(T,"isCompatibleObject",te);const V={origin:[0,0,0],round:4},tt={a:7,c:6,h:1,l:2,m:2,r:4,q:4,s:4,t:2,v:1,z:0},qt=e=>{let t=e.pathValue[e.segmentStart],s=t.toLowerCase();const{data:r}=e;for(;r.length>=tt[s]&&(s==="m"&&r.length>2?(e.segments.push([t].concat(r.splice(0,2))),s="l",t=t==="m"?"l":"L"):e.segments.push([t].concat(r.splice(0,tt[s]))),!!tt[s]););},j="SVGPathCommander Error",ae=e=>{const{index:t,pathValue:s}=e,r=s.charCodeAt(t);if(r===48){e.param=0,e.index+=1;return}if(r===49){e.param=1,e.index+=1;return}e.err=`${j}: invalid Arc flag "${s[t]}", expecting 0 or 1 at index ${t}`},U=e=>e>=48&&e<=57,J="Invalid path value",ue=e=>{const{max:t,pathValue:s,index:r}=e;let n=r,i=!1,o=!1,l=!1,c=!1,a;if(n>=t){e.err=`${j}: ${J} at index ${n}, "pathValue" is missing param`;return}if(a=s.charCodeAt(n),(a===43||a===45)&&(n+=1,a=s.charCodeAt(n)),!U(a)&&a!==46){e.err=`${j}: ${J} at index ${n}, "${s[n]}" is not a number`;return}if(a!==46){if(i=a===48,n+=1,a=s.charCodeAt(n),i&&n<t&&a&&U(a)){e.err=`${j}: ${J} at index ${r}, "${s[r]}" illegal number`;return}for(;n<t&&U(s.charCodeAt(n));)n+=1,o=!0;a=s.charCodeAt(n)}if(a===46){for(c=!0,n+=1;U(s.charCodeAt(n));)n+=1,l=!0;a=s.charCodeAt(n)}if(a===101||a===69){if(c&&!o&&!l){e.err=`${j}: ${J} at index ${n}, "${s[n]}" invalid float exponent`;return}if(n+=1,a=s.charCodeAt(n),(a===43||a===45)&&(n+=1),n<t&&U(s.charCodeAt(n)))for(;n<t&&U(s.charCodeAt(n));)n+=1;else{e.err=`${j}: ${J} at index ${n}, "${s[n]}" invalid integer exponent`;return}}e.index=n,e.param=+e.pathValue.slice(r,n)},me=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),et=e=>{const{pathValue:t,max:s}=e;for(;e.index<s&&me(t.charCodeAt(e.index));)e.index+=1},fe=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}},he=e=>U(e)||e===43||e===45||e===46,ye=e=>(e|32)===97,ge=e=>{switch(e|32){case 109:case 77:return!0;default:return!1}},Dt=e=>{var c;const{max:t,pathValue:s,index:r,segments:n}=e,i=s.charCodeAt(r),o=tt[s[r].toLowerCase()];if(e.segmentStart=r,!fe(i)){e.err=`${j}: ${J} "${s[r]}" is not a path command at index ${r}`;return}const l=n[n.length-1];if(!ge(i)&&((c=l==null?void 0:l[0])==null?void 0:c.toLocaleLowerCase())==="z"){e.err=`${j}: ${J} "${s[r]}" is not a MoveTo path command at index ${r}`;return}if(e.index+=1,et(e),e.data=[],!o){qt(e);return}for(;;){for(let a=o;a>0;a-=1){if(ye(i)&&(a===3||a===4)?ae(e):ue(e),e.err.length)return;e.data.push(e.param),et(e),e.index<t&&s.charCodeAt(e.index)===44&&(e.index+=1,et(e))}if(e.index>=e.max||!he(s.charCodeAt(e.index)))break}qt(e)};class Ot{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 Q=e=>{if(typeof e!="string")return e.slice(0);const t=new Ot(e);for(et(t);t.index<t.max&&!t.err.length;)Dt(t);if(t!=null&&t.err.length)throw TypeError(t.err);return t.segments},at=(e,t,s,r)=>{const[n]=e,i=n.toUpperCase();if(t===0||i===n)return e;if(i==="A")return[i,e[1],e[2],e[3],e[4],e[5],e[6]+s,e[7]+r];if(i==="V")return[i,e[1]+r];if(i==="H")return[i,e[1]+s];if(i==="L")return[i,e[1]+s,e[2]+r];{const l=[],c=e.length;for(let a=1;a<c;a+=1)l.push(e[a]+(a%2?s:r));return[i].concat(l)}},Z=(e,t)=>{let s=e.length,r,n="M",i="M",o=!1,l=0,c=0,a=0,u=0,m=0;for(let h=0;h<s;h+=1){r=e[h],[n]=r,m=r.length,i=n.toUpperCase(),o=i!==n;const g=t(r,h,l,c);if(g===!1)break;i==="Z"?(l=a,c=u):i==="H"?l=r[1]+(o?l:0):i==="V"?c=r[1]+(o?c:0):(l=r[m-2]+(o?l:0),c=r[m-1]+(o?c:0),i==="M"&&(a=l,u=c)),g&&(e[h]=g,g[0]==="C"&&(s=e.length))}return e},ht=e=>{const t=Q(e);return Z(t,at)},Bt=(e,t,s,r)=>{const[n]=e,i=n.toLowerCase();if(t===0||n===i)return e;if(i==="a")return[i,e[1],e[2],e[3],e[4],e[5],e[6]-s,e[7]-r];if(i==="v")return[i,e[1]-r];if(i==="h")return[i,e[1]-s];if(i==="l")return[i,e[1]-s,e[2]-r];{const l=[],c=e.length;for(let a=1;a<c;a+=1)l.push(e[a]-(a%2?s:r));return[i].concat(l)}},Kt=e=>{const t=Q(e);return Z(t,Bt)},st=(e,t,s)=>{const{sin:r,cos:n}=Math,i=e*n(s)-t*r(s),o=e*r(s)+t*n(s);return{x:i,y:o}},Mt=(e,t,s,r,n,i,o,l,c,a)=>{let u=e,m=t,h=s,g=r,f=l,y=c;const p=Math.PI*120/180,M=Math.PI/180*(+n||0);let N=[],x,b,L,C,I;if(a)[b,L,C,I]=a;else{x=st(u,m,-M),u=x.x,m=x.y,x=st(f,y,-M),f=x.x,y=x.y;const v=(u-f)/2,O=(m-y)/2;let X=v*v/(h*h)+O*O/(g*g);X>1&&(X=Math.sqrt(X),h*=X,g*=X);const Tt=h*h,$t=g*g,Jt=(i===o?-1:1)*Math.sqrt(Math.abs((Tt*$t-Tt*O*O-$t*v*v)/(Tt*O*O+$t*v*v)));C=Jt*h*O/g+(u+f)/2,I=Jt*-g*v/h+(m+y)/2,b=Math.asin(((m-I)/g*10**9>>0)/10**9),L=Math.asin(((y-I)/g*10**9>>0)/10**9),b=u<C?Math.PI-b:b,L=f<C?Math.PI-L:L,b<0&&(b=Math.PI*2+b),L<0&&(L=Math.PI*2+L),o&&b>L&&(b-=Math.PI*2),!o&&L>b&&(L-=Math.PI*2)}let R=L-b;if(Math.abs(R)>p){const v=L,O=f,X=y;L=b+p*(o&&L>b?1:-1),f=C+h*Math.cos(L),y=I+g*Math.sin(L),N=Mt(f,y,h,g,n,0,o,O,X,[L,v,C,I])}R=L-b;const P=Math.cos(b),z=Math.sin(b),D=Math.cos(L),K=Math.sin(L),q=Math.tan(R/4),w=4/3*h*q,$=4/3*g*q,E=[u,m],B=[u+w*z,m-$*P],F=[f+w*K,y-$*D],G=[f,y];if(B[0]=2*E[0]-B[0],B[1]=2*E[1]-B[1],a)return[B[0],B[1],F[0],F[1],G[0],G[1]].concat(N);N=[B[0],B[1],F[0],F[1],G[0],G[1]].concat(N);const W=[];for(let v=0,O=N.length;v<O;v+=1)W[v]=v%2?st(N[v-1],N[v],M).y:st(N[v],N[v+1],M).x;return W},xe=(e,t,s,r,n,i)=>{const o=.3333333333333333,l=2/3;return[o*e+l*s,o*t+l*r,o*n+l*s,o*i+l*r,n,i]},H=(e,t,s)=>{const[r,n]=e,[i,o]=t;return[r+(i-r)*s,n+(o-n)*s]},Pt=(e,t,s,r)=>{const n=H([e,t],[s,r],.3333333333333333),i=H([e,t],[s,r],2/3);return[n[0],n[1],i[0],i[1],s,r]},pe=(e,t)=>{const[s]=e,r=e.slice(1).map(Number),[n,i]=r,{x1:o,y1:l,x:c,y:a}=t;return"TQ".includes(s)||(t.qx=null,t.qy=null),s==="M"?(t.x=n,t.y=i,e):s==="A"?["C"].concat(Mt(o,l,r[0],r[1],r[2],r[3],r[4],r[5],r[6])):s==="Q"?(t.qx=n,t.qy=i,["C"].concat(xe(o,l,r[0],r[1],r[2],r[3]))):s==="L"?["C"].concat(Pt(o,l,n,i)):s==="Z"?["C"].concat(Pt(o,l,c,a)):e},wt=(e,t)=>{const[s]=e,r=s.toUpperCase(),n=s!==r,{x1:i,y1:o,x2:l,y2:c,x:a,y:u}=t,m=e.slice(1);let h=m.map((g,f)=>g+(n?f%2?u:a:0));if("TQ".includes(r)||(t.qx=null,t.qy=null),r==="A")return h=m.slice(0,-2).concat(m[5]+(n?a:0),m[6]+(n?u:0)),["A"].concat(h);if(r==="H")return["L",e[1]+(n?a:0),o];if(r==="V")return["L",i,e[1]+(n?u:0)];if(r==="L")return["L",e[1]+(n?a:0),e[2]+(n?u:0)];if(r==="M")return["M",e[1]+(n?a:0),e[2]+(n?u:0)];if(r==="C")return["C"].concat(h);if(r==="S"){const g=i*2-l,f=o*2-c;return t.x1=g,t.y1=f,["C",g,f].concat(h)}else if(r==="T"){const g=i*2-(t.qx?t.qx:0),f=o*2-(t.qy?t.qy:0);return t.qx=g,t.qy=f,["Q",g,f].concat(h)}else if(r==="Q"){const[g,f]=h;return t.qx=g,t.qy=f,["Q"].concat(h)}else if(r==="Z")return["Z"];return e},ut={x1:0,y1:0,x2:0,y2:0,x:0,y:0,qx:null,qy:null},yt=e=>{const t={...ut},s=Q(e);return Z(s,(r,n,i,o)=>{t.x=i,t.y=o;const l=wt(r,t);let c=pe(l,t);c[0]==="C"&&c.length>7&&(s.splice(n+1,0,["C"].concat(c.slice(7))),c=c.slice(0,7));const u=c.length;return t.x1=+c[u-2],t.y1=+c[u-1],t.x2=+c[u-4]||t.x1,t.y2=+c[u-3]||t.y1,c})},k=(e,t)=>{const s=t>=1?10**t:1;return t>0?Math.round(e*s)/s:Math.round(e)},kt=(e,t)=>{const s=e.length;let{round:r}=V,n=e[0],i="";r=t==="off"||typeof t=="number"&&t>=0?t:typeof r=="number"&&r>=0?r:"off";for(let o=0;o<s;o+=1){n=e[o];const[l]=n,c=n.slice(1);if(i+=l,r==="off")i+=c.join(" ");else{let a=0;const u=c.length;for(;a<u;)i+=k(c[a],r),a!==u-1&&(i+=" "),a+=1}}return i},Nt=(e,t)=>Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1])),it=(e,t,s,r)=>Nt([e,t],[s,r]),Ht=(e,t,s,r,n)=>{let i={x:e,y:t};if(typeof n=="number"){const o=Nt([e,t],[s,r]);if(n<=0)i={x:e,y:t};else if(n>=o)i={x:s,y:r};else{const[l,c]=H([e,t],[s,r],n/o);i={x:l,y:c}}}return i},It=(e,t,s,r)=>{const{min:n,max:i}=Math;return[n(e,s),n(t,r),i(e,s),i(t,r)]},Ft=(e,t,s)=>{const r=s/2,n=Math.sin(r),i=Math.cos(r),o=e**2*n**2,l=t**2*i**2,c=Math.sqrt(o+l)*s;return Math.abs(c)},Y=(e,t,s,r,n,i)=>{const{sin:o,cos:l}=Math,c=l(n),a=o(n),u=s*l(i),m=r*o(i);return[e+c*u-a*m,t+a*u+c*m]},Et=(e,t)=>{const{x:s,y:r}=e,{x:n,y:i}=t,o=s*n+r*i,l=Math.sqrt((s**2+r**2)*(n**2+i**2));return(s*i-r*n<0?-1:1)*Math.acos(o/l)},Lt=(e,t,s,r,n,i,o,l,c)=>{const{abs:a,sin:u,cos:m,sqrt:h,PI:g}=Math;let f=a(s),y=a(r);const M=(n%360+360)%360*(g/180);if(e===l&&t===c)return{rx:f,ry:y,startAngle:0,endAngle:0,center:{x:l,y:c}};if(f===0||y===0)return{rx:f,ry:y,startAngle:0,endAngle:0,center:{x:(l+e)/2,y:(c+t)/2}};const N=(e-l)/2,x=(t-c)/2,b={x:m(M)*N+u(M)*x,y:-u(M)*N+m(M)*x},L=b.x**2/f**2+b.y**2/y**2;L>1&&(f*=h(L),y*=h(L));const C=f**2*y**2-f**2*b.y**2-y**2*b.x**2,I=f**2*b.y**2+y**2*b.x**2;let R=C/I;R=R<0?0:R;const P=(i!==o?1:-1)*h(R),z={x:P*(f*b.y/y),y:P*(-(y*b.x)/f)},D={x:m(M)*z.x-u(M)*z.y+(e+l)/2,y:u(M)*z.x+m(M)*z.y+(t+c)/2},K={x:(b.x-z.x)/f,y:(b.y-z.y)/y},q=Et({x:1,y:0},K),w={x:(-b.x-z.x)/f,y:(-b.y-z.y)/y};let $=Et(K,w);!o&&$>0?$-=2*g:o&&$<0&&($+=2*g),$%=2*g;const E=q+$;return{center:D,startAngle:q,endAngle:E,rx:f,ry:y}},_t=(e,t,s,r,n,i,o,l,c)=>{const{rx:a,ry:u,startAngle:m,endAngle:h}=Lt(e,t,s,r,n,i,o,l,c);return Ft(a,u,h-m)},be=(e,t,s,r,n,i,o,l,c,a)=>{let u={x:e,y:t};const{center:m,rx:h,ry:g,startAngle:f,endAngle:y}=Lt(e,t,s,r,n,i,o,l,c);if(typeof a=="number"){const p=Ft(h,g,y-f);if(a<=0)u={x:e,y:t};else if(a>=p)u={x:l,y:c};else{if(e===l&&t===c)return{x:l,y:c};if(h===0||g===0)return Ht(e,t,l,c,a);const{PI:M,cos:N,sin:x}=Math,b=y-f,C=(n%360+360)%360*(M/180),I=f+b*(a/p),R=h*N(I),P=g*x(I);u={x:N(C)*R-x(C)*P+m.x,y:x(C)*R+N(C)*P+m.y}}}return u},de=(e,t,s,r,n,i,o,l,c)=>{const{center:a,rx:u,ry:m,startAngle:h,endAngle:g}=Lt(e,t,s,r,n,i,o,l,c),f=g-h,{min:y,max:p,tan:M,atan2:N,PI:x}=Math,{x:b,y:L}=a,C=n*x/180,I=M(C),R=N(-m*I,u),P=R,z=R+x,D=N(m,u*I),K=D+x;let q=y(e,l),w=p(e,l),$=y(t,c),E=p(t,c);const B=g-f*.001,F=Y(b,L,u,m,C,B),G=g-f*.999,W=Y(b,L,u,m,C,G);if(F[0]>w||W[0]>w){const v=Y(b,L,u,m,C,P);q=y(q,v[0]),$=y($,v[1]),w=p(w,v[0]),E=p(E,v[1])}if(F[0]<q||W[0]<q){const v=Y(b,L,u,m,C,z);q=y(q,v[0]),$=y($,v[1]),w=p(w,v[0]),E=p(E,v[1])}if(F[1]<$||W[1]<$){const v=Y(b,L,u,m,C,K);q=y(q,v[0]),$=y($,v[1]),w=p(w,v[0]),E=p(E,v[1])}if(F[1]>E||W[1]>E){const v=Y(b,L,u,m,C,D);q=y(q,v[0]),$=y($,v[1]),w=p(w,v[0]),E=p(E,v[1])}return[q,$,w,E]},Be=Object.freeze(Object.defineProperty({__proto__:null,angleBetween:Et,arcLength:Ft,arcPoint:Y,getArcBBox:de,getArcLength:_t,getArcProps:Lt,getPointAtArcLength:be},Symbol.toStringTag,{value:"Module"})),Rt=[-.06405689286260563,.06405689286260563,-.1911188674736163,.1911188674736163,-.3150426796961634,.3150426796961634,-.4337935076260451,.4337935076260451,-.5454214713888396,.5454214713888396,-.6480936519369755,.6480936519369755,-.7401241915785544,.7401241915785544,-.820001985973903,.820001985973903,-.8864155270044011,.8864155270044011,-.9382745520027328,.9382745520027328,-.9747285559713095,.9747285559713095,-.9951872199970213,.9951872199970213],Ae=[.12793819534675216,.12793819534675216,.1258374563468283,.1258374563468283,.12167047292780339,.12167047292780339,.1155056680537256,.1155056680537256,.10744427011596563,.10744427011596563,.09761865210411388,.09761865210411388,.08619016153195327,.08619016153195327,.0733464814110803,.0733464814110803,.05929858491543678,.05929858491543678,.04427743881741981,.04427743881741981,.028531388628933663,.028531388628933663,.0123412297999872,.0123412297999872],Me=e=>{const t=[];for(let s=e,r=s.length,n=r-1;r>1;r-=1,n-=1){const i=[];for(let o=0;o<n;o+=1)i.push({x:n*(s[o+1].x-s[o].x),y:n*(s[o+1].y-s[o].y),t:0});t.push(i),s=i}return t},we=(e,t)=>{if(t===0)return e[0].t=0,e[0];const s=e.length-1;if(t===1)return e[s].t=1,e[s];const r=1-t;let n=e;if(s===0)return e[0].t=t,e[0];if(s===1)return{x:r*n[0].x+t*n[1].x,y:r*n[0].y+t*n[1].y,t};const i=r*r,o=t*t;let l=0,c=0,a=0,u=0;return s===2?(n=[n[0],n[1],n[2],{x:0,y:0}],l=i,c=r*t*2,a=o):s===3&&(l=i*r,c=i*t*3,a=r*o*3,u=t*o),{x:l*n[0].x+c*n[1].x+a*n[2].x+u*n[3].x,y:l*n[0].y+c*n[1].y+a*n[2].y+u*n[3].y,t}},Ne=(e,t)=>{const s=e(t),r=s.x*s.x+s.y*s.y;return Math.sqrt(r)},Le=e=>{const s=Rt.length;let r=0;for(let n=0,i;n<s;n++)i=.5*Rt[n]+.5,r+=Ae[n]*Ne(e,i);return .5*r},mt=e=>{const t=[];for(let r=0,n=e.length,i=2;r<n;r+=i)t.push({x:e[r],y:e[r+1]});const s=Me(t);return Le(r=>we(s[0],r))},ve=1e-8,gt=([e,t,s])=>{const r=Math.min(e,s),n=Math.max(e,s);if(t>=e?s>=t:s<=t)return[r,n];const i=(e*s-t*t)/(e-2*t+s);return i<r?[i,n]:[r,i]},St=([e,t,s,r])=>{const n=e-3*t+3*s-r;if(Math.abs(n)<ve)return e===r&&e===t?[e,r]:gt([e,-.5*e+1.5*t,e-3*t+3*s]);const i=-e*s+e*r-t*s-t*r+t*t+s*s;if(i<=0)return[Math.min(e,r),Math.max(e,r)];const o=Math.sqrt(i);let l=Math.min(e,r),c=Math.max(e,r);const a=e-2*t+s;for(let u=(a+o)/n,m=1;m<=2;u=(a-o)/n,m++)if(u>0&&u<1){const h=e*(1-u)*(1-u)*(1-u)+t*3*(1-u)*(1-u)*u+s*3*(1-u)*u*u+r*u*u*u;h<l&&(l=h),h>c&&(c=h)}return[l,c]},Ce=([e,t,s,r,n,i,o,l],c)=>{const a=1-c;return{x:a**3*e+3*a**2*c*s+3*a*c**2*n+c**3*o,y:a**3*t+3*a**2*c*r+3*a*c**2*i+c**3*l}},xt=(e,t,s,r,n,i,o,l)=>mt([e,t,s,r,n,i,o,l]),Te=(e,t,s,r,n,i,o,l,c)=>{const a=typeof c=="number";let u={x:e,y:t};if(a){const m=mt([e,t,s,r,n,i,o,l]);c<=0||(c>=m?u={x:o,y:l}:u=Ce([e,t,s,r,n,i,o,l],c/m))}return u},jt=(e,t,s,r,n,i,o,l)=>{const c=St([e,s,n,o]),a=St([t,r,i,l]);return[c[0],a[0],c[1],a[1]]},$e=([e,t,s,r,n,i],o)=>{const l=1-o;return{x:l**2*e+2*l*o*s+o**2*n,y:l**2*t+2*l*o*r+o**2*i}},pt=(e,t,s,r,n,i)=>mt([e,t,s,r,n,i]),ze=(e,t,s,r,n,i,o)=>{const l=typeof o=="number";let c={x:e,y:t};if(l){const a=mt([e,t,s,r,n,i]);o<=0||(o>=a?c={x:n,y:i}:c=$e([e,t,s,r,n,i],o/a))}return c},Qt=(e,t,s,r,n,i)=>{const o=gt([e,s,n]),l=gt([t,r,i]);return[o[0],l[0],o[1],l[1]]},He=e=>{const t=e.length;let s=-1,r,n=e[t-1],i=0;for(;++s<t;)r=n,n=e[s],i+=r[1]*n[0]-r[0]*n[1];return i/2},Fe=e=>e.reduce((t,s,r)=>r?t+Nt(e[r-1],s):0,0),bt=1e-5,ot=e=>{const t=Q(e),s={...ut};return Z(t,(r,n,i,o)=>{s.x=i,s.y=o;const l=wt(r,s),c=l.length;return s.x1=+l[c-2],s.y1=+l[c-1],s.x2=+l[c-4]||s.x1,s.y2=+l[c-3]||s.y1,l})},rt=(e,t)=>{const s=ot(e);let r=!1,n=[],i="M",o=0,l=0,[c,a]=s[0].slice(1);const u=typeof t=="number";let m={x:c,y:a},h=0,g=m,f=0;return!u||t<bt?m:(Z(s,(y,p,M,N)=>{if([i]=y,r=i==="M",n=r?n:[M,N].concat(y.slice(1)),r?([,c,a]=y,m={x:c,y:a},h=0):i==="L"?(m=Ht(n[0],n[1],n[2],n[3],t-f),h=it(n[0],n[1],n[2],n[3])):i==="A"?(m=be(n[0],n[1],n[2],n[3],n[4],n[5],n[6],n[7],n[8],t-f),h=_t(n[0],n[1],n[2],n[3],n[4],n[5],n[6],n[7],n[8])):i==="C"?(m=Te(n[0],n[1],n[2],n[3],n[4],n[5],n[6],n[7],t-f),h=xt(n[0],n[1],n[2],n[3],n[4],n[5],n[6],n[7])):i==="Q"?(m=ze(n[0],n[1],n[2],n[3],n[4],n[5],t-f),h=pt(n[0],n[1],n[2],n[3],n[4],n[5])):i==="Z"&&(n=[M,N,c,a],m={x:c,y:a},h=it(n[0],n[1],n[2],n[3])),[o,l]=n.slice(-2),f<t)g=m;else return!1;f+=h}),t>f-bt?{x:o,y:l}:g)},nt=e=>{const t=Q(e);let s=0,r=0,n=0,i=0,o=0,l=0,c="M",a=0,u=0,m=0;return Z(t,(h,g,f,y)=>{[c]=h;const p=c.toUpperCase(),N=p!==c?at(h,g,f,y):h.slice(0),x=p==="V"?["L",f,N[1]]:p==="H"?["L",N[1],y]:N;if([c]=x,"TQ".includes(p)||(o=0,l=0),c==="M")[,a,u]=x;else if(c==="L")m+=it(f,y,x[1],x[2]);else if(c==="A")m+=_t(f,y,x[1],x[2],x[3],x[4],x[5],x[6],x[7]);else if(c==="S"){const b=s*2-n,L=r*2-i;m+=xt(f,y,b,L,x[1],x[2],x[3],x[4])}else c==="C"?m+=xt(f,y,x[1],x[2],x[3],x[4],x[5],x[6]):c==="T"?(o=s*2-o,l=r*2-l,m+=pt(f,y,o,l,x[1],x[2])):c==="Q"?(o=x[1],l=x[2],m+=pt(f,y,x[1],x[2],x[3],x[4])):c==="Z"&&(m+=it(f,y,a,u));[s,r]=c==="Z"?[a,u]:x.slice(-2),[n,i]=c==="C"?[x[3],x[4]]:c==="S"?[x[1],x[2]]:[s,r]}),m},Ut=(e,t)=>{const s=Q(e);let r=s.slice(0),n=nt(r),i=r.length-1,o=0,l=0,c=s[0];if(i<=0||!t||!Number.isFinite(t))return{segment:c,index:0,length:l,lengthAtSegment:o};if(t>=n)return r=s.slice(0,-1),o=nt(r),l=n-o,c=s[i],{segment:c,index:i,length:l,lengthAtSegment:o};const a=[];for(;i>0;)c=r[i],r=r.slice(0,-1),o=nt(r),l=n-o,n=o,a.push({segment:c,index:i,length:l,lengthAtSegment:o}),i-=1;return a.find(({lengthAtSegment:u})=>u<=t)},vt=(e,t)=>{const s=Q(e),r=ot(s),n=nt(r),i=b=>{const L=b.x-t.x,C=b.y-t.y;return L*L+C*C};let o=8,l,c={x:0,y:0},a=0,u=0,m=1/0;for(let b=0;b<=n;b+=o)l=rt(r,b),a=i(l),a<m&&(c=l,u=b,m=a);o/=2;let h,g,f=0,y=0,p=0,M=0;for(;o>1e-6&&(f=u-o,h=rt(r,f),p=i(h),y=u+o,g=rt(r,y),M=i(g),f>=0&&p<m?(c=h,u=f,m=p):y<=n&&M<m?(c=g,u=y,m=M):o/=2,!(o<1e-5)););const N=Ut(s,u),x=Math.sqrt(m);return{closest:c,distance:x,segment:N}},_e=(e,t)=>vt(e,t).closest,Ue=(e,t,s,r,n,i,o,l)=>3*((l-t)*(s+n)-(o-e)*(r+i)+r*(e-n)-s*(t-i)+l*(n+e/3)-o*(i+t/3))/20,qe=e=>{let t=0,s=0,r=0;return yt(e).map(n=>{switch(n[0]){case"M":return[,t,s]=n,0;default:return r=Ue(t,s,n[1],n[2],n[3],n[4],n[5],n[6]),[t,s]=n.slice(-2),r}}).reduce((n,i)=>n+i,0)},Je=e=>qe(yt(e))>=0,Wt=e=>{if(!e)return{x:0,y:0,width:0,height:0,x2:0,y2:0,cx:0,cy:0,cz:0};const t=Q(e);let s="M",r=0,n=0;const{max:i,min:o}=Math;let l=1/0,c=1/0,a=-1/0,u=-1/0,m=0,h=0,g=0,f=0,y=0,p=0,M=0,N=0,x=0,b=0;Z(t,(I,R,P,z)=>{[s]=I;const D=s.toUpperCase(),q=D!==s?at(I,R,P,z):I.slice(0),w=D==="V"?["L",P,q[1]]:D==="H"?["L",q[1],z]:q;if([s]=w,"TQ".includes(D)||(x=0,b=0),s==="M")[,r,n]=w,m=r,h=n,g=r,f=n;else if(s==="L")[m,h,g,f]=It(P,z,w[1],w[2]);else if(s==="A")[m,h,g,f]=de(P,z,w[1],w[2],w[3],w[4],w[5],w[6],w[7]);else if(s==="S"){const $=y*2-M,E=p*2-N;[m,h,g,f]=jt(P,z,$,E,w[1],w[2],w[3],w[4])}else s==="C"?[m,h,g,f]=jt(P,z,w[1],w[2],w[3],w[4],w[5],w[6]):s==="T"?(x=y*2-x,b=p*2-b,[m,h,g,f]=Qt(P,z,x,b,w[1],w[2])):s==="Q"?(x=w[1],b=w[2],[m,h,g,f]=Qt(P,z,w[1],w[2],w[3],w[4])):s==="Z"&&([m,h,g,f]=It(P,z,r,n));l=o(m,l),c=o(h,c),a=i(g,a),u=i(f,u),[y,p]=s==="Z"?[r,n]:w.slice(-2),[M,N]=s==="C"?[w[3],w[4]]:s==="S"?[w[1],w[2]]:[y,p]});const L=a-l,C=u-c;return{width:L,height:C,x:l,y:c,x2:a,y2:u,cx:l+L/2,cy:c+C/2,cz:Math.max(L,C)+Math.min(L,C)/2}},Ke=(e,t)=>Ut(e,t).segment,We=(e,t)=>vt(e,t).segment,Ct=e=>Array.isArray(e)&&e.every(t=>{const s=t[0].toLowerCase();return tt[s]===t.length-1&&"achlmqstvz".includes(s)&&t.slice(1).every(Number.isFinite)})&&e.length>0,Pe=e=>Ct(e)&&e.every(([t])=>t===t.toUpperCase()),ke=e=>Pe(e)&&e.every(([t])=>"ACLMQZ".includes(t)),Xe=e=>ke(e)&&e.every(([t])=>"MC".includes(t)),Ye=(e,t)=>{const{distance:s}=vt(e,t);return Math.abs(s)<bt},Ve=e=>Ct(e)&&e.slice(1).every(([t])=>t===t.toLowerCase()),Ie=e=>{if(typeof e!="string"||!e.length)return!1;const t=new Ot(e);for(et(t);t.index<t.max&&!t.err.length;)Dt(t);return!t.err.length&&"mM".includes(t.segments[0][0])},ct={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"]},Ge=e=>{let{x1:t,y1:s,x2:r,y2:n}=e;return[t,s,r,n]=[t,s,r,n].map(i=>+i),[["M",t,s],["L",r,n]]},tn=e=>{const t=[],s=(e.points||"").trim().split(/[\s|,]/).map(n=>+n);let r=0;for(;r<s.length;)t.push([r?"L":"M",s[r],s[r+1]]),r+=2;return e.type==="polygon"?[...t,["z"]]:t},en=e=>{let{cx:t,cy:s,r}=e;return[t,s,r]=[t,s,r].map(n=>+n),[["M",t-r,s],["a",r,r,0,1,0,2*r,0],["a",r,r,0,1,0,-2*r,0]]},nn=e=>{let{cx:t,cy:s}=e,r=e.rx||0,n=e.ry||r;return[t,s,r,n]=[t,s,r,n].map(i=>+i),[["M",t-r,s],["a",r,n,0,1,0,2*r,0],["a",r,n,0,1,0,-2*r,0]]},sn=e=>{const t=+e.x||0,s=+e.y||0,r=+e.width,n=+e.height;let i=+(e.rx||0),o=+(e.ry||i);return i||o?(i*2>r&&(i-=(i*2-r)/2),o*2>n&&(o-=(o*2-n)/2),[["M",t+i,s],["h",r-i*2],["s",i,0,i,o],["v",n-o*2],["s",0,o,-i,o],["h",-r+i*2],["s",-i,0,-i,-o],["v",-n+o*2],["s",0,-o,i,-o]]):[["M",t,s],["h",r],["v",n],["H",t],["Z"]]},Ee=(e,t)=>{const r=(t||document).defaultView||window,n=Object.keys(ct),i=e instanceof r.SVGElement,o=i?e.tagName:null;if(o&&[...n,"path"].every(m=>o!==m))throw TypeError(`${j}: "${o}" is not SVGElement`);const l=i?o:e.type,c=ct[l],a={type:l};i?c.forEach(m=>{a[m]=e.getAttribute(m)}):Object.assign(a,e);let u=[];return l==="circle"?u=en(a):l==="ellipse"?u=nn(a):["polyline","polygon"].includes(l)?u=tn(a):l==="rect"?u=sn(a):l==="line"?u=Ge(a):["glyph","path"].includes(l)&&(u=Q(i?e.getAttribute("d")||"":e.d||"")),Ct(u)&&u.length?u:!1},rn=(e,t,s)=>{const r=s||document,n=r.defaultView||window,i=Object.keys(ct),o=e instanceof n.SVGElement,l=o?e.tagName:null;if(l==="path")throw TypeError(`${j}: "${l}" is already SVGPathElement`);if(l&&i.every(y=>l!==y))throw TypeError(`${j}: "${l}" is not SVGElement`);const c=r.createElementNS("http://www.w3.org/2000/svg","path"),a=o?l:e.type,u=ct[a],m={type:a},h=V.round,g=Ee(e,r),f=g&&g.length?kt(g,h):"";return o?(u.forEach(y=>{m[y]=e.getAttribute(y)}),Object.values(e.attributes).forEach(({name:y,value:p})=>{u.includes(y)||c.setAttribute(y,p)})):(Object.assign(m,e),Object.keys(m).forEach(y=>{!u.includes(y)&&y!=="type"&&c.setAttribute(y.replace(/[A-Z]/g,p=>`-${p.toLowerCase()}`),m[y])})),Ie(f)?(c.setAttribute("d",f),t&&o&&(e.before(c,e),e.remove()),c):!1},Re=e=>{let t=new T;const{origin:s}=e,[r,n]=s,{translate:i}=e,{rotate:o}=e,{skew:l}=e,{scale:c}=e;return Array.isArray(i)&&i.length>=2&&i.every(a=>!Number.isNaN(+a))&&i.some(a=>a!==0)?t=t.translate(...i):typeof i=="number"&&!Number.isNaN(i)&&(t=t.translate(i)),(o||l||c)&&(t=t.translate(r,n),Array.isArray(o)&&o.length>=2&&o.every(a=>!Number.isNaN(+a))&&o.some(a=>a!==0)?t=t.rotate(...o):typeof o=="number"&&!Number.isNaN(o)&&(t=t.rotate(o)),Array.isArray(l)&&l.length===2&&l.every(a=>!Number.isNaN(+a))&&l.some(a=>a!==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(c)&&c.length>=2&&c.every(a=>!Number.isNaN(+a))&&c.some(a=>a!==1)?t=t.scale(...c):typeof c=="number"&&!Number.isNaN(c)&&(t=t.scale(c)),t=t.translate(-r,-n)),t},Se=(e,t,s,r)=>{const[n]=e,{round:i}=V,o=typeof i=="number"?i:4,l=t.slice(1),{x1:c,y1:a,x2:u,y2:m,x:h,y:g}=s,[f,y]=l.slice(-2),p=e;if("TQ".includes(n)||(s.qx=null,s.qy=null),n==="L"){if(k(h,o)===k(f,o))return["V",y];if(k(g,o)===k(y,o))return["H",f]}else if(n==="C"){const[M,N]=l;if(s.x1=M,s.y1=N,"CS".includes(r)&&(k(M,o)===k(c*2-u,o)&&k(N,o)===k(a*2-m,o)||k(c,o)===k(u*2-h,o)&&k(a,o)===k(m*2-g,o)))return["S",l[2],l[3],l[4],l[5]]}else if(n==="Q"){const[M,N]=l;if(s.qx=M,s.qy=N,"QT".includes(r)&&k(M,o)===k(c*2-u,o)&&k(N,o)===k(a*2-m,o))return["T",l[2],l[3]]}return p},dt=(e,t)=>{const s=e.slice(1).map(r=>k(r,t));return[e[0]].concat(s)},Xt=(e,t)=>{const s=ht(e),r=typeof t=="number"&&t>=0?t:2,n={...ut},i=[];let o="M",l="Z";return Z(s,(c,a,u,m)=>{n.x=u,n.y=m;const h=wt(c,n);let g=c;if([o]=c,i[a]=o,a){l=i[a-1];const y=Se(c,h,n,l),p=dt(y,r),M=p.join(""),N=Bt(y,a,u,m),x=dt(N,r),b=x.join("");g=M.length<b.length?p:x}const f=h.length;return n.x1=+h[f-2],n.y1=+h[f-1],n.x2=+h[f-4]||n.x1,n.y2=+h[f-3]||n.y1,g})},on=(e,t)=>{let s=T.Translate(t[0],t[1],t[2]);return[,,,s.m44]=t,s=e.multiply(s),[s.m41,s.m42,s.m43,s.m44]},Zt=(e,t,s)=>{const[r,n,i]=s,[o,l,c]=on(e,[t[0],t[1],0,1]),a=o-r,u=l-n,m=c-i;return[a*(Math.abs(i)/Math.abs(m)||1)+r,u*(Math.abs(i)/Math.abs(m)||1)+n]},cn=e=>{const t=e.slice(1).map((s,r,n)=>r?n[r-1].slice(-2).concat(s.slice(1)):e[0].slice(1).concat(s.slice(1))).map(s=>s.map((r,n)=>s[s.length-n-2*(1-n%2)])).reverse();return[["M"].concat(t[0].slice(0,2))].concat(t.map(s=>["C"].concat(s.slice(2))))},ft=e=>{const t=ht(e),s=ot(t),r=t.length,n=t[r-1][0]==="Z",i=Z(t,(o,l)=>{const c=s[l],a=l&&t[l-1],u=a&&a[0],m=t[l+1],h=m&&m[0],[g]=o,[f,y]=s[l?l-1:r-1].slice(-2);let p=o;switch(g){case"M":p=n?["Z"]:[g,f,y];break;case"A":p=[g,o[1],o[2],o[3],o[4],o[5]===1?0:1,f,y];break;case"C":m&&h==="S"?p=["S",o[1],o[2],f,y]:p=[g,o[3],o[4],o[1],o[2],f,y];break;case"S":u&&"CS".includes(u)&&(!m||h!=="S")?p=["C",c[3],c[4],c[1],c[2],f,y]:p=[g,c[1],c[2],f,y];break;case"Q":m&&h==="T"?p=["T",f,y]:p=[g,o[1],o[2],f,y];break;case"T":u&&"QT".includes(u)&&(!m||h!=="T")?p=["Q",c[1],c[2],f,y]:p=[g,f,y];break;case"Z":p=["M",f,y];break;case"H":p=[g,f];break;case"V":p=[g,y];break;default:p=[g].concat(o.slice(1,-2),f,y)}return p});return n?i.reverse():[i[0]].concat(i.slice(1).reverse())},ln=(e,t)=>{let{round:s}=V;return s=t==="off"||typeof t=="number"&&t>=0?t:typeof s=="number"&&s>=0?s:"off",s==="off"?e.slice(0):Z(e,r=>dt(r,s))},an=(e,t=.5)=>{const s=t,r=e.slice(0,2),n=e.slice(2,4),i=e.slice(4,6),o=e.slice(6,8),l=H(r,n,s),c=H(n,i,s),a=H(i,o,s),u=H(l,c,s),m=H(c,a,s),h=H(u,m,s);return[["C",l[0],l[1],u[0],u[1],h[0],h[1]],["C",m[0],m[1],a[0],a[1],o[0],o[1]]]},Yt=e=>{const t=[];let s,r=-1,n=0,i=0,o=0,l=0;const c={...ut};return e.forEach(a=>{const[u]=a,m=u.toUpperCase(),h=u.toLowerCase(),g=u===h,f=a.slice(1);m==="M"?(r+=1,[n,i]=f,n+=g?c.x:0,i+=g?c.y:0,o=n,l=i,s=[g?[m,o,l]:a]):(m==="Z"?(n=o,i=l):m==="H"?([,n]=a,n+=g?c.x:0):m==="V"?([,i]=a,i+=g?c.y:0):([n,i]=a.slice(-2),n+=g?c.x:0,i+=g?c.y:0),s.push(a)),c.x=n,c.y=i,t[r]=s}),t},Vt=(e,t)=>{let s=0,r=0,n=0,i=0,o=0,l=0,c="M";const a=Q(e),u=t&&Object.keys(t);if(!t||u&&!u.length)return a.slice(0);t.origin||Object.assign(t,{origin:V.origin});const m=t.origin,h=Re(t);return h.isIdentity?a.slice(0):Z(a,(g,f,y,p)=>{[c]=g;const M=c.toUpperCase(),x=M!==c?at(g,f,y,p):g.slice(0);let b=M==="A"?["C"].concat(Mt(y,p,x[1],x[2],x[3],x[4],x[5],x[6],x[7])):M==="V"?["L",y,x[1]]:M==="H"?["L",x[1],p]:x;c=b[0];const L=c==="C"&&b.length>7,C=L?b.slice(0,7):b.slice(0);if(L&&(a.splice(f+1,0,["C"].concat(b.slice(7))),b=C),c==="L")[n,i]=Zt(h,[b[1],b[2]],m),s!==n&&r!==i?b=["L",n,i]:r===i?b=["H",n]:s===n&&(b=["V",i]);else for(o=1,l=b.length;o<l;o+=2)[n,i]=Zt(h,[+b[o],+b[o+1]],m),b[o]=n,b[o+1]=i;return s=n,r=i,b})};class A{constructor(t,s){const r=s||{},n=typeof t>"u";if(n||!t.length)throw TypeError(`${j}: "pathValue" is ${n?"undefined":"empty"}`);this.segments=Q(t);const{round:i,origin:o}=r;let l;Number.isInteger(i)||i==="off"?l=i:l=V.round;let c=V.origin;if(Array.isArray(o)&&o.length>=2){const[a,u,m]=o.map(Number);c=[Number.isNaN(a)?0:a,Number.isNaN(u)?0:u,Number.isNaN(m)?0:m]}return this.round=l,this.origin=c,this}get bbox(){return Wt(this.segments)}get length(){return nt(this.segments)}getBBox(){return this.bbox}getTotalLength(){return this.length}getPointAtLength(t){return rt(this.segments,t)}toAbsolute(){const{segments:t}=this;return this.segments=ht(t),this}toRelative(){const{segments:t}=this;return this.segments=Kt(t),this}toCurve(){const{segments:t}=this;return this.segments=yt(t),this}reverse(t){this.toAbsolute();const{segments:s}=this,r=Yt(s),n=r.length>1?r:!1,i=n?n.map((l,c)=>t?c?ft(l):l.slice(0):ft(l)):s.slice(0);let o=[];return n?o=i.flat(1):o=t?s:ft(s),this.segments=o.slice(0),this}normalize(){const{segments:t}=this;return this.segments=ot(t),this}optimize(){const{segments:t}=this,s=this.round==="off"?2:this.round;return this.segments=Xt(t,s),this}transform(t){if(!t||typeof t!="object"||typeof t=="object"&&!["translate","rotate","skew","scale"].some(c=>c in t))return this;const{segments:s,origin:[r,n,i]}=this,o={};for(const[c,a]of Object.entries(t))c==="skew"&&Array.isArray(a)||(c==="rotate"||c==="translate"||c==="origin"||c==="scale")&&Array.isArray(a)?o[c]=a.map(Number):c!=="origin"&&typeof Number(a)=="number"&&(o[c]=Number(a));const{origin:l}=o;if(Array.isArray(l)&&l.length>=2){const[c,a,u]=l.map(Number);o.origin=[Number.isNaN(c)?r:c,Number.isNaN(a)?n:a,u||i]}else o.origin=[r,n,i];return this.segments=Vt(s,o),this}flipX(){const{cx:t,cy:s}=this.bbox;return this.transform({rotate:[0,180,0],origin:[t,s,0]}),this}flipY(){const{cx:t,cy:s}=this.bbox;return this.transform({rotate:[180,0,0],origin:[t,s,0]}),this}toString(){return kt(this.segments,this.round)}}d(A,"CSSMatrix",T),d(A,"pathToAbsolute",ht),d(A,"pathToRelative",Kt),d(A,"pathToCurve",yt),d(A,"pathToString",kt),d(A,"arcTools",Be),d(A,"bezierTools",{Cvalues:Ae,Tvalues:Rt,minmaxC:St,minmaxQ:gt,getBezierLength:mt,bezierLength:Le,calculateBezier:Ne,computeBezier:we,deriveBezier:Me,CBEZIER_MINMAX_EPSILON:ve}),d(A,"cubicTools",{getCubicLength:xt,getCubicBBox:jt,getPointAtCubicLength:Te,getPointAtCubicSegmentLength:Ce}),d(A,"lineTools",{getPointAtLineLength:Ht,getLineBBox:It,getLineLength:it}),d(A,"quadTools",{getPointAtQuadSegmentLength:$e,getQuadLength:pt,getQuadBBox:Qt,getPointAtQuadLength:ze}),d(A,"polygonTools",{polygonArea:He,polygonLength:Fe}),d(A,"distanceSquareRoot",Nt),d(A,"distanceEpsilon",bt),d(A,"midPoint",H),d(A,"rotateVector",st),d(A,"roundTo",k),d(A,"finalizeSegment",qt),d(A,"invalidPathValue",J),d(A,"isArcCommand",ye),d(A,"isDigit",U),d(A,"isDigitStart",he),d(A,"isMoveCommand",ge),d(A,"isPathCommand",fe),d(A,"isSpace",me),d(A,"paramsCount",tt),d(A,"paramsParser",ut),d(A,"pathParser",Ot),d(A,"scanFlag",ae),d(A,"scanParam",ue),d(A,"scanSegment",Dt),d(A,"skipSpaces",et),d(A,"getPathBBox",Wt),d(A,"getPathArea",qe),d(A,"getTotalLength",nt),d(A,"getDrawDirection",Je),d(A,"getPointAtLength",rt),d(A,"getPropertiesAtLength",Ut),d(A,"getPropertiesAtPoint",vt),d(A,"getClosestPoint",_e),d(A,"getSegmentOfPoint",We),d(A,"getSegmentAtLength",Ke),d(A,"isPointInStroke",Ye),d(A,"isValidPath",Ie),d(A,"isPathArray",Ct),d(A,"isAbsoluteArray",Pe),d(A,"isRelativeArray",Ve),d(A,"isCurveArray",Xe),d(A,"isNormalizedArray",ke),d(A,"shapeToPath",rn),d(A,"shapeToPathArray",Ee),d(A,"shapeParams",ct),d(A,"parsePathString",Q),d(A,"absolutizeSegment",at),d(A,"arcToCubic",Mt),d(A,"getSVGMatrix",Re),d(A,"iterate",Z),d(A,"lineToCubic",Pt),d(A,"normalizePath",ot),d(A,"normalizeSegment",wt),d(A,"optimizePath",Xt),d(A,"projection2d",Zt),d(A,"quadToCubic",xe),d(A,"relativizeSegment",Bt),d(A,"reverseCurve",cn),d(A,"reversePath",ft),d(A,"roundPath",ln),d(A,"roundSegment",dt),d(A,"segmentToCubic",pe),d(A,"shortenSegment",Se),d(A,"splitCubic",an),d(A,"splitPath",Yt),d(A,"transformPath",Vt);module.exports=A;
|
|
2
2
|
//# sourceMappingURL=svg-path-commander.cjs.map
|