@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,146 @@
1
+ 'use strict';
2
+
3
+ var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
4
+ var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
5
+
6
+ // src/charts/gauge/gauge-type.ts
7
+ var gaugeChartType = {
8
+ type: "gauge",
9
+ getScaleTypes() {
10
+ return { x: "categorical", y: "linear" };
11
+ },
12
+ prepareData(data, options) {
13
+ return chunk5QOQR5FE_cjs.prepareNoAxes(data, options);
14
+ },
15
+ render(ctx) {
16
+ const { data, area, theme, options } = ctx;
17
+ const nodes = [];
18
+ const series = data.series[0];
19
+ if (!series || series.values.length === 0) return nodes;
20
+ const gOpts = options;
21
+ const min = gOpts.gaugeMin ?? 0;
22
+ const max = gOpts.gaugeMax ?? 100;
23
+ const showValue = gOpts.showValue ?? true;
24
+ const valueFormat = gOpts.valueFormat ?? ((v) => String(Math.round(v)));
25
+ const value = series.values[0];
26
+ const pct = Math.max(0, Math.min(1, (value - min) / (max - min || 1)));
27
+ const cx = area.x + area.width / 2;
28
+ const toRad = (d) => d * Math.PI / 180;
29
+ const startRad = toRad(150);
30
+ const endRad = toRad(390);
31
+ const labelSpace = Math.min(60, area.height * 0.22);
32
+ const availH = area.height - labelSpace;
33
+ const maxRadiusH = (availH - 8) / 1.55;
34
+ const maxRadiusW = (area.width - 16) / 2;
35
+ const radius = Math.min(maxRadiusH, maxRadiusW);
36
+ const strokeW = Math.max(12, Math.min(radius * 0.18, 28));
37
+ const cy = area.y + radius + strokeW / 2 + 4;
38
+ const arcBottomY = cy + radius * Math.sin(toRad(30));
39
+ nodes.push(chunkXHQWWR5M_cjs.path(strokeArc(cx, cy, radius, startRad, endRad), {
40
+ class: "chartts-gauge-track",
41
+ stroke: theme.gridColor,
42
+ strokeWidth: strokeW,
43
+ fill: "none",
44
+ opacity: 0.3,
45
+ style: "stroke-linecap:round"
46
+ }));
47
+ const color = options.colors[0];
48
+ if (pct > 5e-3) {
49
+ const valueRad = startRad + (endRad - startRad) * pct;
50
+ nodes.push(chunkXHQWWR5M_cjs.path(strokeArc(cx, cy, radius, startRad, valueRad), {
51
+ class: "chartts-gauge-fill",
52
+ stroke: color,
53
+ strokeWidth: strokeW,
54
+ fill: "none",
55
+ style: "stroke-linecap:round",
56
+ "data-series": 0,
57
+ "data-index": 0
58
+ }));
59
+ }
60
+ const needleAngle = startRad + (endRad - startRad) * pct;
61
+ const needleLen = radius - strokeW / 2 - 2;
62
+ const needleTipX = cx + needleLen * Math.cos(needleAngle);
63
+ const needleTipY = cy + needleLen * Math.sin(needleAngle);
64
+ const baseR = 3.5;
65
+ const bAngle1 = needleAngle + Math.PI / 2;
66
+ const bAngle2 = needleAngle - Math.PI / 2;
67
+ const npb = new chunkXHQWWR5M_cjs.PathBuilder();
68
+ npb.moveTo(needleTipX, needleTipY);
69
+ npb.lineTo(cx + baseR * Math.cos(bAngle1), cy + baseR * Math.sin(bAngle1));
70
+ npb.lineTo(cx + baseR * Math.cos(bAngle2), cy + baseR * Math.sin(bAngle2));
71
+ npb.close();
72
+ nodes.push(chunkXHQWWR5M_cjs.path(npb.build(), {
73
+ class: "chartts-gauge-needle",
74
+ fill: color,
75
+ opacity: 0.85
76
+ }));
77
+ nodes.push(chunkXHQWWR5M_cjs.circle(cx, cy, 5, {
78
+ class: "chartts-gauge-needle-cap",
79
+ fill: color
80
+ }));
81
+ if (showValue) {
82
+ const valueFontSize = Math.max(16, Math.min(radius * 0.35, 40));
83
+ const valueY = arcBottomY + labelSpace * 0.28;
84
+ nodes.push(chunkXHQWWR5M_cjs.text(cx, valueY, valueFormat(value), {
85
+ class: "chartts-gauge-value",
86
+ fill: theme.textColor,
87
+ textAnchor: "middle",
88
+ dominantBaseline: "central",
89
+ fontSize: valueFontSize,
90
+ fontFamily: theme.fontFamily,
91
+ fontWeight: 700
92
+ }));
93
+ if (series.name) {
94
+ nodes.push(chunkXHQWWR5M_cjs.text(cx, valueY + valueFontSize * 0.85, series.name, {
95
+ class: "chartts-gauge-label",
96
+ fill: theme.textMuted,
97
+ textAnchor: "middle",
98
+ dominantBaseline: "central",
99
+ fontSize: theme.fontSizeSmall,
100
+ fontFamily: theme.fontFamily
101
+ }));
102
+ }
103
+ const minX = cx + radius * Math.cos(startRad);
104
+ const minY = cy + radius * Math.sin(startRad) + strokeW / 2 + 12;
105
+ nodes.push(chunkXHQWWR5M_cjs.text(minX, minY, valueFormat(min), {
106
+ class: "chartts-gauge-min",
107
+ fill: theme.textMuted,
108
+ textAnchor: "middle",
109
+ dominantBaseline: "central",
110
+ fontSize: theme.fontSizeSmall,
111
+ fontFamily: theme.fontFamily
112
+ }));
113
+ const maxX = cx + radius * Math.cos(toRad(30));
114
+ const maxY = cy + radius * Math.sin(toRad(30)) + strokeW / 2 + 12;
115
+ nodes.push(chunkXHQWWR5M_cjs.text(maxX, maxY, valueFormat(max), {
116
+ class: "chartts-gauge-max",
117
+ fill: theme.textMuted,
118
+ textAnchor: "middle",
119
+ dominantBaseline: "central",
120
+ fontSize: theme.fontSizeSmall,
121
+ fontFamily: theme.fontFamily
122
+ }));
123
+ }
124
+ return nodes;
125
+ },
126
+ hitTest() {
127
+ return null;
128
+ }
129
+ };
130
+ function strokeArc(cx, cy, r, startAngle, endAngle) {
131
+ const pb = new chunkXHQWWR5M_cjs.PathBuilder();
132
+ const x1 = cx + r * Math.cos(startAngle);
133
+ const y1 = cy + r * Math.sin(startAngle);
134
+ const x2 = cx + r * Math.cos(endAngle);
135
+ const y2 = cy + r * Math.sin(endAngle);
136
+ let span = endAngle - startAngle;
137
+ if (span < 0) span += 2 * Math.PI;
138
+ const largeArc = span > Math.PI;
139
+ pb.moveTo(x1, y1);
140
+ pb.arc(r, r, 0, largeArc, true, x2, y2);
141
+ return pb.build();
142
+ }
143
+
144
+ exports.gaugeChartType = gaugeChartType;
145
+ //# sourceMappingURL=chunk-3TTTELGB.cjs.map
146
+ //# sourceMappingURL=chunk-3TTTELGB.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/gauge/gauge-type.ts"],"names":["prepareNoAxes","path","PathBuilder","circle","text"],"mappings":"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","file":"chunk-3TTTELGB.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface GaugeOptions {\n /** Minimum value. Default 0. */\n gaugeMin?: number\n /** Maximum value. Default 100. */\n gaugeMax?: number\n /** Show value text in center. Default true. */\n showValue?: boolean\n /** Value format function. Default: round to int. */\n valueFormat?: (v: number) => string\n}\n\n/**\n * Gauge / Meter chart — single-value 240° arc with stroke-based rendering.\n *\n * Uses stroke-linecap:round for clean rounded endcaps. No fill-based donut arcs.\n * Looks like a modern dashboard gauge (Grafana, Material style).\n */\nexport const gaugeChartType: ChartTypePlugin = {\n type: 'gauge',\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const gOpts = options as unknown as GaugeOptions\n const min = gOpts.gaugeMin ?? 0\n const max = gOpts.gaugeMax ?? 100\n const showValue = gOpts.showValue ?? true\n const valueFormat = gOpts.valueFormat ?? ((v: number) => String(Math.round(v)))\n\n const value = series.values[0]!\n const pct = Math.max(0, Math.min(1, (value - min) / (max - min || 1)))\n\n // ----- Layout -----\n const cx = area.x + area.width / 2\n\n // Arc angles: 240° sweep, opening at the bottom\n // Start at 150° (bottom-left), sweep CW to 30° (bottom-right)\n const toRad = (d: number) => (d * Math.PI) / 180\n const startRad = toRad(150)\n const endRad = toRad(390) // 390° = 30° but keeps sweep direction clear\n\n // Size the arc to fit within the area with padding for labels\n // The arc bottom-most points are at 150° and 30° — y = cy + r*sin(30°) = cy + r*0.5\n // The arc top is at cy - r\n // Below the arc we need ~50px for value text, label, min/max\n const labelSpace = Math.min(60, area.height * 0.22)\n const availH = area.height - labelSpace\n // Arc top to arc bottom-endpoints: r + r*sin(30°) = r*1.5\n // So r*1.5 + strokeW <= availH\n const maxRadiusH = (availH - 8) / 1.55\n const maxRadiusW = (area.width - 16) / 2\n const radius = Math.min(maxRadiusH, maxRadiusW)\n const strokeW = Math.max(12, Math.min(radius * 0.18, 28))\n\n // Position: the top of the arc (cy - radius - strokeW/2) should be just inside area.y\n const cy = area.y + radius + strokeW / 2 + 4\n\n // Arc bottom-left/right y coordinate\n const arcBottomY = cy + radius * Math.sin(toRad(30))\n\n // ----- Track arc (background) -----\n nodes.push(path(strokeArc(cx, cy, radius, startRad, endRad), {\n class: 'chartts-gauge-track',\n stroke: theme.gridColor,\n strokeWidth: strokeW,\n fill: 'none',\n opacity: 0.3,\n style: 'stroke-linecap:round',\n }))\n\n // ----- Value arc -----\n const color = options.colors[0]!\n if (pct > 0.005) {\n const valueRad = startRad + (endRad - startRad) * pct\n nodes.push(path(strokeArc(cx, cy, radius, startRad, valueRad), {\n class: 'chartts-gauge-fill',\n stroke: color,\n strokeWidth: strokeW,\n fill: 'none',\n style: 'stroke-linecap:round',\n 'data-series': 0,\n 'data-index': 0,\n }))\n }\n\n // ----- Needle -----\n const needleAngle = startRad + (endRad - startRad) * pct\n const needleLen = radius - strokeW / 2 - 2\n const needleTipX = cx + needleLen * Math.cos(needleAngle)\n const needleTipY = cy + needleLen * Math.sin(needleAngle)\n\n // Tapered needle triangle\n const baseR = 3.5\n const bAngle1 = needleAngle + Math.PI / 2\n const bAngle2 = needleAngle - Math.PI / 2\n const npb = new PathBuilder()\n npb.moveTo(needleTipX, needleTipY)\n npb.lineTo(cx + baseR * Math.cos(bAngle1), cy + baseR * Math.sin(bAngle1))\n npb.lineTo(cx + baseR * Math.cos(bAngle2), cy + baseR * Math.sin(bAngle2))\n npb.close()\n\n nodes.push(path(npb.build(), {\n class: 'chartts-gauge-needle',\n fill: color,\n opacity: 0.85,\n }))\n\n // Center cap\n nodes.push(circle(cx, cy, 5, {\n class: 'chartts-gauge-needle-cap',\n fill: color,\n }))\n\n // ----- Labels -----\n if (showValue) {\n // Big value — in the gap below the arc center\n const valueFontSize = Math.max(16, Math.min(radius * 0.35, 40))\n const valueY = arcBottomY + labelSpace * 0.28\n nodes.push(text(cx, valueY, valueFormat(value), {\n class: 'chartts-gauge-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: valueFontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 700,\n }))\n\n // Series name\n if (series.name) {\n nodes.push(text(cx, valueY + valueFontSize * 0.85, series.name, {\n class: 'chartts-gauge-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Min / Max at arc endpoints\n const minX = cx + radius * Math.cos(startRad)\n const minY = cy + radius * Math.sin(startRad) + strokeW / 2 + 12\n nodes.push(text(minX, minY, valueFormat(min), {\n class: 'chartts-gauge-min',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n const maxX = cx + radius * Math.cos(toRad(30))\n const maxY = cy + radius * Math.sin(toRad(30)) + strokeW / 2 + 12\n nodes.push(text(maxX, maxY, valueFormat(max), {\n class: 'chartts-gauge-max',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n return nodes\n },\n\n hitTest(): HitResult | null {\n return null\n },\n}\n\n/**\n * Stroke-based arc path (open, for use with thick stroke + stroke-linecap:round).\n * Angles in radians, CW from positive X axis (SVG convention).\n */\nfunction strokeArc(\n cx: number, cy: number, r: number,\n startAngle: number, endAngle: number,\n): string {\n const pb = new PathBuilder()\n const x1 = cx + r * Math.cos(startAngle)\n const y1 = cy + r * Math.sin(startAngle)\n const x2 = cx + r * Math.cos(endAngle)\n const y2 = cy + r * Math.sin(endAngle)\n\n let span = endAngle - startAngle\n if (span < 0) span += 2 * Math.PI\n const largeArc = span > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n return pb.build()\n}\n"]}
@@ -0,0 +1,17 @@
1
+ import { prepareData } from './chunk-3BRQGYDX.js';
2
+
3
+ // src/utils/prepare.ts
4
+ function prepareNoAxes(data, options) {
5
+ return prepareData(data, {
6
+ ...options,
7
+ xAxis: false,
8
+ yAxis: false,
9
+ xGrid: false,
10
+ yGrid: false,
11
+ legend: false
12
+ });
13
+ }
14
+
15
+ export { prepareNoAxes };
16
+ //# sourceMappingURL=chunk-3XVGEBR4.js.map
17
+ //# sourceMappingURL=chunk-3XVGEBR4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/prepare.ts"],"names":[],"mappings":";;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAO,YAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-3XVGEBR4.js","sourcesContent":["import type { ChartData, ResolvedOptions, PreparedData } from '../types'\nimport { prepareData } from '../data/prepare'\n\n/**\n * Prepare data with axes, grid, and legend suppressed.\n * Used by chart types that render their own layout (pie, gauge, treemap, etc.).\n */\nexport function prepareNoAxes(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n}\n"]}
@@ -0,0 +1,128 @@
1
+ 'use strict';
2
+
3
+ var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
+ var chunkLU35QDPN_cjs = require('./chunk-LU35QDPN.cjs');
5
+ var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
6
+
7
+ // src/charts/bar/stacked-bar-type.ts
8
+ var stackedBarChartType = {
9
+ type: "stacked-bar",
10
+ getScaleTypes() {
11
+ return { x: "categorical", y: "linear" };
12
+ },
13
+ prepareData(data, options) {
14
+ const prepared = chunkXHQWWR5M_cjs.prepareData(data, options);
15
+ const pointCount = prepared.series[0]?.values.length ?? 0;
16
+ let maxTotal = 0;
17
+ let minTotal = 0;
18
+ for (let i = 0; i < pointCount; i++) {
19
+ let posSum = 0;
20
+ let negSum = 0;
21
+ for (const s of prepared.series) {
22
+ const v = s.values[i] ?? 0;
23
+ if (v >= 0) posSum += v;
24
+ else negSum += v;
25
+ }
26
+ if (posSum > maxTotal) maxTotal = posSum;
27
+ if (negSum < minTotal) minTotal = negSum;
28
+ }
29
+ if (options.yMin === void 0) prepared.bounds.yMin = Math.min(0, minTotal);
30
+ if (options.yMax === void 0) prepared.bounds.yMax = Math.max(0, maxTotal);
31
+ return prepared;
32
+ },
33
+ render(ctx) {
34
+ const { data, options, xScale, yScale } = ctx;
35
+ const nodes = [];
36
+ const pointCount = data.series[0]?.values.length ?? 0;
37
+ if (pointCount === 0) return nodes;
38
+ const bw = chunkNHGKZMD7_cjs.getBandwidth(xScale);
39
+ const barWidth = bw * (1 - options.barGap);
40
+ const barOffset = -barWidth / 2;
41
+ const baseline = yScale.map(0);
42
+ for (let i = 0; i < pointCount; i++) {
43
+ let posY = baseline;
44
+ let negY = baseline;
45
+ for (const series of data.series) {
46
+ const value = series.values[i] ?? 0;
47
+ if (value === 0) continue;
48
+ const cx = xScale.map(i);
49
+ const barX = cx + barOffset;
50
+ const vy = yScale.map(Math.abs(value));
51
+ const h = Math.abs(vy - baseline);
52
+ let y;
53
+ if (value >= 0) {
54
+ y = posY - h;
55
+ posY = y;
56
+ } else {
57
+ y = negY;
58
+ negY = y + h;
59
+ }
60
+ const barFill = `url(#chartts-bar-${series.index})`;
61
+ const r = Math.min(options.barRadius, barWidth / 2, h / 2);
62
+ const barNode = r > 0 && h > r * 2 ? chunkXHQWWR5M_cjs.path(
63
+ `M${chunkLU35QDPN_cjs.formatNum(barX)},${chunkLU35QDPN_cjs.formatNum(y + h)}V${chunkLU35QDPN_cjs.formatNum(y + r)}Q${chunkLU35QDPN_cjs.formatNum(barX)},${chunkLU35QDPN_cjs.formatNum(y)},${chunkLU35QDPN_cjs.formatNum(barX + r)},${chunkLU35QDPN_cjs.formatNum(y)}H${chunkLU35QDPN_cjs.formatNum(barX + barWidth - r)}Q${chunkLU35QDPN_cjs.formatNum(barX + barWidth)},${chunkLU35QDPN_cjs.formatNum(y)},${chunkLU35QDPN_cjs.formatNum(barX + barWidth)},${chunkLU35QDPN_cjs.formatNum(y + r)}V${chunkLU35QDPN_cjs.formatNum(y + h)}Z`,
64
+ {
65
+ class: "chartts-bar",
66
+ fill: barFill,
67
+ "data-series": series.index,
68
+ "data-index": i,
69
+ tabindex: 0,
70
+ role: "img",
71
+ ariaLabel: `${series.name}: ${value}`
72
+ }
73
+ ) : chunkXHQWWR5M_cjs.rect(barX, y, barWidth, h, {
74
+ class: "chartts-bar",
75
+ fill: barFill,
76
+ "data-series": series.index,
77
+ "data-index": i,
78
+ tabindex: 0,
79
+ role: "img",
80
+ ariaLabel: `${series.name}: ${value}`
81
+ });
82
+ nodes.push(chunkXHQWWR5M_cjs.group([barNode], {
83
+ class: `chartts-series chartts-series-${series.index}`,
84
+ "data-series-name": series.name
85
+ }));
86
+ }
87
+ }
88
+ return nodes;
89
+ },
90
+ hitTest(ctx, mx, my) {
91
+ const { data, xScale, yScale, options } = ctx;
92
+ const pointCount = data.series[0]?.values.length ?? 0;
93
+ if (pointCount === 0) return null;
94
+ const bw = chunkNHGKZMD7_cjs.getBandwidth(xScale);
95
+ const barWidth = bw * (1 - options.barGap);
96
+ const barOffset = -barWidth / 2;
97
+ const baseline = yScale.map(0);
98
+ for (let i = 0; i < pointCount; i++) {
99
+ const cx = xScale.map(i);
100
+ const barX = cx + barOffset;
101
+ if (mx < barX - 2 || mx > barX + barWidth + 2) continue;
102
+ let posY = baseline;
103
+ let negY = baseline;
104
+ for (const series of data.series) {
105
+ const value = series.values[i] ?? 0;
106
+ if (value === 0) continue;
107
+ const vy = yScale.map(Math.abs(value));
108
+ const h = Math.abs(vy - baseline);
109
+ let y;
110
+ if (value >= 0) {
111
+ y = posY - h;
112
+ posY = y;
113
+ } else {
114
+ y = negY;
115
+ negY = y + h;
116
+ }
117
+ if (my >= y - 2 && my <= y + h + 2) {
118
+ return { seriesIndex: series.index, pointIndex: i, distance: 0 };
119
+ }
120
+ }
121
+ }
122
+ return null;
123
+ }
124
+ };
125
+
126
+ exports.stackedBarChartType = stackedBarChartType;
127
+ //# sourceMappingURL=chunk-4HK4RM3X.cjs.map
128
+ //# sourceMappingURL=chunk-4HK4RM3X.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/bar/stacked-bar-type.ts"],"names":["prepareData","getBandwidth","path","formatNum","rect","group"],"mappings":"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","file":"chunk-4HK4RM3X.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Stacked bar chart — all series at the same x position are stacked vertically.\n */\nexport const stackedBarChartType: ChartTypePlugin = {\n type: 'stacked-bar',\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\n // y-axis range should cover cumulative totals per x-index\n const pointCount = prepared.series[0]?.values.length ?? 0\n let maxTotal = 0\n let minTotal = 0\n\n for (let i = 0; i < pointCount; i++) {\n let posSum = 0\n let negSum = 0\n for (const s of prepared.series) {\n const v = s.values[i] ?? 0\n if (v >= 0) posSum += v\n else negSum += v\n }\n if (posSum > maxTotal) maxTotal = posSum\n if (negSum < minTotal) minTotal = negSum\n }\n\n if (options.yMin === undefined) prepared.bounds.yMin = Math.min(0, minTotal)\n if (options.yMax === undefined) prepared.bounds.yMax = Math.max(0, maxTotal)\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 pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n let posY = baseline // tracks current top of positive stack\n let negY = baseline // tracks current bottom of negative stack\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const cx = xScale.map(i)\n const barX = cx + barOffset\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n\n let y: number\n if (value >= 0) {\n y = posY - h\n posY = y\n } else {\n y = negY\n negY = y + h\n }\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n const barNode = (r > 0 && h > r * 2)\n ? path(\n `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`,\n {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n },\n )\n : rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n })\n\n // Wrap each series segment in its own group for hover isolation\n nodes.push(group([barNode], {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\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 const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n const cx = xScale.map(i)\n const barX = cx + barOffset\n\n if (mx < barX - 2 || mx > barX + barWidth + 2) continue\n\n let posY = baseline\n let negY = baseline\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n let y: number\n if (value >= 0) { y = posY - h; posY = y }\n else { y = negY; negY = y + h }\n\n if (my >= y - 2 && my <= y + h + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n"]}
@@ -0,0 +1,130 @@
1
+ import { prepareNoAxes } from './chunk-3XVGEBR4.js';
2
+ import { path, text, group } from './chunk-3BRQGYDX.js';
3
+
4
+ // src/charts/pictorialbar/pictorialbar-type.ts
5
+ var SYMBOL_PATHS = {
6
+ circle: "M0.5,0A0.5,0.5,0,1,1,-0.5,0A0.5,0.5,0,1,1,0.5,0Z",
7
+ diamond: "M0,-0.5L0.5,0L0,-0.5L-0.5,0Z",
8
+ square: "M-0.4,-0.4L0.4,-0.4L0.4,0.4L-0.4,0.4Z",
9
+ triangle: "M0,-0.5L0.5,0.4L-0.5,0.4Z",
10
+ star: "M0,-0.5L0.15,-0.15L0.5,-0.15L0.22,0.07L0.31,0.45L0,0.22L-0.31,0.45L-0.22,0.07L-0.5,-0.15L-0.15,-0.15Z"
11
+ };
12
+ var pictorialBarChartType = {
13
+ type: "pictorialbar",
14
+ getScaleTypes() {
15
+ return { x: "categorical", y: "linear" };
16
+ },
17
+ prepareData(data, options) {
18
+ return prepareNoAxes(data, options);
19
+ },
20
+ render(ctx) {
21
+ const { data, area, theme, options } = ctx;
22
+ const nodes = [];
23
+ const series = data.series[0];
24
+ if (!series || series.values.length === 0) return nodes;
25
+ const pOpts = options;
26
+ const symbolShape = pOpts.symbol ?? "circle";
27
+ const symbolSize = pOpts.symbolSize ?? 14;
28
+ const symbolGap = pOpts.symbolGap ?? 2;
29
+ const showValues = pOpts.showValues ?? true;
30
+ const values = series.values;
31
+ const maxVal = Math.max(...values.map(Math.abs));
32
+ if (maxVal === 0) return nodes;
33
+ const barCount = values.length;
34
+ const barGap = 16;
35
+ const barWidth = Math.min(
36
+ (area.width - barGap * (barCount + 1)) / barCount,
37
+ symbolSize * 3
38
+ );
39
+ const totalWidth = barCount * barWidth + (barCount - 1) * barGap;
40
+ const startX = area.x + (area.width - totalWidth) / 2;
41
+ const symbolStep = symbolSize + symbolGap;
42
+ const maxSymbols = Math.floor((area.height - 30) / symbolStep);
43
+ for (let i = 0; i < barCount; i++) {
44
+ const val = Math.abs(values[i]);
45
+ const symbolCount = Math.max(1, Math.round(val / maxVal * maxSymbols));
46
+ const color = options.colors[i % options.colors.length];
47
+ const cx = startX + i * (barWidth + barGap) + barWidth / 2;
48
+ const barNodes = [];
49
+ for (let s = 0; s < symbolCount; s++) {
50
+ const sy = area.y + area.height - 20 - s * symbolStep - symbolSize / 2;
51
+ if (symbolShape === "circle") {
52
+ barNodes.push({
53
+ type: "circle",
54
+ cx,
55
+ cy: sy,
56
+ r: symbolSize / 2,
57
+ attrs: {
58
+ class: "chartts-pictorialbar-symbol",
59
+ fill: color,
60
+ fillOpacity: 0.85,
61
+ "data-series": 0,
62
+ "data-index": i
63
+ }
64
+ });
65
+ } else {
66
+ const symbolPath = SYMBOL_PATHS[symbolShape] ?? SYMBOL_PATHS.circle;
67
+ barNodes.push(path(symbolPath, {
68
+ class: "chartts-pictorialbar-symbol",
69
+ fill: color,
70
+ fillOpacity: 0.85,
71
+ transform: `translate(${cx},${sy}) scale(${symbolSize})`,
72
+ "data-series": 0,
73
+ "data-index": i
74
+ }));
75
+ }
76
+ }
77
+ if (showValues) {
78
+ const topY = area.y + area.height - 20 - (symbolCount - 1) * symbolStep - symbolSize;
79
+ barNodes.push(text(cx, topY - 8, String(values[i]), {
80
+ class: "chartts-pictorialbar-value",
81
+ fill: theme.textColor,
82
+ textAnchor: "middle",
83
+ dominantBaseline: "auto",
84
+ fontSize: theme.fontSizeSmall,
85
+ fontFamily: theme.fontFamily,
86
+ fontWeight: 600
87
+ }));
88
+ }
89
+ barNodes.push(text(cx, area.y + area.height - 4, String(data.labels[i] ?? `Cat ${i + 1}`), {
90
+ class: "chartts-pictorialbar-label",
91
+ fill: theme.textMuted,
92
+ textAnchor: "middle",
93
+ dominantBaseline: "auto",
94
+ fontSize: theme.fontSizeSmall,
95
+ fontFamily: theme.fontFamily
96
+ }));
97
+ nodes.push(group(barNodes, {
98
+ class: `chartts-series chartts-series-${i}`,
99
+ "data-series-name": String(data.labels[i] ?? `Cat ${i + 1}`)
100
+ }));
101
+ }
102
+ return nodes;
103
+ },
104
+ hitTest(ctx, mx, _my) {
105
+ const { data, area } = ctx;
106
+ const series = data.series[0];
107
+ if (!series || series.values.length === 0) return null;
108
+ const pOpts = ctx.options;
109
+ const symbolSize = pOpts.symbolSize ?? 14;
110
+ const barCount = series.values.length;
111
+ const barGap = 16;
112
+ const barWidth = Math.min(
113
+ (area.width - barGap * (barCount + 1)) / barCount,
114
+ symbolSize * 3
115
+ );
116
+ const totalWidth = barCount * barWidth + (barCount - 1) * barGap;
117
+ const startX = area.x + (area.width - totalWidth) / 2;
118
+ for (let i = 0; i < barCount; i++) {
119
+ const cx = startX + i * (barWidth + barGap) + barWidth / 2;
120
+ if (Math.abs(mx - cx) < barWidth / 2 + 5) {
121
+ return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) };
122
+ }
123
+ }
124
+ return null;
125
+ }
126
+ };
127
+
128
+ export { pictorialBarChartType };
129
+ //# sourceMappingURL=chunk-4VG47RLS.js.map
130
+ //# sourceMappingURL=chunk-4VG47RLS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/pictorialbar/pictorialbar-type.ts"],"names":[],"mappings":"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","file":"chunk-4VG47RLS.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\n\n/**\n * PictorialBar chart — bar chart where bars are filled with repeated symbols.\n *\n * Data convention:\n * - labels: category names\n * - series[0].values: bar values\n *\n * The bars are made of stacked symbols (circles, diamonds, or custom shapes)\n * creating a pictograph/isotype visualization.\n */\n\nexport interface PictorialBarOptions {\n /** Symbol shape. Default 'circle'. */\n symbol?: 'circle' | 'diamond' | 'square' | 'triangle' | 'star'\n /** Symbol size in px. Default 12. */\n symbolSize?: number\n /** Gap between symbols. Default 2. */\n symbolGap?: number\n /** Show value labels. Default true. */\n showValues?: boolean\n}\n\n// SVG path data for symbols (centered at 0,0, size 1x1)\nconst SYMBOL_PATHS: Record<string, string> = {\n circle: 'M0.5,0A0.5,0.5,0,1,1,-0.5,0A0.5,0.5,0,1,1,0.5,0Z',\n diamond: 'M0,-0.5L0.5,0L0,-0.5L-0.5,0Z',\n square: 'M-0.4,-0.4L0.4,-0.4L0.4,0.4L-0.4,0.4Z',\n triangle: 'M0,-0.5L0.5,0.4L-0.5,0.4Z',\n star: 'M0,-0.5L0.15,-0.15L0.5,-0.15L0.22,0.07L0.31,0.45L0,0.22L-0.31,0.45L-0.22,0.07L-0.5,-0.15L-0.15,-0.15Z',\n}\n\nexport const pictorialBarChartType: ChartTypePlugin = {\n type: 'pictorialbar',\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const pOpts = options as unknown as PictorialBarOptions\n const symbolShape = pOpts.symbol ?? 'circle'\n const symbolSize = pOpts.symbolSize ?? 14\n const symbolGap = pOpts.symbolGap ?? 2\n const showValues = pOpts.showValues ?? true\n\n const values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n if (maxVal === 0) return nodes\n\n const barCount = values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n const symbolStep = symbolSize + symbolGap\n const maxSymbols = Math.floor((area.height - 30) / symbolStep)\n\n for (let i = 0; i < barCount; i++) {\n const val = Math.abs(values[i]!)\n const symbolCount = Math.max(1, Math.round((val / maxVal) * maxSymbols))\n const color = options.colors[i % options.colors.length]!\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n const barNodes: RenderNode[] = []\n\n for (let s = 0; s < symbolCount; s++) {\n const sy = area.y + area.height - 20 - s * symbolStep - symbolSize / 2\n\n if (symbolShape === 'circle') {\n barNodes.push({\n type: 'circle',\n cx,\n cy: sy,\n r: symbolSize / 2,\n attrs: {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n },\n })\n } else {\n // Use path-based symbols\n const symbolPath = SYMBOL_PATHS[symbolShape] ?? SYMBOL_PATHS.circle!\n barNodes.push(path(symbolPath, {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n transform: `translate(${cx},${sy}) scale(${symbolSize})`,\n 'data-series': 0,\n 'data-index': i,\n }))\n }\n }\n\n // Value label above bar\n if (showValues) {\n const topY = area.y + area.height - 20 - (symbolCount - 1) * symbolStep - symbolSize\n barNodes.push(text(cx, topY - 8, String(values[i]!), {\n class: 'chartts-pictorialbar-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n // Category label below\n barNodes.push(text(cx, area.y + area.height - 4, String(data.labels[i] ?? `Cat ${i + 1}`), {\n class: 'chartts-pictorialbar-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Cat ${i + 1}`),\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 series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const pOpts = ctx.options as unknown as PictorialBarOptions\n const symbolSize = pOpts.symbolSize ?? 14\n\n const barCount = series.values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n for (let i = 0; i < barCount; i++) {\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n if (Math.abs(mx - cx) < barWidth / 2 + 5) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) }\n }\n }\n\n return null\n },\n}\n"]}
@@ -0,0 +1,68 @@
1
+ 'use strict';
2
+
3
+ var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
4
+
5
+ // src/charts/scatter/scatter-type.ts
6
+ var scatterChartType = {
7
+ type: "scatter",
8
+ getScaleTypes() {
9
+ return { x: "categorical", y: "linear" };
10
+ },
11
+ prepareData(data, options) {
12
+ return chunkXHQWWR5M_cjs.prepareData(data, options);
13
+ },
14
+ render(ctx) {
15
+ const { data, xScale, yScale, theme } = ctx;
16
+ const nodes = [];
17
+ for (const series of data.series) {
18
+ const dots = [];
19
+ for (let i = 0; i < series.values.length; i++) {
20
+ const x = xScale.map(i);
21
+ const y = yScale.map(series.values[i]);
22
+ dots.push(chunkXHQWWR5M_cjs.circle(x, y, (theme.pointRadius + 1.5) * 2.5, {
23
+ class: "chartts-dot-glow",
24
+ fill: `url(#chartts-pglow-${series.index})`
25
+ }));
26
+ dots.push(chunkXHQWWR5M_cjs.circle(x, y, theme.pointRadius + 1.5, {
27
+ class: "chartts-dot",
28
+ fill: series.color,
29
+ fillOpacity: 0.7,
30
+ stroke: series.color,
31
+ strokeWidth: 1.5,
32
+ "data-series": series.index,
33
+ "data-index": i,
34
+ tabindex: 0,
35
+ role: "img",
36
+ ariaLabel: `${series.name}: ${series.values[i]}`
37
+ }));
38
+ }
39
+ nodes.push(chunkXHQWWR5M_cjs.group(dots, {
40
+ class: `chartts-series chartts-series-${series.index}`,
41
+ "data-series-name": series.name
42
+ }));
43
+ }
44
+ return nodes;
45
+ },
46
+ hitTest(ctx, mx, my) {
47
+ const { data, xScale, yScale, theme } = ctx;
48
+ let best = null;
49
+ let bestDist = Infinity;
50
+ const hitRadius = theme.pointRadius + 8;
51
+ for (const series of data.series) {
52
+ for (let i = 0; i < series.values.length; i++) {
53
+ const x = xScale.map(i);
54
+ const y = yScale.map(series.values[i]);
55
+ const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2);
56
+ if (dist < bestDist && dist < hitRadius) {
57
+ bestDist = dist;
58
+ best = { seriesIndex: series.index, pointIndex: i, distance: dist };
59
+ }
60
+ }
61
+ }
62
+ return best;
63
+ }
64
+ };
65
+
66
+ exports.scatterChartType = scatterChartType;
67
+ //# sourceMappingURL=chunk-4YJPBUX2.cjs.map
68
+ //# sourceMappingURL=chunk-4YJPBUX2.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/scatter/scatter-type.ts"],"names":["prepareData","circle","group"],"mappings":"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","file":"chunk-4YJPBUX2.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, circle } from '../../render/tree'\n\nexport const scatterChartType: ChartTypePlugin = {\n type: 'scatter',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n for (const series of data.series) {\n const dots: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n\n // Ambient glow\n dots.push(circle(x, y, (theme.pointRadius + 1.5) * 2.5, {\n class: 'chartts-dot-glow',\n fill: `url(#chartts-pglow-${series.index})`,\n }))\n\n dots.push(circle(x, y, theme.pointRadius + 1.5, {\n class: 'chartts-dot',\n fill: series.color,\n fillOpacity: 0.7,\n stroke: series.color,\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(dots, {\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, theme } = ctx\n let best: HitResult | null = null\n let bestDist = Infinity\n const hitRadius = theme.pointRadius + 8\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist && dist < hitRadius) {\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,19 @@
1
+ 'use strict';
2
+
3
+ var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
4
+
5
+ // src/utils/prepare.ts
6
+ function prepareNoAxes(data, options) {
7
+ return chunkXHQWWR5M_cjs.prepareData(data, {
8
+ ...options,
9
+ xAxis: false,
10
+ yAxis: false,
11
+ xGrid: false,
12
+ yGrid: false,
13
+ legend: false
14
+ });
15
+ }
16
+
17
+ exports.prepareNoAxes = prepareNoAxes;
18
+ //# sourceMappingURL=chunk-5QOQR5FE.cjs.map
19
+ //# sourceMappingURL=chunk-5QOQR5FE.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/prepare.ts"],"names":["prepareData"],"mappings":";;;;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAOA,8BAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-5QOQR5FE.cjs","sourcesContent":["import type { ChartData, ResolvedOptions, PreparedData } from '../types'\nimport { prepareData } from '../data/prepare'\n\n/**\n * Prepare data with axes, grid, and legend suppressed.\n * Used by chart types that render their own layout (pie, gauge, treemap, etc.).\n */\nexport function prepareNoAxes(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n}\n"]}