likec4 1.56.0 → 1.58.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 (207) hide show
  1. package/__app__/codegen/react.mjs +7 -8
  2. package/__app__/codegen/webcomponent.mjs +77 -736
  3. package/__app__/src/aichat/index.mjs +8 -0
  4. package/__app__/src/chunks/AIChat.mjs +959 -0
  5. package/__app__/src/chunks/DiagramActorProvider.mjs +7638 -0
  6. package/__app__/src/chunks/LikeC4Styles.mjs +1866 -0
  7. package/__app__/src/chunks/Markdown.mjs +146 -0
  8. package/__app__/src/chunks/NavigationPanel.mjs +61 -0
  9. package/__app__/src/chunks/ProjectsOverview.mjs +540 -0
  10. package/__app__/src/chunks/adhoc-editor.mjs +3386 -0
  11. package/__app__/src/chunks/es.mjs +439 -0
  12. package/__app__/src/chunks/hooks.mjs +145 -0
  13. package/__app__/src/chunks/libs/@dagrejs/dagre.mjs +1894 -0
  14. package/__app__/src/chunks/libs/@floating-ui.mjs +2218 -0
  15. package/__app__/src/chunks/libs/@mantine.mjs +12070 -0
  16. package/__app__/src/chunks/libs/@tabler/icons-react.mjs +252 -0
  17. package/__app__/src/chunks/libs/@tanstack-ai.mjs +1768 -0
  18. package/__app__/src/chunks/libs/@tanstack.mjs +2718 -0
  19. package/__app__/src/chunks/libs/@xstate/react.mjs +1982 -0
  20. package/__app__/src/chunks/libs/@xyflow/react.mjs +5256 -0
  21. package/__app__/src/chunks/libs/bezier-js.mjs +1003 -0
  22. package/__app__/src/chunks/libs/d3.mjs +2842 -0
  23. package/__app__/src/chunks/libs/fast-equals.mjs +268 -0
  24. package/__app__/src/chunks/libs/framer.mjs +5872 -0
  25. package/__app__/src/chunks/libs/remeda.mjs +642 -0
  26. package/__app__/src/chunks/libs/zod.mjs +3170 -0
  27. package/__app__/src/chunks/rolldown-runtime.mjs +23 -0
  28. package/__app__/src/chunks/styled-system.mjs +1040 -0
  29. package/__app__/src/fonts.css +1 -1
  30. package/__app__/src/main.mjs +14847 -1
  31. package/__app__/src/style.css +1 -1
  32. package/config/schema.json +14 -41
  33. package/dist/chunks/enableServer.mjs +1 -0
  34. package/dist/chunks/filenames.mjs +2 -2
  35. package/dist/chunks/index2.d.mts +2057 -722
  36. package/dist/chunks/libs/@chevrotain/gast.mjs +1 -1
  37. package/dist/chunks/libs/@logtape/logtape.mjs +4 -3
  38. package/dist/chunks/libs/@ts-graphviz/ast.mjs +3 -0
  39. package/dist/chunks/libs/@ts-graphviz/common.d.mts +9 -0
  40. package/dist/chunks/libs/@ts-graphviz/core.mjs +1 -0
  41. package/dist/chunks/libs/chevrotain-allstar.mjs +2 -2
  42. package/dist/chunks/libs/chevrotain.mjs +26 -26
  43. package/dist/chunks/libs/langium.d.mts +5 -5
  44. package/dist/chunks/libs/langium.mjs +10 -10
  45. package/dist/chunks/libs/merge-error-cause.mjs +1 -1
  46. package/dist/chunks/libs/pako.mjs +3 -1
  47. package/dist/chunks/libs/pretty-ms.mjs +1 -1
  48. package/dist/chunks/libs/remeda.mjs +1 -1
  49. package/dist/chunks/libs/ufo.mjs +1 -1
  50. package/dist/chunks/libs/unstorage.mjs +1 -1
  51. package/dist/chunks/libs/which.mjs +1 -1
  52. package/dist/chunks/libs/zod.d.mts +60 -25
  53. package/dist/chunks/libs/zod.mjs +65 -0
  54. package/dist/chunks/node.mjs +84 -56
  55. package/dist/chunks/sequence-view.mjs +1 -1
  56. package/dist/chunks/vite-plugin.mjs +593 -0
  57. package/dist/cli/index.mjs +184 -141
  58. package/dist/index.d.mts +2 -131
  59. package/dist/index.mjs +1 -1
  60. package/dist/model/index.d.mts +2 -2
  61. package/dist/vite-plugin/index.d.mts +53 -2
  62. package/dist/vite-plugin/index.mjs +1 -1
  63. package/dist/vite-plugin/internal/index.d.mts +327 -4
  64. package/dist/vite-plugin/internal/index.mjs +946 -1
  65. package/package.json +85 -72
  66. package/react/index.d.mts +174 -73
  67. package/react/index.mjs +42468 -38926
  68. package/vite-plugin-modules.d.ts +4 -0
  69. package/__app__/chunks/ColorSchemeToggle.mjs +0 -1
  70. package/__app__/chunks/DiagramActorProvider.mjs +0 -10
  71. package/__app__/chunks/Fallback.mjs +0 -1
  72. package/__app__/chunks/Header.mjs +0 -13
  73. package/__app__/chunks/IconRenderer.mjs +0 -1
  74. package/__app__/chunks/LikeC4Diagram.mjs +0 -19
  75. package/__app__/chunks/LikeC4ModelContext.mjs +0 -1
  76. package/__app__/chunks/LikeC4ModelContext2.mjs +0 -1
  77. package/__app__/chunks/LikeC4Styles.mjs +0 -48
  78. package/__app__/chunks/NavigationPanel.mjs +0 -1
  79. package/__app__/chunks/StaticLikeC4Diagram.mjs +0 -1
  80. package/__app__/chunks/ViewReact.mjs +0 -1
  81. package/__app__/chunks/__root.mjs +0 -1
  82. package/__app__/chunks/adhoc-editor.mjs +0 -1
  83. package/__app__/chunks/hooks.mjs +0 -1
  84. package/__app__/chunks/libs/@dagrejs/dagre.mjs +0 -1
  85. package/__app__/chunks/libs/@floating-ui/core.mjs +0 -1
  86. package/__app__/chunks/libs/@floating-ui/dom.mjs +0 -1
  87. package/__app__/chunks/libs/@floating-ui/react.mjs +0 -1
  88. package/__app__/chunks/libs/@mantine/core.mjs +0 -41
  89. package/__app__/chunks/libs/@mantine/hooks.mjs +0 -1
  90. package/__app__/chunks/libs/@nanostores/react.mjs +0 -1
  91. package/__app__/chunks/libs/@react-hookz/web.mjs +0 -1
  92. package/__app__/chunks/libs/@tabler/icons-react.mjs +0 -15
  93. package/__app__/chunks/libs/@tanstack/history.mjs +0 -1
  94. package/__app__/chunks/libs/@tanstack/react-router.mjs +0 -3
  95. package/__app__/chunks/libs/@tanstack/router-core.mjs +0 -1
  96. package/__app__/chunks/libs/@xstate/react.mjs +0 -1
  97. package/__app__/chunks/libs/@xstate/store.mjs +0 -1
  98. package/__app__/chunks/libs/@xyflow/react.mjs +0 -7
  99. package/__app__/chunks/libs/@zag-js/anatomy.mjs +0 -1
  100. package/__app__/chunks/libs/@zag-js/collection.mjs +0 -1
  101. package/__app__/chunks/libs/@zag-js/core.mjs +0 -1
  102. package/__app__/chunks/libs/@zag-js/react.mjs +0 -1
  103. package/__app__/chunks/libs/@zag-js/tree-view.mjs +0 -1
  104. package/__app__/chunks/libs/bezier-js.mjs +0 -1
  105. package/__app__/chunks/libs/d3-path.mjs +0 -1
  106. package/__app__/chunks/libs/d3-shape.mjs +0 -1
  107. package/__app__/chunks/libs/fast-equals.mjs +0 -1
  108. package/__app__/chunks/libs/framer-motion.mjs +0 -9
  109. package/__app__/chunks/libs/html-to-image.mjs +0 -2
  110. package/__app__/chunks/libs/motion-dom.mjs +0 -1
  111. package/__app__/chunks/libs/motion.mjs +0 -1
  112. package/__app__/chunks/libs/nanostores.mjs +0 -1
  113. package/__app__/chunks/libs/react-error-boundary.mjs +0 -1
  114. package/__app__/chunks/libs/react-resizable-panels.mjs +0 -1
  115. package/__app__/chunks/libs/remeda.mjs +0 -1
  116. package/__app__/chunks/libs/xstate.mjs +0 -1
  117. package/__app__/chunks/libs/zod.mjs +0 -39
  118. package/__app__/chunks/rolldown-runtime.mjs +0 -1
  119. package/__app__/chunks/safeCtx.mjs +0 -1
  120. package/__app__/chunks/searchParams.mjs +0 -1
  121. package/__app__/chunks/single-index.mjs +0 -1
  122. package/__app__/chunks/styled-system.mjs +0 -1
  123. package/__app__/chunks/styles.css.mjs +0 -1
  124. package/__app__/chunks/useLikeC4Project.mjs +0 -1
  125. package/__app__/chunks/useUpdateEffect.mjs +0 -1
  126. package/__app__/src/pages/AdHocViewEditor.mjs +0 -1
  127. package/__app__/src/pages/EmbedPage.mjs +0 -1
  128. package/__app__/src/pages/ExportPage.mjs +0 -1
  129. package/__app__/src/pages/ProjectsOverview.mjs +0 -1
  130. package/__app__/src/pages/ViewAsD2.mjs +0 -1
  131. package/__app__/src/pages/ViewAsDot.mjs +0 -1
  132. package/__app__/src/pages/ViewAsMmd.mjs +0 -1
  133. package/__app__/src/pages/ViewAsPuml.mjs +0 -1
  134. package/__app__/src/pages/ViewEditor.mjs +0 -1
  135. package/__app__/src/pages/ViewReact.mjs +0 -1
  136. package/__app__/src/routeTree.gen.mjs +0 -1
  137. package/__app__/src/routes/__root.mjs +0 -1
  138. package/__app__/src/routes/_single/adhoc.mjs +0 -1
  139. package/__app__/src/routes/_single/embed._viewId.mjs +0 -1
  140. package/__app__/src/routes/_single/export._viewId.mjs +0 -1
  141. package/__app__/src/routes/_single/route.mjs +0 -1
  142. package/__app__/src/routes/_single/single-index.mjs +0 -1
  143. package/__app__/src/routes/_single/view._viewId.d2.mjs +0 -1
  144. package/__app__/src/routes/_single/view._viewId.dot.mjs +0 -1
  145. package/__app__/src/routes/_single/view._viewId.index.mjs +0 -1
  146. package/__app__/src/routes/_single/view._viewId.mjs +0 -1
  147. package/__app__/src/routes/_single/view._viewId.mmd.mjs +0 -1
  148. package/__app__/src/routes/_single/view._viewId.puml.mjs +0 -1
  149. package/__app__/src/routes/_single/webcomponent._.mjs +0 -33
  150. package/__app__/src/routes/index.mjs +0 -1
  151. package/__app__/src/routes/project._projectId/-components.mjs +0 -1
  152. package/__app__/src/routes/project._projectId/adhoc.mjs +0 -1
  153. package/__app__/src/routes/project._projectId/embed._viewId.mjs +0 -1
  154. package/__app__/src/routes/project._projectId/export._viewId.mjs +0 -1
  155. package/__app__/src/routes/project._projectId/index.mjs +0 -1
  156. package/__app__/src/routes/project._projectId/route.mjs +0 -1
  157. package/__app__/src/routes/project._projectId/view._viewId.d2.mjs +0 -1
  158. package/__app__/src/routes/project._projectId/view._viewId.dot.mjs +0 -1
  159. package/__app__/src/routes/project._projectId/view._viewId.index.mjs +0 -1
  160. package/__app__/src/routes/project._projectId/view._viewId.mjs +0 -1
  161. package/__app__/src/routes/project._projectId/view._viewId.mmd.mjs +0 -1
  162. package/__app__/src/routes/project._projectId/view._viewId.puml.mjs +0 -1
  163. package/__app__/src/routes/projects.mjs +0 -1
  164. package/dist/chunks/libs/@chevrotain/utils.mjs +0 -1
  165. package/dist/chunks/libs/@hono/mcp.mjs +0 -45
  166. package/dist/chunks/libs/@hono/node-server.mjs +0 -1
  167. package/dist/chunks/libs/@logtape/logtape.d.mts +0 -1023
  168. package/dist/chunks/libs/@modelcontextprotocol/sdk.mjs +0 -12
  169. package/dist/chunks/libs/ajv.mjs +0 -1
  170. package/dist/chunks/libs/ansi-align.mjs +0 -2
  171. package/dist/chunks/libs/ansi-regex.mjs +0 -1
  172. package/dist/chunks/libs/ansi-styles.mjs +0 -1
  173. package/dist/chunks/libs/atomically.mjs +0 -1
  174. package/dist/chunks/libs/boxen.mjs +0 -22
  175. package/dist/chunks/libs/conf.mjs +0 -1
  176. package/dist/chunks/libs/defu.mjs +0 -1
  177. package/dist/chunks/libs/destr.mjs +0 -1
  178. package/dist/chunks/libs/find-up-simple.mjs +0 -1
  179. package/dist/chunks/libs/get-port.mjs +0 -1
  180. package/dist/chunks/libs/hono.mjs +0 -1
  181. package/dist/chunks/libs/is-docker.mjs +0 -1
  182. package/dist/chunks/libs/is-error-instance.mjs +0 -1
  183. package/dist/chunks/libs/is-inside-container.mjs +0 -1
  184. package/dist/chunks/libs/is-plain-obj.mjs +0 -1
  185. package/dist/chunks/libs/isexe.mjs +0 -1
  186. package/dist/chunks/libs/ky.mjs +0 -3
  187. package/dist/chunks/libs/p-debounce.mjs +0 -1
  188. package/dist/chunks/libs/p-limit.mjs +0 -1
  189. package/dist/chunks/libs/p-timeout.mjs +0 -1
  190. package/dist/chunks/libs/package-up.mjs +0 -1
  191. package/dist/chunks/libs/parse-ms.mjs +0 -1
  192. package/dist/chunks/libs/safe-stringify.mjs +0 -1
  193. package/dist/chunks/libs/strip-indent.mjs +0 -1
  194. package/dist/chunks/libs/tinyrainbow.mjs +0 -1
  195. package/dist/chunks/libs/ts-graphviz.d.mts +0 -12
  196. package/dist/chunks/libs/ts-graphviz.mjs +0 -4
  197. package/dist/chunks/libs/vscode-languageserver.mjs +0 -1
  198. package/dist/chunks/libs/word-wrap.mjs +0 -12
  199. package/dist/chunks/plugin.mjs +0 -400
  200. package/dist/vite-plugin/internal/chunks/libs/@nanostores/react.d.mts +0 -269
  201. package/dist/vite-plugin/internal/chunks/libs/@nanostores/react.mjs +0 -1
  202. package/dist/vite-plugin/internal/chunks/libs/birpc.mjs +0 -1
  203. package/dist/vite-plugin/internal/chunks/libs/fast-equals.mjs +0 -1
  204. package/dist/vite-plugin/internal/chunks/libs/nanostores.d.mts +0 -59
  205. package/dist/vite-plugin/internal/chunks/libs/nanostores.mjs +0 -1
  206. package/dist/vite-plugin/internal/chunks/libs/remeda.mjs +0 -1
  207. package/dist/vite-plugin/internal/chunks/rolldown-runtime.mjs +0 -1
