@chartts/core 0.1.4 → 0.1.5

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 (359) hide show
  1. package/dist/area.cjs +10 -10
  2. package/dist/area.js +5 -5
  3. package/dist/bar.cjs +9 -9
  4. package/dist/bar.js +4 -4
  5. package/dist/baseline.cjs +9 -9
  6. package/dist/baseline.js +4 -4
  7. package/dist/boxplot.cjs +9 -9
  8. package/dist/boxplot.js +4 -4
  9. package/dist/bubble.cjs +9 -9
  10. package/dist/bubble.js +4 -4
  11. package/dist/bullet.cjs +10 -10
  12. package/dist/bullet.js +5 -5
  13. package/dist/calendar.cjs +10 -10
  14. package/dist/calendar.js +5 -5
  15. package/dist/candlestick.cjs +9 -9
  16. package/dist/candlestick.js +4 -4
  17. package/dist/chord.cjs +10 -10
  18. package/dist/chord.js +5 -5
  19. package/dist/chunk-2OWMJBRN.js +122 -0
  20. package/dist/chunk-2OWMJBRN.js.map +1 -0
  21. package/dist/{chunk-62DBXI4N.js → chunk-2VHG2N75.js} +4 -4
  22. package/dist/{chunk-62DBXI4N.js.map → chunk-2VHG2N75.js.map} +1 -1
  23. package/dist/{chunk-VJXUBN7J.js → chunk-2X7UIG3G.js} +3 -3
  24. package/dist/{chunk-VJXUBN7J.js.map → chunk-2X7UIG3G.js.map} +1 -1
  25. package/dist/{chunk-ESJMEDLY.cjs → chunk-35XUPEAD.cjs} +4 -4
  26. package/dist/{chunk-ESJMEDLY.cjs.map → chunk-35XUPEAD.cjs.map} +1 -1
  27. package/dist/{chunk-Y6CVUI6A.cjs → chunk-3HBRAGJA.cjs} +13 -13
  28. package/dist/{chunk-Y6CVUI6A.cjs.map → chunk-3HBRAGJA.cjs.map} +1 -1
  29. package/dist/{chunk-ZOEN3ARN.js → chunk-45Y77XDM.js} +3 -3
  30. package/dist/{chunk-ZOEN3ARN.js.map → chunk-45Y77XDM.js.map} +1 -1
  31. package/dist/{chunk-PCAYYCLY.cjs → chunk-47R2QUID.cjs} +10 -10
  32. package/dist/{chunk-PCAYYCLY.cjs.map → chunk-47R2QUID.cjs.map} +1 -1
  33. package/dist/{chunk-IF6RQ53Q.cjs → chunk-4C5IV57Z.cjs} +9 -9
  34. package/dist/{chunk-IF6RQ53Q.cjs.map → chunk-4C5IV57Z.cjs.map} +1 -1
  35. package/dist/{chunk-2BUIZDOB.js → chunk-4EV5UN6V.js} +3 -3
  36. package/dist/{chunk-2BUIZDOB.js.map → chunk-4EV5UN6V.js.map} +1 -1
  37. package/dist/{chunk-THHZMRFU.js → chunk-5JDHVXPE.js} +3 -3
  38. package/dist/{chunk-THHZMRFU.js.map → chunk-5JDHVXPE.js.map} +1 -1
  39. package/dist/{chunk-PKXW45G4.js → chunk-5VI5F5XA.js} +3 -3
  40. package/dist/{chunk-PKXW45G4.js.map → chunk-5VI5F5XA.js.map} +1 -1
  41. package/dist/{chunk-TEZNWW3R.cjs → chunk-64B7FGFP.cjs} +8 -8
  42. package/dist/{chunk-TEZNWW3R.cjs.map → chunk-64B7FGFP.cjs.map} +1 -1
  43. package/dist/{chunk-5HZEDCJG.js → chunk-66GE7TI3.js} +3 -3
  44. package/dist/{chunk-5HZEDCJG.js.map → chunk-66GE7TI3.js.map} +1 -1
  45. package/dist/{chunk-CWZADOJ6.js → chunk-6H34P4AG.js} +3 -3
  46. package/dist/{chunk-CWZADOJ6.js.map → chunk-6H34P4AG.js.map} +1 -1
  47. package/dist/{chunk-BGGESAAG.cjs → chunk-6KNS32OH.cjs} +7 -7
  48. package/dist/{chunk-BGGESAAG.cjs.map → chunk-6KNS32OH.cjs.map} +1 -1
  49. package/dist/{chunk-GBL4R3GH.cjs → chunk-6S2NCXNP.cjs} +6 -6
  50. package/dist/{chunk-GBL4R3GH.cjs.map → chunk-6S2NCXNP.cjs.map} +1 -1
  51. package/dist/{chunk-FVLVTY5D.cjs → chunk-6XD3VSAM.cjs} +6 -6
  52. package/dist/{chunk-FVLVTY5D.cjs.map → chunk-6XD3VSAM.cjs.map} +1 -1
  53. package/dist/{chunk-KWSVJRXX.cjs → chunk-6XWZSV6M.cjs} +4 -4
  54. package/dist/{chunk-KWSVJRXX.cjs.map → chunk-6XWZSV6M.cjs.map} +1 -1
  55. package/dist/{chunk-N35UAFEU.js → chunk-7FUQMZGT.js} +4 -4
  56. package/dist/{chunk-N35UAFEU.js.map → chunk-7FUQMZGT.js.map} +1 -1
  57. package/dist/chunk-7LZVSOZR.cjs +172 -0
  58. package/dist/chunk-7LZVSOZR.cjs.map +1 -0
  59. package/dist/{chunk-A5G32G2R.cjs → chunk-7XOK2HLV.cjs} +9 -9
  60. package/dist/{chunk-A5G32G2R.cjs.map → chunk-7XOK2HLV.cjs.map} +1 -1
  61. package/dist/{chunk-SGZUUUXU.js → chunk-ACN4JCSF.js} +4 -4
  62. package/dist/{chunk-SGZUUUXU.js.map → chunk-ACN4JCSF.js.map} +1 -1
  63. package/dist/{chunk-3NHH6C4K.cjs → chunk-AOZ47DTE.cjs} +13 -13
  64. package/dist/{chunk-3NHH6C4K.cjs.map → chunk-AOZ47DTE.cjs.map} +1 -1
  65. package/dist/{chunk-WZCES5M6.js → chunk-AYEXPYFE.js} +4 -4
  66. package/dist/{chunk-WZCES5M6.js.map → chunk-AYEXPYFE.js.map} +1 -1
  67. package/dist/{chunk-D5QUAWF3.cjs → chunk-BPXEQPZU.cjs} +10 -10
  68. package/dist/{chunk-D5QUAWF3.cjs.map → chunk-BPXEQPZU.cjs.map} +1 -1
  69. package/dist/{chunk-YZXRD6K6.cjs → chunk-BQUMYOBP.cjs} +7 -7
  70. package/dist/{chunk-YZXRD6K6.cjs.map → chunk-BQUMYOBP.cjs.map} +1 -1
  71. package/dist/{chunk-FGHSUT6X.cjs → chunk-CG4KMZRU.cjs} +6 -6
  72. package/dist/{chunk-FGHSUT6X.cjs.map → chunk-CG4KMZRU.cjs.map} +1 -1
  73. package/dist/{chunk-BFBVJ6MU.js → chunk-CLBVCWJG.js} +3 -3
  74. package/dist/{chunk-BFBVJ6MU.js.map → chunk-CLBVCWJG.js.map} +1 -1
  75. package/dist/{chunk-754Z4OR6.cjs → chunk-CVKWXLXW.cjs} +10 -10
  76. package/dist/{chunk-754Z4OR6.cjs.map → chunk-CVKWXLXW.cjs.map} +1 -1
  77. package/dist/{chunk-5E7FXDBM.js → chunk-D4RP2H6A.js} +4 -4
  78. package/dist/{chunk-5E7FXDBM.js.map → chunk-D4RP2H6A.js.map} +1 -1
  79. package/dist/{chunk-HCIBBUV5.js → chunk-DMBUUJGU.js} +3 -3
  80. package/dist/{chunk-HCIBBUV5.js.map → chunk-DMBUUJGU.js.map} +1 -1
  81. package/dist/{chunk-EWVXMQRW.js → chunk-DQAFYVCX.js} +5 -5
  82. package/dist/{chunk-EWVXMQRW.js.map → chunk-DQAFYVCX.js.map} +1 -1
  83. package/dist/{chunk-ATMSGQCW.cjs → chunk-EXA5HCX7.cjs} +9 -9
  84. package/dist/{chunk-ATMSGQCW.cjs.map → chunk-EXA5HCX7.cjs.map} +1 -1
  85. package/dist/{chunk-TLHQ6JCK.cjs → chunk-F3TVVAYG.cjs} +11 -11
  86. package/dist/{chunk-TLHQ6JCK.cjs.map → chunk-F3TVVAYG.cjs.map} +1 -1
  87. package/dist/{chunk-HCK2VUWD.cjs → chunk-FCDKWHIV.cjs} +8 -8
  88. package/dist/{chunk-HCK2VUWD.cjs.map → chunk-FCDKWHIV.cjs.map} +1 -1
  89. package/dist/{chunk-IDZTDJLH.js → chunk-FWKYNE3A.js} +3 -3
  90. package/dist/{chunk-IDZTDJLH.js.map → chunk-FWKYNE3A.js.map} +1 -1
  91. package/dist/{chunk-6QMV75NT.js → chunk-GAXX6YK5.js} +4 -4
  92. package/dist/{chunk-6QMV75NT.js.map → chunk-GAXX6YK5.js.map} +1 -1
  93. package/dist/{chunk-OMAW52LY.cjs → chunk-H2DHSBPO.cjs} +6 -6
  94. package/dist/{chunk-OMAW52LY.cjs.map → chunk-H2DHSBPO.cjs.map} +1 -1
  95. package/dist/{chunk-DX77WSIB.js → chunk-I7HB3FBC.js} +5 -5
  96. package/dist/{chunk-DX77WSIB.js.map → chunk-I7HB3FBC.js.map} +1 -1
  97. package/dist/{chunk-MJY25P44.js → chunk-IGIAGPC5.js} +3 -3
  98. package/dist/{chunk-MJY25P44.js.map → chunk-IGIAGPC5.js.map} +1 -1
  99. package/dist/{chunk-4QRND2V5.js → chunk-ILD5ZZHH.js} +3 -3
  100. package/dist/{chunk-4QRND2V5.js.map → chunk-ILD5ZZHH.js.map} +1 -1
  101. package/dist/{chunk-CU5ZXVZQ.js → chunk-IN7SCXMD.js} +4 -4
  102. package/dist/{chunk-CU5ZXVZQ.js.map → chunk-IN7SCXMD.js.map} +1 -1
  103. package/dist/chunk-IRBGJP2E.js +170 -0
  104. package/dist/chunk-IRBGJP2E.js.map +1 -0
  105. package/dist/{chunk-7GLCJPV5.js → chunk-J6A72I5K.js} +4 -4
  106. package/dist/{chunk-7GLCJPV5.js.map → chunk-J6A72I5K.js.map} +1 -1
  107. package/dist/chunk-JRTD6Y34.cjs +148 -0
  108. package/dist/chunk-JRTD6Y34.cjs.map +1 -0
  109. package/dist/{chunk-KNMEXOKJ.js → chunk-K7NVM76W.js} +4 -4
  110. package/dist/{chunk-KNMEXOKJ.js.map → chunk-K7NVM76W.js.map} +1 -1
  111. package/dist/chunk-KNUMF6K2.cjs +156 -0
  112. package/dist/chunk-KNUMF6K2.cjs.map +1 -0
  113. package/dist/chunk-KQJZJADP.js +146 -0
  114. package/dist/chunk-KQJZJADP.js.map +1 -0
  115. package/dist/{chunk-OMSHGBV3.js → chunk-KRLKDJPM.js} +4 -4
  116. package/dist/{chunk-OMSHGBV3.js.map → chunk-KRLKDJPM.js.map} +1 -1
  117. package/dist/{chunk-ZNKVOTPB.cjs → chunk-KSCMLSUI.cjs} +15 -15
  118. package/dist/{chunk-ZNKVOTPB.cjs.map → chunk-KSCMLSUI.cjs.map} +1 -1
  119. package/dist/{chunk-OTXHJHXU.cjs → chunk-KT4LY42Y.cjs} +11 -11
  120. package/dist/{chunk-OTXHJHXU.cjs.map → chunk-KT4LY42Y.cjs.map} +1 -1
  121. package/dist/chunk-KX4ZBUHB.cjs +211 -0
  122. package/dist/chunk-KX4ZBUHB.cjs.map +1 -0
  123. package/dist/{chunk-56BN43J4.js → chunk-KXJOIVL5.js} +5 -5
  124. package/dist/{chunk-56BN43J4.js.map → chunk-KXJOIVL5.js.map} +1 -1
  125. package/dist/{chunk-EPUWA3ZW.js → chunk-LFV46XLH.js} +4 -4
  126. package/dist/{chunk-EPUWA3ZW.js.map → chunk-LFV46XLH.js.map} +1 -1
  127. package/dist/{chunk-T7SCCACB.js → chunk-LKSKGQX7.js} +3 -3
  128. package/dist/{chunk-T7SCCACB.js.map → chunk-LKSKGQX7.js.map} +1 -1
  129. package/dist/{chunk-LARNENXE.cjs → chunk-LQ26WSLH.cjs} +10 -10
  130. package/dist/{chunk-LARNENXE.cjs.map → chunk-LQ26WSLH.cjs.map} +1 -1
  131. package/dist/{chunk-NRULNA5F.js → chunk-LROB73B4.js} +4 -4
  132. package/dist/{chunk-NRULNA5F.js.map → chunk-LROB73B4.js.map} +1 -1
  133. package/dist/{chunk-34DQGCPP.js → chunk-LXBBM6IF.js} +4 -4
  134. package/dist/{chunk-34DQGCPP.js.map → chunk-LXBBM6IF.js.map} +1 -1
  135. package/dist/{chunk-QPHWRD25.js → chunk-MCORUYWB.js} +3 -3
  136. package/dist/{chunk-QPHWRD25.js.map → chunk-MCORUYWB.js.map} +1 -1
  137. package/dist/{chunk-2JYK52HV.js → chunk-MJFCMUIY.js} +4 -4
  138. package/dist/{chunk-2JYK52HV.js.map → chunk-MJFCMUIY.js.map} +1 -1
  139. package/dist/{chunk-7PHOSSLJ.cjs → chunk-NHSPO4BN.cjs} +9 -9
  140. package/dist/{chunk-7PHOSSLJ.cjs.map → chunk-NHSPO4BN.cjs.map} +1 -1
  141. package/dist/{chunk-5QT67VYJ.cjs → chunk-NR5NQ6TV.cjs} +10 -10
  142. package/dist/{chunk-5QT67VYJ.cjs.map → chunk-NR5NQ6TV.cjs.map} +1 -1
  143. package/dist/{chunk-DT4GG5BF.cjs → chunk-NRMQMPUE.cjs} +7 -7
  144. package/dist/{chunk-DT4GG5BF.cjs.map → chunk-NRMQMPUE.cjs.map} +1 -1
  145. package/dist/{chunk-FGBIJ6PL.js → chunk-NW4JBVY2.js} +4 -4
  146. package/dist/{chunk-FGBIJ6PL.js.map → chunk-NW4JBVY2.js.map} +1 -1
  147. package/dist/{chunk-2QRCHYTZ.cjs → chunk-OLY33H6E.cjs} +7 -7
  148. package/dist/{chunk-2QRCHYTZ.cjs.map → chunk-OLY33H6E.cjs.map} +1 -1
  149. package/dist/{chunk-2IWLOBSF.cjs → chunk-OUQ63IJQ.cjs} +6 -6
  150. package/dist/{chunk-2IWLOBSF.cjs.map → chunk-OUQ63IJQ.cjs.map} +1 -1
  151. package/dist/{chunk-VUHNBLFA.js → chunk-PHFBF5ON.js} +3 -3
  152. package/dist/{chunk-VUHNBLFA.js.map → chunk-PHFBF5ON.js.map} +1 -1
  153. package/dist/{chunk-4MNVJVK3.cjs → chunk-PL3M46GS.cjs} +6 -6
  154. package/dist/{chunk-4MNVJVK3.cjs.map → chunk-PL3M46GS.cjs.map} +1 -1
  155. package/dist/{chunk-JYVRX3BX.cjs → chunk-PNHDHEBQ.cjs} +8 -8
  156. package/dist/{chunk-JYVRX3BX.cjs.map → chunk-PNHDHEBQ.cjs.map} +1 -1
  157. package/dist/{chunk-QYI7ZV3B.cjs → chunk-PX7MLSIH.cjs} +369 -124
  158. package/dist/chunk-PX7MLSIH.cjs.map +1 -0
  159. package/dist/{chunk-YCL43UQM.cjs → chunk-QCEC2KBW.cjs} +12 -12
  160. package/dist/{chunk-YCL43UQM.cjs.map → chunk-QCEC2KBW.cjs.map} +1 -1
  161. package/dist/{chunk-ZFGLBJYC.js → chunk-QRVTY6UU.js} +3 -3
  162. package/dist/{chunk-ZFGLBJYC.js.map → chunk-QRVTY6UU.js.map} +1 -1
  163. package/dist/chunk-QS6GR2CQ.js +154 -0
  164. package/dist/chunk-QS6GR2CQ.js.map +1 -0
  165. package/dist/{chunk-QPHUAF3R.cjs → chunk-QVQKYVD2.cjs} +8 -8
  166. package/dist/{chunk-QPHUAF3R.cjs.map → chunk-QVQKYVD2.cjs.map} +1 -1
  167. package/dist/{chunk-CUIPBYMG.cjs → chunk-RIJPMRKC.cjs} +8 -8
  168. package/dist/{chunk-CUIPBYMG.cjs.map → chunk-RIJPMRKC.cjs.map} +1 -1
  169. package/dist/{chunk-5QVUBGM7.js → chunk-RKX7GKOU.js} +4 -4
  170. package/dist/{chunk-5QVUBGM7.js.map → chunk-RKX7GKOU.js.map} +1 -1
  171. package/dist/{chunk-3SVNEKXE.cjs → chunk-ROUFAI5M.cjs} +11 -11
  172. package/dist/{chunk-3SVNEKXE.cjs.map → chunk-ROUFAI5M.cjs.map} +1 -1
  173. package/dist/{chunk-55ZTXQQQ.cjs → chunk-S52RCLDQ.cjs} +12 -12
  174. package/dist/{chunk-55ZTXQQQ.cjs.map → chunk-S52RCLDQ.cjs.map} +1 -1
  175. package/dist/{chunk-GRXHW5S3.cjs → chunk-SEOHPUXV.cjs} +12 -12
  176. package/dist/{chunk-GRXHW5S3.cjs.map → chunk-SEOHPUXV.cjs.map} +1 -1
  177. package/dist/{chunk-KHG3G2ZX.js → chunk-SI4VJK4A.js} +3 -3
  178. package/dist/{chunk-KHG3G2ZX.js.map → chunk-SI4VJK4A.js.map} +1 -1
  179. package/dist/{chunk-VGJD4F4H.js → chunk-SUB5WML4.js} +3 -3
  180. package/dist/{chunk-VGJD4F4H.js.map → chunk-SUB5WML4.js.map} +1 -1
  181. package/dist/{chunk-CA42BCSM.cjs → chunk-T5NDUMLD.cjs} +8 -8
  182. package/dist/{chunk-CA42BCSM.cjs.map → chunk-T5NDUMLD.cjs.map} +1 -1
  183. package/dist/{chunk-QEPMEEZC.cjs → chunk-TKHYY3B5.cjs} +6 -6
  184. package/dist/{chunk-QEPMEEZC.cjs.map → chunk-TKHYY3B5.cjs.map} +1 -1
  185. package/dist/{chunk-LXYNL7BI.cjs → chunk-TMQ2V5B2.cjs} +10 -10
  186. package/dist/{chunk-LXYNL7BI.cjs.map → chunk-TMQ2V5B2.cjs.map} +1 -1
  187. package/dist/{chunk-R2W3RJFW.cjs → chunk-TNIMRV3N.cjs} +13 -13
  188. package/dist/{chunk-R2W3RJFW.cjs.map → chunk-TNIMRV3N.cjs.map} +1 -1
  189. package/dist/{chunk-NQ7Y6ZKH.js → chunk-TUPPYHUR.js} +3 -3
  190. package/dist/{chunk-NQ7Y6ZKH.js.map → chunk-TUPPYHUR.js.map} +1 -1
  191. package/dist/{chunk-MSCRIA2U.cjs → chunk-U456ET3M.cjs} +12 -12
  192. package/dist/{chunk-MSCRIA2U.cjs.map → chunk-U456ET3M.cjs.map} +1 -1
  193. package/dist/{chunk-NE2W2MF3.cjs → chunk-UMS2MPYC.cjs} +10 -10
  194. package/dist/{chunk-NE2W2MF3.cjs.map → chunk-UMS2MPYC.cjs.map} +1 -1
  195. package/dist/{chunk-DAAU5H24.js → chunk-UNQBXGX5.js} +3 -3
  196. package/dist/{chunk-DAAU5H24.js.map → chunk-UNQBXGX5.js.map} +1 -1
  197. package/dist/{chunk-VBMLJUBE.js → chunk-V3AENTZB.js} +4 -4
  198. package/dist/{chunk-VBMLJUBE.js.map → chunk-V3AENTZB.js.map} +1 -1
  199. package/dist/{chunk-3JB4JBBK.js → chunk-V5LLTYOY.js} +4 -4
  200. package/dist/{chunk-3JB4JBBK.js.map → chunk-V5LLTYOY.js.map} +1 -1
  201. package/dist/chunk-VALFF4NG.cjs +124 -0
  202. package/dist/chunk-VALFF4NG.cjs.map +1 -0
  203. package/dist/{chunk-MEERXUZS.js → chunk-VJT5UA7J.js} +4 -4
  204. package/dist/{chunk-MEERXUZS.js.map → chunk-VJT5UA7J.js.map} +1 -1
  205. package/dist/{chunk-JVVGQLJQ.cjs → chunk-W626EAS5.cjs} +100 -6
  206. package/dist/chunk-W626EAS5.cjs.map +1 -0
  207. package/dist/{chunk-IOV77VHP.js → chunk-WHGNA44O.js} +4 -4
  208. package/dist/{chunk-IOV77VHP.js.map → chunk-WHGNA44O.js.map} +1 -1
  209. package/dist/{chunk-ZYXRRVR6.js → chunk-WIA4MDRX.js} +3 -3
  210. package/dist/{chunk-ZYXRRVR6.js.map → chunk-WIA4MDRX.js.map} +1 -1
  211. package/dist/{chunk-OEGSDOJ2.cjs → chunk-WOYVHVXC.cjs} +7 -7
  212. package/dist/{chunk-OEGSDOJ2.cjs.map → chunk-WOYVHVXC.cjs.map} +1 -1
  213. package/dist/{chunk-V5Q6UNUK.cjs → chunk-X5SG6MFS.cjs} +4 -4
  214. package/dist/{chunk-V5Q6UNUK.cjs.map → chunk-X5SG6MFS.cjs.map} +1 -1
  215. package/dist/{chunk-LRHMLNPW.js → chunk-XB5K7OYD.js} +353 -108
  216. package/dist/chunk-XB5K7OYD.js.map +1 -0
  217. package/dist/{chunk-AEQXFDL7.js → chunk-XIVC32HU.js} +100 -6
  218. package/dist/chunk-XIVC32HU.js.map +1 -0
  219. package/dist/{chunk-TC3H6ZED.js → chunk-XQ7BTVV3.js} +4 -4
  220. package/dist/{chunk-TC3H6ZED.js.map → chunk-XQ7BTVV3.js.map} +1 -1
  221. package/dist/{chunk-4D6PVH2C.cjs → chunk-YMOQGTGJ.cjs} +9 -9
  222. package/dist/{chunk-4D6PVH2C.cjs.map → chunk-YMOQGTGJ.cjs.map} +1 -1
  223. package/dist/{chunk-2IMUTDTD.cjs → chunk-YOK3JGW5.cjs} +10 -10
  224. package/dist/{chunk-2IMUTDTD.cjs.map → chunk-YOK3JGW5.cjs.map} +1 -1
  225. package/dist/{chunk-24557PYN.js → chunk-YUIHMAHA.js} +3 -3
  226. package/dist/{chunk-24557PYN.js.map → chunk-YUIHMAHA.js.map} +1 -1
  227. package/dist/chunk-ZBWBLCY2.js +209 -0
  228. package/dist/chunk-ZBWBLCY2.js.map +1 -0
  229. package/dist/{chunk-W476ER4X.cjs → chunk-ZCLW4B5S.cjs} +17 -17
  230. package/dist/{chunk-W476ER4X.cjs.map → chunk-ZCLW4B5S.cjs.map} +1 -1
  231. package/dist/combo.cjs +9 -9
  232. package/dist/combo.js +4 -4
  233. package/dist/custom.cjs +10 -10
  234. package/dist/custom.js +5 -5
  235. package/dist/donut.cjs +11 -11
  236. package/dist/donut.js +6 -6
  237. package/dist/dumbbell.cjs +10 -10
  238. package/dist/dumbbell.js +5 -5
  239. package/dist/funnel.cjs +10 -10
  240. package/dist/funnel.js +5 -5
  241. package/dist/gauge.cjs +10 -10
  242. package/dist/gauge.js +5 -5
  243. package/dist/geo.cjs +12 -12
  244. package/dist/geo.js +5 -5
  245. package/dist/graph-type-Cyb5U1y2.d.ts +5 -0
  246. package/dist/graph-type-DRbMI2E9.d.cts +5 -0
  247. package/dist/graph.cjs +10 -10
  248. package/dist/graph.d.cts +1 -1
  249. package/dist/graph.d.ts +1 -1
  250. package/dist/graph.js +5 -5
  251. package/dist/heatmap.cjs +10 -10
  252. package/dist/heatmap.js +5 -5
  253. package/dist/histogram.cjs +9 -9
  254. package/dist/histogram.js +4 -4
  255. package/dist/horizontal-bar.cjs +9 -9
  256. package/dist/horizontal-bar.js +4 -4
  257. package/dist/index.cjs +242 -192
  258. package/dist/index.cjs.map +1 -1
  259. package/dist/index.d.cts +12 -2
  260. package/dist/index.d.ts +12 -2
  261. package/dist/index.js +123 -93
  262. package/dist/index.js.map +1 -1
  263. package/dist/kagi.cjs +10 -10
  264. package/dist/kagi.js +5 -5
  265. package/dist/line.cjs +9 -9
  266. package/dist/line.js +4 -4
  267. package/dist/lines.cjs +10 -10
  268. package/dist/lines.js +5 -5
  269. package/dist/lollipop.cjs +9 -9
  270. package/dist/lollipop.js +4 -4
  271. package/dist/matrix.cjs +10 -10
  272. package/dist/matrix.js +5 -5
  273. package/dist/ohlc.cjs +9 -9
  274. package/dist/ohlc.js +4 -4
  275. package/dist/pack-type-CdtdkPBR.d.cts +10 -0
  276. package/dist/pack-type-Dm27RLC-.d.ts +10 -0
  277. package/dist/pack.cjs +33 -0
  278. package/dist/pack.cjs.map +1 -0
  279. package/dist/pack.d.cts +8 -0
  280. package/dist/pack.d.ts +8 -0
  281. package/dist/pack.js +12 -0
  282. package/dist/pack.js.map +1 -0
  283. package/dist/parallel.cjs +10 -10
  284. package/dist/parallel.js +5 -5
  285. package/dist/pictorialbar.cjs +10 -10
  286. package/dist/pictorialbar.js +5 -5
  287. package/dist/pie.cjs +11 -11
  288. package/dist/pie.js +6 -6
  289. package/dist/pillar-type-CIcSuZdu.d.cts +11 -0
  290. package/dist/pillar-type-DNpR_98h.d.ts +11 -0
  291. package/dist/pillar.cjs +33 -0
  292. package/dist/pillar.cjs.map +1 -0
  293. package/dist/pillar.d.cts +8 -0
  294. package/dist/pillar.d.ts +8 -0
  295. package/dist/pillar.js +12 -0
  296. package/dist/pillar.js.map +1 -0
  297. package/dist/polar.cjs +11 -11
  298. package/dist/polar.js +6 -6
  299. package/dist/radar.cjs +10 -10
  300. package/dist/radar.js +5 -5
  301. package/dist/radialbar.cjs +10 -10
  302. package/dist/radialbar.js +5 -5
  303. package/dist/range.cjs +9 -9
  304. package/dist/range.js +4 -4
  305. package/dist/renko.cjs +10 -10
  306. package/dist/renko.js +5 -5
  307. package/dist/sankey.cjs +10 -10
  308. package/dist/sankey.js +5 -5
  309. package/dist/scatter.cjs +9 -9
  310. package/dist/scatter.js +4 -4
  311. package/dist/sparkline.cjs +9 -9
  312. package/dist/sparkline.js +4 -4
  313. package/dist/stacked-bar.cjs +9 -9
  314. package/dist/stacked-bar.js +4 -4
  315. package/dist/step.cjs +10 -10
  316. package/dist/step.js +5 -5
  317. package/dist/sunburst.cjs +11 -11
  318. package/dist/sunburst.js +6 -6
  319. package/dist/themeriver.cjs +10 -10
  320. package/dist/themeriver.js +5 -5
  321. package/dist/tree.cjs +10 -10
  322. package/dist/tree.js +5 -5
  323. package/dist/treemap.cjs +10 -10
  324. package/dist/treemap.js +5 -5
  325. package/dist/violin-type-6KmTiJNp.d.cts +5 -0
  326. package/dist/violin-type-BOmiulQc.d.ts +5 -0
  327. package/dist/violin.cjs +33 -0
  328. package/dist/violin.cjs.map +1 -0
  329. package/dist/violin.d.cts +8 -0
  330. package/dist/violin.d.ts +8 -0
  331. package/dist/violin.js +12 -0
  332. package/dist/violin.js.map +1 -0
  333. package/dist/volume.cjs +9 -9
  334. package/dist/volume.js +4 -4
  335. package/dist/voronoi-type-BU5WnrcT.d.cts +12 -0
  336. package/dist/voronoi-type-D7n4mFNp.d.ts +12 -0
  337. package/dist/voronoi.cjs +33 -0
  338. package/dist/voronoi.cjs.map +1 -0
  339. package/dist/voronoi.d.cts +8 -0
  340. package/dist/voronoi.d.ts +8 -0
  341. package/dist/voronoi.js +12 -0
  342. package/dist/voronoi.js.map +1 -0
  343. package/dist/waterfall.cjs +9 -9
  344. package/dist/waterfall.js +4 -4
  345. package/dist/wordcloud-type-C6X9ORRR.d.ts +11 -0
  346. package/dist/wordcloud-type-CCm8rWK7.d.cts +11 -0
  347. package/dist/wordcloud.cjs +33 -0
  348. package/dist/wordcloud.cjs.map +1 -0
  349. package/dist/wordcloud.d.cts +8 -0
  350. package/dist/wordcloud.d.ts +8 -0
  351. package/dist/wordcloud.js +12 -0
  352. package/dist/wordcloud.js.map +1 -0
  353. package/package.json +1 -1
  354. package/dist/chunk-AEQXFDL7.js.map +0 -1
  355. package/dist/chunk-JVVGQLJQ.cjs.map +0 -1
  356. package/dist/chunk-LRHMLNPW.js.map +0 -1
  357. package/dist/chunk-QYI7ZV3B.cjs.map +0 -1
  358. package/dist/graph-type-Bg04GFeS.d.ts +0 -15
  359. package/dist/graph-type-DF-vww8T.d.cts +0 -15
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
- import { text, rect, group } from './chunk-AEQXFDL7.js';
1
+ import { prepareNoAxes } from './chunk-LKSKGQX7.js';
2
+ import { text, rect, group } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/calendar/calendar-type.ts
5
5
  var calendarChartType = {
@@ -109,5 +109,5 @@ function interpolateOpacity(hexColor, t) {
109
109
  }
110
110
 
111
111
  export { calendarChartType };
112
- //# sourceMappingURL=chunk-CU5ZXVZQ.js.map
113
- //# sourceMappingURL=chunk-CU5ZXVZQ.js.map
112
+ //# sourceMappingURL=chunk-IN7SCXMD.js.map
113
+ //# sourceMappingURL=chunk-IN7SCXMD.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/calendar/calendar-type.ts"],"names":[],"mappings":"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","file":"chunk-CU5ZXVZQ.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Calendar heatmap — GitHub-style contribution grid.\n *\n * Data format:\n * - labels: dates as strings (YYYY-MM-DD) or numbers (day index)\n * - series[0]: values for each day (intensity)\n *\n * Renders a 7-row (days of week) x N-column (weeks) grid.\n * If labels aren't dates, treats data as a flat grid: 7 rows.\n */\nexport const calendarChartType: ChartTypePlugin = {\n type: 'calendar',\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 values = series.values\n const count = values.length\n const rows = 7 // days of week\n const cols = Math.ceil(count / rows)\n\n let maxVal = 0\n for (const v of values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (maxVal === 0) maxVal = 1\n\n // Day labels\n const dayLabels = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW // square cells\n const gap = Math.max(1, cellW * 0.12)\n\n const color = options.colors[0] ?? '#10b981'\n\n // Day-of-week labels\n for (let r = 0; r < rows; r++) {\n if (r % 2 === 0) { // show Mon, Wed, Fri, Sun\n nodes.push(text(area.x + labelW - 4, area.y + r * (cellH + gap) + cellH / 2, dayLabels[r]!, {\n class: 'chartts-calendar-daylabel',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall * 0.8, cellH * 0.6),\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n // Cells\n for (let idx = 0; idx < count; idx++) {\n const col = Math.floor(idx / rows)\n const row = idx % rows\n const val = Math.abs(values[idx]!)\n const intensity = val / maxVal\n\n const x = gridX + col * (cellW + gap)\n const y = area.y + row * (cellH + gap)\n\n const cellColor = intensity === 0\n ? (theme.gridColor ?? '#e5e7eb')\n : interpolateOpacity(color, intensity)\n\n const cellNodes: RenderNode[] = [\n rect(x, y, cellW, cellH, {\n class: 'chartts-calendar-cell',\n fill: cellColor,\n rx: 3,\n ry: 3,\n 'data-series': 0,\n 'data-index': idx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[idx] ?? `Day ${idx + 1}`}: ${values[idx]}`,\n }),\n ]\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${idx}`,\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 count = series.values.length\n const rows = 7\n const cols = Math.ceil(count / rows)\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW\n const gap = Math.max(1, cellW * 0.12)\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - area.y) / (cellH + gap))\n\n if (col < 0 || col >= cols || row < 0 || row >= rows) return null\n\n const idx = col * rows + row\n if (idx >= count) return null\n\n // Check if actually within the cell bounds\n const cellX = gridX + col * (cellW + gap)\n const cellY = area.y + row * (cellH + gap)\n if (mx >= cellX && mx <= cellX + cellW && my >= cellY && my <= cellY + cellH) {\n return { seriesIndex: 0, pointIndex: idx, distance: 0, x: cellX + cellW / 2, y: cellY + cellH / 2 }\n }\n\n return null\n },\n}\n\nfunction interpolateOpacity(hexColor: string, t: number): string {\n // Parse hex\n const hex = hexColor.replace('#', '')\n const r = parseInt(hex.substring(0, 2), 16)\n const g = parseInt(hex.substring(2, 4), 16)\n const b = parseInt(hex.substring(4, 6), 16)\n\n // Blend with a minimum opacity of 0.15 up to 1.0\n const alpha = 0.15 + t * 0.85\n return `rgba(${r},${g},${b},${alpha})`\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/calendar/calendar-type.ts"],"names":[],"mappings":"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","file":"chunk-IN7SCXMD.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Calendar heatmap — GitHub-style contribution grid.\n *\n * Data format:\n * - labels: dates as strings (YYYY-MM-DD) or numbers (day index)\n * - series[0]: values for each day (intensity)\n *\n * Renders a 7-row (days of week) x N-column (weeks) grid.\n * If labels aren't dates, treats data as a flat grid: 7 rows.\n */\nexport const calendarChartType: ChartTypePlugin = {\n type: 'calendar',\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 values = series.values\n const count = values.length\n const rows = 7 // days of week\n const cols = Math.ceil(count / rows)\n\n let maxVal = 0\n for (const v of values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (maxVal === 0) maxVal = 1\n\n // Day labels\n const dayLabels = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW // square cells\n const gap = Math.max(1, cellW * 0.12)\n\n const color = options.colors[0] ?? '#10b981'\n\n // Day-of-week labels\n for (let r = 0; r < rows; r++) {\n if (r % 2 === 0) { // show Mon, Wed, Fri, Sun\n nodes.push(text(area.x + labelW - 4, area.y + r * (cellH + gap) + cellH / 2, dayLabels[r]!, {\n class: 'chartts-calendar-daylabel',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall * 0.8, cellH * 0.6),\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n // Cells\n for (let idx = 0; idx < count; idx++) {\n const col = Math.floor(idx / rows)\n const row = idx % rows\n const val = Math.abs(values[idx]!)\n const intensity = val / maxVal\n\n const x = gridX + col * (cellW + gap)\n const y = area.y + row * (cellH + gap)\n\n const cellColor = intensity === 0\n ? (theme.gridColor ?? '#e5e7eb')\n : interpolateOpacity(color, intensity)\n\n const cellNodes: RenderNode[] = [\n rect(x, y, cellW, cellH, {\n class: 'chartts-calendar-cell',\n fill: cellColor,\n rx: 3,\n ry: 3,\n 'data-series': 0,\n 'data-index': idx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[idx] ?? `Day ${idx + 1}`}: ${values[idx]}`,\n }),\n ]\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${idx}`,\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 count = series.values.length\n const rows = 7\n const cols = Math.ceil(count / rows)\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW\n const gap = Math.max(1, cellW * 0.12)\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - area.y) / (cellH + gap))\n\n if (col < 0 || col >= cols || row < 0 || row >= rows) return null\n\n const idx = col * rows + row\n if (idx >= count) return null\n\n // Check if actually within the cell bounds\n const cellX = gridX + col * (cellW + gap)\n const cellY = area.y + row * (cellH + gap)\n if (mx >= cellX && mx <= cellX + cellW && my >= cellY && my <= cellY + cellH) {\n return { seriesIndex: 0, pointIndex: idx, distance: 0, x: cellX + cellW / 2, y: cellY + cellH / 2 }\n }\n\n return null\n },\n}\n\nfunction interpolateOpacity(hexColor: string, t: number): string {\n // Parse hex\n const hex = hexColor.replace('#', '')\n const r = parseInt(hex.substring(0, 2), 16)\n const g = parseInt(hex.substring(2, 4), 16)\n const b = parseInt(hex.substring(4, 6), 16)\n\n // Blend with a minimum opacity of 0.15 up to 1.0\n const alpha = 0.15 + t * 0.85\n return `rgba(${r},${g},${b},${alpha})`\n}\n"]}
@@ -0,0 +1,170 @@
1
+ import { getBandwidth } from './chunk-E6PR75X7.js';
2
+ import { path, rect, line, group, prepareData } from './chunk-XIVC32HU.js';
3
+
4
+ // src/charts/violin/violin-type.ts
5
+ var violinChartType = {
6
+ type: "violin",
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 vOpts = options;
31
+ const widthRatio = vOpts.violinWidth ?? 0.7;
32
+ const showBox = vOpts.showBox !== false;
33
+ const bw = getBandwidth(xScale);
34
+ const halfW = bw * widthRatio / 2;
35
+ for (let i = 0; i < data.labels.length; i++) {
36
+ let vals;
37
+ if (data.series.length === 5 && data.series[0].values.length === data.labels.length) {
38
+ vals = [
39
+ data.series[0].values[i],
40
+ data.series[1].values[i],
41
+ data.series[2].values[i],
42
+ data.series[3].values[i],
43
+ data.series[4].values[i]
44
+ ];
45
+ } else if (data.series.length === 1) {
46
+ const s = data.series[0];
47
+ if (s.values.length >= (i + 1) * 5) {
48
+ vals = s.values.slice(i * 5, i * 5 + 5);
49
+ } else continue;
50
+ } else if (data.series.length > i && data.series[i].values.length >= 5) {
51
+ vals = data.series[i].values.slice(0, 5);
52
+ } else continue;
53
+ const [vMin, q1, median, q3, vMax] = vals;
54
+ const cx = xScale.map(i);
55
+ const color = options.colors[i % options.colors.length];
56
+ const seriesIdx = Math.min(i, data.series.length - 1);
57
+ const steps = 32;
58
+ const range = vMax - vMin || 1;
59
+ const densities = [];
60
+ let maxDensity = 0;
61
+ for (let s = 0; s <= steps; s++) {
62
+ const v = vMin + s / steps * range;
63
+ const dQ1 = gaussianKernel(v, q1, range * 0.15);
64
+ const dMed = gaussianKernel(v, median, range * 0.12);
65
+ const dQ3 = gaussianKernel(v, q3, range * 0.15);
66
+ const dMin = gaussianKernel(v, vMin, range * 0.08);
67
+ const dMax = gaussianKernel(v, vMax, range * 0.08);
68
+ const density = dMin * 0.3 + dQ1 * 1 + dMed * 1.5 + dQ3 * 1 + dMax * 0.3;
69
+ densities.push(density);
70
+ if (density > maxDensity) maxDensity = density;
71
+ }
72
+ if (maxDensity === 0) continue;
73
+ const rightPoints = [];
74
+ const leftPoints = [];
75
+ for (let s = 0; s <= steps; s++) {
76
+ const v = vMin + s / steps * range;
77
+ const py = yScale.map(v);
78
+ const w = densities[s] / maxDensity * halfW;
79
+ if (s === 0) rightPoints.push(`M ${cx + w} ${py}`);
80
+ else rightPoints.push(`L ${cx + w} ${py}`);
81
+ leftPoints.unshift(`L ${cx - w} ${py}`);
82
+ }
83
+ const d = rightPoints.join(" ") + " " + leftPoints.join(" ") + " Z";
84
+ const violinNodes = [];
85
+ violinNodes.push(path(d, {
86
+ class: "chartts-violin-shape",
87
+ fill: color,
88
+ fillOpacity: 0.3,
89
+ stroke: color,
90
+ strokeWidth: 1.5,
91
+ style: `--chartts-i:${i}`,
92
+ "data-series": seriesIdx,
93
+ "data-index": i,
94
+ tabindex: 0,
95
+ role: "img",
96
+ ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`
97
+ }));
98
+ if (showBox) {
99
+ const yQ1 = yScale.map(q1);
100
+ const yQ3 = yScale.map(q3);
101
+ const boxTop = Math.min(yQ1, yQ3);
102
+ const boxH = Math.abs(yQ3 - yQ1);
103
+ const boxW = halfW * 0.3;
104
+ violinNodes.push(rect(cx - boxW, boxTop, boxW * 2, boxH, {
105
+ class: "chartts-violin-box",
106
+ fill: color,
107
+ fillOpacity: 0.5,
108
+ stroke: color,
109
+ strokeWidth: 1,
110
+ rx: 2
111
+ }));
112
+ const yMed = yScale.map(median);
113
+ violinNodes.push(line(cx - boxW, yMed, cx + boxW, yMed, {
114
+ class: "chartts-violin-median",
115
+ stroke: "#fff",
116
+ strokeWidth: 2
117
+ }));
118
+ }
119
+ nodes.push(group(violinNodes, {
120
+ class: `chartts-series chartts-series-${i}`,
121
+ "data-series-name": String(data.labels[i])
122
+ }));
123
+ }
124
+ return nodes;
125
+ },
126
+ hitTest(ctx, mx, my) {
127
+ const { data, xScale, yScale, options } = ctx;
128
+ if (data.labels.length === 0) return null;
129
+ const vOpts = options;
130
+ const widthRatio = vOpts.violinWidth ?? 0.7;
131
+ const bw = getBandwidth(xScale);
132
+ const halfW = bw * widthRatio / 2;
133
+ for (let i = 0; i < data.labels.length; i++) {
134
+ let vals;
135
+ if (data.series.length === 5 && data.series[0].values.length === data.labels.length) {
136
+ vals = [
137
+ data.series[0].values[i],
138
+ data.series[1].values[i],
139
+ data.series[2].values[i],
140
+ data.series[3].values[i],
141
+ data.series[4].values[i]
142
+ ];
143
+ } else if (data.series.length === 1) {
144
+ const s = data.series[0];
145
+ if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5);
146
+ else continue;
147
+ } else if (data.series.length > i && data.series[i].values.length >= 5) {
148
+ vals = data.series[i].values.slice(0, 5);
149
+ } else continue;
150
+ const cx = xScale.map(i);
151
+ const yMin = yScale.map(vals[0]);
152
+ const yMax = yScale.map(vals[4]);
153
+ const top = Math.min(yMin, yMax);
154
+ const bottom = Math.max(yMin, yMax);
155
+ if (mx >= cx - halfW - 4 && mx <= cx + halfW + 4 && my >= top - 4 && my <= bottom + 4) {
156
+ const seriesIdx = Math.min(i, data.series.length - 1);
157
+ return { seriesIndex: seriesIdx, pointIndex: i, distance: 0, x: cx, y: yScale.map(vals[2]) };
158
+ }
159
+ }
160
+ return null;
161
+ }
162
+ };
163
+ function gaussianKernel(x, mu, sigma) {
164
+ const z = (x - mu) / sigma;
165
+ return Math.exp(-0.5 * z * z);
166
+ }
167
+
168
+ export { violinChartType };
169
+ //# sourceMappingURL=chunk-IRBGJP2E.js.map
170
+ //# sourceMappingURL=chunk-IRBGJP2E.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/violin/violin-type.ts"],"names":[],"mappings":"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","file":"chunk-IRBGJP2E.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, line, rect } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Violin chart — shows the full distribution shape for each category.\n *\n * Data format: same as boxplot — single series with N*5 values per label:\n * [min, Q1, median, Q3, max] repeated per category.\n *\n * Additionally accepts raw sample values via options.violin.samples\n * for true KDE computation. Falls back to a smooth approximation\n * from the 5-number summary when samples aren't provided.\n */\nexport interface ViolinOptions {\n /** KDE bandwidth (smoothing). Default 0.3 of data range. */\n bandwidth?: number\n /** Show inner box + median line. Default true. */\n showBox?: boolean\n /** Width ratio relative to band. Default 0.7. */\n violinWidth?: number\n}\n\nexport const violinChartType: ChartTypePlugin = {\n type: 'violin',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\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 const padded: string[] = (data.labels ?? []).map(String)\n while (padded.length < valLen) padded.push('')\n syntheticData.labels = padded\n }\n const prepared = prepareData(syntheticData, options)\n if (data.labels && data.labels.length < valLen) {\n prepared.labels = [...data.labels]\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 if (seriesCount === 0) return nodes\n\n const vOpts = options as unknown as ViolinOptions\n const widthRatio = vOpts.violinWidth ?? 0.7\n const showBox = vOpts.showBox !== false\n\n const bw = getBandwidth(xScale)\n const halfW = (bw * widthRatio) / 2\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 5 && data.series[0]!.values.length === data.labels.length) {\n // Boxplot format: 5 series (Min, Q1, Median, Q3, Max), each with one value per label\n vals = [\n data.series[0]!.values[i]!,\n data.series[1]!.values[i]!,\n data.series[2]!.values[i]!,\n data.series[3]!.values[i]!,\n data.series[4]!.values[i]!,\n ]\n } else 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 color = options.colors[i % options.colors.length]!\n const seriesIdx = Math.min(i, data.series.length - 1)\n\n // Generate KDE-like density profile from 5-number summary\n const steps = 32\n const range = vMax - vMin || 1\n const densities: number[] = []\n let maxDensity = 0\n\n for (let s = 0; s <= steps; s++) {\n const v = vMin + (s / steps) * range\n // Approximate density using a smooth curve peaked at the median\n // with mass concentrated between Q1 and Q3\n const dQ1 = gaussianKernel(v, q1, range * 0.15)\n const dMed = gaussianKernel(v, median, range * 0.12)\n const dQ3 = gaussianKernel(v, q3, range * 0.15)\n const dMin = gaussianKernel(v, vMin, range * 0.08)\n const dMax = gaussianKernel(v, vMax, range * 0.08)\n const density = dMin * 0.3 + dQ1 * 1.0 + dMed * 1.5 + dQ3 * 1.0 + dMax * 0.3\n densities.push(density)\n if (density > maxDensity) maxDensity = density\n }\n\n if (maxDensity === 0) continue\n\n // Build mirrored violin path\n const rightPoints: string[] = []\n const leftPoints: string[] = []\n\n for (let s = 0; s <= steps; s++) {\n const v = vMin + (s / steps) * range\n const py = yScale.map(v)\n const w = (densities[s]! / maxDensity) * halfW\n\n if (s === 0) rightPoints.push(`M ${cx + w} ${py}`)\n else rightPoints.push(`L ${cx + w} ${py}`)\n\n leftPoints.unshift(`L ${cx - w} ${py}`)\n }\n\n const d = rightPoints.join(' ') + ' ' + leftPoints.join(' ') + ' Z'\n\n const violinNodes: RenderNode[] = []\n\n violinNodes.push(path(d, {\n class: 'chartts-violin-shape',\n fill: color,\n fillOpacity: 0.3,\n stroke: color,\n strokeWidth: 1.5,\n style: `--chartts-i:${i}`,\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 if (showBox) {\n // Inner IQR box\n const yQ1 = yScale.map(q1)\n const yQ3 = yScale.map(q3)\n const boxTop = Math.min(yQ1, yQ3)\n const boxH = Math.abs(yQ3 - yQ1)\n const boxW = halfW * 0.3\n\n violinNodes.push(rect(cx - boxW, boxTop, boxW * 2, boxH, {\n class: 'chartts-violin-box',\n fill: color,\n fillOpacity: 0.5,\n stroke: color,\n strokeWidth: 1,\n rx: 2,\n }))\n\n // Median line\n const yMed = yScale.map(median)\n violinNodes.push(line(cx - boxW, yMed, cx + boxW, yMed, {\n class: 'chartts-violin-median',\n stroke: '#fff',\n strokeWidth: 2,\n }))\n }\n\n nodes.push(group(violinNodes, {\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 vOpts = options as unknown as ViolinOptions\n const widthRatio = vOpts.violinWidth ?? 0.7\n const bw = getBandwidth(xScale)\n const halfW = (bw * widthRatio) / 2\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 5 && data.series[0]!.values.length === data.labels.length) {\n vals = [\n data.series[0]!.values[i]!,\n data.series[1]!.values[i]!,\n data.series[2]!.values[i]!,\n data.series[3]!.values[i]!,\n data.series[4]!.values[i]!,\n ]\n } else 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 const top = Math.min(yMin, yMax)\n const bottom = Math.max(yMin, yMax)\n\n if (mx >= cx - halfW - 4 && mx <= cx + halfW + 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, x: cx, y: yScale.map(vals[2]!) }\n }\n }\n\n return null\n },\n}\n\nfunction gaussianKernel(x: number, mu: number, sigma: number): number {\n const z = (x - mu) / sigma\n return Math.exp(-0.5 * z * z)\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
- import { path, text, group, circle, rect } from './chunk-AEQXFDL7.js';
1
+ import { prepareNoAxes } from './chunk-LKSKGQX7.js';
2
+ import { path, text, group, circle, rect } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/geo/world-regions.ts
5
5
  var WORLD_REGIONS = [
@@ -512,5 +512,5 @@ function getPathBBox(d) {
512
512
  }
513
513
 
514
514
  export { WORLD_REGIONS, WORLD_SIMPLE, geoChartType };
515
- //# sourceMappingURL=chunk-7GLCJPV5.js.map
516
- //# sourceMappingURL=chunk-7GLCJPV5.js.map
515
+ //# sourceMappingURL=chunk-J6A72I5K.js.map
516
+ //# sourceMappingURL=chunk-J6A72I5K.js.map