@chartts/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (575) hide show
  1. package/dist/area-type-B3CtuIIP.d.cts +9 -0
  2. package/dist/area-type-DmB6fTVf.d.ts +9 -0
  3. package/dist/area.cjs +34 -0
  4. package/dist/area.cjs.map +1 -0
  5. package/dist/area.d.cts +8 -0
  6. package/dist/area.d.ts +8 -0
  7. package/dist/area.js +13 -0
  8. package/dist/area.js.map +1 -0
  9. package/dist/bar-type-Bne_khsO.d.ts +5 -0
  10. package/dist/bar-type-CkI-kkrC.d.cts +5 -0
  11. package/dist/bar.cjs +34 -0
  12. package/dist/bar.cjs.map +1 -0
  13. package/dist/bar.d.cts +8 -0
  14. package/dist/bar.d.ts +8 -0
  15. package/dist/bar.js +13 -0
  16. package/dist/bar.js.map +1 -0
  17. package/dist/baseline-type-B1O4XHT3.d.ts +25 -0
  18. package/dist/baseline-type-BAPrZJ5W.d.cts +25 -0
  19. package/dist/baseline.cjs +32 -0
  20. package/dist/baseline.cjs.map +1 -0
  21. package/dist/baseline.d.cts +8 -0
  22. package/dist/baseline.d.ts +8 -0
  23. package/dist/baseline.js +11 -0
  24. package/dist/baseline.js.map +1 -0
  25. package/dist/boxplot-type-CEWf7p5X.d.ts +5 -0
  26. package/dist/boxplot-type-Da8_smoe.d.cts +5 -0
  27. package/dist/boxplot.cjs +33 -0
  28. package/dist/boxplot.cjs.map +1 -0
  29. package/dist/boxplot.d.cts +8 -0
  30. package/dist/boxplot.d.ts +8 -0
  31. package/dist/boxplot.js +12 -0
  32. package/dist/boxplot.js.map +1 -0
  33. package/dist/bubble-type-Dxb2JCKv.d.cts +9 -0
  34. package/dist/bubble-type-pru5MgB7.d.ts +9 -0
  35. package/dist/bubble.cjs +32 -0
  36. package/dist/bubble.cjs.map +1 -0
  37. package/dist/bubble.d.cts +8 -0
  38. package/dist/bubble.d.ts +8 -0
  39. package/dist/bubble.js +11 -0
  40. package/dist/bubble.js.map +1 -0
  41. package/dist/bullet-type-CPEYkEvt.d.ts +15 -0
  42. package/dist/bullet-type-khCmwFqH.d.cts +15 -0
  43. package/dist/bullet.cjs +33 -0
  44. package/dist/bullet.cjs.map +1 -0
  45. package/dist/bullet.d.cts +8 -0
  46. package/dist/bullet.d.ts +8 -0
  47. package/dist/bullet.js +12 -0
  48. package/dist/bullet.js.map +1 -0
  49. package/dist/calendar-type-Br5mpdea.d.cts +15 -0
  50. package/dist/calendar-type-yJWPY6qT.d.ts +15 -0
  51. package/dist/calendar.cjs +33 -0
  52. package/dist/calendar.cjs.map +1 -0
  53. package/dist/calendar.d.cts +8 -0
  54. package/dist/calendar.d.ts +8 -0
  55. package/dist/calendar.js +12 -0
  56. package/dist/calendar.js.map +1 -0
  57. package/dist/candlestick-type-CazXUb77.d.cts +22 -0
  58. package/dist/candlestick-type-CtLZy_uC.d.ts +22 -0
  59. package/dist/candlestick.cjs +33 -0
  60. package/dist/candlestick.cjs.map +1 -0
  61. package/dist/candlestick.d.cts +8 -0
  62. package/dist/candlestick.d.ts +8 -0
  63. package/dist/candlestick.js +12 -0
  64. package/dist/candlestick.js.map +1 -0
  65. package/dist/chord-type-ChIZaOZd.d.cts +5 -0
  66. package/dist/chord-type-ruvHboZl.d.ts +5 -0
  67. package/dist/chord.cjs +33 -0
  68. package/dist/chord.cjs.map +1 -0
  69. package/dist/chord.d.cts +8 -0
  70. package/dist/chord.d.ts +8 -0
  71. package/dist/chord.js +12 -0
  72. package/dist/chord.js.map +1 -0
  73. package/dist/chunk-22LR6CFM.js +176 -0
  74. package/dist/chunk-22LR6CFM.js.map +1 -0
  75. package/dist/chunk-2TWYS3BT.cjs +199 -0
  76. package/dist/chunk-2TWYS3BT.cjs.map +1 -0
  77. package/dist/chunk-3BRQGYDX.js +4859 -0
  78. package/dist/chunk-3BRQGYDX.js.map +1 -0
  79. package/dist/chunk-3TTTELGB.cjs +146 -0
  80. package/dist/chunk-3TTTELGB.cjs.map +1 -0
  81. package/dist/chunk-3XVGEBR4.js +17 -0
  82. package/dist/chunk-3XVGEBR4.js.map +1 -0
  83. package/dist/chunk-4HK4RM3X.cjs +128 -0
  84. package/dist/chunk-4HK4RM3X.cjs.map +1 -0
  85. package/dist/chunk-4VG47RLS.js +130 -0
  86. package/dist/chunk-4VG47RLS.js.map +1 -0
  87. package/dist/chunk-4YJPBUX2.cjs +68 -0
  88. package/dist/chunk-4YJPBUX2.cjs.map +1 -0
  89. package/dist/chunk-5QOQR5FE.cjs +19 -0
  90. package/dist/chunk-5QOQR5FE.cjs.map +1 -0
  91. package/dist/chunk-66HSJRRH.js +112 -0
  92. package/dist/chunk-66HSJRRH.js.map +1 -0
  93. package/dist/chunk-6KNBJ4CE.js +144 -0
  94. package/dist/chunk-6KNBJ4CE.js.map +1 -0
  95. package/dist/chunk-6LKN3HRX.js +79 -0
  96. package/dist/chunk-6LKN3HRX.js.map +1 -0
  97. package/dist/chunk-6N66T7VQ.js +103 -0
  98. package/dist/chunk-6N66T7VQ.js.map +1 -0
  99. package/dist/chunk-6YKFTEX4.js +336 -0
  100. package/dist/chunk-6YKFTEX4.js.map +1 -0
  101. package/dist/chunk-7CGXK7KT.js +124 -0
  102. package/dist/chunk-7CGXK7KT.js.map +1 -0
  103. package/dist/chunk-7HDAYWK3.cjs +358 -0
  104. package/dist/chunk-7HDAYWK3.cjs.map +1 -0
  105. package/dist/chunk-7SEHTEMR.js +91 -0
  106. package/dist/chunk-7SEHTEMR.js.map +1 -0
  107. package/dist/chunk-7YV56WPE.js +157 -0
  108. package/dist/chunk-7YV56WPE.js.map +1 -0
  109. package/dist/chunk-B54L2CPW.cjs +165 -0
  110. package/dist/chunk-B54L2CPW.cjs.map +1 -0
  111. package/dist/chunk-BC6KW2OG.js +197 -0
  112. package/dist/chunk-BC6KW2OG.js.map +1 -0
  113. package/dist/chunk-BEYG2HQ4.cjs +178 -0
  114. package/dist/chunk-BEYG2HQ4.cjs.map +1 -0
  115. package/dist/chunk-BR3KTAGW.js +113 -0
  116. package/dist/chunk-BR3KTAGW.js.map +1 -0
  117. package/dist/chunk-BRSHEDTZ.js +30 -0
  118. package/dist/chunk-BRSHEDTZ.js.map +1 -0
  119. package/dist/chunk-BXX2EPFE.cjs +160 -0
  120. package/dist/chunk-BXX2EPFE.cjs.map +1 -0
  121. package/dist/chunk-BYXRFTEI.cjs +114 -0
  122. package/dist/chunk-BYXRFTEI.cjs.map +1 -0
  123. package/dist/chunk-CMEXNS5V.js +158 -0
  124. package/dist/chunk-CMEXNS5V.js.map +1 -0
  125. package/dist/chunk-D2SV6YT3.js +47 -0
  126. package/dist/chunk-D2SV6YT3.js.map +1 -0
  127. package/dist/chunk-DL7P72FA.cjs +273 -0
  128. package/dist/chunk-DL7P72FA.cjs.map +1 -0
  129. package/dist/chunk-DNQ6N3VG.js +208 -0
  130. package/dist/chunk-DNQ6N3VG.js.map +1 -0
  131. package/dist/chunk-E2S7RAT2.js +126 -0
  132. package/dist/chunk-E2S7RAT2.js.map +1 -0
  133. package/dist/chunk-E6PR75X7.js +15 -0
  134. package/dist/chunk-E6PR75X7.js.map +1 -0
  135. package/dist/chunk-EGQ4JCFU.cjs +109 -0
  136. package/dist/chunk-EGQ4JCFU.cjs.map +1 -0
  137. package/dist/chunk-ETPZGEL7.cjs +105 -0
  138. package/dist/chunk-ETPZGEL7.cjs.map +1 -0
  139. package/dist/chunk-FFJ6BVEY.cjs +132 -0
  140. package/dist/chunk-FFJ6BVEY.cjs.map +1 -0
  141. package/dist/chunk-FKYNRMPX.js +133 -0
  142. package/dist/chunk-FKYNRMPX.js.map +1 -0
  143. package/dist/chunk-FRWC6GUR.cjs +126 -0
  144. package/dist/chunk-FRWC6GUR.cjs.map +1 -0
  145. package/dist/chunk-FUZFNUCJ.js +104 -0
  146. package/dist/chunk-FUZFNUCJ.js.map +1 -0
  147. package/dist/chunk-GM3ZO5WV.js +13 -0
  148. package/dist/chunk-GM3ZO5WV.js.map +1 -0
  149. package/dist/chunk-GNRRK7TZ.cjs +149 -0
  150. package/dist/chunk-GNRRK7TZ.cjs.map +1 -0
  151. package/dist/chunk-H2AE7JMU.js +128 -0
  152. package/dist/chunk-H2AE7JMU.js.map +1 -0
  153. package/dist/chunk-H4RNJ7FK.cjs +115 -0
  154. package/dist/chunk-H4RNJ7FK.cjs.map +1 -0
  155. package/dist/chunk-HB4EGHJ7.cjs +153 -0
  156. package/dist/chunk-HB4EGHJ7.cjs.map +1 -0
  157. package/dist/chunk-HDWWUEPD.js +122 -0
  158. package/dist/chunk-HDWWUEPD.js.map +1 -0
  159. package/dist/chunk-HOOOCSU4.js +216 -0
  160. package/dist/chunk-HOOOCSU4.js.map +1 -0
  161. package/dist/chunk-J6NPRKT4.cjs +49 -0
  162. package/dist/chunk-J6NPRKT4.cjs.map +1 -0
  163. package/dist/chunk-JO6U4YR4.js +355 -0
  164. package/dist/chunk-JO6U4YR4.js.map +1 -0
  165. package/dist/chunk-KE7ILTM4.cjs +162 -0
  166. package/dist/chunk-KE7ILTM4.cjs.map +1 -0
  167. package/dist/chunk-KSRROKYC.cjs +135 -0
  168. package/dist/chunk-KSRROKYC.cjs.map +1 -0
  169. package/dist/chunk-KVI6DN3R.js +147 -0
  170. package/dist/chunk-KVI6DN3R.js.map +1 -0
  171. package/dist/chunk-L54BZYAI.cjs +111 -0
  172. package/dist/chunk-L54BZYAI.cjs.map +1 -0
  173. package/dist/chunk-LB4MV5CG.js +109 -0
  174. package/dist/chunk-LB4MV5CG.js.map +1 -0
  175. package/dist/chunk-LEJGLR2P.cjs +106 -0
  176. package/dist/chunk-LEJGLR2P.cjs.map +1 -0
  177. package/dist/chunk-LU35QDPN.cjs +30 -0
  178. package/dist/chunk-LU35QDPN.cjs.map +1 -0
  179. package/dist/chunk-LUTU4WW3.js +151 -0
  180. package/dist/chunk-LUTU4WW3.js.map +1 -0
  181. package/dist/chunk-M4AQD6WX.cjs +220 -0
  182. package/dist/chunk-M4AQD6WX.cjs.map +1 -0
  183. package/dist/chunk-M4UST3UU.cjs +159 -0
  184. package/dist/chunk-M4UST3UU.cjs.map +1 -0
  185. package/dist/chunk-MLD5ZIDO.cjs +359 -0
  186. package/dist/chunk-MLD5ZIDO.cjs.map +1 -0
  187. package/dist/chunk-MLX3EO2C.js +107 -0
  188. package/dist/chunk-MLX3EO2C.js.map +1 -0
  189. package/dist/chunk-MVWERW4G.cjs +28 -0
  190. package/dist/chunk-MVWERW4G.cjs.map +1 -0
  191. package/dist/chunk-MYPCA25Y.cjs +115 -0
  192. package/dist/chunk-MYPCA25Y.cjs.map +1 -0
  193. package/dist/chunk-N6IVODRJ.js +114 -0
  194. package/dist/chunk-N6IVODRJ.js.map +1 -0
  195. package/dist/chunk-NFD6VAVM.js +155 -0
  196. package/dist/chunk-NFD6VAVM.js.map +1 -0
  197. package/dist/chunk-NHGKZMD7.cjs +18 -0
  198. package/dist/chunk-NHGKZMD7.cjs.map +1 -0
  199. package/dist/chunk-NMLDPXOL.js +167 -0
  200. package/dist/chunk-NMLDPXOL.js.map +1 -0
  201. package/dist/chunk-NONU7KUN.cjs +32 -0
  202. package/dist/chunk-NONU7KUN.cjs.map +1 -0
  203. package/dist/chunk-NQSC7CKN.js +130 -0
  204. package/dist/chunk-NQSC7CKN.js.map +1 -0
  205. package/dist/chunk-NYVFC2SF.js +87 -0
  206. package/dist/chunk-NYVFC2SF.js.map +1 -0
  207. package/dist/chunk-O5KGKQSU.js +218 -0
  208. package/dist/chunk-O5KGKQSU.js.map +1 -0
  209. package/dist/chunk-OGSZO22B.js +26 -0
  210. package/dist/chunk-OGSZO22B.js.map +1 -0
  211. package/dist/chunk-Q2BDB5ZA.cjs +218 -0
  212. package/dist/chunk-Q2BDB5ZA.cjs.map +1 -0
  213. package/dist/chunk-Q6U5D2ZB.cjs +210 -0
  214. package/dist/chunk-Q6U5D2ZB.cjs.map +1 -0
  215. package/dist/chunk-QAYX6XN3.js +26 -0
  216. package/dist/chunk-QAYX6XN3.js.map +1 -0
  217. package/dist/chunk-QHJHYV3H.cjs +15 -0
  218. package/dist/chunk-QHJHYV3H.cjs.map +1 -0
  219. package/dist/chunk-QIJZZOX7.js +249 -0
  220. package/dist/chunk-QIJZZOX7.js.map +1 -0
  221. package/dist/chunk-QLRK46YY.cjs +93 -0
  222. package/dist/chunk-QLRK46YY.cjs.map +1 -0
  223. package/dist/chunk-QZ4ZYTP6.js +124 -0
  224. package/dist/chunk-QZ4ZYTP6.js.map +1 -0
  225. package/dist/chunk-RCVRZCCC.cjs +156 -0
  226. package/dist/chunk-RCVRZCCC.cjs.map +1 -0
  227. package/dist/chunk-ROYZ7W4M.cjs +81 -0
  228. package/dist/chunk-ROYZ7W4M.cjs.map +1 -0
  229. package/dist/chunk-SJS4ISBA.js +163 -0
  230. package/dist/chunk-SJS4ISBA.js.map +1 -0
  231. package/dist/chunk-SKVCPG5R.cjs +124 -0
  232. package/dist/chunk-SKVCPG5R.cjs.map +1 -0
  233. package/dist/chunk-SQJAKZ4W.js +113 -0
  234. package/dist/chunk-SQJAKZ4W.js.map +1 -0
  235. package/dist/chunk-SUNC3CPV.js +79 -0
  236. package/dist/chunk-SUNC3CPV.js.map +1 -0
  237. package/dist/chunk-SWYCVF46.js +145 -0
  238. package/dist/chunk-SWYCVF46.js.map +1 -0
  239. package/dist/chunk-SZVK6RRQ.js +98 -0
  240. package/dist/chunk-SZVK6RRQ.js.map +1 -0
  241. package/dist/chunk-TOS2RYHQ.js +154 -0
  242. package/dist/chunk-TOS2RYHQ.js.map +1 -0
  243. package/dist/chunk-TTOX27BZ.cjs +116 -0
  244. package/dist/chunk-TTOX27BZ.cjs.map +1 -0
  245. package/dist/chunk-TW6KPQIS.js +160 -0
  246. package/dist/chunk-TW6KPQIS.js.map +1 -0
  247. package/dist/chunk-UN7K3YQG.cjs +81 -0
  248. package/dist/chunk-UN7K3YQG.cjs.map +1 -0
  249. package/dist/chunk-UQBDGCS6.cjs +89 -0
  250. package/dist/chunk-UQBDGCS6.cjs.map +1 -0
  251. package/dist/chunk-VPI7UGB3.cjs +130 -0
  252. package/dist/chunk-VPI7UGB3.cjs.map +1 -0
  253. package/dist/chunk-X2JNB5UN.js +271 -0
  254. package/dist/chunk-X2JNB5UN.js.map +1 -0
  255. package/dist/chunk-XBIM73HV.cjs +126 -0
  256. package/dist/chunk-XBIM73HV.cjs.map +1 -0
  257. package/dist/chunk-XHQWWR5M.cjs +4892 -0
  258. package/dist/chunk-XHQWWR5M.cjs.map +1 -0
  259. package/dist/chunk-Y2JZHX3P.cjs +169 -0
  260. package/dist/chunk-Y2JZHX3P.cjs.map +1 -0
  261. package/dist/chunk-Y4P4VY7A.cjs +251 -0
  262. package/dist/chunk-Y4P4VY7A.cjs.map +1 -0
  263. package/dist/chunk-Y54XVNXB.cjs +157 -0
  264. package/dist/chunk-Y54XVNXB.cjs.map +1 -0
  265. package/dist/chunk-Z6E3XVP2.cjs +132 -0
  266. package/dist/chunk-Z6E3XVP2.cjs.map +1 -0
  267. package/dist/chunk-ZDYCIP6N.cjs +100 -0
  268. package/dist/chunk-ZDYCIP6N.cjs.map +1 -0
  269. package/dist/chunk-ZDZQG3GH.cjs +148 -0
  270. package/dist/chunk-ZDZQG3GH.cjs.map +1 -0
  271. package/dist/chunk-ZL25X5WW.js +66 -0
  272. package/dist/chunk-ZL25X5WW.js.map +1 -0
  273. package/dist/combo-type-BdSohVyy.d.ts +16 -0
  274. package/dist/combo-type-wodyLq1f.d.cts +16 -0
  275. package/dist/combo.cjs +34 -0
  276. package/dist/combo.cjs.map +1 -0
  277. package/dist/combo.d.cts +8 -0
  278. package/dist/combo.d.ts +8 -0
  279. package/dist/combo.js +13 -0
  280. package/dist/combo.js.map +1 -0
  281. package/dist/custom-type-B6w1n5Ua.d.cts +23 -0
  282. package/dist/custom-type-XFjuPwCr.d.ts +23 -0
  283. package/dist/custom.cjs +33 -0
  284. package/dist/custom.cjs.map +1 -0
  285. package/dist/custom.d.cts +8 -0
  286. package/dist/custom.d.ts +8 -0
  287. package/dist/custom.js +12 -0
  288. package/dist/custom.js.map +1 -0
  289. package/dist/donut.cjs +33 -0
  290. package/dist/donut.cjs.map +1 -0
  291. package/dist/donut.d.cts +8 -0
  292. package/dist/donut.d.ts +8 -0
  293. package/dist/donut.js +12 -0
  294. package/dist/donut.js.map +1 -0
  295. package/dist/dumbbell-type-DPSE0OTg.d.ts +12 -0
  296. package/dist/dumbbell-type-w424KzI2.d.cts +12 -0
  297. package/dist/dumbbell.cjs +34 -0
  298. package/dist/dumbbell.cjs.map +1 -0
  299. package/dist/dumbbell.d.cts +8 -0
  300. package/dist/dumbbell.d.ts +8 -0
  301. package/dist/dumbbell.js +13 -0
  302. package/dist/dumbbell.js.map +1 -0
  303. package/dist/engine-CNukbv7k.d.cts +426 -0
  304. package/dist/engine-CNukbv7k.d.ts +426 -0
  305. package/dist/factory-dbngWV4d.d.cts +8 -0
  306. package/dist/factory-jRzNNxwj.d.ts +8 -0
  307. package/dist/finance.cjs +92 -0
  308. package/dist/finance.cjs.map +1 -0
  309. package/dist/finance.d.cts +192 -0
  310. package/dist/finance.d.ts +192 -0
  311. package/dist/finance.js +3 -0
  312. package/dist/finance.js.map +1 -0
  313. package/dist/funnel-type-BeVl3ohX.d.cts +9 -0
  314. package/dist/funnel-type-CMXGQq4T.d.ts +9 -0
  315. package/dist/funnel.cjs +33 -0
  316. package/dist/funnel.cjs.map +1 -0
  317. package/dist/funnel.d.cts +8 -0
  318. package/dist/funnel.d.ts +8 -0
  319. package/dist/funnel.js +12 -0
  320. package/dist/funnel.js.map +1 -0
  321. package/dist/gauge-type-BpDBwCeD.d.ts +11 -0
  322. package/dist/gauge-type-DmjDdfsY.d.cts +11 -0
  323. package/dist/gauge.cjs +33 -0
  324. package/dist/gauge.cjs.map +1 -0
  325. package/dist/gauge.d.cts +8 -0
  326. package/dist/gauge.d.ts +8 -0
  327. package/dist/gauge.js +12 -0
  328. package/dist/gauge.js.map +1 -0
  329. package/dist/geo.cjs +41 -0
  330. package/dist/geo.cjs.map +1 -0
  331. package/dist/geo.d.cts +8 -0
  332. package/dist/geo.d.ts +8 -0
  333. package/dist/geo.js +12 -0
  334. package/dist/geo.js.map +1 -0
  335. package/dist/graph-type-DkdAB6Vc.d.cts +5 -0
  336. package/dist/graph-type-ul9xwdf5.d.ts +5 -0
  337. package/dist/graph.cjs +33 -0
  338. package/dist/graph.cjs.map +1 -0
  339. package/dist/graph.d.cts +8 -0
  340. package/dist/graph.d.ts +8 -0
  341. package/dist/graph.js +12 -0
  342. package/dist/graph.js.map +1 -0
  343. package/dist/heatmap-type-D0shkxK7.d.cts +12 -0
  344. package/dist/heatmap-type-q6nNhVTr.d.ts +12 -0
  345. package/dist/heatmap.cjs +33 -0
  346. package/dist/heatmap.cjs.map +1 -0
  347. package/dist/heatmap.d.cts +8 -0
  348. package/dist/heatmap.d.ts +8 -0
  349. package/dist/heatmap.js +12 -0
  350. package/dist/heatmap.js.map +1 -0
  351. package/dist/histogram-type-BWil-Rb7.d.cts +13 -0
  352. package/dist/histogram-type-CF593WSp.d.ts +13 -0
  353. package/dist/histogram.cjs +33 -0
  354. package/dist/histogram.cjs.map +1 -0
  355. package/dist/histogram.d.cts +8 -0
  356. package/dist/histogram.d.ts +8 -0
  357. package/dist/histogram.js +12 -0
  358. package/dist/histogram.js.map +1 -0
  359. package/dist/horizontal-bar-type-0mqnyMUR.d.cts +11 -0
  360. package/dist/horizontal-bar-type-DAlrxY0h.d.ts +11 -0
  361. package/dist/horizontal-bar.cjs +34 -0
  362. package/dist/horizontal-bar.cjs.map +1 -0
  363. package/dist/horizontal-bar.d.cts +8 -0
  364. package/dist/horizontal-bar.d.ts +8 -0
  365. package/dist/horizontal-bar.js +13 -0
  366. package/dist/horizontal-bar.js.map +1 -0
  367. package/dist/index.cjs +1604 -0
  368. package/dist/index.cjs.map +1 -0
  369. package/dist/index.d.cts +594 -0
  370. package/dist/index.d.ts +594 -0
  371. package/dist/index.js +1201 -0
  372. package/dist/index.js.map +1 -0
  373. package/dist/kagi-type-Y5XUVm3h.d.ts +26 -0
  374. package/dist/kagi-type-aG-Q1bWk.d.cts +26 -0
  375. package/dist/kagi.cjs +33 -0
  376. package/dist/kagi.cjs.map +1 -0
  377. package/dist/kagi.d.cts +8 -0
  378. package/dist/kagi.d.ts +8 -0
  379. package/dist/kagi.js +12 -0
  380. package/dist/kagi.js.map +1 -0
  381. package/dist/line-type-B8lgTFjb.d.cts +5 -0
  382. package/dist/line-type-Diw0nXj7.d.ts +5 -0
  383. package/dist/line.cjs +33 -0
  384. package/dist/line.cjs.map +1 -0
  385. package/dist/line.d.cts +8 -0
  386. package/dist/line.d.ts +8 -0
  387. package/dist/line.js +12 -0
  388. package/dist/line.js.map +1 -0
  389. package/dist/lines-type-CGrg_mDi.d.cts +31 -0
  390. package/dist/lines-type-V-seVNZ4.d.ts +31 -0
  391. package/dist/lines.cjs +33 -0
  392. package/dist/lines.cjs.map +1 -0
  393. package/dist/lines.d.cts +8 -0
  394. package/dist/lines.d.ts +8 -0
  395. package/dist/lines.js +12 -0
  396. package/dist/lines.js.map +1 -0
  397. package/dist/lollipop-type-CoTzKLSu.d.cts +11 -0
  398. package/dist/lollipop-type-Ygc4rRql.d.ts +11 -0
  399. package/dist/lollipop.cjs +33 -0
  400. package/dist/lollipop.cjs.map +1 -0
  401. package/dist/lollipop.d.cts +8 -0
  402. package/dist/lollipop.d.ts +8 -0
  403. package/dist/lollipop.js +12 -0
  404. package/dist/lollipop.js.map +1 -0
  405. package/dist/matrix-type-Crb_NwUJ.d.cts +26 -0
  406. package/dist/matrix-type-Dag1VLCY.d.ts +26 -0
  407. package/dist/matrix.cjs +33 -0
  408. package/dist/matrix.cjs.map +1 -0
  409. package/dist/matrix.d.cts +8 -0
  410. package/dist/matrix.d.ts +8 -0
  411. package/dist/matrix.js +12 -0
  412. package/dist/matrix.js.map +1 -0
  413. package/dist/ohlc-type-BQBHvVJO.d.cts +28 -0
  414. package/dist/ohlc-type-CGR-vRGL.d.ts +28 -0
  415. package/dist/ohlc.cjs +33 -0
  416. package/dist/ohlc.cjs.map +1 -0
  417. package/dist/ohlc.d.cts +8 -0
  418. package/dist/ohlc.d.ts +8 -0
  419. package/dist/ohlc.js +12 -0
  420. package/dist/ohlc.js.map +1 -0
  421. package/dist/parallel-type-6t6xyHMg.d.ts +14 -0
  422. package/dist/parallel-type-D-S-EqeC.d.cts +14 -0
  423. package/dist/parallel.cjs +33 -0
  424. package/dist/parallel.cjs.map +1 -0
  425. package/dist/parallel.d.cts +8 -0
  426. package/dist/parallel.d.ts +8 -0
  427. package/dist/parallel.js +12 -0
  428. package/dist/parallel.js.map +1 -0
  429. package/dist/pictorialbar-type-A-8mTX1N.d.ts +5 -0
  430. package/dist/pictorialbar-type-CnJEH9GZ.d.cts +5 -0
  431. package/dist/pictorialbar.cjs +33 -0
  432. package/dist/pictorialbar.cjs.map +1 -0
  433. package/dist/pictorialbar.d.cts +8 -0
  434. package/dist/pictorialbar.d.ts +8 -0
  435. package/dist/pictorialbar.js +12 -0
  436. package/dist/pictorialbar.js.map +1 -0
  437. package/dist/pie-type-S7kUKGRS.d.ts +7 -0
  438. package/dist/pie-type-duX5xkfQ.d.cts +7 -0
  439. package/dist/pie.cjs +33 -0
  440. package/dist/pie.cjs.map +1 -0
  441. package/dist/pie.d.cts +8 -0
  442. package/dist/pie.d.ts +8 -0
  443. package/dist/pie.js +12 -0
  444. package/dist/pie.js.map +1 -0
  445. package/dist/polar-type-CI6-I8Yg.d.cts +11 -0
  446. package/dist/polar-type-Dj21GIc9.d.ts +11 -0
  447. package/dist/polar.cjs +33 -0
  448. package/dist/polar.cjs.map +1 -0
  449. package/dist/polar.d.cts +8 -0
  450. package/dist/polar.d.ts +8 -0
  451. package/dist/polar.js +12 -0
  452. package/dist/polar.js.map +1 -0
  453. package/dist/radar-type-CYjZHuKm.d.ts +9 -0
  454. package/dist/radar-type-Dgyr13Zd.d.cts +9 -0
  455. package/dist/radar.cjs +33 -0
  456. package/dist/radar.cjs.map +1 -0
  457. package/dist/radar.d.cts +8 -0
  458. package/dist/radar.d.ts +8 -0
  459. package/dist/radar.js +12 -0
  460. package/dist/radar.js.map +1 -0
  461. package/dist/radialbar-type-CLZ8XgST.d.ts +11 -0
  462. package/dist/radialbar-type-C_SBXoaa.d.cts +11 -0
  463. package/dist/radialbar.cjs +33 -0
  464. package/dist/radialbar.cjs.map +1 -0
  465. package/dist/radialbar.d.cts +8 -0
  466. package/dist/radialbar.d.ts +8 -0
  467. package/dist/radialbar.js +12 -0
  468. package/dist/radialbar.js.map +1 -0
  469. package/dist/range-type-CkriEnLm.d.cts +26 -0
  470. package/dist/range-type-_LbMV4tl.d.ts +26 -0
  471. package/dist/range.cjs +32 -0
  472. package/dist/range.cjs.map +1 -0
  473. package/dist/range.d.cts +8 -0
  474. package/dist/range.d.ts +8 -0
  475. package/dist/range.js +11 -0
  476. package/dist/range.js.map +1 -0
  477. package/dist/renko-type-43OXCtZ3.d.cts +24 -0
  478. package/dist/renko-type-ejoXt2ro.d.ts +24 -0
  479. package/dist/renko.cjs +33 -0
  480. package/dist/renko.cjs.map +1 -0
  481. package/dist/renko.d.cts +8 -0
  482. package/dist/renko.d.ts +8 -0
  483. package/dist/renko.js +12 -0
  484. package/dist/renko.js.map +1 -0
  485. package/dist/sankey-type-CN7PL5MQ.d.ts +5 -0
  486. package/dist/sankey-type-DfkTUnXB.d.cts +5 -0
  487. package/dist/sankey.cjs +33 -0
  488. package/dist/sankey.cjs.map +1 -0
  489. package/dist/sankey.d.cts +8 -0
  490. package/dist/sankey.d.ts +8 -0
  491. package/dist/sankey.js +12 -0
  492. package/dist/sankey.js.map +1 -0
  493. package/dist/scatter-type-CD7X1pZb.d.cts +5 -0
  494. package/dist/scatter-type-D3HdPkZ6.d.ts +5 -0
  495. package/dist/scatter.cjs +32 -0
  496. package/dist/scatter.cjs.map +1 -0
  497. package/dist/scatter.d.cts +8 -0
  498. package/dist/scatter.d.ts +8 -0
  499. package/dist/scatter.js +11 -0
  500. package/dist/scatter.js.map +1 -0
  501. package/dist/sparkline-type-COW3izgF.d.ts +9 -0
  502. package/dist/sparkline-type-qt3yoLs7.d.cts +9 -0
  503. package/dist/sparkline.cjs +33 -0
  504. package/dist/sparkline.cjs.map +1 -0
  505. package/dist/sparkline.d.cts +8 -0
  506. package/dist/sparkline.d.ts +8 -0
  507. package/dist/sparkline.js +12 -0
  508. package/dist/sparkline.js.map +1 -0
  509. package/dist/stacked-bar-type-C-5pmb-D.d.ts +8 -0
  510. package/dist/stacked-bar-type-Ct6HK2A0.d.cts +8 -0
  511. package/dist/stacked-bar.cjs +34 -0
  512. package/dist/stacked-bar.cjs.map +1 -0
  513. package/dist/stacked-bar.d.cts +8 -0
  514. package/dist/stacked-bar.d.ts +8 -0
  515. package/dist/stacked-bar.js +13 -0
  516. package/dist/stacked-bar.js.map +1 -0
  517. package/dist/step-type-BSL-CUny.d.cts +11 -0
  518. package/dist/step-type-Cleoshov.d.ts +11 -0
  519. package/dist/step.cjs +34 -0
  520. package/dist/step.cjs.map +1 -0
  521. package/dist/step.d.cts +8 -0
  522. package/dist/step.d.ts +8 -0
  523. package/dist/step.js +13 -0
  524. package/dist/step.js.map +1 -0
  525. package/dist/sunburst-type-BOztb_Px.d.cts +5 -0
  526. package/dist/sunburst-type-ZFw2w6m8.d.ts +5 -0
  527. package/dist/sunburst.cjs +33 -0
  528. package/dist/sunburst.cjs.map +1 -0
  529. package/dist/sunburst.d.cts +8 -0
  530. package/dist/sunburst.d.ts +8 -0
  531. package/dist/sunburst.js +12 -0
  532. package/dist/sunburst.js.map +1 -0
  533. package/dist/themeriver-type-B5PYChcC.d.ts +15 -0
  534. package/dist/themeriver-type-BnRSsyal.d.cts +15 -0
  535. package/dist/themeriver.cjs +33 -0
  536. package/dist/themeriver.cjs.map +1 -0
  537. package/dist/themeriver.d.cts +8 -0
  538. package/dist/themeriver.d.ts +8 -0
  539. package/dist/themeriver.js +12 -0
  540. package/dist/themeriver.js.map +1 -0
  541. package/dist/tree-type-B-bOSg0l.d.ts +5 -0
  542. package/dist/tree-type-Cz84wHnR.d.cts +5 -0
  543. package/dist/tree.cjs +33 -0
  544. package/dist/tree.cjs.map +1 -0
  545. package/dist/tree.d.cts +8 -0
  546. package/dist/tree.d.ts +8 -0
  547. package/dist/tree.js +12 -0
  548. package/dist/tree.js.map +1 -0
  549. package/dist/treemap-type-DYDj-rWv.d.ts +11 -0
  550. package/dist/treemap-type-OBCGexiK.d.cts +11 -0
  551. package/dist/treemap.cjs +33 -0
  552. package/dist/treemap.cjs.map +1 -0
  553. package/dist/treemap.d.cts +8 -0
  554. package/dist/treemap.d.ts +8 -0
  555. package/dist/treemap.js +12 -0
  556. package/dist/treemap.js.map +1 -0
  557. package/dist/volume-type-C9wRmKR6.d.ts +21 -0
  558. package/dist/volume-type-CfERBN5g.d.cts +21 -0
  559. package/dist/volume.cjs +33 -0
  560. package/dist/volume.cjs.map +1 -0
  561. package/dist/volume.d.cts +8 -0
  562. package/dist/volume.d.ts +8 -0
  563. package/dist/volume.js +12 -0
  564. package/dist/volume.js.map +1 -0
  565. package/dist/waterfall-type-CpdVtBi_.d.ts +10 -0
  566. package/dist/waterfall-type-hm5ylGgW.d.cts +10 -0
  567. package/dist/waterfall.cjs +33 -0
  568. package/dist/waterfall.cjs.map +1 -0
  569. package/dist/waterfall.d.cts +8 -0
  570. package/dist/waterfall.d.ts +8 -0
  571. package/dist/waterfall.js +12 -0
  572. package/dist/waterfall.js.map +1 -0
  573. package/dist/world-regions-Cfvxpbx0.d.ts +50 -0
  574. package/dist/world-regions-cMulhqDW.d.cts +50 -0
  575. package/package.json +262 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/themeriver/themeriver-type.ts"],"names":[],"mappings":"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","file":"chunk-NMLDPXOL.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * ThemeRiver / StreamGraph chart — stacked area chart with a center baseline.\n *\n * Data convention:\n * - labels: time points (x-axis categories)\n * - series[i]: a stream layer. values[j] = thickness at time j\n *\n * The streams are stacked symmetrically around the horizontal center,\n * creating an organic river-like visualization.\n */\n\nexport const themeRiverChartType: ChartTypePlugin = {\n type: 'themeriver',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return nodes\n\n const seriesCount = data.series.length\n\n // Compute stacked values\n const stacks: number[][] = []\n for (let t = 0; t < timeCount; t++) {\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n stacks.push(column)\n }\n\n // Compute baseline offsets (wiggle / silhouette centering)\n const baselines: number[] = []\n for (let t = 0; t < timeCount; t++) {\n const total = stacks[t]!.reduce((s, v) => s + v, 0)\n baselines.push(-total / 2) // Center around 0\n }\n\n // Find global min/max for y-scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let t = 0; t < timeCount; t++) {\n let cumulative = baselines[t]!\n if (cumulative < yMin) yMin = cumulative\n for (let si = 0; si < seriesCount; si++) {\n cumulative += stacks[t]![si]!\n }\n if (cumulative > yMax) yMax = cumulative\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const xStep = area.width / Math.max(timeCount - 1, 1)\n const mapX = (t: number) => area.x + t * xStep\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Render each series as a stream band\n for (let si = 0; si < seriesCount; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n // Compute top and bottom edges for this series\n const tops: { x: number; y: number }[] = []\n const bottoms: { x: number; y: number }[] = []\n\n for (let t = 0; t < timeCount; t++) {\n let cumBottom = baselines[t]!\n for (let s = 0; s < si; s++) {\n cumBottom += stacks[t]![s]!\n }\n const cumTop = cumBottom + stacks[t]![si]!\n\n tops.push({ x: mapX(t), y: mapY(cumTop) })\n bottoms.push({ x: mapX(t), y: mapY(cumBottom) })\n }\n\n // Build smooth path: top edge forward, bottom edge backward\n const pb = new PathBuilder()\n\n // Top edge (left to right)\n pb.moveTo(tops[0]!.x, tops[0]!.y)\n for (let t = 1; t < timeCount; t++) {\n const prev = tops[t - 1]!\n const curr = tops[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n // Bottom edge (right to left)\n pb.lineTo(bottoms[timeCount - 1]!.x, bottoms[timeCount - 1]!.y)\n for (let t = timeCount - 2; t >= 0; t--) {\n const prev = bottoms[t + 1]!\n const curr = bottoms[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-themeriver-stream',\n fill: color,\n fillOpacity: 0.75,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}`,\n }))\n\n // Label at the widest point\n let maxWidth = 0\n let maxT = 0\n for (let t = 0; t < timeCount; t++) {\n const width = Math.abs(tops[t]!.y - bottoms[t]!.y)\n if (width > maxWidth) {\n maxWidth = width\n maxT = t\n }\n }\n\n if (maxWidth > 16) {\n const midY = (tops[maxT]!.y + bottoms[maxT]!.y) / 2\n const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4)\n nodes.push(text(tops[maxT]!.x, midY, series.name, {\n class: 'chartts-themeriver-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return null\n\n const seriesCount = data.series.length\n const xStep = area.width / Math.max(timeCount - 1, 1)\n\n // Find closest time index\n const t = Math.round((mx - area.x) / xStep)\n if (t < 0 || t >= timeCount) return null\n\n // Compute stacks at this time\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n const total = column.reduce((s, v) => s + v, 0)\n const baseline = -total / 2\n\n // Find global scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let tt = 0; tt < timeCount; tt++) {\n let cum = 0\n for (let si = 0; si < seriesCount; si++) {\n cum += Math.abs(data.series[si]!.values[tt] ?? 0)\n }\n const bl = -cum / 2\n if (bl < yMin) yMin = bl\n if (bl + cum > yMax) yMax = bl + cum\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Check which stream the y coordinate falls in\n let cumBottom = baseline\n for (let si = 0; si < seriesCount; si++) {\n const cumTop = cumBottom + column[si]!\n const topY = mapY(cumTop)\n const bottomY = mapY(cumBottom)\n\n if (my >= topY && my <= bottomY) {\n return { seriesIndex: si, pointIndex: t, distance: 0 }\n }\n cumBottom = cumTop\n }\n\n return null\n },\n}\n"]}
@@ -0,0 +1,32 @@
1
+ 'use strict';
2
+
3
+ var chunk2TWYS3BT_cjs = require('./chunk-2TWYS3BT.cjs');
4
+
5
+ // src/charts/area/area-type.ts
6
+ var areaChartType = {
7
+ type: "area",
8
+ getScaleTypes() {
9
+ return { x: "categorical", y: "linear" };
10
+ },
11
+ prepareData(data, options) {
12
+ const filled = {
13
+ ...data,
14
+ series: data.series.map((s) => ({
15
+ ...s,
16
+ fill: s.fill ?? true,
17
+ fillOpacity: s.fillOpacity ?? 0.25
18
+ }))
19
+ };
20
+ return chunk2TWYS3BT_cjs.lineChartType.prepareData(filled, options);
21
+ },
22
+ render(ctx) {
23
+ return chunk2TWYS3BT_cjs.lineChartType.render(ctx);
24
+ },
25
+ hitTest(ctx, mx, my) {
26
+ return chunk2TWYS3BT_cjs.lineChartType.hitTest(ctx, mx, my);
27
+ }
28
+ };
29
+
30
+ exports.areaChartType = areaChartType;
31
+ //# sourceMappingURL=chunk-NONU7KUN.cjs.map
32
+ //# sourceMappingURL=chunk-NONU7KUN.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/area/area-type.ts"],"names":["lineChartType"],"mappings":";;;;;AAUO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AAEnE,IAAA,MAAM,MAAA,GAAoB;AAAA,MACxB,GAAG,IAAA;AAAA,MACH,MAAA,EAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,CAAA,CAAA,MAAM;AAAA,QAC5B,GAAG,CAAA;AAAA,QACH,IAAA,EAAM,EAAE,IAAA,IAAQ,IAAA;AAAA,QAChB,WAAA,EAAa,EAAE,WAAA,IAAe;AAAA,OAChC,CAAE;AAAA,KACJ;AACA,IAAA,OAAOA,+BAAA,CAAc,WAAA,CAAY,MAAA,EAAQ,OAAO,CAAA;AAAA,EAClD,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,OAAOA,+BAAA,CAAc,OAAO,GAAG,CAAA;AAAA,EACjC,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,OAAOA,+BAAA,CAAc,OAAA,CAAQ,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,EAC1C;AACF","file":"chunk-NONU7KUN.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { lineChartType } from '../line/line-type'\n\n/**\n * Area chart — line chart with fill enabled on all series by default.\n * Delegates entirely to lineChartType after forcing fill:true.\n */\nexport const areaChartType: ChartTypePlugin = {\n type: 'area',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Force fill on all series\n const filled: ChartData = {\n ...data,\n series: data.series.map(s => ({\n ...s,\n fill: s.fill ?? true,\n fillOpacity: s.fillOpacity ?? 0.25,\n })),\n }\n return lineChartType.prepareData(filled, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n return lineChartType.render(ctx)\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n return lineChartType.hitTest(ctx, mx, my)\n },\n}\n"]}
@@ -0,0 +1,130 @@
1
+ import { getBandwidth } from './chunk-E6PR75X7.js';
2
+ import { line, rect, group, prepareData } from './chunk-3BRQGYDX.js';
3
+
4
+ // src/charts/boxplot/boxplot-type.ts
5
+ var boxplotChartType = {
6
+ type: "boxplot",
7
+ getScaleTypes() {
8
+ return { x: "categorical", y: "linear" };
9
+ },
10
+ prepareData(data, options) {
11
+ const labelCount = data.labels?.length ?? 0;
12
+ const valLen = data.series[0]?.values.length ?? 0;
13
+ const syntheticData = { ...data };
14
+ if (labelCount > 0 && valLen > labelCount) {
15
+ const padded = (data.labels ?? []).map(String);
16
+ while (padded.length < valLen) padded.push("");
17
+ syntheticData.labels = padded;
18
+ }
19
+ const prepared = prepareData(syntheticData, options);
20
+ if (data.labels && data.labels.length < valLen) {
21
+ prepared.labels = [...data.labels];
22
+ }
23
+ return prepared;
24
+ },
25
+ render(ctx) {
26
+ const { data, options, xScale, yScale } = ctx;
27
+ const nodes = [];
28
+ const seriesCount = data.series.length;
29
+ if (seriesCount === 0) return nodes;
30
+ const bOpts = options;
31
+ const boxWidthRatio = bOpts.boxWidth ?? 0.6;
32
+ const bw = getBandwidth(xScale);
33
+ const boxWidth = bw * boxWidthRatio;
34
+ for (let i = 0; i < data.labels.length; i++) {
35
+ let vals;
36
+ if (data.series.length === 1) {
37
+ const s = data.series[0];
38
+ if (s.values.length >= (i + 1) * 5) {
39
+ vals = s.values.slice(i * 5, i * 5 + 5);
40
+ } else continue;
41
+ } else if (data.series.length > i && data.series[i].values.length >= 5) {
42
+ vals = data.series[i].values.slice(0, 5);
43
+ } else continue;
44
+ const [vMin, q1, median, q3, vMax] = vals;
45
+ const cx = xScale.map(i);
46
+ const boxX = cx - boxWidth / 2;
47
+ const yMin = yScale.map(vMin);
48
+ const yQ1 = yScale.map(q1);
49
+ const yMed = yScale.map(median);
50
+ const yQ3 = yScale.map(q3);
51
+ const yMax = yScale.map(vMax);
52
+ const color = options.colors[i % options.colors.length];
53
+ const seriesIdx = Math.min(i, data.series.length - 1);
54
+ const boxNodes = [];
55
+ boxNodes.push(line(cx, yMin, cx, yMax, {
56
+ class: "chartts-boxplot-whisker",
57
+ stroke: color,
58
+ strokeWidth: 1.5
59
+ }));
60
+ boxNodes.push(line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {
61
+ class: "chartts-boxplot-cap",
62
+ stroke: color,
63
+ strokeWidth: 1.5
64
+ }));
65
+ boxNodes.push(line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {
66
+ class: "chartts-boxplot-cap",
67
+ stroke: color,
68
+ strokeWidth: 1.5
69
+ }));
70
+ const boxTop = Math.min(yQ1, yQ3);
71
+ const boxH = Math.abs(yQ3 - yQ1);
72
+ boxNodes.push(rect(boxX, boxTop, boxWidth, boxH, {
73
+ class: "chartts-boxplot-box",
74
+ fill: color,
75
+ fillOpacity: 0.25,
76
+ stroke: color,
77
+ strokeWidth: 1.5,
78
+ rx: 4,
79
+ ry: 4,
80
+ "data-series": seriesIdx,
81
+ "data-index": i,
82
+ tabindex: 0,
83
+ role: "img",
84
+ ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`
85
+ }));
86
+ boxNodes.push(line(boxX, yMed, boxX + boxWidth, yMed, {
87
+ class: "chartts-boxplot-median",
88
+ stroke: color,
89
+ strokeWidth: 2.5
90
+ }));
91
+ nodes.push(group(boxNodes, {
92
+ class: `chartts-series chartts-series-${i}`,
93
+ "data-series-name": String(data.labels[i])
94
+ }));
95
+ }
96
+ return nodes;
97
+ },
98
+ hitTest(ctx, mx, my) {
99
+ const { data, xScale, yScale, options } = ctx;
100
+ if (data.labels.length === 0) return null;
101
+ const bOpts = options;
102
+ const boxWidthRatio = bOpts.boxWidth ?? 0.6;
103
+ const bw = getBandwidth(xScale);
104
+ const boxWidth = bw * boxWidthRatio;
105
+ for (let i = 0; i < data.labels.length; i++) {
106
+ let vals;
107
+ if (data.series.length === 1) {
108
+ const s = data.series[0];
109
+ if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5);
110
+ else continue;
111
+ } else if (data.series.length > i && data.series[i].values.length >= 5) {
112
+ vals = data.series[i].values.slice(0, 5);
113
+ } else continue;
114
+ const cx = xScale.map(i);
115
+ const yMin = yScale.map(vals[0]);
116
+ const yMax = yScale.map(vals[4]);
117
+ const top = Math.min(yMin, yMax);
118
+ const bottom = Math.max(yMin, yMax);
119
+ if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 && my >= top - 4 && my <= bottom + 4) {
120
+ const seriesIdx = Math.min(i, data.series.length - 1);
121
+ return { seriesIndex: seriesIdx, pointIndex: i, distance: 0 };
122
+ }
123
+ }
124
+ return null;
125
+ }
126
+ };
127
+
128
+ export { boxplotChartType };
129
+ //# sourceMappingURL=chunk-NQSC7CKN.js.map
130
+ //# sourceMappingURL=chunk-NQSC7CKN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/boxplot/boxplot-type.ts"],"names":[],"mappings":"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","file":"chunk-NQSC7CKN.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Boxplot / Whisker chart — displays statistical distribution for each category.\n *\n * Data format: each series has exactly 5 values per label:\n * [min, Q1, median, Q3, max]\n *\n * For simplicity, if there are N labels, series[0] has N*5 values:\n * [min1, q1_1, med1, q3_1, max1, min2, q1_2, med2, q3_2, max2, ...]\n *\n * Or use multiple series where each series has 5 values for its category.\n */\nexport interface BoxplotOptions {\n /** Width ratio of boxes. Default 0.6. */\n boxWidth?: number\n}\n\nexport const boxplotChartType: ChartTypePlugin = {\n type: 'boxplot',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Boxplot: single series with N*5 values. Create synthetic labels if needed.\n // We need to trick the validator: expand labels to match values length.\n const labelCount = data.labels?.length ?? 0\n const valLen = data.series[0]?.values.length ?? 0\n const syntheticData = { ...data }\n if (labelCount > 0 && valLen > labelCount) {\n // Pad labels to match values length (validator needs them equal)\n const padded: string[] = (data.labels ?? []).map(String)\n while (padded.length < valLen) padded.push('')\n syntheticData.labels = padded\n }\n\n const prepared = prepareData(syntheticData, options)\n\n // Restore original labels for rendering\n if (data.labels && data.labels.length < valLen) {\n prepared.labels = [...data.labels]\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n // Each series represents one boxplot: 5 values = [min, Q1, median, Q3, max]\n const seriesCount = data.series.length\n if (seriesCount === 0) return nodes\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n // Collect the 5 values for this label from all series,\n // or if single series with N*5 values, extract 5 at offset i*5\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) {\n vals = s.values.slice(i * 5, i * 5 + 5)\n } else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const [vMin, q1, median, q3, vMax] = vals as [number, number, number, number, number]\n const cx = xScale.map(i)\n const boxX = cx - boxWidth / 2\n\n const yMin = yScale.map(vMin)\n const yQ1 = yScale.map(q1)\n const yMed = yScale.map(median)\n const yQ3 = yScale.map(q3)\n const yMax = yScale.map(vMax)\n\n const color = options.colors[i % options.colors.length]!\n const seriesIdx = Math.min(i, data.series.length - 1)\n const boxNodes: RenderNode[] = []\n\n // Whisker line (min to max)\n boxNodes.push(line(cx, yMin, cx, yMax, {\n class: 'chartts-boxplot-whisker',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Min whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Max whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // IQR box (Q1 to Q3)\n const boxTop = Math.min(yQ1, yQ3)\n const boxH = Math.abs(yQ3 - yQ1)\n boxNodes.push(rect(boxX, boxTop, boxWidth, boxH, {\n class: 'chartts-boxplot-box',\n fill: color,\n fillOpacity: 0.25,\n stroke: color,\n strokeWidth: 1.5,\n rx: 4,\n ry: 4,\n 'data-series': seriesIdx,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`,\n }))\n\n // Median line\n boxNodes.push(line(boxX, yMed, boxX + boxWidth, yMed, {\n class: 'chartts-boxplot-median',\n stroke: color,\n strokeWidth: 2.5,\n }))\n\n nodes.push(group(boxNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i]),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.labels.length === 0) return null\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5)\n else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const cx = xScale.map(i)\n const yMin = yScale.map(vals[0]!)\n const yMax = yScale.map(vals[4]!)\n\n const top = Math.min(yMin, yMax)\n const bottom = Math.max(yMin, yMax)\n\n if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 &&\n my >= top - 4 && my <= bottom + 4) {\n const seriesIdx = Math.min(i, data.series.length - 1)\n return { seriesIndex: seriesIdx, pointIndex: i, distance: 0 }\n }\n }\n\n return null\n },\n}\n"]}
@@ -0,0 +1,87 @@
1
+ import { getBandwidth } from './chunk-E6PR75X7.js';
2
+ import { line, circle, group, prepareData } from './chunk-3BRQGYDX.js';
3
+
4
+ // src/charts/lollipop/lollipop-type.ts
5
+ var lollipopChartType = {
6
+ type: "lollipop",
7
+ getScaleTypes() {
8
+ return { x: "categorical", y: "linear" };
9
+ },
10
+ prepareData(data, options) {
11
+ const prepared = prepareData(data, options);
12
+ if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
13
+ prepared.bounds.yMin = 0;
14
+ }
15
+ return prepared;
16
+ },
17
+ render(ctx) {
18
+ const { data, options, xScale, yScale } = ctx;
19
+ const nodes = [];
20
+ const seriesCount = data.series.length;
21
+ const pointCount = data.series[0]?.values.length ?? 0;
22
+ if (pointCount === 0) return nodes;
23
+ const bw = getBandwidth(xScale);
24
+ const groupWidth = bw * 0.8;
25
+ const stemGap = groupWidth / seriesCount;
26
+ const dotR = Math.min(6, stemGap * 0.35);
27
+ const baselineY = yScale.map(0);
28
+ for (const series of data.series) {
29
+ const seriesNodes = [];
30
+ for (let i = 0; i < series.values.length; i++) {
31
+ const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap;
32
+ const vy = yScale.map(series.values[i]);
33
+ const color = options.colors[series.index % options.colors.length];
34
+ seriesNodes.push(line(cx, baselineY, cx, vy, {
35
+ class: "chartts-lollipop-stem",
36
+ stroke: color,
37
+ strokeWidth: 2
38
+ }));
39
+ seriesNodes.push(circle(cx, vy, dotR, {
40
+ class: "chartts-lollipop-dot",
41
+ fill: color,
42
+ stroke: "#fff",
43
+ strokeWidth: 1.5,
44
+ "data-series": series.index,
45
+ "data-index": i,
46
+ tabindex: 0,
47
+ role: "img",
48
+ ariaLabel: `${series.name}: ${series.values[i]}`
49
+ }));
50
+ }
51
+ nodes.push(group(seriesNodes, {
52
+ class: `chartts-series chartts-series-${series.index}`,
53
+ "data-series-name": series.name
54
+ }));
55
+ }
56
+ return nodes;
57
+ },
58
+ hitTest(ctx, mx, my) {
59
+ const { data, xScale, yScale } = ctx;
60
+ const seriesCount = data.series.length;
61
+ const pointCount = data.series[0]?.values.length ?? 0;
62
+ if (pointCount === 0) return null;
63
+ const bw = getBandwidth(xScale);
64
+ const groupWidth = bw * 0.8;
65
+ const stemGap = groupWidth / seriesCount;
66
+ let best = null;
67
+ let bestDist = 20;
68
+ for (const series of data.series) {
69
+ for (let i = 0; i < series.values.length; i++) {
70
+ const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap;
71
+ const vy = yScale.map(series.values[i]);
72
+ const dx = mx - cx;
73
+ const dy = my - vy;
74
+ const dist = Math.sqrt(dx * dx + dy * dy);
75
+ if (dist < bestDist) {
76
+ bestDist = dist;
77
+ best = { seriesIndex: series.index, pointIndex: i, distance: dist };
78
+ }
79
+ }
80
+ }
81
+ return best;
82
+ }
83
+ };
84
+
85
+ export { lollipopChartType };
86
+ //# sourceMappingURL=chunk-NYVFC2SF.js.map
87
+ //# sourceMappingURL=chunk-NYVFC2SF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":[],"mappings":"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","file":"chunk-NYVFC2SF.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(6, stemGap * 0.35)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2,\n }))\n\n // Dot\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\n fill: color,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -0,0 +1,218 @@
1
+ import { prepareNoAxes } from './chunk-3XVGEBR4.js';
2
+ import { PathBuilder, path, text } from './chunk-3BRQGYDX.js';
3
+
4
+ // src/charts/chord/chord-type.ts
5
+ var chordChartType = {
6
+ type: "chord",
7
+ getScaleTypes() {
8
+ return { x: "categorical", y: "linear" };
9
+ },
10
+ prepareData(data, options) {
11
+ return prepareNoAxes(data, options);
12
+ },
13
+ render(ctx) {
14
+ const { data, area, theme, options } = ctx;
15
+ const nodes = [];
16
+ const { arcs, ribbons } = buildChordLayout(data);
17
+ if (arcs.length === 0) return nodes;
18
+ const cx = area.x + area.width / 2;
19
+ const cy = area.y + area.height / 2;
20
+ const outerR = Math.min(area.width, area.height) / 2 - 20;
21
+ const innerR = outerR - 14;
22
+ for (const arc of arcs) {
23
+ if (arc.endAngle - arc.startAngle < 0.01) continue;
24
+ const color = options.colors[arc.index % options.colors.length];
25
+ const pb = new PathBuilder();
26
+ const x1o = cx + outerR * Math.cos(arc.startAngle);
27
+ const y1o = cy + outerR * Math.sin(arc.startAngle);
28
+ const x2o = cx + outerR * Math.cos(arc.endAngle);
29
+ const y2o = cy + outerR * Math.sin(arc.endAngle);
30
+ const x1i = cx + innerR * Math.cos(arc.endAngle);
31
+ const y1i = cy + innerR * Math.sin(arc.endAngle);
32
+ const x2i = cx + innerR * Math.cos(arc.startAngle);
33
+ const y2i = cy + innerR * Math.sin(arc.startAngle);
34
+ const largeArc = arc.endAngle - arc.startAngle > Math.PI;
35
+ pb.moveTo(x1o, y1o);
36
+ pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
37
+ pb.lineTo(x1i, y1i);
38
+ pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i);
39
+ pb.close();
40
+ nodes.push(path(pb.build(), {
41
+ class: "chartts-chord-arc",
42
+ fill: color,
43
+ stroke: color,
44
+ strokeWidth: 0.5,
45
+ "data-series": arc.index,
46
+ "data-index": 0,
47
+ tabindex: 0,
48
+ role: "img",
49
+ ariaLabel: `${arc.name}: ${arc.total}`
50
+ }));
51
+ const midAngle = (arc.startAngle + arc.endAngle) / 2;
52
+ const labelR = outerR + 12;
53
+ const lx = cx + labelR * Math.cos(midAngle);
54
+ const ly = cy + labelR * Math.sin(midAngle);
55
+ const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? "middle" : Math.cos(midAngle) > 0 ? "start" : "end";
56
+ nodes.push(text(lx, ly, arc.name, {
57
+ class: "chartts-chord-label",
58
+ fill: theme.textColor,
59
+ textAnchor: anchor,
60
+ dominantBaseline: "central",
61
+ fontSize: theme.fontSizeSmall,
62
+ fontFamily: theme.fontFamily
63
+ }));
64
+ }
65
+ for (let ri = 0; ri < ribbons.length; ri++) {
66
+ const ribbon = ribbons[ri];
67
+ const color = options.colors[ribbon.source % options.colors.length];
68
+ const pb = new PathBuilder();
69
+ const sx1 = cx + innerR * Math.cos(ribbon.sourceStart);
70
+ const sy1 = cy + innerR * Math.sin(ribbon.sourceStart);
71
+ const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd);
72
+ const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd);
73
+ const tx1 = cx + innerR * Math.cos(ribbon.targetStart);
74
+ const ty1 = cy + innerR * Math.sin(ribbon.targetStart);
75
+ const tx2 = cx + innerR * Math.cos(ribbon.targetEnd);
76
+ const ty2 = cy + innerR * Math.sin(ribbon.targetEnd);
77
+ const srcLarge = ribbon.sourceEnd - ribbon.sourceStart > Math.PI;
78
+ const tgtLarge = ribbon.targetEnd - ribbon.targetStart > Math.PI;
79
+ pb.moveTo(sx1, sy1);
80
+ pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2);
81
+ pb.quadTo(cx, cy, tx1, ty1);
82
+ pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2);
83
+ pb.quadTo(cx, cy, sx1, sy1);
84
+ pb.close();
85
+ nodes.push(path(pb.build(), {
86
+ class: "chartts-chord-ribbon",
87
+ fill: color,
88
+ fillOpacity: 0.35,
89
+ stroke: color,
90
+ strokeWidth: 0.3,
91
+ "data-series": ribbon.source,
92
+ "data-index": ri,
93
+ tabindex: 0,
94
+ role: "img",
95
+ ariaLabel: `${arcs[ribbon.source].name} \u2192 ${arcs[ribbon.target].name}: ${ribbon.value}`
96
+ }));
97
+ }
98
+ return nodes;
99
+ },
100
+ hitTest(ctx, mx, my) {
101
+ const { data, area, options } = ctx;
102
+ const { arcs } = buildChordLayout(data);
103
+ if (arcs.length === 0) return null;
104
+ const cx = area.x + area.width / 2;
105
+ const cy = area.y + area.height / 2;
106
+ const outerR = Math.min(area.width, area.height) / 2 - 20;
107
+ const innerR = outerR - 14;
108
+ const dx = mx - cx;
109
+ const dy = my - cy;
110
+ const dist = Math.sqrt(dx * dx + dy * dy);
111
+ if (dist >= innerR && dist <= outerR) {
112
+ let angle = Math.atan2(dy, dx);
113
+ if (angle < -Math.PI / 2) angle += Math.PI * 2;
114
+ for (const arc of arcs) {
115
+ if (angle >= arc.startAngle && angle <= arc.endAngle) {
116
+ return { seriesIndex: arc.index, pointIndex: 0, distance: 0 };
117
+ }
118
+ }
119
+ }
120
+ return null;
121
+ }
122
+ };
123
+ function buildChordLayout(data, _options) {
124
+ const arcs = [];
125
+ const ribbons = [];
126
+ const hasArrows = data.series.some((s) => s.name.includes("\u2192") || s.name.includes("->"));
127
+ const nodeNames = [];
128
+ const nodeMap = /* @__PURE__ */ new Map();
129
+ function getOrCreate(name) {
130
+ if (nodeMap.has(name)) return nodeMap.get(name);
131
+ const idx = nodeNames.length;
132
+ nodeMap.set(name, idx);
133
+ nodeNames.push(name);
134
+ return idx;
135
+ }
136
+ if (hasArrows) {
137
+ for (const series of data.series) {
138
+ const parts = series.name.split(/\s*(?:→|->)\s*/);
139
+ if (parts.length < 2) continue;
140
+ getOrCreate(parts[0].trim());
141
+ getOrCreate(parts[1].trim());
142
+ }
143
+ } else {
144
+ for (let i = 0; i < data.labels.length; i++) {
145
+ getOrCreate(String(data.labels[i]));
146
+ }
147
+ }
148
+ const n = nodeNames.length;
149
+ if (n === 0) return { arcs, ribbons, matrix: [] };
150
+ const matrix = Array.from({ length: n }, () => new Array(n).fill(0));
151
+ if (hasArrows) {
152
+ for (const series of data.series) {
153
+ const parts = series.name.split(/\s*(?:→|->)\s*/);
154
+ if (parts.length < 2) continue;
155
+ const src = getOrCreate(parts[0].trim());
156
+ const tgt = getOrCreate(parts[1].trim());
157
+ const val = series.values[0] ?? 0;
158
+ if (val > 0) matrix[src][tgt] += val;
159
+ }
160
+ } else {
161
+ for (let si = 0; si < data.series.length && si < n; si++) {
162
+ for (let j = 0; j < data.series[si].values.length && j < n; j++) {
163
+ const val = data.series[si].values[j];
164
+ if (val > 0) matrix[si][j] = val;
165
+ }
166
+ }
167
+ }
168
+ const totals = nodeNames.map((_, i) => {
169
+ let total = 0;
170
+ for (let j = 0; j < n; j++) {
171
+ total += matrix[i][j];
172
+ total += matrix[j][i];
173
+ }
174
+ return total;
175
+ });
176
+ const grandTotal = totals.reduce((s, t) => s + t, 0);
177
+ if (grandTotal === 0) return { arcs, ribbons, matrix };
178
+ const padAngle = 0.04;
179
+ const totalPad = padAngle * n;
180
+ const available = Math.PI * 2 - totalPad;
181
+ let angle = -Math.PI / 2;
182
+ for (let i = 0; i < n; i++) {
183
+ const span = totals[i] / grandTotal * available;
184
+ arcs.push({
185
+ index: i,
186
+ name: nodeNames[i],
187
+ total: totals[i],
188
+ startAngle: angle,
189
+ endAngle: angle + span
190
+ });
191
+ angle += span + padAngle;
192
+ }
193
+ const arcOffsets = arcs.map((a) => a.startAngle);
194
+ for (let i = 0; i < n; i++) {
195
+ for (let j = i; j < n; j++) {
196
+ const val = matrix[i][j] + matrix[j][i];
197
+ if (val <= 0) continue;
198
+ const srcSpan = matrix[i][j] / Math.max(totals[i], 1) * (arcs[i].endAngle - arcs[i].startAngle);
199
+ const tgtSpan = matrix[j][i] / Math.max(totals[j], 1) * (arcs[j].endAngle - arcs[j].startAngle);
200
+ ribbons.push({
201
+ source: i,
202
+ target: j,
203
+ value: val,
204
+ sourceStart: arcOffsets[i],
205
+ sourceEnd: arcOffsets[i] + srcSpan,
206
+ targetStart: arcOffsets[j],
207
+ targetEnd: arcOffsets[j] + tgtSpan
208
+ });
209
+ arcOffsets[i] += srcSpan;
210
+ arcOffsets[j] += tgtSpan;
211
+ }
212
+ }
213
+ return { arcs, ribbons, matrix };
214
+ }
215
+
216
+ export { chordChartType };
217
+ //# sourceMappingURL=chunk-O5KGKQSU.js.map
218
+ //# sourceMappingURL=chunk-O5KGKQSU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/chord/chord-type.ts"],"names":[],"mappings":"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","file":"chunk-O5KGKQSU.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Chord diagram — shows relationships between entities via ribbons\n * connecting arcs on a circle.\n *\n * Data convention:\n * - labels: entity names (placed around the circle as arcs)\n * - series[i].values[j]: flow from entity i to entity j (adjacency matrix)\n * series.length should equal labels.length for a square matrix.\n *\n * Alternative: arrow notation like Sankey\n * - series names contain \"→\" or \"->\" (e.g., \"A → B\")\n */\n\ninterface ChordArc {\n index: number\n name: string\n total: number\n startAngle: number\n endAngle: number\n}\n\ninterface ChordRibbon {\n source: number\n target: number\n value: number\n sourceStart: number\n sourceEnd: number\n targetStart: number\n targetEnd: number\n}\n\nexport const chordChartType: ChartTypePlugin = {\n type: 'chord',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const { arcs, ribbons } = buildChordLayout(data, options)\n if (arcs.length === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n // Render arcs\n for (const arc of arcs) {\n if (arc.endAngle - arc.startAngle < 0.01) continue\n\n const color = options.colors[arc.index % options.colors.length]!\n const pb = new PathBuilder()\n\n const x1o = cx + outerR * Math.cos(arc.startAngle)\n const y1o = cy + outerR * Math.sin(arc.startAngle)\n const x2o = cx + outerR * Math.cos(arc.endAngle)\n const y2o = cy + outerR * Math.sin(arc.endAngle)\n const x1i = cx + innerR * Math.cos(arc.endAngle)\n const y1i = cy + innerR * Math.sin(arc.endAngle)\n const x2i = cx + innerR * Math.cos(arc.startAngle)\n const y2i = cy + innerR * Math.sin(arc.startAngle)\n const largeArc = (arc.endAngle - arc.startAngle) > Math.PI\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-arc',\n fill: color,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': arc.index,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arc.name}: ${arc.total}`,\n }))\n\n // Label\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const labelR = outerR + 12\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, arc.name, {\n class: 'chartts-chord-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Render ribbons\n for (let ri = 0; ri < ribbons.length; ri++) {\n const ribbon = ribbons[ri]!\n const color = options.colors[ribbon.source % options.colors.length]!\n\n const pb = new PathBuilder()\n // Source arc on inner ring\n const sx1 = cx + innerR * Math.cos(ribbon.sourceStart)\n const sy1 = cy + innerR * Math.sin(ribbon.sourceStart)\n const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd)\n const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd)\n // Target arc on inner ring\n const tx1 = cx + innerR * Math.cos(ribbon.targetStart)\n const ty1 = cy + innerR * Math.sin(ribbon.targetStart)\n const tx2 = cx + innerR * Math.cos(ribbon.targetEnd)\n const ty2 = cy + innerR * Math.sin(ribbon.targetEnd)\n\n const srcLarge = (ribbon.sourceEnd - ribbon.sourceStart) > Math.PI\n const tgtLarge = (ribbon.targetEnd - ribbon.targetStart) > Math.PI\n\n pb.moveTo(sx1, sy1)\n pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2)\n // Bezier to target\n pb.quadTo(cx, cy, tx1, ty1)\n pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2)\n // Bezier back to source\n pb.quadTo(cx, cy, sx1, sy1)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-ribbon',\n fill: color,\n fillOpacity: 0.35,\n stroke: color,\n strokeWidth: 0.3,\n 'data-series': ribbon.source,\n 'data-index': ri,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arcs[ribbon.source]!.name} → ${arcs[ribbon.target]!.name}: ${ribbon.value}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { arcs } = buildChordLayout(data, options)\n if (arcs.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n // Check arc hits\n if (dist >= innerR && dist <= outerR) {\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n for (const arc of arcs) {\n if (angle >= arc.startAngle && angle <= arc.endAngle) {\n return { seriesIndex: arc.index, pointIndex: 0, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Layout computation\n// ---------------------------------------------------------------------------\n\nfunction buildChordLayout(\n data: PreparedData,\n _options: ResolvedOptions,\n): { arcs: ChordArc[]; ribbons: ChordRibbon[]; matrix: number[][] } {\n const arcs: ChordArc[] = []\n const ribbons: ChordRibbon[] = []\n\n // Check for arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n // Build adjacency matrix\n const nodeNames: string[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreate(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = nodeNames.length\n nodeMap.set(name, idx)\n nodeNames.push(name)\n return idx\n }\n\n if (hasArrows) {\n // Parse arrow notation\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n getOrCreate(parts[0]!.trim())\n getOrCreate(parts[1]!.trim())\n }\n } else {\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreate(String(data.labels[i]))\n }\n }\n\n const n = nodeNames.length\n if (n === 0) return { arcs, ribbons, matrix: [] }\n\n const matrix: number[][] = Array.from({ length: n }, () => new Array(n).fill(0))\n\n if (hasArrows) {\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const src = getOrCreate(parts[0]!.trim())\n const tgt = getOrCreate(parts[1]!.trim())\n const val = series.values[0] ?? 0\n if (val > 0) matrix[src]![tgt]! += val\n }\n } else {\n for (let si = 0; si < data.series.length && si < n; si++) {\n for (let j = 0; j < data.series[si]!.values.length && j < n; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0) matrix[si]![j]! = val\n }\n }\n }\n\n // Compute totals per node\n const totals = nodeNames.map((_, i) => {\n let total = 0\n for (let j = 0; j < n; j++) {\n total += matrix[i]![j]!\n total += matrix[j]![i]!\n }\n return total\n })\n\n const grandTotal = totals.reduce((s, t) => s + t, 0)\n if (grandTotal === 0) return { arcs, ribbons, matrix }\n\n // Layout arcs\n const padAngle = 0.04\n const totalPad = padAngle * n\n const available = Math.PI * 2 - totalPad\n\n let angle = -Math.PI / 2\n for (let i = 0; i < n; i++) {\n const span = (totals[i]! / grandTotal) * available\n arcs.push({\n index: i,\n name: nodeNames[i]!,\n total: totals[i]!,\n startAngle: angle,\n endAngle: angle + span,\n })\n angle += span + padAngle\n }\n\n // Layout ribbons — track offsets within each arc\n const arcOffsets = arcs.map(a => a.startAngle)\n\n for (let i = 0; i < n; i++) {\n for (let j = i; j < n; j++) {\n const val = matrix[i]![j]! + matrix[j]![i]!\n if (val <= 0) continue\n\n const srcSpan = (matrix[i]![j]! / Math.max(totals[i]!, 1)) * (arcs[i]!.endAngle - arcs[i]!.startAngle)\n const tgtSpan = (matrix[j]![i]! / Math.max(totals[j]!, 1)) * (arcs[j]!.endAngle - arcs[j]!.startAngle)\n\n ribbons.push({\n source: i,\n target: j,\n value: val,\n sourceStart: arcOffsets[i]!,\n sourceEnd: arcOffsets[i]! + srcSpan,\n targetStart: arcOffsets[j]!,\n targetEnd: arcOffsets[j]! + tgtSpan,\n })\n\n arcOffsets[i]! += srcSpan\n arcOffsets[j]! += tgtSpan\n }\n }\n\n return { arcs, ribbons, matrix }\n}\n"]}
@@ -0,0 +1,26 @@
1
+ // src/utils/format.ts
2
+ function formatNum(v) {
3
+ return Number.isInteger(v) ? String(v) : v.toFixed(2);
4
+ }
5
+ function formatValue(value) {
6
+ const abs = Math.abs(value);
7
+ if (abs >= 1e12) return trimSuffix(value / 1e12, "T");
8
+ if (abs >= 1e9) return trimSuffix(value / 1e9, "B");
9
+ if (abs >= 1e6) return trimSuffix(value / 1e6, "M");
10
+ if (abs >= 1e3) return trimSuffix(value / 1e3, "K");
11
+ if (Number.isInteger(value)) return String(value);
12
+ return value.toFixed(1);
13
+ }
14
+ function formatPercent(value) {
15
+ const v = Math.abs(value) <= 1 ? value * 100 : value;
16
+ const s = v.toFixed(1);
17
+ return (s.endsWith(".0") ? s.slice(0, -2) : s) + "%";
18
+ }
19
+ function trimSuffix(v, suffix) {
20
+ const s = v.toFixed(1);
21
+ return (s.endsWith(".0") ? s.slice(0, -2) : s) + suffix;
22
+ }
23
+
24
+ export { formatNum, formatPercent, formatValue };
25
+ //# sourceMappingURL=chunk-OGSZO22B.js.map
26
+ //# sourceMappingURL=chunk-OGSZO22B.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/format.ts"],"names":[],"mappings":";AAIO,SAAS,UAAU,CAAA,EAAmB;AAC3C,EAAA,OAAO,MAAA,CAAO,UAAU,CAAC,CAAA,GAAI,OAAO,CAAC,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACtD;AAMO,SAAS,YAAY,KAAA,EAAuB;AACjD,EAAA,MAAM,GAAA,GAAM,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA;AAC1B,EAAA,IAAI,OAAO,IAAA,EAAM,OAAO,UAAA,CAAW,KAAA,GAAQ,MAAM,GAAG,CAAA;AACpD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,SAAA,CAAU,KAAK,CAAA,EAAG,OAAO,OAAO,KAAK,CAAA;AAChD,EAAA,OAAO,KAAA,CAAM,QAAQ,CAAC,CAAA;AACxB;AAMO,SAAS,cAAc,KAAA,EAAuB;AACnD,EAAA,MAAM,IAAI,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA,IAAK,CAAA,GAAI,QAAQ,GAAA,GAAM,KAAA;AAC/C,EAAA,MAAM,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACrB,EAAA,OAAA,CAAQ,CAAA,CAAE,SAAS,IAAI,CAAA,GAAI,EAAE,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,CAAA,IAAK,GAAA;AACnD;AAEA,SAAS,UAAA,CAAW,GAAW,MAAA,EAAwB;AACrD,EAAA,MAAM,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACrB,EAAA,OAAA,CAAQ,CAAA,CAAE,SAAS,IAAI,CAAA,GAAI,EAAE,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,CAAA,IAAK,MAAA;AACnD","file":"chunk-OGSZO22B.js","sourcesContent":["/**\n * Shared number formatting for SVG path data strings.\n * Outputs integers as-is, decimals with 2 decimal places.\n */\nexport function formatNum(v: number): string {\n return Number.isInteger(v) ? String(v) : v.toFixed(2)\n}\n\n/**\n * Human-readable value formatter with SI suffixes.\n * 1500 → \"1.5K\", 2000000 → \"2M\", 3000000000 → \"3B\"\n */\nexport function formatValue(value: number): string {\n const abs = Math.abs(value)\n if (abs >= 1e12) return trimSuffix(value / 1e12, 'T')\n if (abs >= 1e9) return trimSuffix(value / 1e9, 'B')\n if (abs >= 1e6) return trimSuffix(value / 1e6, 'M')\n if (abs >= 1e3) return trimSuffix(value / 1e3, 'K')\n if (Number.isInteger(value)) return String(value)\n return value.toFixed(1)\n}\n\n/**\n * Percentage formatter: 0.75 → \"75%\", 42 → \"42%\"\n * Values <= 1 are treated as ratios and multiplied by 100.\n */\nexport function formatPercent(value: number): string {\n const v = Math.abs(value) <= 1 ? value * 100 : value\n const s = v.toFixed(1)\n return (s.endsWith('.0') ? s.slice(0, -2) : s) + '%'\n}\n\nfunction trimSuffix(v: number, suffix: string): string {\n const s = v.toFixed(1)\n return (s.endsWith('.0') ? s.slice(0, -2) : s) + suffix\n}\n"]}