@chartts/core 0.1.3 → 0.1.4

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 (291) 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-XKERO5K2.js → chunk-24557PYN.js} +3 -3
  20. package/dist/{chunk-XKERO5K2.js.map → chunk-24557PYN.js.map} +1 -1
  21. package/dist/{chunk-5YNIOIKK.js → chunk-2BUIZDOB.js} +3 -3
  22. package/dist/{chunk-5YNIOIKK.js.map → chunk-2BUIZDOB.js.map} +1 -1
  23. package/dist/{chunk-EHKHXQ46.cjs → chunk-2IMUTDTD.cjs} +10 -10
  24. package/dist/{chunk-EHKHXQ46.cjs.map → chunk-2IMUTDTD.cjs.map} +1 -1
  25. package/dist/{chunk-7ZPHLIFP.cjs → chunk-2IWLOBSF.cjs} +6 -6
  26. package/dist/{chunk-7ZPHLIFP.cjs.map → chunk-2IWLOBSF.cjs.map} +1 -1
  27. package/dist/{chunk-F5AOBHQY.js → chunk-2JYK52HV.js} +4 -4
  28. package/dist/{chunk-F5AOBHQY.js.map → chunk-2JYK52HV.js.map} +1 -1
  29. package/dist/{chunk-WVQVGQJO.cjs → chunk-2QRCHYTZ.cjs} +7 -7
  30. package/dist/{chunk-WVQVGQJO.cjs.map → chunk-2QRCHYTZ.cjs.map} +1 -1
  31. package/dist/{chunk-XWCY67K5.js → chunk-34DQGCPP.js} +4 -4
  32. package/dist/{chunk-XWCY67K5.js.map → chunk-34DQGCPP.js.map} +1 -1
  33. package/dist/{chunk-5J26EN5I.js → chunk-3JB4JBBK.js} +4 -4
  34. package/dist/{chunk-5J26EN5I.js.map → chunk-3JB4JBBK.js.map} +1 -1
  35. package/dist/{chunk-EHNX3MG3.cjs → chunk-3NHH6C4K.cjs} +13 -13
  36. package/dist/{chunk-EHNX3MG3.cjs.map → chunk-3NHH6C4K.cjs.map} +1 -1
  37. package/dist/{chunk-ECB3UPTC.cjs → chunk-3SVNEKXE.cjs} +11 -11
  38. package/dist/{chunk-ECB3UPTC.cjs.map → chunk-3SVNEKXE.cjs.map} +1 -1
  39. package/dist/{chunk-BYB3LQAT.cjs → chunk-4D6PVH2C.cjs} +9 -9
  40. package/dist/{chunk-BYB3LQAT.cjs.map → chunk-4D6PVH2C.cjs.map} +1 -1
  41. package/dist/{chunk-NG7DRWWT.cjs → chunk-4MNVJVK3.cjs} +6 -6
  42. package/dist/{chunk-NG7DRWWT.cjs.map → chunk-4MNVJVK3.cjs.map} +1 -1
  43. package/dist/{chunk-RQJRVKAH.js → chunk-4QRND2V5.js} +3 -3
  44. package/dist/{chunk-RQJRVKAH.js.map → chunk-4QRND2V5.js.map} +1 -1
  45. package/dist/{chunk-NGKUI7XE.cjs → chunk-55ZTXQQQ.cjs} +12 -12
  46. package/dist/{chunk-NGKUI7XE.cjs.map → chunk-55ZTXQQQ.cjs.map} +1 -1
  47. package/dist/{chunk-2MWA7H6J.js → chunk-56BN43J4.js} +5 -5
  48. package/dist/{chunk-2MWA7H6J.js.map → chunk-56BN43J4.js.map} +1 -1
  49. package/dist/{chunk-RJIPFWW7.js → chunk-5E7FXDBM.js} +4 -4
  50. package/dist/{chunk-RJIPFWW7.js.map → chunk-5E7FXDBM.js.map} +1 -1
  51. package/dist/{chunk-ILCWDAKD.js → chunk-5HZEDCJG.js} +3 -3
  52. package/dist/{chunk-ILCWDAKD.js.map → chunk-5HZEDCJG.js.map} +1 -1
  53. package/dist/{chunk-DKXW2FQC.cjs → chunk-5QT67VYJ.cjs} +10 -10
  54. package/dist/{chunk-DKXW2FQC.cjs.map → chunk-5QT67VYJ.cjs.map} +1 -1
  55. package/dist/{chunk-XE5ZYFGM.js → chunk-5QVUBGM7.js} +4 -4
  56. package/dist/{chunk-XE5ZYFGM.js.map → chunk-5QVUBGM7.js.map} +1 -1
  57. package/dist/{chunk-DR5MQC3W.js → chunk-62DBXI4N.js} +4 -4
  58. package/dist/{chunk-DR5MQC3W.js.map → chunk-62DBXI4N.js.map} +1 -1
  59. package/dist/{chunk-HMB2RIEE.js → chunk-6QMV75NT.js} +4 -4
  60. package/dist/{chunk-HMB2RIEE.js.map → chunk-6QMV75NT.js.map} +1 -1
  61. package/dist/{chunk-OUN3MWRQ.cjs → chunk-754Z4OR6.cjs} +10 -10
  62. package/dist/{chunk-OUN3MWRQ.cjs.map → chunk-754Z4OR6.cjs.map} +1 -1
  63. package/dist/{chunk-3SOKHPAO.js → chunk-7GLCJPV5.js} +4 -4
  64. package/dist/{chunk-3SOKHPAO.js.map → chunk-7GLCJPV5.js.map} +1 -1
  65. package/dist/{chunk-PQCHNZHM.cjs → chunk-7PHOSSLJ.cjs} +9 -9
  66. package/dist/{chunk-PQCHNZHM.cjs.map → chunk-7PHOSSLJ.cjs.map} +1 -1
  67. package/dist/{chunk-VBEZS3Q4.cjs → chunk-A5G32G2R.cjs} +9 -9
  68. package/dist/{chunk-VBEZS3Q4.cjs.map → chunk-A5G32G2R.cjs.map} +1 -1
  69. package/dist/{chunk-DX4FBN3I.js → chunk-AEQXFDL7.js} +14 -9
  70. package/dist/chunk-AEQXFDL7.js.map +1 -0
  71. package/dist/{chunk-RHTVKBRC.cjs → chunk-ATMSGQCW.cjs} +9 -9
  72. package/dist/{chunk-RHTVKBRC.cjs.map → chunk-ATMSGQCW.cjs.map} +1 -1
  73. package/dist/{chunk-2ITF366P.js → chunk-BFBVJ6MU.js} +3 -3
  74. package/dist/{chunk-2ITF366P.js.map → chunk-BFBVJ6MU.js.map} +1 -1
  75. package/dist/{chunk-E43H3A3G.cjs → chunk-BGGESAAG.cjs} +7 -7
  76. package/dist/{chunk-E43H3A3G.cjs.map → chunk-BGGESAAG.cjs.map} +1 -1
  77. package/dist/{chunk-R6ZDSXN7.cjs → chunk-CA42BCSM.cjs} +8 -8
  78. package/dist/{chunk-R6ZDSXN7.cjs.map → chunk-CA42BCSM.cjs.map} +1 -1
  79. package/dist/{chunk-FV7R2LLD.js → chunk-CU5ZXVZQ.js} +4 -4
  80. package/dist/{chunk-FV7R2LLD.js.map → chunk-CU5ZXVZQ.js.map} +1 -1
  81. package/dist/{chunk-JNQ4NL3R.cjs → chunk-CUIPBYMG.cjs} +8 -8
  82. package/dist/{chunk-JNQ4NL3R.cjs.map → chunk-CUIPBYMG.cjs.map} +1 -1
  83. package/dist/{chunk-CCMLOCTH.js → chunk-CWZADOJ6.js} +3 -3
  84. package/dist/{chunk-CCMLOCTH.js.map → chunk-CWZADOJ6.js.map} +1 -1
  85. package/dist/{chunk-FZIBM3G5.cjs → chunk-D5QUAWF3.cjs} +10 -10
  86. package/dist/{chunk-FZIBM3G5.cjs.map → chunk-D5QUAWF3.cjs.map} +1 -1
  87. package/dist/{chunk-YZQROIJY.js → chunk-DAAU5H24.js} +3 -3
  88. package/dist/{chunk-YZQROIJY.js.map → chunk-DAAU5H24.js.map} +1 -1
  89. package/dist/{chunk-GAWIUMAK.cjs → chunk-DT4GG5BF.cjs} +7 -7
  90. package/dist/{chunk-GAWIUMAK.cjs.map → chunk-DT4GG5BF.cjs.map} +1 -1
  91. package/dist/{chunk-4L62MAZA.js → chunk-DX77WSIB.js} +5 -5
  92. package/dist/{chunk-4L62MAZA.js.map → chunk-DX77WSIB.js.map} +1 -1
  93. package/dist/{chunk-4ORSJM2I.js → chunk-EPUWA3ZW.js} +4 -4
  94. package/dist/{chunk-4ORSJM2I.js.map → chunk-EPUWA3ZW.js.map} +1 -1
  95. package/dist/{chunk-ZTUKOCJN.cjs → chunk-ESJMEDLY.cjs} +4 -4
  96. package/dist/{chunk-ZTUKOCJN.cjs.map → chunk-ESJMEDLY.cjs.map} +1 -1
  97. package/dist/{chunk-6JNW43SE.js → chunk-EWVXMQRW.js} +5 -5
  98. package/dist/{chunk-6JNW43SE.js.map → chunk-EWVXMQRW.js.map} +1 -1
  99. package/dist/{chunk-LIY7MYRG.js → chunk-FGBIJ6PL.js} +4 -4
  100. package/dist/{chunk-LIY7MYRG.js.map → chunk-FGBIJ6PL.js.map} +1 -1
  101. package/dist/{chunk-OFEROCC5.cjs → chunk-FGHSUT6X.cjs} +6 -6
  102. package/dist/{chunk-OFEROCC5.cjs.map → chunk-FGHSUT6X.cjs.map} +1 -1
  103. package/dist/{chunk-QKJUAMRK.cjs → chunk-FVLVTY5D.cjs} +6 -6
  104. package/dist/{chunk-QKJUAMRK.cjs.map → chunk-FVLVTY5D.cjs.map} +1 -1
  105. package/dist/{chunk-YX6RW6ZW.cjs → chunk-GBL4R3GH.cjs} +6 -6
  106. package/dist/{chunk-YX6RW6ZW.cjs.map → chunk-GBL4R3GH.cjs.map} +1 -1
  107. package/dist/{chunk-SXVMEC6N.cjs → chunk-GRXHW5S3.cjs} +12 -12
  108. package/dist/{chunk-SXVMEC6N.cjs.map → chunk-GRXHW5S3.cjs.map} +1 -1
  109. package/dist/{chunk-K5TPJVOK.js → chunk-HCIBBUV5.js} +3 -3
  110. package/dist/{chunk-K5TPJVOK.js.map → chunk-HCIBBUV5.js.map} +1 -1
  111. package/dist/{chunk-HFWO37RY.cjs → chunk-HCK2VUWD.cjs} +8 -8
  112. package/dist/{chunk-HFWO37RY.cjs.map → chunk-HCK2VUWD.cjs.map} +1 -1
  113. package/dist/{chunk-FSDI3NJV.js → chunk-IDZTDJLH.js} +3 -3
  114. package/dist/{chunk-FSDI3NJV.js.map → chunk-IDZTDJLH.js.map} +1 -1
  115. package/dist/{chunk-FDNJNVKA.cjs → chunk-IF6RQ53Q.cjs} +9 -9
  116. package/dist/{chunk-FDNJNVKA.cjs.map → chunk-IF6RQ53Q.cjs.map} +1 -1
  117. package/dist/{chunk-PVPTFMJJ.js → chunk-IOV77VHP.js} +4 -4
  118. package/dist/{chunk-PVPTFMJJ.js.map → chunk-IOV77VHP.js.map} +1 -1
  119. package/dist/{chunk-UMIJYYF3.cjs → chunk-JVVGQLJQ.cjs} +14 -9
  120. package/dist/chunk-JVVGQLJQ.cjs.map +1 -0
  121. package/dist/{chunk-MY4KMVJ5.cjs → chunk-JYVRX3BX.cjs} +8 -8
  122. package/dist/{chunk-MY4KMVJ5.cjs.map → chunk-JYVRX3BX.cjs.map} +1 -1
  123. package/dist/{chunk-ZY7ETQD6.js → chunk-KHG3G2ZX.js} +3 -3
  124. package/dist/{chunk-ZY7ETQD6.js.map → chunk-KHG3G2ZX.js.map} +1 -1
  125. package/dist/{chunk-ASNAQ35U.js → chunk-KNMEXOKJ.js} +4 -4
  126. package/dist/{chunk-ASNAQ35U.js.map → chunk-KNMEXOKJ.js.map} +1 -1
  127. package/dist/{chunk-WYIIWTIR.cjs → chunk-KWSVJRXX.cjs} +4 -4
  128. package/dist/{chunk-WYIIWTIR.cjs.map → chunk-KWSVJRXX.cjs.map} +1 -1
  129. package/dist/{chunk-OAL5RS2X.cjs → chunk-LARNENXE.cjs} +10 -10
  130. package/dist/{chunk-OAL5RS2X.cjs.map → chunk-LARNENXE.cjs.map} +1 -1
  131. package/dist/{chunk-MYXLKVJE.js → chunk-LRHMLNPW.js} +12 -4
  132. package/dist/chunk-LRHMLNPW.js.map +1 -0
  133. package/dist/{chunk-66BHM3UN.cjs → chunk-LXYNL7BI.cjs} +10 -10
  134. package/dist/{chunk-66BHM3UN.cjs.map → chunk-LXYNL7BI.cjs.map} +1 -1
  135. package/dist/{chunk-V45C74EB.js → chunk-MEERXUZS.js} +4 -4
  136. package/dist/{chunk-V45C74EB.js.map → chunk-MEERXUZS.js.map} +1 -1
  137. package/dist/{chunk-YJHB2GHQ.js → chunk-MJY25P44.js} +3 -3
  138. package/dist/{chunk-YJHB2GHQ.js.map → chunk-MJY25P44.js.map} +1 -1
  139. package/dist/{chunk-6UWYKNFN.cjs → chunk-MSCRIA2U.cjs} +12 -12
  140. package/dist/{chunk-6UWYKNFN.cjs.map → chunk-MSCRIA2U.cjs.map} +1 -1
  141. package/dist/{chunk-UZH6PVHD.js → chunk-N35UAFEU.js} +4 -4
  142. package/dist/{chunk-UZH6PVHD.js.map → chunk-N35UAFEU.js.map} +1 -1
  143. package/dist/{chunk-6E6ZDWZD.cjs → chunk-NE2W2MF3.cjs} +10 -10
  144. package/dist/{chunk-6E6ZDWZD.cjs.map → chunk-NE2W2MF3.cjs.map} +1 -1
  145. package/dist/{chunk-7PNCJ4OQ.js → chunk-NQ7Y6ZKH.js} +3 -3
  146. package/dist/{chunk-7PNCJ4OQ.js.map → chunk-NQ7Y6ZKH.js.map} +1 -1
  147. package/dist/{chunk-LK2A3HBT.js → chunk-NRULNA5F.js} +4 -4
  148. package/dist/{chunk-LK2A3HBT.js.map → chunk-NRULNA5F.js.map} +1 -1
  149. package/dist/{chunk-47EP245Y.cjs → chunk-OEGSDOJ2.cjs} +7 -7
  150. package/dist/{chunk-47EP245Y.cjs.map → chunk-OEGSDOJ2.cjs.map} +1 -1
  151. package/dist/{chunk-ZFSFOD5W.cjs → chunk-OMAW52LY.cjs} +6 -6
  152. package/dist/{chunk-ZFSFOD5W.cjs.map → chunk-OMAW52LY.cjs.map} +1 -1
  153. package/dist/{chunk-YOLF5DYU.js → chunk-OMSHGBV3.js} +4 -4
  154. package/dist/{chunk-YOLF5DYU.js.map → chunk-OMSHGBV3.js.map} +1 -1
  155. package/dist/{chunk-4H2LGLGI.cjs → chunk-OTXHJHXU.cjs} +11 -11
  156. package/dist/{chunk-4H2LGLGI.cjs.map → chunk-OTXHJHXU.cjs.map} +1 -1
  157. package/dist/{chunk-DRIJNFWP.cjs → chunk-PCAYYCLY.cjs} +10 -10
  158. package/dist/{chunk-DRIJNFWP.cjs.map → chunk-PCAYYCLY.cjs.map} +1 -1
  159. package/dist/{chunk-QERWC7U6.js → chunk-PKXW45G4.js} +3 -3
  160. package/dist/{chunk-QERWC7U6.js.map → chunk-PKXW45G4.js.map} +1 -1
  161. package/dist/{chunk-YDQDZWZ7.cjs → chunk-QEPMEEZC.cjs} +6 -6
  162. package/dist/{chunk-YDQDZWZ7.cjs.map → chunk-QEPMEEZC.cjs.map} +1 -1
  163. package/dist/{chunk-G6R6MSRF.cjs → chunk-QPHUAF3R.cjs} +8 -8
  164. package/dist/{chunk-G6R6MSRF.cjs.map → chunk-QPHUAF3R.cjs.map} +1 -1
  165. package/dist/{chunk-RFEKSP62.js → chunk-QPHWRD25.js} +3 -3
  166. package/dist/{chunk-RFEKSP62.js.map → chunk-QPHWRD25.js.map} +1 -1
  167. package/dist/{chunk-XN6YS55F.cjs → chunk-QYI7ZV3B.cjs} +30 -22
  168. package/dist/chunk-QYI7ZV3B.cjs.map +1 -0
  169. package/dist/{chunk-3V64BDKG.cjs → chunk-R2W3RJFW.cjs} +13 -13
  170. package/dist/{chunk-3V64BDKG.cjs.map → chunk-R2W3RJFW.cjs.map} +1 -1
  171. package/dist/{chunk-46ZZTP5B.js → chunk-SGZUUUXU.js} +4 -4
  172. package/dist/{chunk-46ZZTP5B.js.map → chunk-SGZUUUXU.js.map} +1 -1
  173. package/dist/{chunk-MPQECPE3.js → chunk-T7SCCACB.js} +3 -3
  174. package/dist/{chunk-MPQECPE3.js.map → chunk-T7SCCACB.js.map} +1 -1
  175. package/dist/{chunk-GPSNBZPX.js → chunk-TC3H6ZED.js} +4 -4
  176. package/dist/{chunk-GPSNBZPX.js.map → chunk-TC3H6ZED.js.map} +1 -1
  177. package/dist/{chunk-AG7VY6MJ.cjs → chunk-TEZNWW3R.cjs} +8 -8
  178. package/dist/{chunk-AG7VY6MJ.cjs.map → chunk-TEZNWW3R.cjs.map} +1 -1
  179. package/dist/{chunk-KTCP23W6.js → chunk-THHZMRFU.js} +3 -3
  180. package/dist/{chunk-KTCP23W6.js.map → chunk-THHZMRFU.js.map} +1 -1
  181. package/dist/{chunk-RWQH5EO5.cjs → chunk-TLHQ6JCK.cjs} +11 -11
  182. package/dist/{chunk-RWQH5EO5.cjs.map → chunk-TLHQ6JCK.cjs.map} +1 -1
  183. package/dist/{chunk-CDS2NXGT.cjs → chunk-V5Q6UNUK.cjs} +4 -4
  184. package/dist/{chunk-CDS2NXGT.cjs.map → chunk-V5Q6UNUK.cjs.map} +1 -1
  185. package/dist/{chunk-BT5H3WMI.js → chunk-VBMLJUBE.js} +4 -4
  186. package/dist/{chunk-BT5H3WMI.js.map → chunk-VBMLJUBE.js.map} +1 -1
  187. package/dist/{chunk-UFMPALRH.js → chunk-VGJD4F4H.js} +3 -3
  188. package/dist/{chunk-UFMPALRH.js.map → chunk-VGJD4F4H.js.map} +1 -1
  189. package/dist/{chunk-RN7NNB6I.js → chunk-VJXUBN7J.js} +3 -3
  190. package/dist/{chunk-RN7NNB6I.js.map → chunk-VJXUBN7J.js.map} +1 -1
  191. package/dist/{chunk-TVDQNLGJ.js → chunk-VUHNBLFA.js} +3 -3
  192. package/dist/{chunk-TVDQNLGJ.js.map → chunk-VUHNBLFA.js.map} +1 -1
  193. package/dist/{chunk-OAIMES5S.cjs → chunk-W476ER4X.cjs} +17 -17
  194. package/dist/{chunk-OAIMES5S.cjs.map → chunk-W476ER4X.cjs.map} +1 -1
  195. package/dist/{chunk-4XVJYNOT.js → chunk-WZCES5M6.js} +4 -4
  196. package/dist/{chunk-4XVJYNOT.js.map → chunk-WZCES5M6.js.map} +1 -1
  197. package/dist/{chunk-2EZ2TVYT.cjs → chunk-Y6CVUI6A.cjs} +13 -13
  198. package/dist/{chunk-2EZ2TVYT.cjs.map → chunk-Y6CVUI6A.cjs.map} +1 -1
  199. package/dist/{chunk-4WQUX2B4.cjs → chunk-YCL43UQM.cjs} +12 -12
  200. package/dist/{chunk-4WQUX2B4.cjs.map → chunk-YCL43UQM.cjs.map} +1 -1
  201. package/dist/{chunk-XWN43PZF.cjs → chunk-YZXRD6K6.cjs} +7 -7
  202. package/dist/{chunk-XWN43PZF.cjs.map → chunk-YZXRD6K6.cjs.map} +1 -1
  203. package/dist/{chunk-IRUIWMH6.js → chunk-ZFGLBJYC.js} +3 -3
  204. package/dist/{chunk-IRUIWMH6.js.map → chunk-ZFGLBJYC.js.map} +1 -1
  205. package/dist/{chunk-6EGHZDZI.cjs → chunk-ZNKVOTPB.cjs} +15 -15
  206. package/dist/{chunk-6EGHZDZI.cjs.map → chunk-ZNKVOTPB.cjs.map} +1 -1
  207. package/dist/{chunk-WJP6CRML.js → chunk-ZOEN3ARN.js} +3 -3
  208. package/dist/{chunk-WJP6CRML.js.map → chunk-ZOEN3ARN.js.map} +1 -1
  209. package/dist/{chunk-TWSWD4PU.js → chunk-ZYXRRVR6.js} +3 -3
  210. package/dist/{chunk-TWSWD4PU.js.map → chunk-ZYXRRVR6.js.map} +1 -1
  211. package/dist/combo.cjs +9 -9
  212. package/dist/combo.js +4 -4
  213. package/dist/custom.cjs +10 -10
  214. package/dist/custom.js +5 -5
  215. package/dist/donut.cjs +11 -11
  216. package/dist/donut.js +6 -6
  217. package/dist/dumbbell.cjs +10 -10
  218. package/dist/dumbbell.js +5 -5
  219. package/dist/funnel.cjs +10 -10
  220. package/dist/funnel.js +5 -5
  221. package/dist/gauge.cjs +10 -10
  222. package/dist/gauge.js +5 -5
  223. package/dist/geo.cjs +12 -12
  224. package/dist/geo.js +5 -5
  225. package/dist/graph.cjs +10 -10
  226. package/dist/graph.js +5 -5
  227. package/dist/heatmap.cjs +10 -10
  228. package/dist/heatmap.js +5 -5
  229. package/dist/histogram.cjs +9 -9
  230. package/dist/histogram.js +4 -4
  231. package/dist/horizontal-bar.cjs +9 -9
  232. package/dist/horizontal-bar.js +4 -4
  233. package/dist/index.cjs +180 -180
  234. package/dist/index.d.cts +4 -0
  235. package/dist/index.d.ts +4 -0
  236. package/dist/index.js +92 -92
  237. package/dist/kagi.cjs +10 -10
  238. package/dist/kagi.js +5 -5
  239. package/dist/line.cjs +9 -9
  240. package/dist/line.js +4 -4
  241. package/dist/lines.cjs +10 -10
  242. package/dist/lines.js +5 -5
  243. package/dist/lollipop.cjs +9 -9
  244. package/dist/lollipop.js +4 -4
  245. package/dist/matrix.cjs +10 -10
  246. package/dist/matrix.js +5 -5
  247. package/dist/ohlc.cjs +9 -9
  248. package/dist/ohlc.js +4 -4
  249. package/dist/parallel.cjs +10 -10
  250. package/dist/parallel.js +5 -5
  251. package/dist/pictorialbar.cjs +10 -10
  252. package/dist/pictorialbar.js +5 -5
  253. package/dist/pie.cjs +11 -11
  254. package/dist/pie.js +6 -6
  255. package/dist/polar.cjs +11 -11
  256. package/dist/polar.js +6 -6
  257. package/dist/radar.cjs +10 -10
  258. package/dist/radar.js +5 -5
  259. package/dist/radialbar.cjs +10 -10
  260. package/dist/radialbar.js +5 -5
  261. package/dist/range.cjs +9 -9
  262. package/dist/range.js +4 -4
  263. package/dist/renko.cjs +10 -10
  264. package/dist/renko.js +5 -5
  265. package/dist/sankey.cjs +10 -10
  266. package/dist/sankey.js +5 -5
  267. package/dist/scatter.cjs +9 -9
  268. package/dist/scatter.js +4 -4
  269. package/dist/sparkline.cjs +9 -9
  270. package/dist/sparkline.js +4 -4
  271. package/dist/stacked-bar.cjs +9 -9
  272. package/dist/stacked-bar.js +4 -4
  273. package/dist/step.cjs +10 -10
  274. package/dist/step.js +5 -5
  275. package/dist/sunburst.cjs +11 -11
  276. package/dist/sunburst.js +6 -6
  277. package/dist/themeriver.cjs +10 -10
  278. package/dist/themeriver.js +5 -5
  279. package/dist/tree.cjs +10 -10
  280. package/dist/tree.js +5 -5
  281. package/dist/treemap.cjs +10 -10
  282. package/dist/treemap.js +5 -5
  283. package/dist/volume.cjs +9 -9
  284. package/dist/volume.js +4 -4
  285. package/dist/waterfall.cjs +9 -9
  286. package/dist/waterfall.js +4 -4
  287. package/package.json +1 -1
  288. package/dist/chunk-DX4FBN3I.js.map +0 -1
  289. package/dist/chunk-MYXLKVJE.js.map +0 -1
  290. package/dist/chunk-UMIJYYF3.cjs.map +0 -1
  291. package/dist/chunk-XN6YS55F.cjs.map +0 -1
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/candlestick/candlestick-type.ts
7
7
  var candlestickChartType = {
@@ -12,7 +12,7 @@ var candlestickChartType = {
12
12
  prepareData(data, options) {
13
13
  const cOpts = options;
14
14
  const ohlc = cOpts.ohlc;
15
- const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
15
+ const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
16
16
  if (ohlc) {
17
17
  let yMin = prepared.bounds.yMin;
18
18
  let yMax = prepared.bounds.yMax;
@@ -69,7 +69,7 @@ var candlestickChartType = {
69
69
  "data-index": i
70
70
  }
71
71
  });
72
- candleNodes.push(chunkUMIJYYF3_cjs.rect(cx - candleWidth / 2, bodyTop, candleWidth, bodyHeight, {
72
+ candleNodes.push(chunkJVVGQLJQ_cjs.rect(cx - candleWidth / 2, bodyTop, candleWidth, bodyHeight, {
73
73
  rx: 2,
74
74
  ry: 2,
75
75
  class: "chartts-candle",
@@ -83,7 +83,7 @@ var candlestickChartType = {
83
83
  ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`
84
84
  }));
85
85
  }
86
- nodes.push(chunkUMIJYYF3_cjs.group(candleNodes, {
86
+ nodes.push(chunkJVVGQLJQ_cjs.group(candleNodes, {
87
87
  class: "chartts-series chartts-series-0",
88
88
  "data-series-name": series.name
89
89
  }));
@@ -107,5 +107,5 @@ var candlestickChartType = {
107
107
  };
108
108
 
109
109
  exports.candlestickChartType = candlestickChartType;
110
- //# sourceMappingURL=chunk-ZFSFOD5W.cjs.map
111
- //# sourceMappingURL=chunk-ZFSFOD5W.cjs.map
110
+ //# sourceMappingURL=chunk-OMAW52LY.cjs.map
111
+ //# sourceMappingURL=chunk-OMAW52LY.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/candlestick/candlestick-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":";;;;;;AAyCO,IAAM,oBAAA,GAAwC;AAAA,EACnD,IAAA,EAAM,aAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,MAAM,OAAO,KAAA,CAAM,IAAA;AAGnB,IAAA,MAAM,QAAA,GAAWA,6BAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAE1C,IAAA,IAAI,IAAA,EAAM;AACR,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,QAAA,IAAI,IAAA,CAAK,KAAK,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AAC5C,QAAA,IAAI,IAAA,CAAK,KAAK,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AAC5C,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,IAAI,CAAC,CAAA;AAC1C,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC5C;AACA,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AACvB,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AAAA,IACzB;AAEA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,SAAQ,GAAI,GAAA;AAC1C,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,MAAM,OAAO,KAAA,CAAM,IAAA;AACnB,IAAA,IAAI,CAAC,MAAM,OAAO,KAAA;AAElB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,KAAA;AAEpB,IAAA,MAAM,OAAA,GAAU,MAAM,OAAA,IAAW,mCAAA;AACjC,IAAA,MAAM,SAAA,GAAY,MAAM,SAAA,IAAa,+BAAA;AACrC,IAAA,MAAM,SAAA,GAAY,MAAM,SAAA,IAAa,GAAA;AAGrC,IAAA,MAAM,EAAA,GAAKC,+BAAa,MAAM,CAAA;AAC9B,IAAA,MAAM,cAAc,EAAA,GAAK,GAAA;AAEzB,IAAA,MAAM,cAA4B,EAAC;AAEnC,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,MAAA,MAAM,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,CAAC,CAAA;AACxB,MAAA,MAAM,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,CAAC,CAAA;AACxB,MAAA,MAAM,GAAA,GAAM,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,CAAC,CAAA;AAE1B,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,MAAM,OAAO,KAAA,IAAS,IAAA;AACtB,MAAA,MAAM,KAAA,GAAQ,OAAO,OAAA,GAAU,SAAA;AAE/B,MAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAC7B,MAAA,MAAM,IAAA,GAAO,MAAA,CAAO,GAAA,CAAI,GAAG,CAAA;AAC3B,MAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAC7B,MAAA,MAAM,MAAA,GAAS,MAAA,CAAO,GAAA,CAAI,KAAK,CAAA;AAE/B,MAAA,MAAM,OAAA,GAAU,IAAA,CAAK,GAAA,CAAI,KAAA,EAAO,MAAM,CAAA;AACtC,MAAA,MAAM,UAAA,GAAa,KAAK,GAAA,CAAI,IAAA,CAAK,IAAI,KAAA,GAAQ,MAAM,GAAG,CAAC,CAAA;AAGvD,MAAA,WAAA,CAAY,IAAA,CAAK;AAAA,QACf,IAAA,EAAM,MAAA;AAAA,QACN,EAAA,EAAI,EAAA;AAAA,QACJ,EAAA,EAAI,KAAA;AAAA,QACJ,EAAA,EAAI,EAAA;AAAA,QACJ,EAAA,EAAI,IAAA;AAAA,QACJ,KAAA,EAAO;AAAA,UACL,KAAA,EAAO,cAAA;AAAA,UACP,MAAA,EAAQ,KAAA;AAAA,UACR,WAAA,EAAa,SAAA;AAAA,UACb,aAAA,EAAe,CAAA;AAAA,UACf,YAAA,EAAc;AAAA;AAChB,OACD,CAAA;AAGD,MAAA,WAAA,CAAY,KAAKC,sBAAA,CAAK,EAAA,GAAK,cAAc,CAAA,EAAG,OAAA,EAAS,aAAa,UAAA,EAAY;AAAA,QAC5E,EAAA,EAAI,CAAA;AAAA,QAAG,EAAA,EAAI,CAAA;AAAA,QACX,KAAA,EAAO,gBAAA;AAAA,QACP,IAAA,EAAM,OAAO,KAAA,GAAQ,KAAA;AAAA,QACrB,MAAA,EAAQ,KAAA;AAAA,QACR,WAAA,EAAa,CAAA;AAAA,QACb,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc,CAAA;AAAA,QACd,QAAA,EAAU,CAAA;AAAA,QACV,IAAA,EAAM,KAAA;AAAA,QACN,SAAA,EAAW,CAAA,EAAG,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAC,CAAA,GAAA,EAAM,IAAI,CAAA,EAAA,EAAK,IAAI,CAAA,EAAA,EAAK,GAAG,KAAK,KAAK,CAAA;AAAA,OACvE,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,WAAA,EAAa;AAAA,MAC5B,KAAA,EAAO,iCAAA;AAAA,MACP,oBAAoB,MAAA,CAAO;AAAA,KAC5B,CAAC,CAAA;AAEF,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,GAAA,EAA+B;AACrE,IAAA,MAAM,EAAE,MAAA,EAAQ,MAAA,EAAQ,OAAA,EAAQ,GAAI,GAAA;AACpC,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,MAAM,OAAO,KAAA,CAAM,IAAA;AACnB,IAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAElB,IAAA,MAAM,EAAA,GAAKF,+BAAa,MAAM,CAAA;AAC9B,IAAA,MAAM,cAAc,EAAA,GAAK,GAAA;AAEzB,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,IAAI,EAAA,IAAM,KAAK,WAAA,GAAc,CAAA,GAAI,KAAK,EAAA,IAAM,EAAA,GAAK,WAAA,GAAc,CAAA,GAAI,CAAA,EAAG;AACpE,QAAA,OAAO,EAAE,aAAa,CAAA,EAAG,UAAA,EAAY,GAAG,QAAA,EAAU,IAAA,CAAK,IAAI,EAAA,GAAK,EAAE,GAAG,CAAA,EAAG,EAAA,EAAI,GAAG,MAAA,CAAO,GAAA,CAAI,KAAK,KAAA,CAAM,CAAC,CAAE,CAAA,EAAE;AAAA,MAC5G;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-ZFSFOD5W.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 } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface CandlestickOptions {\n /** OHLC data: { open, high, low, close } arrays. */\n ohlc?: {\n open: number[]\n high: number[]\n low: number[]\n close: number[]\n }\n /** Up candle color. Default green. */\n upColor?: string\n /** Down candle color. Default red. */\n downColor?: string\n /** Wick width. Default 1.5. */\n wickWidth?: number\n}\n\n/**\n * Candlestick / OHLC chart for financial data.\n *\n * Pass OHLC data via options:\n * ```ts\n * Candlestick('#el', {\n * data: { labels: ['Mon','Tue','Wed'], series: [{ name: 'AAPL', values: [150, 152, 148] }] },\n * ohlc: {\n * open: [148, 150, 152],\n * high: [153, 155, 154],\n * low: [146, 149, 147],\n * close: [150, 152, 148],\n * }\n * })\n * ```\n * The series values are used as close prices for scale computation.\n */\nexport const candlestickChartType: ChartTypePlugin = {\n type: 'candlestick',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n\n // Expand bounds to include all OHLC values\n const prepared = prepareData(data, options)\n\n if (ohlc) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < ohlc.high.length; i++) {\n if (ohlc.high[i]! < yMin) yMin = ohlc.high[i]!\n if (ohlc.high[i]! > yMax) yMax = ohlc.high[i]!\n if (ohlc.low[i]! < yMin) yMin = ohlc.low[i]!\n if (ohlc.low[i]! > yMax) yMax = ohlc.low[i]!\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const nodes: RenderNode[] = []\n\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n if (!ohlc) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const upColor = cOpts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = cOpts.downColor ?? 'var(--color-red-500, #ef4444)'\n const wickWidth = cOpts.wickWidth ?? 1.5\n\n // Get bandwidth for candle width\n const bw = getBandwidth(xScale)\n const candleWidth = bw * 0.6\n\n const candleNodes: RenderNode[] = []\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const open = ohlc.open[i]!\n const high = ohlc.high[i]!\n const low = ohlc.low[i]!\n const close = ohlc.close[i]!\n\n const cx = xScale.map(i)\n const isUp = close >= open\n const color = isUp ? upColor : downColor\n\n const yHigh = yScale.map(high)\n const yLow = yScale.map(low)\n const yOpen = yScale.map(open)\n const yClose = yScale.map(close)\n\n const bodyTop = Math.min(yOpen, yClose)\n const bodyHeight = Math.max(Math.abs(yOpen - yClose), 1)\n\n // Wick (high-low line)\n candleNodes.push({\n type: 'line',\n x1: cx,\n y1: yHigh,\n x2: cx,\n y2: yLow,\n attrs: {\n class: 'chartts-wick',\n stroke: color,\n strokeWidth: wickWidth,\n 'data-series': 0,\n 'data-index': i,\n },\n })\n\n // Body (open-close rect)\n candleNodes.push(rect(cx - candleWidth / 2, bodyTop, candleWidth, bodyHeight, {\n rx: 2, ry: 2,\n class: 'chartts-candle',\n fill: isUp ? color : color,\n stroke: color,\n strokeWidth: 1,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`,\n }))\n }\n\n nodes.push(group(candleNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { xScale, yScale, options } = ctx\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n if (!ohlc) return null\n\n const bw = getBandwidth(xScale)\n const candleWidth = bw * 0.6\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - candleWidth / 2 - 4 && mx <= cx + candleWidth / 2 + 4) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(ohlc.close[i]!) }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/candlestick/candlestick-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-OMAW52LY.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 } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface CandlestickOptions {\n /** OHLC data: { open, high, low, close } arrays. */\n ohlc?: {\n open: number[]\n high: number[]\n low: number[]\n close: number[]\n }\n /** Up candle color. Default green. */\n upColor?: string\n /** Down candle color. Default red. */\n downColor?: string\n /** Wick width. Default 1.5. */\n wickWidth?: number\n}\n\n/**\n * Candlestick / OHLC chart for financial data.\n *\n * Pass OHLC data via options:\n * ```ts\n * Candlestick('#el', {\n * data: { labels: ['Mon','Tue','Wed'], series: [{ name: 'AAPL', values: [150, 152, 148] }] },\n * ohlc: {\n * open: [148, 150, 152],\n * high: [153, 155, 154],\n * low: [146, 149, 147],\n * close: [150, 152, 148],\n * }\n * })\n * ```\n * The series values are used as close prices for scale computation.\n */\nexport const candlestickChartType: ChartTypePlugin = {\n type: 'candlestick',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n\n // Expand bounds to include all OHLC values\n const prepared = prepareData(data, options)\n\n if (ohlc) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < ohlc.high.length; i++) {\n if (ohlc.high[i]! < yMin) yMin = ohlc.high[i]!\n if (ohlc.high[i]! > yMax) yMax = ohlc.high[i]!\n if (ohlc.low[i]! < yMin) yMin = ohlc.low[i]!\n if (ohlc.low[i]! > yMax) yMax = ohlc.low[i]!\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const nodes: RenderNode[] = []\n\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n if (!ohlc) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const upColor = cOpts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = cOpts.downColor ?? 'var(--color-red-500, #ef4444)'\n const wickWidth = cOpts.wickWidth ?? 1.5\n\n // Get bandwidth for candle width\n const bw = getBandwidth(xScale)\n const candleWidth = bw * 0.6\n\n const candleNodes: RenderNode[] = []\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const open = ohlc.open[i]!\n const high = ohlc.high[i]!\n const low = ohlc.low[i]!\n const close = ohlc.close[i]!\n\n const cx = xScale.map(i)\n const isUp = close >= open\n const color = isUp ? upColor : downColor\n\n const yHigh = yScale.map(high)\n const yLow = yScale.map(low)\n const yOpen = yScale.map(open)\n const yClose = yScale.map(close)\n\n const bodyTop = Math.min(yOpen, yClose)\n const bodyHeight = Math.max(Math.abs(yOpen - yClose), 1)\n\n // Wick (high-low line)\n candleNodes.push({\n type: 'line',\n x1: cx,\n y1: yHigh,\n x2: cx,\n y2: yLow,\n attrs: {\n class: 'chartts-wick',\n stroke: color,\n strokeWidth: wickWidth,\n 'data-series': 0,\n 'data-index': i,\n },\n })\n\n // Body (open-close rect)\n candleNodes.push(rect(cx - candleWidth / 2, bodyTop, candleWidth, bodyHeight, {\n rx: 2, ry: 2,\n class: 'chartts-candle',\n fill: isUp ? color : color,\n stroke: color,\n strokeWidth: 1,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`,\n }))\n }\n\n nodes.push(group(candleNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { xScale, yScale, options } = ctx\n const cOpts = options as unknown as CandlestickOptions\n const ohlc = cOpts.ohlc\n if (!ohlc) return null\n\n const bw = getBandwidth(xScale)\n const candleWidth = bw * 0.6\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - candleWidth / 2 - 4 && mx <= cx + candleWidth / 2 + 4) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(ohlc.close[i]!) }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
- import { PathBuilder, path, text, group } from './chunk-DX4FBN3I.js';
1
+ import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
+ import { PathBuilder, path, text, group } from './chunk-AEQXFDL7.js';
3
3
 
4
4
  // src/charts/radialbar/radialbar-type.ts
5
5
  var radialBarChartType = {
@@ -122,5 +122,5 @@ function strokeArc(pb, cx, cy, r, startAngle, endAngle) {
122
122
  }
123
123
 
124
124
  export { radialBarChartType };
125
- //# sourceMappingURL=chunk-YOLF5DYU.js.map
126
- //# sourceMappingURL=chunk-YOLF5DYU.js.map
125
+ //# sourceMappingURL=chunk-OMSHGBV3.js.map
126
+ //# sourceMappingURL=chunk-OMSHGBV3.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/radialbar/radialbar-type.ts"],"names":[],"mappings":"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","file":"chunk-YOLF5DYU.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'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\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 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 const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring) — rounded caps\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc — rounded caps for polished look\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n const midR = (rInner + rOuter) / 2\n const hitAngle = Math.atan2(dy, dx)\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(hitAngle), y: cy + midR * Math.sin(hitAngle) }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\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 const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/radialbar/radialbar-type.ts"],"names":[],"mappings":"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","file":"chunk-OMSHGBV3.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'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\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 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 const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring) — rounded caps\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc — rounded caps for polished look\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n const midR = (rInner + rOuter) / 2\n const hitAngle = Math.atan2(dy, dx)\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(hitAngle), y: cy + midR * Math.sin(hitAngle) }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\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 const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
3
+ var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/radialbar/radialbar-type.ts
7
7
  var radialBarChartType = {
@@ -10,7 +10,7 @@ var radialBarChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
13
+ return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -41,10 +41,10 @@ var radialBarChartType = {
41
41
  const colorIndex = i % options.colors.length;
42
42
  const color = options.colors[colorIndex];
43
43
  const label = String(data.labels[i] ?? `Item ${i + 1}`);
44
- const trackPb = new chunkUMIJYYF3_cjs.PathBuilder();
44
+ const trackPb = new chunkJVVGQLJQ_cjs.PathBuilder();
45
45
  const trackEnd = startAngle + Math.PI * 2 * 0.95;
46
46
  strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd);
47
- nodes.push(chunkUMIJYYF3_cjs.path(trackPb.build(), {
47
+ nodes.push(chunkJVVGQLJQ_cjs.path(trackPb.build(), {
48
48
  class: "chartts-radialbar-track",
49
49
  stroke: theme.gridColor,
50
50
  strokeWidth: ringWidth,
@@ -53,10 +53,10 @@ var radialBarChartType = {
53
53
  opacity: 0.15
54
54
  }));
55
55
  if (sweepAngle > 0.01) {
56
- const arcPb = new chunkUMIJYYF3_cjs.PathBuilder();
56
+ const arcPb = new chunkJVVGQLJQ_cjs.PathBuilder();
57
57
  strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle);
58
58
  const arcNodes = [
59
- chunkUMIJYYF3_cjs.path(arcPb.build(), {
59
+ chunkJVVGQLJQ_cjs.path(arcPb.build(), {
60
60
  class: "chartts-radialbar-arc",
61
61
  stroke: color,
62
62
  strokeWidth: ringWidth,
@@ -71,7 +71,7 @@ var radialBarChartType = {
71
71
  })
72
72
  ];
73
73
  const ringMidR = (rOuter + rInner) / 2;
74
- arcNodes.push(chunkUMIJYYF3_cjs.text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {
74
+ arcNodes.push(chunkJVVGQLJQ_cjs.text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {
75
75
  class: "chartts-radialbar-label",
76
76
  fill: theme.textMuted,
77
77
  textAnchor: "end",
@@ -79,7 +79,7 @@ var radialBarChartType = {
79
79
  fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),
80
80
  fontFamily: theme.fontFamily
81
81
  }));
82
- nodes.push(chunkUMIJYYF3_cjs.group(arcNodes, {
82
+ nodes.push(chunkJVVGQLJQ_cjs.group(arcNodes, {
83
83
  class: `chartts-series chartts-series-${i}`,
84
84
  "data-series-name": label
85
85
  }));
@@ -124,5 +124,5 @@ function strokeArc(pb, cx, cy, r, startAngle, endAngle) {
124
124
  }
125
125
 
126
126
  exports.radialBarChartType = radialBarChartType;
127
- //# sourceMappingURL=chunk-4H2LGLGI.cjs.map
128
- //# sourceMappingURL=chunk-4H2LGLGI.cjs.map
127
+ //# sourceMappingURL=chunk-OTXHJHXU.cjs.map
128
+ //# sourceMappingURL=chunk-OTXHJHXU.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/radialbar/radialbar-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-4H2LGLGI.cjs","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'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\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 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 const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring) — rounded caps\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc — rounded caps for polished look\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n const midR = (rInner + rOuter) / 2\n const hitAngle = Math.atan2(dy, dx)\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(hitAngle), y: cy + midR * Math.sin(hitAngle) }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\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 const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/radialbar/radialbar-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-OTXHJHXU.cjs","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'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\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 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 const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring) — rounded caps\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc — rounded caps for polished look\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n strokeLinecap: 'round',\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n const midR = (rInner + rOuter) / 2\n const hitAngle = Math.atan2(dy, dx)\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(hitAngle), y: cy + midR * Math.sin(hitAngle) }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\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 const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
5
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
5
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
6
6
 
7
7
  // src/charts/dumbbell/dumbbell-type.ts
8
8
  var dumbbellChartType = {
@@ -11,7 +11,7 @@ var dumbbellChartType = {
11
11
  return { x: "categorical", y: "linear" };
12
12
  },
13
13
  prepareData(data, options) {
14
- return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
14
+ return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
15
15
  },
16
16
  render(ctx) {
17
17
  const { data, area, theme, options, yScale } = ctx;
@@ -37,7 +37,7 @@ var dumbbellChartType = {
37
37
  const x2 = valueToX(v2);
38
38
  const label = String(data.labels[i] ?? `Item ${i + 1}`);
39
39
  const rowNodes = [];
40
- rowNodes.push(chunkUMIJYYF3_cjs.text(area.x + labelWidth - 8, cy, label, {
40
+ rowNodes.push(chunkJVVGQLJQ_cjs.text(area.x + labelWidth - 8, cy, label, {
41
41
  class: "chartts-dumbbell-label",
42
42
  fill: theme.textMuted,
43
43
  textAnchor: "end",
@@ -45,12 +45,12 @@ var dumbbellChartType = {
45
45
  fontSize: theme.fontSizeSmall,
46
46
  fontFamily: theme.fontFamily
47
47
  }));
48
- rowNodes.push(chunkUMIJYYF3_cjs.line(x1, cy, x2, cy, {
48
+ rowNodes.push(chunkJVVGQLJQ_cjs.line(x1, cy, x2, cy, {
49
49
  class: "chartts-dumbbell-connector",
50
50
  stroke: theme.gridColor,
51
51
  strokeWidth: 2
52
52
  }));
53
- rowNodes.push(chunkUMIJYYF3_cjs.circle(x1, cy, dotR, {
53
+ rowNodes.push(chunkJVVGQLJQ_cjs.circle(x1, cy, dotR, {
54
54
  class: "chartts-dumbbell-dot",
55
55
  fill: color1,
56
56
  stroke: "#fff",
@@ -61,7 +61,7 @@ var dumbbellChartType = {
61
61
  role: "img",
62
62
  ariaLabel: `${label} \u2014 ${s1.name}: ${v1}`
63
63
  }));
64
- rowNodes.push(chunkUMIJYYF3_cjs.circle(x2, cy, dotR, {
64
+ rowNodes.push(chunkJVVGQLJQ_cjs.circle(x2, cy, dotR, {
65
65
  class: "chartts-dumbbell-dot",
66
66
  fill: color2,
67
67
  stroke: "#fff",
@@ -72,7 +72,7 @@ var dumbbellChartType = {
72
72
  role: "img",
73
73
  ariaLabel: `${label} \u2014 ${s2.name}: ${v2}`
74
74
  }));
75
- nodes.push(chunkUMIJYYF3_cjs.group(rowNodes, {
75
+ nodes.push(chunkJVVGQLJQ_cjs.group(rowNodes, {
76
76
  class: `chartts-series chartts-series-${i}`,
77
77
  "data-series-name": label
78
78
  }));
@@ -111,5 +111,5 @@ var dumbbellChartType = {
111
111
  };
112
112
 
113
113
  exports.dumbbellChartType = dumbbellChartType;
114
- //# sourceMappingURL=chunk-DRIJNFWP.cjs.map
115
- //# sourceMappingURL=chunk-DRIJNFWP.cjs.map
114
+ //# sourceMappingURL=chunk-PCAYYCLY.cjs.map
115
+ //# sourceMappingURL=chunk-PCAYYCLY.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/dumbbell/dumbbell-type.ts"],"names":["prepareNoAxes","createHorizontalMapper","text","line","circle","group"],"mappings":"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","file":"chunk-DRIJNFWP.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, line, circle, text } from '../../render/tree'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Dumbbell / connected dot chart.\n *\n * Two dots per category connected by a line.\n * Horizontal layout — categories on y-axis, values on x-axis.\n * Requires exactly 2 series. Shows before/after or comparison.\n */\nexport const dumbbellChartType: ChartTypePlugin = {\n type: 'dumbbell',\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, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length < 2) return nodes\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return nodes\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n const dotR = Math.min(6, rowHeight * 0.2)\n\n const color1 = options.colors[0]!\n const color2 = options.colors[1 % options.colors.length]!\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const v1 = s1.values[i]!\n const v2 = s2.values[i]!\n const x1 = valueToX(v1)\n const x2 = valueToX(v2)\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n const rowNodes: RenderNode[] = []\n\n // Label\n rowNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-dumbbell-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Connecting line\n rowNodes.push(line(x1, cy, x2, cy, {\n class: 'chartts-dumbbell-connector',\n stroke: theme.gridColor,\n strokeWidth: 2,\n }))\n\n // Dot 1 (series 0)\n rowNodes.push(circle(x1, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color1,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s1.name}: ${v1}`,\n }))\n\n // Dot 2 (series 1)\n rowNodes.push(circle(x2, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color2,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 1,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s2.name}: ${v2}`,\n }))\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, yScale } = ctx\n if (data.series.length < 2) return null\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return null\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n let best: HitResult | null = null\n let bestDist = 15\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n\n for (const [si, series] of [s1, s2].entries()) {\n const vx = valueToX(series.values[i]!)\n const dx = mx - vx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: i, distance: dist, x: vx, y: cy }\n }\n }\n }\n\n return best\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/dumbbell/dumbbell-type.ts"],"names":["prepareNoAxes","createHorizontalMapper","text","line","circle","group"],"mappings":"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","file":"chunk-PCAYYCLY.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, line, circle, text } from '../../render/tree'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Dumbbell / connected dot chart.\n *\n * Two dots per category connected by a line.\n * Horizontal layout — categories on y-axis, values on x-axis.\n * Requires exactly 2 series. Shows before/after or comparison.\n */\nexport const dumbbellChartType: ChartTypePlugin = {\n type: 'dumbbell',\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, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length < 2) return nodes\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return nodes\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n const dotR = Math.min(6, rowHeight * 0.2)\n\n const color1 = options.colors[0]!\n const color2 = options.colors[1 % options.colors.length]!\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const v1 = s1.values[i]!\n const v2 = s2.values[i]!\n const x1 = valueToX(v1)\n const x2 = valueToX(v2)\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n const rowNodes: RenderNode[] = []\n\n // Label\n rowNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-dumbbell-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Connecting line\n rowNodes.push(line(x1, cy, x2, cy, {\n class: 'chartts-dumbbell-connector',\n stroke: theme.gridColor,\n strokeWidth: 2,\n }))\n\n // Dot 1 (series 0)\n rowNodes.push(circle(x1, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color1,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s1.name}: ${v1}`,\n }))\n\n // Dot 2 (series 1)\n rowNodes.push(circle(x2, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color2,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 1,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s2.name}: ${v2}`,\n }))\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, yScale } = ctx\n if (data.series.length < 2) return null\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return null\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n let best: HitResult | null = null\n let bestDist = 15\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n\n for (const [si, series] of [s1, s2].entries()) {\n const vx = valueToX(series.values[i]!)\n const dx = mx - vx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: i, distance: dist, x: vx, y: cy }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { lineChartType } from './chunk-WJP6CRML.js';
1
+ import { lineChartType } from './chunk-ZOEN3ARN.js';
2
2
 
3
3
  // src/charts/step/step-type.ts
4
4
  var stepChartType = {
@@ -22,5 +22,5 @@ var stepChartType = {
22
22
  };
23
23
 
24
24
  export { stepChartType };
25
- //# sourceMappingURL=chunk-QERWC7U6.js.map
26
- //# sourceMappingURL=chunk-QERWC7U6.js.map
25
+ //# sourceMappingURL=chunk-PKXW45G4.js.map
26
+ //# sourceMappingURL=chunk-PKXW45G4.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/step/step-type.ts"],"names":[],"mappings":";;;AAYO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,WAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAAA,EAChD,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AAEvC,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,GAAG,GAAA;AAAA,MACH,SAAS,EAAE,GAAG,GAAA,CAAI,OAAA,EAAS,OAAO,MAAA;AAAgB,KACpD;AACA,IAAA,OAAO,aAAA,CAAc,OAAO,OAAO,CAAA;AAAA,EACrC,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,OAAO,aAAA,CAAc,OAAA,CAAQ,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,EAC1C;AACF","file":"chunk-QERWC7U6.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { lineChartType } from '../line/line-type'\n\n/**\n * Step chart — line chart with stair-step interpolation.\n *\n * Delegates entirely to lineChartType after forcing curve:'step'.\n * Used for: interest rates, order books, discrete pricing tiers.\n */\nexport const stepChartType: ChartTypePlugin = {\n type: 'step',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return lineChartType.prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n // Force step interpolation\n const stepCtx = {\n ...ctx,\n options: { ...ctx.options, curve: 'step' as const },\n }\n return lineChartType.render(stepCtx)\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n return lineChartType.hitTest(ctx, mx, my)\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/step/step-type.ts"],"names":[],"mappings":";;;AAYO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,WAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAAA,EAChD,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AAEvC,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,GAAG,GAAA;AAAA,MACH,SAAS,EAAE,GAAG,GAAA,CAAI,OAAA,EAAS,OAAO,MAAA;AAAgB,KACpD;AACA,IAAA,OAAO,aAAA,CAAc,OAAO,OAAO,CAAA;AAAA,EACrC,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,OAAO,aAAA,CAAc,OAAA,CAAQ,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,EAC1C;AACF","file":"chunk-PKXW45G4.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { lineChartType } from '../line/line-type'\n\n/**\n * Step chart — line chart with stair-step interpolation.\n *\n * Delegates entirely to lineChartType after forcing curve:'step'.\n * Used for: interest rates, order books, discrete pricing tiers.\n */\nexport const stepChartType: ChartTypePlugin = {\n type: 'step',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return lineChartType.prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n // Force step interpolation\n const stepCtx = {\n ...ctx,\n options: { ...ctx.options, curve: 'step' as const },\n }\n return lineChartType.render(stepCtx)\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n return lineChartType.hitTest(ctx, mx, my)\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/volume/volume-type.ts
7
7
  var volumeChartType = {
@@ -10,7 +10,7 @@ var volumeChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
13
+ const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
14
14
  if (prepared.bounds.yMin > 0) prepared.bounds.yMin = 0;
15
15
  return prepared;
16
16
  },
@@ -37,7 +37,7 @@ var volumeChartType = {
37
37
  const barHeight = Math.max(baseline - yTop, 1);
38
38
  const dir = directions[i] ?? "up";
39
39
  const color = dir === "up" ? upColor : downColor;
40
- barNodes.push(chunkUMIJYYF3_cjs.rect(cx - barWidth / 2, yTop, barWidth, barHeight, {
40
+ barNodes.push(chunkJVVGQLJQ_cjs.rect(cx - barWidth / 2, yTop, barWidth, barHeight, {
41
41
  rx: 1,
42
42
  ry: 1,
43
43
  class: "chartts-volume-bar",
@@ -50,7 +50,7 @@ var volumeChartType = {
50
50
  ariaLabel: `${data.labels[i] ?? i}: ${val} (${dir})`
51
51
  }));
52
52
  }
53
- nodes.push(chunkUMIJYYF3_cjs.group(barNodes, {
53
+ nodes.push(chunkJVVGQLJQ_cjs.group(barNodes, {
54
54
  class: "chartts-series chartts-series-0",
55
55
  "data-series-name": series.name
56
56
  }));
@@ -77,5 +77,5 @@ var volumeChartType = {
77
77
  };
78
78
 
79
79
  exports.volumeChartType = volumeChartType;
80
- //# sourceMappingURL=chunk-YDQDZWZ7.cjs.map
81
- //# sourceMappingURL=chunk-YDQDZWZ7.cjs.map
80
+ //# sourceMappingURL=chunk-QEPMEEZC.cjs.map
81
+ //# sourceMappingURL=chunk-QEPMEEZC.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/volume/volume-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-YDQDZWZ7.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 } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface VolumeOptions {\n /** Explicit direction per bar: 'up' or 'down'. Auto-detected if omitted. */\n directions?: ('up' | 'down')[]\n /** Up color (volume on up-price day). Default green. */\n upColor?: string\n /** Down color (volume on down-price day). Default red. */\n downColor?: string\n /** Gap between bars as fraction of bandwidth. Default 0.2. */\n gap?: number\n}\n\n/**\n * Volume chart — vertical bars colored by price direction.\n *\n * Essential companion to candlestick/OHLC price charts.\n * Green bars = volume on up days, red bars = volume on down days.\n */\nexport const volumeChartType: ChartTypePlugin = {\n type: 'volume',\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 // Volume always starts at zero\n if (prepared.bounds.yMin > 0) prepared.bounds.yMin = 0\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, area, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series) return nodes\n\n const opts = options as unknown as VolumeOptions\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const gapFrac = opts.gap ?? 0.2\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - gapFrac)\n const baseline = area.y + area.height\n\n // Auto-detect direction: current value vs previous\n const directions = opts.directions ?? series.values.map((v, i) =>\n i === 0 ? 'up' as const : (v >= series.values[i - 1]! ? 'up' as const : 'down' as const),\n )\n\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const cx = xScale.map(i)\n const yTop = yScale.map(val)\n const barHeight = Math.max(baseline - yTop, 1)\n const dir = directions[i] ?? 'up'\n const color = dir === 'up' ? upColor : downColor\n\n barNodes.push(rect(cx - barWidth / 2, yTop, barWidth, barHeight, {\n rx: 1, ry: 1,\n class: 'chartts-volume-bar',\n fill: color,\n fillOpacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${val} (${dir})`,\n }))\n }\n\n nodes.push(group(barNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, area, options } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const opts = options as unknown as VolumeOptions\n const gapFrac = opts.gap ?? 0.2\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - gapFrac)\n const baseline = area.y + area.height\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n const yTop = yScale.map(series.values[i]!)\n if (mx >= cx - barWidth / 2 && mx <= cx + barWidth / 2 && my >= yTop && my <= baseline) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yTop }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/volume/volume-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-QEPMEEZC.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 } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface VolumeOptions {\n /** Explicit direction per bar: 'up' or 'down'. Auto-detected if omitted. */\n directions?: ('up' | 'down')[]\n /** Up color (volume on up-price day). Default green. */\n upColor?: string\n /** Down color (volume on down-price day). Default red. */\n downColor?: string\n /** Gap between bars as fraction of bandwidth. Default 0.2. */\n gap?: number\n}\n\n/**\n * Volume chart — vertical bars colored by price direction.\n *\n * Essential companion to candlestick/OHLC price charts.\n * Green bars = volume on up days, red bars = volume on down days.\n */\nexport const volumeChartType: ChartTypePlugin = {\n type: 'volume',\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 // Volume always starts at zero\n if (prepared.bounds.yMin > 0) prepared.bounds.yMin = 0\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, area, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series) return nodes\n\n const opts = options as unknown as VolumeOptions\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const gapFrac = opts.gap ?? 0.2\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - gapFrac)\n const baseline = area.y + area.height\n\n // Auto-detect direction: current value vs previous\n const directions = opts.directions ?? series.values.map((v, i) =>\n i === 0 ? 'up' as const : (v >= series.values[i - 1]! ? 'up' as const : 'down' as const),\n )\n\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const cx = xScale.map(i)\n const yTop = yScale.map(val)\n const barHeight = Math.max(baseline - yTop, 1)\n const dir = directions[i] ?? 'up'\n const color = dir === 'up' ? upColor : downColor\n\n barNodes.push(rect(cx - barWidth / 2, yTop, barWidth, barHeight, {\n rx: 1, ry: 1,\n class: 'chartts-volume-bar',\n fill: color,\n fillOpacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${val} (${dir})`,\n }))\n }\n\n nodes.push(group(barNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, area, options } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const opts = options as unknown as VolumeOptions\n const gapFrac = opts.gap ?? 0.2\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - gapFrac)\n const baseline = area.y + area.height\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n const yTop = yScale.map(series.values[i]!)\n if (mx >= cx - barWidth / 2 && mx <= cx + barWidth / 2 && my >= yTop && my <= baseline) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yTop }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/ohlc/ohlc-type.ts
7
7
  var ohlcChartType = {
@@ -12,7 +12,7 @@ var ohlcChartType = {
12
12
  prepareData(data, options) {
13
13
  const opts = options;
14
14
  const ohlc = opts.ohlc;
15
- const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
15
+ const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
16
16
  if (ohlc) {
17
17
  let yMin = prepared.bounds.yMin;
18
18
  let yMax = prepared.bounds.yMax;
@@ -53,21 +53,21 @@ var ohlcChartType = {
53
53
  const yLow = yScale.map(low);
54
54
  const yOpen = yScale.map(open);
55
55
  const yClose = yScale.map(close);
56
- tickNodes.push(chunkUMIJYYF3_cjs.line(cx, yHigh, cx, yLow, {
56
+ tickNodes.push(chunkJVVGQLJQ_cjs.line(cx, yHigh, cx, yLow, {
57
57
  class: "chartts-ohlc-stem",
58
58
  stroke: color,
59
59
  strokeWidth: lw,
60
60
  "data-series": 0,
61
61
  "data-index": i
62
62
  }));
63
- tickNodes.push(chunkUMIJYYF3_cjs.line(cx - tickWidth, yOpen, cx, yOpen, {
63
+ tickNodes.push(chunkJVVGQLJQ_cjs.line(cx - tickWidth, yOpen, cx, yOpen, {
64
64
  class: "chartts-ohlc-tick",
65
65
  stroke: color,
66
66
  strokeWidth: lw,
67
67
  "data-series": 0,
68
68
  "data-index": i
69
69
  }));
70
- tickNodes.push(chunkUMIJYYF3_cjs.line(cx, yClose, cx + tickWidth, yClose, {
70
+ tickNodes.push(chunkJVVGQLJQ_cjs.line(cx, yClose, cx + tickWidth, yClose, {
71
71
  class: "chartts-ohlc-tick",
72
72
  stroke: color,
73
73
  strokeWidth: lw,
@@ -78,7 +78,7 @@ var ohlcChartType = {
78
78
  ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`
79
79
  }));
80
80
  }
81
- nodes.push(chunkUMIJYYF3_cjs.group(tickNodes, {
81
+ nodes.push(chunkJVVGQLJQ_cjs.group(tickNodes, {
82
82
  class: "chartts-series chartts-series-0",
83
83
  "data-series-name": series.name
84
84
  }));
@@ -102,5 +102,5 @@ var ohlcChartType = {
102
102
  };
103
103
 
104
104
  exports.ohlcChartType = ohlcChartType;
105
- //# sourceMappingURL=chunk-G6R6MSRF.cjs.map
106
- //# sourceMappingURL=chunk-G6R6MSRF.cjs.map
105
+ //# sourceMappingURL=chunk-QPHUAF3R.cjs.map
106
+ //# sourceMappingURL=chunk-QPHUAF3R.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/ohlc/ohlc-type.ts"],"names":["prepareData","getBandwidth","line","group"],"mappings":"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","file":"chunk-G6R6MSRF.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface OHLCOptions {\n /** OHLC data arrays. */\n ohlc?: {\n open: number[]\n high: number[]\n low: number[]\n close: number[]\n }\n /** Up color (close >= open). Default green. */\n upColor?: string\n /** Down color (close < open). Default red. */\n downColor?: string\n /** Line width for stems and ticks. Default 1.5. */\n lineWidth?: number\n}\n\n/**\n * OHLC (Open-High-Low-Close) chart — tick-mark style.\n *\n * Each bar is a vertical line (high→low) with horizontal ticks:\n * - Left tick = open price\n * - Right tick = close price\n * Color indicates direction (green=up, red=down).\n */\nexport const ohlcChartType: ChartTypePlugin = {\n type: 'ohlc',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n const prepared = prepareData(data, options)\n\n if (ohlc) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < ohlc.high.length; i++) {\n if (ohlc.high[i]! < yMin) yMin = ohlc.high[i]!\n if (ohlc.high[i]! > yMax) yMax = ohlc.high[i]!\n if (ohlc.low[i]! < yMin) yMin = ohlc.low[i]!\n if (ohlc.low[i]! > yMax) yMax = ohlc.low[i]!\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const lw = opts.lineWidth ?? 1.5\n\n const bw = getBandwidth(xScale)\n const tickWidth = bw * 0.3\n\n const tickNodes: RenderNode[] = []\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const open = ohlc.open[i]!\n const high = ohlc.high[i]!\n const low = ohlc.low[i]!\n const close = ohlc.close[i]!\n\n const cx = xScale.map(i)\n const isUp = close >= open\n const color = isUp ? upColor : downColor\n\n const yHigh = yScale.map(high)\n const yLow = yScale.map(low)\n const yOpen = yScale.map(open)\n const yClose = yScale.map(close)\n\n // Vertical stem (high → low)\n tickNodes.push(line(cx, yHigh, cx, yLow, {\n class: 'chartts-ohlc-stem',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Left tick (open)\n tickNodes.push(line(cx - tickWidth, yOpen, cx, yOpen, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Right tick (close)\n tickNodes.push(line(cx, yClose, cx + tickWidth, yClose, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`,\n }))\n }\n\n nodes.push(group(tickNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { xScale, yScale, options } = ctx\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return null\n\n const bw = getBandwidth(xScale)\n const half = bw * 0.35\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - half && mx <= cx + half) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(ohlc.close[i]!) }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/ohlc/ohlc-type.ts"],"names":["prepareData","getBandwidth","line","group"],"mappings":";;;;;;AAgCO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,OAAO,IAAA,CAAK,IAAA;AAClB,IAAA,MAAM,QAAA,GAAWA,6BAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAE1C,IAAA,IAAI,IAAA,EAAM;AACR,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,QAAA,IAAI,IAAA,CAAK,KAAK,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AAC5C,QAAA,IAAI,IAAA,CAAK,KAAK,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AAC5C,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,IAAI,CAAC,CAAA;AAC1C,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAK,MAAM,IAAA,GAAO,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC5C;AACA,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AACvB,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AAAA,IACzB;AAEA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,SAAQ,GAAI,GAAA;AAC1C,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,OAAO,IAAA,CAAK,IAAA;AAClB,IAAA,IAAI,CAAC,MAAM,OAAO,KAAA;AAElB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,KAAA;AAEpB,IAAA,MAAM,OAAA,GAAU,KAAK,OAAA,IAAW,mCAAA;AAChC,IAAA,MAAM,SAAA,GAAY,KAAK,SAAA,IAAa,+BAAA;AACpC,IAAA,MAAM,EAAA,GAAK,KAAK,SAAA,IAAa,GAAA;AAE7B,IAAA,MAAM,EAAA,GAAKC,+BAAa,MAAM,CAAA;AAC9B,IAAA,MAAM,YAAY,EAAA,GAAK,GAAA;AAEvB,IAAA,MAAM,YAA0B,EAAC;AAEjC,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,MAAA,MAAM,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,CAAC,CAAA;AACxB,MAAA,MAAM,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,CAAC,CAAA;AACxB,MAAA,MAAM,GAAA,GAAM,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,CAAC,CAAA;AAE1B,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,MAAM,OAAO,KAAA,IAAS,IAAA;AACtB,MAAA,MAAM,KAAA,GAAQ,OAAO,OAAA,GAAU,SAAA;AAE/B,MAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAC7B,MAAA,MAAM,IAAA,GAAO,MAAA,CAAO,GAAA,CAAI,GAAG,CAAA;AAC3B,MAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAC7B,MAAA,MAAM,MAAA,GAAS,MAAA,CAAO,GAAA,CAAI,KAAK,CAAA;AAG/B,MAAA,SAAA,CAAU,IAAA,CAAKC,sBAAA,CAAK,EAAA,EAAI,KAAA,EAAO,IAAI,IAAA,EAAM;AAAA,QACvC,KAAA,EAAO,mBAAA;AAAA,QACP,MAAA,EAAQ,KAAA;AAAA,QACR,WAAA,EAAa,EAAA;AAAA,QACb,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc;AAAA,OACf,CAAC,CAAA;AAGF,MAAA,SAAA,CAAU,KAAKA,sBAAA,CAAK,EAAA,GAAK,SAAA,EAAW,KAAA,EAAO,IAAI,KAAA,EAAO;AAAA,QACpD,KAAA,EAAO,mBAAA;AAAA,QACP,MAAA,EAAQ,KAAA;AAAA,QACR,WAAA,EAAa,EAAA;AAAA,QACb,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc;AAAA,OACf,CAAC,CAAA;AAGF,MAAA,SAAA,CAAU,KAAKA,sBAAA,CAAK,EAAA,EAAI,MAAA,EAAQ,EAAA,GAAK,WAAW,MAAA,EAAQ;AAAA,QACtD,KAAA,EAAO,mBAAA;AAAA,QACP,MAAA,EAAQ,KAAA;AAAA,QACR,WAAA,EAAa,EAAA;AAAA,QACb,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc,CAAA;AAAA,QACd,QAAA,EAAU,CAAA;AAAA,QACV,IAAA,EAAM,KAAA;AAAA,QACN,SAAA,EAAW,CAAA,EAAG,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAC,CAAA,GAAA,EAAM,IAAI,CAAA,EAAA,EAAK,IAAI,CAAA,EAAA,EAAK,GAAG,KAAK,KAAK,CAAA;AAAA,OACvE,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,SAAA,EAAW;AAAA,MAC1B,KAAA,EAAO,iCAAA;AAAA,MACP,oBAAoB,MAAA,CAAO;AAAA,KAC5B,CAAC,CAAA;AAEF,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,GAAA,EAA+B;AACrE,IAAA,MAAM,EAAE,MAAA,EAAQ,MAAA,EAAQ,OAAA,EAAQ,GAAI,GAAA;AACpC,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,OAAO,IAAA,CAAK,IAAA;AAClB,IAAA,IAAI,CAAC,MAAM,OAAO,IAAA;AAElB,IAAA,MAAM,EAAA,GAAKF,+BAAa,MAAM,CAAA;AAC9B,IAAA,MAAM,OAAO,EAAA,GAAK,IAAA;AAElB,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,QAAQ,CAAA,EAAA,EAAK;AACzC,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,IAAI,EAAA,IAAM,EAAA,GAAK,IAAA,IAAQ,EAAA,IAAM,KAAK,IAAA,EAAM;AACtC,QAAA,OAAO,EAAE,aAAa,CAAA,EAAG,UAAA,EAAY,GAAG,QAAA,EAAU,IAAA,CAAK,IAAI,EAAA,GAAK,EAAE,GAAG,CAAA,EAAG,EAAA,EAAI,GAAG,MAAA,CAAO,GAAA,CAAI,KAAK,KAAA,CAAM,CAAC,CAAE,CAAA,EAAE;AAAA,MAC5G;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-QPHUAF3R.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface OHLCOptions {\n /** OHLC data arrays. */\n ohlc?: {\n open: number[]\n high: number[]\n low: number[]\n close: number[]\n }\n /** Up color (close >= open). Default green. */\n upColor?: string\n /** Down color (close < open). Default red. */\n downColor?: string\n /** Line width for stems and ticks. Default 1.5. */\n lineWidth?: number\n}\n\n/**\n * OHLC (Open-High-Low-Close) chart — tick-mark style.\n *\n * Each bar is a vertical line (high→low) with horizontal ticks:\n * - Left tick = open price\n * - Right tick = close price\n * Color indicates direction (green=up, red=down).\n */\nexport const ohlcChartType: ChartTypePlugin = {\n type: 'ohlc',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n const prepared = prepareData(data, options)\n\n if (ohlc) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < ohlc.high.length; i++) {\n if (ohlc.high[i]! < yMin) yMin = ohlc.high[i]!\n if (ohlc.high[i]! > yMax) yMax = ohlc.high[i]!\n if (ohlc.low[i]! < yMin) yMin = ohlc.low[i]!\n if (ohlc.low[i]! > yMax) yMax = ohlc.low[i]!\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const lw = opts.lineWidth ?? 1.5\n\n const bw = getBandwidth(xScale)\n const tickWidth = bw * 0.3\n\n const tickNodes: RenderNode[] = []\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const open = ohlc.open[i]!\n const high = ohlc.high[i]!\n const low = ohlc.low[i]!\n const close = ohlc.close[i]!\n\n const cx = xScale.map(i)\n const isUp = close >= open\n const color = isUp ? upColor : downColor\n\n const yHigh = yScale.map(high)\n const yLow = yScale.map(low)\n const yOpen = yScale.map(open)\n const yClose = yScale.map(close)\n\n // Vertical stem (high → low)\n tickNodes.push(line(cx, yHigh, cx, yLow, {\n class: 'chartts-ohlc-stem',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Left tick (open)\n tickNodes.push(line(cx - tickWidth, yOpen, cx, yOpen, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Right tick (close)\n tickNodes.push(line(cx, yClose, cx + tickWidth, yClose, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`,\n }))\n }\n\n nodes.push(group(tickNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { xScale, yScale, options } = ctx\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return null\n\n const bw = getBandwidth(xScale)\n const half = bw * 0.35\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - half && mx <= cx + half) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(ohlc.close[i]!) }\n }\n }\n\n return null\n },\n}\n"]}