@@ -0,0 +1,1003 @@
1
+ import "../rolldown-runtime.mjs";
2
+ //#region ../../node_modules/.pnpm/bezier-js@6.1.4/node_modules/bezier-js/src/utils.js
3
+ var { abs: e, cos: n, sin: r, acos: i, atan2: a, sqrt: o, pow: s } = Math;
4
+ function crt(e) {
5
+ return e < 0 ? -s(-e, 1 / 3) : s(e, 1 / 3);
6
+ }
7
+ var c = Math.PI, l = 2 * c, u = c / 2, f = 1e-6, p = 2 ** 53 - 1 || 9007199254740991, m = -(2 ** 53 - 1) || -9007199254740991, h = {
8
+ x: 0,
9
+ y: 0,
10
+ z: 0
11
+ }, g = {
12
+ Tvalues: [
13
+ -.06405689286260563,
14
+ .06405689286260563,
15
+ -.1911188674736163,
16
+ .1911188674736163,
17
+ -.3150426796961634,
18
+ .3150426796961634,
19
+ -.4337935076260451,
20
+ .4337935076260451,
21
+ -.5454214713888396,
22
+ .5454214713888396,
23
+ -.6480936519369755,
24
+ .6480936519369755,
25
+ -.7401241915785544,
26
+ .7401241915785544,
27
+ -.820001985973903,
28
+ .820001985973903,
29
+ -.8864155270044011,
30
+ .8864155270044011,
31
+ -.9382745520027328,
32
+ .9382745520027328,
33
+ -.9747285559713095,
34
+ .9747285559713095,
35
+ -.9951872199970213,
36
+ .9951872199970213
37
+ ],
38
+ Cvalues: [
39
+ .12793819534675216,
40
+ .12793819534675216,
41
+ .1258374563468283,
42
+ .1258374563468283,
43
+ .12167047292780339,
44
+ .12167047292780339,
45
+ .1155056680537256,
46
+ .1155056680537256,
47
+ .10744427011596563,
48
+ .10744427011596563,
49
+ .09761865210411388,
50
+ .09761865210411388,
51
+ .08619016153195327,
52
+ .08619016153195327,
53
+ .0733464814110803,
54
+ .0733464814110803,
55
+ .05929858491543678,
56
+ .05929858491543678,
57
+ .04427743881741981,
58
+ .04427743881741981,
59
+ .028531388628933663,
60
+ .028531388628933663,
61
+ .0123412297999872,
62
+ .0123412297999872
63
+ ],
64
+ arcfn: function(e, n) {
65
+ let r = n(e), i = r.x * r.x + r.y * r.y;
66
+ return r.z !== void 0 && (i += r.z * r.z), o(i);
67
+ },
68
+ compute: function(e, n, r) {
69
+ if (e === 0) return n[0].t = 0, n[0];
70
+ let i = n.length - 1;
71
+ if (e === 1) return n[i].t = 1, n[i];
72
+ let a = 1 - e, o = n;
73
+ if (i === 0) return n[0].t = e, n[0];
74
+ if (i === 1) {
75
+ let n = {
76
+ x: a * o[0].x + e * o[1].x,
77
+ y: a * o[0].y + e * o[1].y,
78
+ t: e
79
+ };
80
+ return r && (n.z = a * o[0].z + e * o[1].z), n;
81
+ }
82
+ if (i < 4) {
83
+ let n = a * a, s = e * e, c, l, u, f = 0;
84
+ i === 2 ? (o = [
85
+ o[0],
86
+ o[1],
87
+ o[2],
88
+ h
89
+ ], c = n, l = a * e * 2, u = s) : i === 3 && (c = n * a, l = n * e * 3, u = a * s * 3, f = e * s);
90
+ let p = {
91
+ x: c * o[0].x + l * o[1].x + u * o[2].x + f * o[3].x,
92
+ y: c * o[0].y + l * o[1].y + u * o[2].y + f * o[3].y,
93
+ t: e
94
+ };
95
+ return r && (p.z = c * o[0].z + l * o[1].z + u * o[2].z + f * o[3].z), p;
96
+ }
97
+ let s = JSON.parse(JSON.stringify(n));
98
+ for (; s.length > 1;) {
99
+ for (let n = 0; n < s.length - 1; n++) s[n] = {
100
+ x: s[n].x + (s[n + 1].x - s[n].x) * e,
101
+ y: s[n].y + (s[n + 1].y - s[n].y) * e
102
+ }, s[n].z !== void 0 && (s[n].z = s[n].z + (s[n + 1].z - s[n].z) * e);
103
+ s.splice(s.length - 1, 1);
104
+ }
105
+ return s[0].t = e, s[0];
106
+ },
107
+ computeWithRatios: function(e, n, r, i) {
108
+ let a = 1 - e, o = r, s = n, c = o[0], l = o[1], u = o[2], f = o[3], p;
109
+ if (c *= a, l *= e, s.length === 2) return p = c + l, {
110
+ x: (c * s[0].x + l * s[1].x) / p,
111
+ y: (c * s[0].y + l * s[1].y) / p,
112
+ z: i ? (c * s[0].z + l * s[1].z) / p : !1,
113
+ t: e
114
+ };
115
+ if (c *= a, l *= 2 * a, u *= e * e, s.length === 3) return p = c + l + u, {
116
+ x: (c * s[0].x + l * s[1].x + u * s[2].x) / p,
117
+ y: (c * s[0].y + l * s[1].y + u * s[2].y) / p,
118
+ z: i ? (c * s[0].z + l * s[1].z + u * s[2].z) / p : !1,
119
+ t: e
120
+ };
121
+ if (c *= a, l *= 1.5 * a, u *= 3 * a, f *= e * e * e, s.length === 4) return p = c + l + u + f, {
122
+ x: (c * s[0].x + l * s[1].x + u * s[2].x + f * s[3].x) / p,
123
+ y: (c * s[0].y + l * s[1].y + u * s[2].y + f * s[3].y) / p,
124
+ z: i ? (c * s[0].z + l * s[1].z + u * s[2].z + f * s[3].z) / p : !1,
125
+ t: e
126
+ };
127
+ },
128
+ derive: function(e, n) {
129
+ let r = [];
130
+ for (let i = e, a = i.length, o = a - 1; a > 1; a--, o--) {
131
+ let e = [];
132
+ for (let r = 0, a; r < o; r++) a = {
133
+ x: o * (i[r + 1].x - i[r].x),
134
+ y: o * (i[r + 1].y - i[r].y)
135
+ }, n && (a.z = o * (i[r + 1].z - i[r].z)), e.push(a);
136
+ r.push(e), i = e;
137
+ }
138
+ return r;
139
+ },
140
+ between: function(e, n, r) {
141
+ return n <= e && e <= r || g.approximately(e, n) || g.approximately(e, r);
142
+ },
143
+ approximately: function(n, r, i) {
144
+ return e(n - r) <= (i || f);
145
+ },
146
+ length: function(e) {
147
+ let n = .5, r = g.Tvalues.length, i = 0;
148
+ for (let a = 0, o; a < r; a++) o = n * g.Tvalues[a] + n, i += g.Cvalues[a] * g.arcfn(o, e);
149
+ return n * i;
150
+ },
151
+ map: function(e, n, r, i, a) {
152
+ let o = r - n;
153
+ return i + (a - i) * ((e - n) / o);
154
+ },
155
+ lerp: function(e, n, r) {
156
+ let i = {
157
+ x: n.x + e * (r.x - n.x),
158
+ y: n.y + e * (r.y - n.y)
159
+ };
160
+ return n.z !== void 0 && r.z !== void 0 && (i.z = n.z + e * (r.z - n.z)), i;
161
+ },
162
+ pointToString: function(e) {
163
+ let n = e.x + "/" + e.y;
164
+ return e.z !== void 0 && (n += "/" + e.z), n;
165
+ },
166
+ pointsToString: function(e) {
167
+ return "[" + e.map(g.pointToString).join(", ") + "]";
168
+ },
169
+ copy: function(e) {
170
+ return JSON.parse(JSON.stringify(e));
171
+ },
172
+ angle: function(e, n, r) {
173
+ let i = n.x - e.x, o = n.y - e.y, s = r.x - e.x, c = r.y - e.y;
174
+ return a(i * c - o * s, i * s + o * c);
175
+ },
176
+ round: function(e, n) {
177
+ let r = "" + e, i = r.indexOf(".");
178
+ return parseFloat(r.substring(0, i + 1 + n));
179
+ },
180
+ dist: function(e, n) {
181
+ let r = e.x - n.x, i = e.y - n.y;
182
+ return o(r * r + i * i);
183
+ },
184
+ closest: function(e, n) {
185
+ let r = s(2, 63), i, a;
186
+ return e.forEach(function(e, o) {
187
+ a = g.dist(n, e), a < r && (r = a, i = o);
188
+ }), {
189
+ mdist: r,
190
+ mpos: i
191
+ };
192
+ },
193
+ abcratio: function(n, r) {
194
+ if (r !== 2 && r !== 3) return !1;
195
+ if (n === void 0) n = .5;
196
+ else if (n === 0 || n === 1) return n;
197
+ let i = s(n, r) + s(1 - n, r);
198
+ return e((i - 1) / i);
199
+ },
200
+ projectionratio: function(e, n) {
201
+ if (n !== 2 && n !== 3) return !1;
202
+ if (e === void 0) e = .5;
203
+ else if (e === 0 || e === 1) return e;
204
+ let r = s(1 - e, n);
205
+ return r / (s(e, n) + r);
206
+ },
207
+ lli8: function(e, n, r, i, a, o, s, c) {
208
+ let l = (e * i - n * r) * (a - s) - (e - r) * (a * c - o * s), u = (e * i - n * r) * (o - c) - (n - i) * (a * c - o * s), f = (e - r) * (o - c) - (n - i) * (a - s);
209
+ return f == 0 ? !1 : {
210
+ x: l / f,
211
+ y: u / f
212
+ };
213
+ },
214
+ lli4: function(e, n, r, i) {
215
+ let a = e.x, o = e.y, s = n.x, c = n.y, l = r.x, u = r.y, f = i.x, p = i.y;
216
+ return g.lli8(a, o, s, c, l, u, f, p);
217
+ },
218
+ lli: function(e, n) {
219
+ return g.lli4(e, e.c, n, n.c);
220
+ },
221
+ makeline: function(e, n) {
222
+ return new E(e.x, e.y, (e.x + n.x) / 2, (e.y + n.y) / 2, n.x, n.y);
223
+ },
224
+ findbbox: function(e) {
225
+ let n = p, r = p, i = m, a = m;
226
+ return e.forEach(function(e) {
227
+ let o = e.bbox();
228
+ n > o.x.min && (n = o.x.min), r > o.y.min && (r = o.y.min), i < o.x.max && (i = o.x.max), a < o.y.max && (a = o.y.max);
229
+ }), {
230
+ x: {
231
+ min: n,
232
+ mid: (n + i) / 2,
233
+ max: i,
234
+ size: i - n
235
+ },
236
+ y: {
237
+ min: r,
238
+ mid: (r + a) / 2,
239
+ max: a,
240
+ size: a - r
241
+ }
242
+ };
243
+ },
244
+ shapeintersections: function(e, n, r, i, a) {
245
+ if (!g.bboxoverlap(n, i)) return [];
246
+ let o = [], s = [
247
+ e.startcap,
248
+ e.forward,
249
+ e.back,
250
+ e.endcap
251
+ ], c = [
252
+ r.startcap,
253
+ r.forward,
254
+ r.back,
255
+ r.endcap
256
+ ];
257
+ return s.forEach(function(n) {
258
+ n.virtual || c.forEach(function(i) {
259
+ if (i.virtual) return;
260
+ let s = n.intersects(i, a);
261
+ s.length > 0 && (s.c1 = n, s.c2 = i, s.s1 = e, s.s2 = r, o.push(s));
262
+ });
263
+ }), o;
264
+ },
265
+ makeshape: function(e, n, r) {
266
+ let i = n.points.length, a = e.points.length, o = g.makeline(n.points[i - 1], e.points[0]), s = g.makeline(e.points[a - 1], n.points[0]), c = {
267
+ startcap: o,
268
+ forward: e,
269
+ back: n,
270
+ endcap: s,
271
+ bbox: g.findbbox([
272
+ o,
273
+ e,
274
+ n,
275
+ s
276
+ ])
277
+ };
278
+ return c.intersections = function(e) {
279
+ return g.shapeintersections(c, c.bbox, e, e.bbox, r);
280
+ }, c;
281
+ },
282
+ getminmax: function(e, n, r) {
283
+ if (!r) return {
284
+ min: 0,
285
+ max: 0
286
+ };
287
+ let i = p, a = m, o, s;
288
+ r.indexOf(0) === -1 && (r = [0].concat(r)), r.indexOf(1) === -1 && r.push(1);
289
+ for (let c = 0, l = r.length; c < l; c++) o = r[c], s = e.get(o), s[n] < i && (i = s[n]), s[n] > a && (a = s[n]);
290
+ return {
291
+ min: i,
292
+ mid: (i + a) / 2,
293
+ max: a,
294
+ size: a - i
295
+ };
296
+ },
297
+ align: function(e, i) {
298
+ let o = i.p1.x, s = i.p1.y, c = -a(i.p2.y - s, i.p2.x - o), d = function(e) {
299
+ return {
300
+ x: (e.x - o) * n(c) - (e.y - s) * r(c),
301
+ y: (e.x - o) * r(c) + (e.y - s) * n(c)
302
+ };
303
+ };
304
+ return e.map(d);
305
+ },
306
+ roots: function(e, r) {
307
+ r ||= {
308
+ p1: {
309
+ x: 0,
310
+ y: 0
311
+ },
312
+ p2: {
313
+ x: 1,
314
+ y: 0
315
+ }
316
+ };
317
+ let a = e.length - 1, s = g.align(e, r), reduce = function(e) {
318
+ return 0 <= e && e <= 1;
319
+ };
320
+ if (a === 2) {
321
+ let e = s[0].y, n = s[1].y, r = s[2].y, i = e - 2 * n + r;
322
+ if (i !== 0) {
323
+ let a = -o(n * n - e * r), s = -e + n;
324
+ return [-(a + s) / i, -(-a + s) / i].filter(reduce);
325
+ } else if (n !== r && i === 0) return [(2 * n - r) / (2 * n - 2 * r)].filter(reduce);
326
+ return [];
327
+ }
328
+ let c = s[0].y, u = s[1].y, f = s[2].y, p = s[3].y, m = -c + 3 * u - 3 * f + p, h = 3 * c - 6 * u + 3 * f, _ = -3 * c + 3 * u, v = c;
329
+ if (g.approximately(m, 0)) {
330
+ if (g.approximately(h, 0)) return g.approximately(_, 0) ? [] : [-v / _].filter(reduce);
331
+ let e = o(_ * _ - 4 * h * v), n = 2 * h;
332
+ return [(e - _) / n, (-_ - e) / n].filter(reduce);
333
+ }
334
+ h /= m, _ /= m, v /= m;
335
+ let y = (3 * _ - h * h) / 3, b = y / 3, x = (2 * h * h * h - 9 * h * _ + 27 * v) / 27, S = x / 2, C = S * S + b * b * b, w, T, E, D, O;
336
+ if (C < 0) {
337
+ let e = -y / 3, r = o(e * e * e), a = -x / (2 * r), s = i(a < -1 ? -1 : a > 1 ? 1 : a), c = 2 * crt(r);
338
+ return E = c * n(s / 3) - h / 3, D = c * n((s + l) / 3) - h / 3, O = c * n((s + 2 * l) / 3) - h / 3, [
339
+ E,
340
+ D,
341
+ O
342
+ ].filter(reduce);
343
+ } else if (C === 0) return w = S < 0 ? crt(-S) : -crt(S), E = 2 * w - h / 3, D = -w - h / 3, [E, D].filter(reduce);
344
+ else {
345
+ let e = o(C);
346
+ return w = crt(-S + e), T = crt(S + e), [w - T - h / 3].filter(reduce);
347
+ }
348
+ },
349
+ droots: function(e) {
350
+ if (e.length === 3) {
351
+ let n = e[0], r = e[1], i = e[2], a = n - 2 * r + i;
352
+ if (a !== 0) {
353
+ let e = -o(r * r - n * i), s = -n + r;
354
+ return [-(e + s) / a, -(-e + s) / a];
355
+ } else if (r !== i && a === 0) return [(2 * r - i) / (2 * (r - i))];
356
+ return [];
357
+ }
358
+ if (e.length === 2) {
359
+ let n = e[0], r = e[1];
360
+ return n === r ? [] : [n / (n - r)];
361
+ }
362
+ return [];
363
+ },
364
+ curvature: function(n, r, i, a, c) {
365
+ let l, u, f, p, m = 0, h = 0, _ = g.compute(n, r), v = g.compute(n, i), y = _.x * _.x + _.y * _.y;
366
+ if (a ? (l = o(s(_.y * v.z - v.y * _.z, 2) + s(_.z * v.x - v.z * _.x, 2) + s(_.x * v.y - v.x * _.y, 2)), u = s(y + _.z * _.z, 3 / 2)) : (l = _.x * v.y - _.y * v.x, u = s(y, 3 / 2)), l === 0 || u === 0) return {
367
+ k: 0,
368
+ r: 0
369
+ };
370
+ if (m = l / u, h = u / l, !c) {
371
+ let o = g.curvature(n - .001, r, i, a, !0).k, s = g.curvature(n + .001, r, i, a, !0).k;
372
+ p = (s - m + (m - o)) / 2, f = (e(s - m) + e(m - o)) / 2;
373
+ }
374
+ return {
375
+ k: m,
376
+ r: h,
377
+ dk: p,
378
+ adk: f
379
+ };
380
+ },
381
+ inflections: function(e) {
382
+ if (e.length < 4) return [];
383
+ let n = g.align(e, {
384
+ p1: e[0],
385
+ p2: e.slice(-1)[0]
386
+ }), r = n[2].x * n[1].y, i = n[3].x * n[1].y, a = n[1].x * n[2].y, o = n[3].x * n[2].y, s = 18 * (-3 * r + 2 * i + 3 * a - o), c = 18 * (3 * r - i - 3 * a), l = 18 * (a - r);
387
+ if (g.approximately(s, 0)) {
388
+ if (!g.approximately(c, 0)) {
389
+ let e = -l / c;
390
+ if (0 <= e && e <= 1) return [e];
391
+ }
392
+ return [];
393
+ }
394
+ let u = 2 * s;
395
+ if (g.approximately(u, 0)) return [];
396
+ let f = c * c - 4 * s * l;
397
+ if (f < 0) return [];
398
+ let p = Math.sqrt(f);
399
+ return [(p - c) / u, -(c + p) / u].filter(function(e) {
400
+ return 0 <= e && e <= 1;
401
+ });
402
+ },
403
+ bboxoverlap: function(n, r) {
404
+ let i = ["x", "y"], a = i.length;
405
+ for (let o = 0, s, c, l, u; o < a; o++) if (s = i[o], c = n[s].mid, l = r[s].mid, u = (n[s].size + r[s].size) / 2, e(c - l) >= u) return !1;
406
+ return !0;
407
+ },
408
+ expandbox: function(e, n) {
409
+ n.x.min < e.x.min && (e.x.min = n.x.min), n.y.min < e.y.min && (e.y.min = n.y.min), n.z && n.z.min < e.z.min && (e.z.min = n.z.min), n.x.max > e.x.max && (e.x.max = n.x.max), n.y.max > e.y.max && (e.y.max = n.y.max), n.z && n.z.max > e.z.max && (e.z.max = n.z.max), e.x.mid = (e.x.min + e.x.max) / 2, e.y.mid = (e.y.min + e.y.max) / 2, e.z && (e.z.mid = (e.z.min + e.z.max) / 2), e.x.size = e.x.max - e.x.min, e.y.size = e.y.max - e.y.min, e.z && (e.z.size = e.z.max - e.z.min);
410
+ },
411
+ pairiteration: function(e, n, r) {
412
+ let i = e.bbox(), a = n.bbox(), o = 1e5, s = r || .5;
413
+ if (i.x.size + i.y.size < s && a.x.size + a.y.size < s) return [(o * (e._t1 + e._t2) / 2 | 0) / o + "/" + (o * (n._t1 + n._t2) / 2 | 0) / o];
414
+ let c = e.split(.5), l = n.split(.5), u = [
415
+ {
416
+ left: c.left,
417
+ right: l.left
418
+ },
419
+ {
420
+ left: c.left,
421
+ right: l.right
422
+ },
423
+ {
424
+ left: c.right,
425
+ right: l.right
426
+ },
427
+ {
428
+ left: c.right,
429
+ right: l.left
430
+ }
431
+ ];
432
+ u = u.filter(function(e) {
433
+ return g.bboxoverlap(e.left.bbox(), e.right.bbox());
434
+ });
435
+ let f = [];
436
+ return u.length === 0 ? f : (u.forEach(function(e) {
437
+ f = f.concat(g.pairiteration(e.left, e.right, s));
438
+ }), f = f.filter(function(e, n) {
439
+ return f.indexOf(e) === n;
440
+ }), f);
441
+ },
442
+ getccenter: function(e, i, o) {
443
+ let s = i.x - e.x, c = i.y - e.y, f = o.x - i.x, p = o.y - i.y, m = s * n(u) - c * r(u), h = s * r(u) + c * n(u), _ = f * n(u) - p * r(u), v = f * r(u) + p * n(u), y = (e.x + i.x) / 2, b = (e.y + i.y) / 2, x = (i.x + o.x) / 2, S = (i.y + o.y) / 2, C = y + m, w = b + h, T = x + _, E = S + v, D = g.lli8(y, b, C, w, x, S, T, E), O = g.dist(D, e), k = a(e.y - D.y, e.x - D.x), A = a(i.y - D.y, i.x - D.x), j = a(o.y - D.y, o.x - D.x), M;
444
+ return k < j ? ((k > A || A > j) && (k += l), k > j && (M = j, j = k, k = M)) : j < A && A < k ? (M = j, j = k, k = M) : j += l, D.s = k, D.e = j, D.r = O, D;
445
+ },
446
+ numberSort: function(e, n) {
447
+ return e - n;
448
+ }
449
+ }, _ = class PolyBezier {
450
+ constructor(e) {
451
+ this.curves = [], this._3d = !1, e && (this.curves = e, this._3d = this.curves[0]._3d);
452
+ }
453
+ valueOf() {
454
+ return this.toString();
455
+ }
456
+ toString() {
457
+ return "[" + this.curves.map(function(e) {
458
+ return g.pointsToString(e.points);
459
+ }).join(", ") + "]";
460
+ }
461
+ addCurve(e) {
462
+ this.curves.push(e), this._3d = this._3d || e._3d;
463
+ }
464
+ length() {
465
+ return this.curves.map(function(e) {
466
+ return e.length();
467
+ }).reduce(function(e, n) {
468
+ return e + n;
469
+ });
470
+ }
471
+ curve(e) {
472
+ return this.curves[e];
473
+ }
474
+ bbox() {
475
+ let e = this.curves;
476
+ for (var n = e[0].bbox(), r = 1; r < e.length; r++) g.expandbox(n, e[r].bbox());
477
+ return n;
478
+ }
479
+ offset(e) {
480
+ let n = [];
481
+ return this.curves.forEach(function(r) {
482
+ n.push(...r.offset(e));
483
+ }), new PolyBezier(n);
484
+ }
485
+ }, { abs: v, min: y, max: b, cos: x, sin: S, acos: C, sqrt: w } = Math, T = Math.PI, E = class Bezier {
486
+ constructor(e) {
487
+ let n = e && e.forEach ? e : Array.from(arguments).slice(), r = !1;
488
+ if (typeof n[0] == "object") {
489
+ r = n.length;
490
+ let e = [];
491
+ n.forEach(function(n) {
492
+ [
493
+ "x",
494
+ "y",
495
+ "z"
496
+ ].forEach(function(r) {
497
+ n[r] !== void 0 && e.push(n[r]);
498
+ });
499
+ }), n = e;
500
+ }
501
+ let i = !1, a = n.length;
502
+ if (r) {
503
+ if (r > 4) {
504
+ if (arguments.length !== 1) throw Error("Only new Bezier(point[]) is accepted for 4th and higher order curves");
505
+ i = !0;
506
+ }
507
+ } else if (a !== 6 && a !== 8 && a !== 9 && a !== 12 && arguments.length !== 1) throw Error("Only new Bezier(point[]) is accepted for 4th and higher order curves");
508
+ let o = this._3d = !i && (a === 9 || a === 12) || e && e[0] && e[0].z !== void 0, s = this.points = [];
509
+ for (let e = 0, r = o ? 3 : 2; e < a; e += r) {
510
+ var c = {
511
+ x: n[e],
512
+ y: n[e + 1]
513
+ };
514
+ o && (c.z = n[e + 2]), s.push(c);
515
+ }
516
+ let l = this.order = s.length - 1, u = this.dims = ["x", "y"];
517
+ o && u.push("z"), this.dimlen = u.length;
518
+ let f = g.align(s, {
519
+ p1: s[0],
520
+ p2: s[l]
521
+ }), p = g.dist(s[0], s[l]);
522
+ this._linear = f.reduce((e, n) => e + v(n.y), 0) < p / 50, this._lut = [], this._t1 = 0, this._t2 = 1, this.update();
523
+ }
524
+ static quadraticFromPoints(e, n, r, i) {
525
+ return i === void 0 && (i = .5), i === 0 ? new Bezier(n, n, r) : i === 1 ? new Bezier(e, n, n) : new Bezier(e, Bezier.getABC(2, e, n, r, i).A, r);
526
+ }
527
+ static cubicFromPoints(e, n, r, i, a) {
528
+ i === void 0 && (i = .5);
529
+ let o = Bezier.getABC(3, e, n, r, i);
530
+ a === void 0 && (a = g.dist(n, o.C));
531
+ let s = a * (1 - i) / i, c = g.dist(e, r), l = (r.x - e.x) / c, u = (r.y - e.y) / c, f = a * l, p = a * u, m = s * l, h = s * u, _ = {
532
+ x: n.x - f,
533
+ y: n.y - p
534
+ }, v = {
535
+ x: n.x + m,
536
+ y: n.y + h
537
+ }, y = o.A, b = {
538
+ x: y.x + (_.x - y.x) / (1 - i),
539
+ y: y.y + (_.y - y.y) / (1 - i)
540
+ }, x = {
541
+ x: y.x + (v.x - y.x) / i,
542
+ y: y.y + (v.y - y.y) / i
543
+ };
544
+ return new Bezier(e, {
545
+ x: e.x + (b.x - e.x) / i,
546
+ y: e.y + (b.y - e.y) / i
547
+ }, {
548
+ x: r.x + (x.x - r.x) / (1 - i),
549
+ y: r.y + (x.y - r.y) / (1 - i)
550
+ }, r);
551
+ }
552
+ static getUtils() {
553
+ return g;
554
+ }
555
+ getUtils() {
556
+ return Bezier.getUtils();
557
+ }
558
+ static get PolyBezier() {
559
+ return _;
560
+ }
561
+ valueOf() {
562
+ return this.toString();
563
+ }
564
+ toString() {
565
+ return g.pointsToString(this.points);
566
+ }
567
+ toSVG() {
568
+ if (this._3d) return !1;
569
+ let e = this.points, n = [
570
+ "M",
571
+ e[0].x,
572
+ e[0].y,
573
+ this.order === 2 ? "Q" : "C"
574
+ ];
575
+ for (let r = 1, i = e.length; r < i; r++) n.push(e[r].x), n.push(e[r].y);
576
+ return n.join(" ");
577
+ }
578
+ setRatios(e) {
579
+ if (e.length !== this.points.length) throw Error("incorrect number of ratio values");
580
+ this.ratios = e, this._lut = [];
581
+ }
582
+ verify() {
583
+ let e = this.coordDigest();
584
+ e !== this._print && (this._print = e, this.update());
585
+ }
586
+ coordDigest() {
587
+ return this.points.map(function(e, n) {
588
+ return "" + n + e.x + e.y + (e.z ? e.z : 0);
589
+ }).join("");
590
+ }
591
+ update() {
592
+ this._lut = [], this.dpoints = g.derive(this.points, this._3d), this.computedirection();
593
+ }
594
+ computedirection() {
595
+ let e = this.points, n = g.angle(e[0], e[this.order], e[1]);
596
+ this.clockwise = n > 0;
597
+ }
598
+ length() {
599
+ return g.length(this.derivative.bind(this));
600
+ }
601
+ static getABC(e = 2, n, r, i, a = .5) {
602
+ let o = g.projectionratio(a, e), s = 1 - o, c = {
603
+ x: o * n.x + s * i.x,
604
+ y: o * n.y + s * i.y
605
+ }, l = g.abcratio(a, e);
606
+ return {
607
+ A: {
608
+ x: r.x + (r.x - c.x) / l,
609
+ y: r.y + (r.y - c.y) / l
610
+ },
611
+ B: r,
612
+ C: c,
613
+ S: n,
614
+ E: i
615
+ };
616
+ }
617
+ getABC(e, n) {
618
+ n ||= this.get(e);
619
+ let r = this.points[0], i = this.points[this.order];
620
+ return Bezier.getABC(this.order, r, n, i, e);
621
+ }
622
+ getLUT(e) {
623
+ if (this.verify(), e ||= 100, this._lut.length === e + 1) return this._lut;
624
+ this._lut = [], e++, this._lut = [];
625
+ for (let n = 0, r, i; n < e; n++) i = n / (e - 1), r = this.compute(i), r.t = i, this._lut.push(r);
626
+ return this._lut;
627
+ }
628
+ on(e, n) {
629
+ n ||= 5;
630
+ let r = this.getLUT(), i = [];
631
+ for (let a = 0, o, s = 0; a < r.length; a++) o = r[a], g.dist(o, e) < n && (i.push(o), s += a / r.length);
632
+ return i.length ? t /= i.length : !1;
633
+ }
634
+ project(e) {
635
+ let n = this.getLUT(), r = n.length - 1, i = g.closest(n, e), a = i.mpos, o = (a - 1) / r, s = (a + 1) / r, c = .1 / r, l = i.mdist, u = o, f = u, p;
636
+ l += 1;
637
+ for (let n; u < s + c; u += c) p = this.compute(u), n = g.dist(e, p), n < l && (l = n, f = u);
638
+ return f = f < 0 ? 0 : f > 1 ? 1 : f, p = this.compute(f), p.t = f, p.d = l, p;
639
+ }
640
+ get(e) {
641
+ return this.compute(e);
642
+ }
643
+ point(e) {
644
+ return this.points[e];
645
+ }
646
+ compute(e) {
647
+ return this.ratios ? g.computeWithRatios(e, this.points, this.ratios, this._3d) : g.compute(e, this.points, this._3d, this.ratios);
648
+ }
649
+ raise() {
650
+ let e = this.points, n = [e[0]], r = e.length;
651
+ for (let i = 1, a, o; i < r; i++) a = e[i], o = e[i - 1], n[i] = {
652
+ x: (r - i) / r * a.x + i / r * o.x,
653
+ y: (r - i) / r * a.y + i / r * o.y
654
+ };
655
+ return n[r] = e[r - 1], new Bezier(n);
656
+ }
657
+ derivative(e) {
658
+ return g.compute(e, this.dpoints[0], this._3d);
659
+ }
660
+ dderivative(e) {
661
+ return g.compute(e, this.dpoints[1], this._3d);
662
+ }
663
+ align() {
664
+ let e = this.points;
665
+ return new Bezier(g.align(e, {
666
+ p1: e[0],
667
+ p2: e[e.length - 1]
668
+ }));
669
+ }
670
+ curvature(e) {
671
+ return g.curvature(e, this.dpoints[0], this.dpoints[1], this._3d);
672
+ }
673
+ inflections() {
674
+ return g.inflections(this.points);
675
+ }
676
+ normal(e) {
677
+ return this._3d ? this.__normal3(e) : this.__normal2(e);
678
+ }
679
+ __normal2(e) {
680
+ let n = this.derivative(e), r = w(n.x * n.x + n.y * n.y);
681
+ return {
682
+ t: e,
683
+ x: -n.y / r,
684
+ y: n.x / r
685
+ };
686
+ }
687
+ __normal3(e) {
688
+ let n = this.derivative(e), r = this.derivative(e + .01), i = w(n.x * n.x + n.y * n.y + n.z * n.z), a = w(r.x * r.x + r.y * r.y + r.z * r.z);
689
+ n.x /= i, n.y /= i, n.z /= i, r.x /= a, r.y /= a, r.z /= a;
690
+ let o = {
691
+ x: r.y * n.z - r.z * n.y,
692
+ y: r.z * n.x - r.x * n.z,
693
+ z: r.x * n.y - r.y * n.x
694
+ }, s = w(o.x * o.x + o.y * o.y + o.z * o.z);
695
+ o.x /= s, o.y /= s, o.z /= s;
696
+ let c = [
697
+ o.x * o.x,
698
+ o.x * o.y - o.z,
699
+ o.x * o.z + o.y,
700
+ o.x * o.y + o.z,
701
+ o.y * o.y,
702
+ o.y * o.z - o.x,
703
+ o.x * o.z - o.y,
704
+ o.y * o.z + o.x,
705
+ o.z * o.z
706
+ ];
707
+ return {
708
+ t: e,
709
+ x: c[0] * n.x + c[1] * n.y + c[2] * n.z,
710
+ y: c[3] * n.x + c[4] * n.y + c[5] * n.z,
711
+ z: c[6] * n.x + c[7] * n.y + c[8] * n.z
712
+ };
713
+ }
714
+ hull(e) {
715
+ let n = this.points, r = [], i = [], a = 0;
716
+ for (i[a++] = n[0], i[a++] = n[1], i[a++] = n[2], this.order === 3 && (i[a++] = n[3]); n.length > 1;) {
717
+ r = [];
718
+ for (let o = 0, s, c = n.length - 1; o < c; o++) s = g.lerp(e, n[o], n[o + 1]), i[a++] = s, r.push(s);
719
+ n = r;
720
+ }
721
+ return i;
722
+ }
723
+ split(e, n) {
724
+ if (e === 0 && n) return this.split(n).left;
725
+ if (n === 1) return this.split(e).right;
726
+ let r = this.hull(e), i = {
727
+ left: this.order === 2 ? new Bezier([
728
+ r[0],
729
+ r[3],
730
+ r[5]
731
+ ]) : new Bezier([
732
+ r[0],
733
+ r[4],
734
+ r[7],
735
+ r[9]
736
+ ]),
737
+ right: this.order === 2 ? new Bezier([
738
+ r[5],
739
+ r[4],
740
+ r[2]
741
+ ]) : new Bezier([
742
+ r[9],
743
+ r[8],
744
+ r[6],
745
+ r[3]
746
+ ]),
747
+ span: r
748
+ };
749
+ return i.left._t1 = g.map(0, 0, 1, this._t1, this._t2), i.left._t2 = g.map(e, 0, 1, this._t1, this._t2), i.right._t1 = g.map(e, 0, 1, this._t1, this._t2), i.right._t2 = g.map(1, 0, 1, this._t1, this._t2), n ? (n = g.map(n, e, 1, 0, 1), i.right.split(n).left) : i;
750
+ }
751
+ extrema() {
752
+ let e = {}, n = [];
753
+ return this.dims.forEach(function(r) {
754
+ let mfn = function(e) {
755
+ return e[r];
756
+ }, i = this.dpoints[0].map(mfn);
757
+ e[r] = g.droots(i), this.order === 3 && (i = this.dpoints[1].map(mfn), e[r] = e[r].concat(g.droots(i))), e[r] = e[r].filter(function(e) {
758
+ return e >= 0 && e <= 1;
759
+ }), n = n.concat(e[r].sort(g.numberSort));
760
+ }.bind(this)), e.values = n.sort(g.numberSort).filter(function(e, r) {
761
+ return n.indexOf(e) === r;
762
+ }), e;
763
+ }
764
+ bbox() {
765
+ let e = this.extrema(), n = {};
766
+ return this.dims.forEach(function(r) {
767
+ n[r] = g.getminmax(this, r, e[r]);
768
+ }.bind(this)), n;
769
+ }
770
+ overlaps(e) {
771
+ let n = this.bbox(), r = e.bbox();
772
+ return g.bboxoverlap(n, r);
773
+ }
774
+ offset(e, n) {
775
+ if (n !== void 0) {
776
+ let r = this.get(e), i = this.normal(e), a = {
777
+ c: r,
778
+ n: i,
779
+ x: r.x + i.x * n,
780
+ y: r.y + i.y * n
781
+ };
782
+ return this._3d && (a.z = r.z + i.z * n), a;
783
+ }
784
+ if (this._linear) {
785
+ let n = this.normal(0);
786
+ return [new Bezier(this.points.map(function(r) {
787
+ let i = {
788
+ x: r.x + e * n.x,
789
+ y: r.y + e * n.y
790
+ };
791
+ return r.z && n.z && (i.z = r.z + e * n.z), i;
792
+ }))];
793
+ }
794
+ return this.reduce().map(function(n) {
795
+ return n._linear ? n.offset(e)[0] : n.scale(e);
796
+ });
797
+ }
798
+ simple() {
799
+ if (this.order === 3) {
800
+ let e = g.angle(this.points[0], this.points[3], this.points[1]), n = g.angle(this.points[0], this.points[3], this.points[2]);
801
+ if (e > 0 && n < 0 || e < 0 && n > 0) return !1;
802
+ }
803
+ let e = this.normal(0), n = this.normal(1), r = e.x * n.x + e.y * n.y;
804
+ return this._3d && (r += e.z * n.z), v(C(r)) < T / 3;
805
+ }
806
+ reduce() {
807
+ let e, n = 0, r = 0, i = .01, a, o = [], s = [], c = this.extrema().values;
808
+ for (c.indexOf(0) === -1 && (c = [0].concat(c)), c.indexOf(1) === -1 && c.push(1), n = c[0], e = 1; e < c.length; e++) r = c[e], a = this.split(n, r), a._t1 = n, a._t2 = r, o.push(a), n = r;
809
+ return o.forEach(function(e) {
810
+ for (n = 0, r = 0; r <= 1;) for (r = n + i; r <= 1.01; r += i) if (a = e.split(n, r), !a.simple()) {
811
+ if (r -= i, v(n - r) < i) return [];
812
+ a = e.split(n, r), a._t1 = g.map(n, 0, 1, e._t1, e._t2), a._t2 = g.map(r, 0, 1, e._t1, e._t2), s.push(a), n = r;
813
+ break;
814
+ }
815
+ n < 1 && (a = e.split(n, 1), a._t1 = g.map(n, 0, 1, e._t1, e._t2), a._t2 = e._t2, s.push(a));
816
+ }), s;
817
+ }
818
+ translate(e, n, r) {
819
+ r = typeof r == "number" ? r : n;
820
+ let i = this.order, a = this.points.map((e, a) => (1 - a / i) * n + a / i * r);
821
+ return new Bezier(this.points.map((n, r) => ({
822
+ x: n.x + e.x * a[r],
823
+ y: n.y + e.y * a[r]
824
+ })));
825
+ }
826
+ scale(e) {
827
+ let n = this.order, r = !1;
828
+ if (typeof e == "function" && (r = e), r && n === 2) return this.raise().scale(r);
829
+ let i = this.clockwise, a = this.points;
830
+ if (this._linear) return this.translate(this.normal(0), r ? r(0) : e, r ? r(1) : e);
831
+ let o = r ? r(0) : e, s = r ? r(1) : e, c = [this.offset(0, 10), this.offset(1, 10)], l = [], u = g.lli4(c[0], c[0].c, c[1], c[1].c);
832
+ if (!u) throw Error("cannot scale this curve. Try reducing it first.");
833
+ return [0, 1].forEach(function(e) {
834
+ let r = l[e * n] = g.copy(a[e * n]);
835
+ r.x += (e ? s : o) * c[e].n.x, r.y += (e ? s : o) * c[e].n.y;
836
+ }), r ? ([0, 1].forEach(function(o) {
837
+ if (!(n === 2 && o)) {
838
+ var s = a[o + 1], c = {
839
+ x: s.x - u.x,
840
+ y: s.y - u.y
841
+ }, f = r ? r((o + 1) / n) : e;
842
+ r && !i && (f = -f);
843
+ var p = w(c.x * c.x + c.y * c.y);
844
+ c.x /= p, c.y /= p, l[o + 1] = {
845
+ x: s.x + f * c.x,
846
+ y: s.y + f * c.y
847
+ };
848
+ }
849
+ }), new Bezier(l)) : ([0, 1].forEach((e) => {
850
+ if (n === 2 && e) return;
851
+ let r = l[e * n], i = this.derivative(e), o = {
852
+ x: r.x + i.x,
853
+ y: r.y + i.y
854
+ };
855
+ l[e + 1] = g.lli4(r, o, u, a[e + 1]);
856
+ }), new Bezier(l));
857
+ }
858
+ outline(e, n, r, i) {
859
+ if (n = n === void 0 ? e : n, this._linear) {
860
+ let a = this.normal(0), o = this.points[0], s = this.points[this.points.length - 1], c, l, u;
861
+ r === void 0 && (r = e, i = n), c = {
862
+ x: o.x + a.x * e,
863
+ y: o.y + a.y * e
864
+ }, u = {
865
+ x: s.x + a.x * r,
866
+ y: s.y + a.y * r
867
+ }, l = {
868
+ x: (c.x + u.x) / 2,
869
+ y: (c.y + u.y) / 2
870
+ };
871
+ let f = [
872
+ c,
873
+ l,
874
+ u
875
+ ];
876
+ c = {
877
+ x: o.x - a.x * n,
878
+ y: o.y - a.y * n
879
+ }, u = {
880
+ x: s.x - a.x * i,
881
+ y: s.y - a.y * i
882
+ }, l = {
883
+ x: (c.x + u.x) / 2,
884
+ y: (c.y + u.y) / 2
885
+ };
886
+ let p = [
887
+ u,
888
+ l,
889
+ c
890
+ ], m = g.makeline(p[2], f[0]), h = g.makeline(f[2], p[0]);
891
+ return new _([
892
+ m,
893
+ new Bezier(f),
894
+ h,
895
+ new Bezier(p)
896
+ ]);
897
+ }
898
+ let a = this.reduce(), o = a.length, s = [], c = [], l, u = 0, f = this.length(), p = r !== void 0 && i !== void 0;
899
+ function linearDistanceFunction(e, n, r, i, a) {
900
+ return function(o) {
901
+ let s = i / r, c = (i + a) / r, l = n - e;
902
+ return g.map(o, 0, 1, e + s * l, e + c * l);
903
+ };
904
+ }
905
+ a.forEach(function(a) {
906
+ let o = a.length();
907
+ p ? (s.push(a.scale(linearDistanceFunction(e, r, f, u, o))), c.push(a.scale(linearDistanceFunction(-n, -i, f, u, o)))) : (s.push(a.scale(e)), c.push(a.scale(-n))), u += o;
908
+ }), c = c.map(function(e) {
909
+ return l = e.points, l[3] ? e.points = [
910
+ l[3],
911
+ l[2],
912
+ l[1],
913
+ l[0]
914
+ ] : e.points = [
915
+ l[2],
916
+ l[1],
917
+ l[0]
918
+ ], e;
919
+ }).reverse();
920
+ let m = s[0].points[0], h = s[o - 1].points[s[o - 1].points.length - 1], v = c[o - 1].points[c[o - 1].points.length - 1], y = c[0].points[0], b = g.makeline(v, m), x = g.makeline(h, y);
921
+ return new _([b].concat(s, [x], c));
922
+ }
923
+ outlineshapes(e, n, r) {
924
+ n ||= e;
925
+ let i = this.outline(e, n).curves, a = [];
926
+ for (let e = 1, n = i.length; e < n / 2; e++) {
927
+ let o = g.makeshape(i[e], i[n - e], r);
928
+ o.startcap.virtual = e > 1, o.endcap.virtual = e < n / 2 - 1, a.push(o);
929
+ }
930
+ return a;
931
+ }
932
+ intersects(e, n) {
933
+ return e ? e.p1 && e.p2 ? this.lineIntersects(e) : (e instanceof Bezier && (e = e.reduce()), this.curveintersects(this.reduce(), e, n)) : this.selfintersects(n);
934
+ }
935
+ lineIntersects(e) {
936
+ let n = y(e.p1.x, e.p2.x), r = y(e.p1.y, e.p2.y), i = b(e.p1.x, e.p2.x), a = b(e.p1.y, e.p2.y);
937
+ return g.roots(this.points, e).filter((e) => {
938
+ var o = this.get(e);
939
+ return g.between(o.x, n, i) && g.between(o.y, r, a);
940
+ });
941
+ }
942
+ selfintersects(e) {
943
+ let n = this.reduce(), r = n.length - 2, i = [];
944
+ for (let a = 0, o, s, c; a < r; a++) s = n.slice(a, a + 1), c = n.slice(a + 2), o = this.curveintersects(s, c, e), i.push(...o);
945
+ return i;
946
+ }
947
+ curveintersects(e, n, r) {
948
+ let i = [];
949
+ e.forEach(function(e) {
950
+ n.forEach(function(n) {
951
+ e.overlaps(n) && i.push({
952
+ left: e,
953
+ right: n
954
+ });
955
+ });
956
+ });
957
+ let a = [];
958
+ return i.forEach(function(e) {
959
+ let n = g.pairiteration(e.left, e.right, r);
960
+ n.length > 0 && (a = a.concat(n));
961
+ }), a;
962
+ }
963
+ arcs(e) {
964
+ return e ||= .5, this._iterate(e, []);
965
+ }
966
+ _error(e, n, r, i) {
967
+ let a = (i - r) / 4, o = this.get(r + a), s = this.get(i - a), c = g.dist(e, n), l = g.dist(e, o), u = g.dist(e, s);
968
+ return v(l - c) + v(u - c);
969
+ }
970
+ _iterate(e, n) {
971
+ let r = 0, i = 1, a;
972
+ do {
973
+ a = 0, i = 1;
974
+ let o = this.get(r), s, c, l, u, f = !1, p = !1, m, h = i, _ = 1, v = 0;
975
+ do
976
+ if (p = f, u = l, h = (r + i) / 2, v++, s = this.get(h), c = this.get(i), l = g.getccenter(o, s, c), l.interval = {
977
+ start: r,
978
+ end: i
979
+ }, f = this._error(l, o, r, i) <= e, m = p && !f, m || (_ = i), f) {
980
+ if (i >= 1) {
981
+ if (l.interval.end = _ = 1, u = l, i > 1) {
982
+ let e = {
983
+ x: l.x + l.r * x(l.e),
984
+ y: l.y + l.r * S(l.e)
985
+ };
986
+ l.e += g.angle({
987
+ x: l.x,
988
+ y: l.y
989
+ }, e, this.get(1));
990
+ }
991
+ break;
992
+ }
993
+ i += (i - r) / 2;
994
+ } else i = h;
995
+ while (!m && a++ < 100);
996
+ if (a >= 100) break;
997
+ u ||= l, n.push(u), r = _;
998
+ } while (i < 1);
999
+ return n;
1000
+ }
1001
+ };
1002
+ //#endregion
1003
+ export { E as t };