@chartts/core 0.1.2 → 0.1.3
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.
- package/LICENSE +21 -0
- package/dist/{area-type-B3CtuIIP.d.cts → area-type-BanqpQvK.d.cts} +1 -1
- package/dist/{area-type-DmB6fTVf.d.ts → area-type-Bzn6ur_t.d.ts} +1 -1
- package/dist/area.cjs +10 -10
- package/dist/area.d.cts +4 -4
- package/dist/area.d.ts +4 -4
- package/dist/area.js +5 -5
- package/dist/{bar-type-CkI-kkrC.d.cts → bar-type-BjYOtm2e.d.cts} +1 -1
- package/dist/{bar-type-Bne_khsO.d.ts → bar-type-D1gkUeQ2.d.ts} +1 -1
- package/dist/bar.cjs +9 -9
- package/dist/bar.d.cts +4 -4
- package/dist/bar.d.ts +4 -4
- package/dist/bar.js +4 -4
- package/dist/{baseline-type-B1O4XHT3.d.ts → baseline-type-DnAv8oax.d.ts} +1 -1
- package/dist/{baseline-type-BAPrZJ5W.d.cts → baseline-type-DskNy6iR.d.cts} +1 -1
- package/dist/baseline.cjs +9 -9
- package/dist/baseline.d.cts +4 -4
- package/dist/baseline.d.ts +4 -4
- package/dist/baseline.js +4 -4
- package/dist/{boxplot-type-CEWf7p5X.d.ts → boxplot-type-Bi46NGr5.d.ts} +1 -1
- package/dist/{boxplot-type-Da8_smoe.d.cts → boxplot-type-Df2L92GY.d.cts} +1 -1
- package/dist/boxplot.cjs +9 -9
- package/dist/boxplot.d.cts +4 -4
- package/dist/boxplot.d.ts +4 -4
- package/dist/boxplot.js +4 -4
- package/dist/{bubble-type-Dxb2JCKv.d.cts → bubble-type-D2_dA-tK.d.cts} +1 -1
- package/dist/{bubble-type-pru5MgB7.d.ts → bubble-type-XCkdPCxY.d.ts} +1 -1
- package/dist/bubble.cjs +9 -9
- package/dist/bubble.d.cts +4 -4
- package/dist/bubble.d.ts +4 -4
- package/dist/bubble.js +4 -4
- package/dist/{bullet-type-CPEYkEvt.d.ts → bullet-type-CluDVdqG.d.ts} +1 -1
- package/dist/{bullet-type-khCmwFqH.d.cts → bullet-type-yyHFEoBR.d.cts} +1 -1
- package/dist/bullet.cjs +10 -10
- package/dist/bullet.d.cts +4 -4
- package/dist/bullet.d.ts +4 -4
- package/dist/bullet.js +5 -5
- package/dist/{calendar-type-yJWPY6qT.d.ts → calendar-type-BXl4jP0I.d.ts} +1 -1
- package/dist/{calendar-type-Br5mpdea.d.cts → calendar-type-_hW3OLW-.d.cts} +1 -1
- package/dist/calendar.cjs +10 -10
- package/dist/calendar.d.cts +4 -4
- package/dist/calendar.d.ts +4 -4
- package/dist/calendar.js +5 -5
- package/dist/{candlestick-type-CtLZy_uC.d.ts → candlestick-type-CAfkfMPN.d.ts} +1 -1
- package/dist/{candlestick-type-CazXUb77.d.cts → candlestick-type-D-fhJzmV.d.cts} +1 -1
- package/dist/candlestick.cjs +9 -9
- package/dist/candlestick.d.cts +4 -4
- package/dist/candlestick.d.ts +4 -4
- package/dist/candlestick.js +4 -4
- package/dist/{chord-type-ruvHboZl.d.ts → chord-type-BLjyRxsx.d.ts} +1 -1
- package/dist/{chord-type-ChIZaOZd.d.cts → chord-type-Dvuvx5rp.d.cts} +1 -1
- package/dist/chord.cjs +10 -10
- package/dist/chord.d.cts +4 -4
- package/dist/chord.d.ts +4 -4
- package/dist/chord.js +5 -5
- package/dist/{chunk-FEQKBVCZ.cjs → chunk-2EZ2TVYT.cjs} +14 -14
- package/dist/chunk-2EZ2TVYT.cjs.map +1 -0
- package/dist/{chunk-GI7PBJSK.js → chunk-2ITF366P.js} +4 -4
- package/dist/chunk-2ITF366P.js.map +1 -0
- package/dist/{chunk-YMJQUKKX.js → chunk-2MWA7H6J.js} +68 -42
- package/dist/chunk-2MWA7H6J.js.map +1 -0
- package/dist/{chunk-CJEMSKW3.js → chunk-3SOKHPAO.js} +217 -57
- package/dist/chunk-3SOKHPAO.js.map +1 -0
- package/dist/{chunk-3N447NTJ.cjs → chunk-3V64BDKG.cjs} +14 -14
- package/dist/chunk-3V64BDKG.cjs.map +1 -0
- package/dist/{chunk-DZW35WR2.js → chunk-46ZZTP5B.js} +5 -5
- package/dist/chunk-46ZZTP5B.js.map +1 -0
- package/dist/{chunk-PCTMS2PX.cjs → chunk-47EP245Y.cjs} +19 -9
- package/dist/chunk-47EP245Y.cjs.map +1 -0
- package/dist/{chunk-DZHP4UUE.cjs → chunk-4H2LGLGI.cjs} +16 -12
- package/dist/chunk-4H2LGLGI.cjs.map +1 -0
- package/dist/{chunk-7HOU6XMW.js → chunk-4L62MAZA.js} +25 -28
- package/dist/chunk-4L62MAZA.js.map +1 -0
- package/dist/{chunk-GQR7IHER.js → chunk-4ORSJM2I.js} +6 -6
- package/dist/chunk-4ORSJM2I.js.map +1 -0
- package/dist/{chunk-FQG4DRJS.cjs → chunk-4WQUX2B4.cjs} +71 -45
- package/dist/chunk-4WQUX2B4.cjs.map +1 -0
- package/dist/{chunk-3QXN7JBV.js → chunk-4XVJYNOT.js} +7 -5
- package/dist/chunk-4XVJYNOT.js.map +1 -0
- package/dist/{chunk-6WJJ26J5.js → chunk-5J26EN5I.js} +6 -6
- package/dist/chunk-5J26EN5I.js.map +1 -0
- package/dist/{chunk-K2EZ4SS4.js → chunk-5YNIOIKK.js} +5 -5
- package/dist/chunk-5YNIOIKK.js.map +1 -0
- package/dist/{chunk-5LQ26P4J.cjs → chunk-66BHM3UN.cjs} +11 -11
- package/dist/chunk-66BHM3UN.cjs.map +1 -0
- package/dist/{chunk-DAH76GIX.cjs → chunk-6E6ZDWZD.cjs} +11 -11
- package/dist/chunk-6E6ZDWZD.cjs.map +1 -0
- package/dist/{chunk-COPERSVL.cjs → chunk-6EGHZDZI.cjs} +15 -15
- package/dist/{chunk-COPERSVL.cjs.map → chunk-6EGHZDZI.cjs.map} +1 -1
- package/dist/{chunk-KHQRHTTN.js → chunk-6JNW43SE.js} +40 -30
- package/dist/chunk-6JNW43SE.js.map +1 -0
- package/dist/{chunk-3YFDZGHO.cjs → chunk-6UWYKNFN.cjs} +13 -13
- package/dist/{chunk-3YFDZGHO.cjs.map → chunk-6UWYKNFN.cjs.map} +1 -1
- package/dist/{chunk-CHERQT4B.js → chunk-7PNCJ4OQ.js} +4 -4
- package/dist/chunk-7PNCJ4OQ.js.map +1 -0
- package/dist/{chunk-2KMMVJEE.cjs → chunk-7ZPHLIFP.cjs} +7 -7
- package/dist/chunk-7ZPHLIFP.cjs.map +1 -0
- package/dist/{chunk-FIAKZSRR.cjs → chunk-AG7VY6MJ.cjs} +19 -12
- package/dist/chunk-AG7VY6MJ.cjs.map +1 -0
- package/dist/{chunk-7MXBXWVD.js → chunk-ASNAQ35U.js} +5 -5
- package/dist/chunk-ASNAQ35U.js.map +1 -0
- package/dist/{chunk-DKVRRL3F.js → chunk-BT5H3WMI.js} +6 -6
- package/dist/chunk-BT5H3WMI.js.map +1 -0
- package/dist/{chunk-S64PTNT7.cjs → chunk-BYB3LQAT.cjs} +27 -30
- package/dist/chunk-BYB3LQAT.cjs.map +1 -0
- package/dist/{chunk-NZWFBAFQ.js → chunk-CCMLOCTH.js} +30 -4
- package/dist/chunk-CCMLOCTH.js.map +1 -0
- package/dist/{chunk-HOPFELRP.cjs → chunk-CDS2NXGT.cjs} +4 -4
- package/dist/{chunk-HOPFELRP.cjs.map → chunk-CDS2NXGT.cjs.map} +1 -1
- package/dist/{chunk-7JN6GXML.cjs → chunk-DKXW2FQC.cjs} +13 -11
- package/dist/chunk-DKXW2FQC.cjs.map +1 -0
- package/dist/{chunk-QCR6L55R.js → chunk-DR5MQC3W.js} +8 -5
- package/dist/chunk-DR5MQC3W.js.map +1 -0
- package/dist/{chunk-GUVPVNPD.cjs → chunk-DRIJNFWP.cjs} +11 -11
- package/dist/chunk-DRIJNFWP.cjs.map +1 -0
- package/dist/{chunk-BMTVFAX2.js → chunk-DX4FBN3I.js} +230 -99
- package/dist/chunk-DX4FBN3I.js.map +1 -0
- package/dist/{chunk-IKUA7O73.cjs → chunk-E43H3A3G.cjs} +7 -7
- package/dist/{chunk-IKUA7O73.cjs.map → chunk-E43H3A3G.cjs.map} +1 -1
- package/dist/{chunk-K7UR7GYC.cjs → chunk-ECB3UPTC.cjs} +13 -13
- package/dist/chunk-ECB3UPTC.cjs.map +1 -0
- package/dist/{chunk-TVPS2NJH.cjs → chunk-EHKHXQ46.cjs} +11 -11
- package/dist/chunk-EHKHXQ46.cjs.map +1 -0
- package/dist/{chunk-SLJNRP7O.cjs → chunk-EHNX3MG3.cjs} +14 -24
- package/dist/chunk-EHNX3MG3.cjs.map +1 -0
- package/dist/{chunk-MQBKLKYF.js → chunk-F5AOBHQY.js} +4 -4
- package/dist/{chunk-MQBKLKYF.js.map → chunk-F5AOBHQY.js.map} +1 -1
- package/dist/{chunk-KUFDELQM.cjs → chunk-FDNJNVKA.cjs} +10 -10
- package/dist/chunk-FDNJNVKA.cjs.map +1 -0
- package/dist/{chunk-NML7F34A.js → chunk-FSDI3NJV.js} +4 -4
- package/dist/chunk-FSDI3NJV.js.map +1 -0
- package/dist/{chunk-CCHMQZIB.js → chunk-FV7R2LLD.js} +5 -5
- package/dist/chunk-FV7R2LLD.js.map +1 -0
- package/dist/{chunk-ID7GYRYL.cjs → chunk-FZIBM3G5.cjs} +11 -11
- package/dist/chunk-FZIBM3G5.cjs.map +1 -0
- package/dist/{chunk-43WDYYVH.cjs → chunk-G6R6MSRF.cjs} +10 -10
- package/dist/chunk-G6R6MSRF.cjs.map +1 -0
- package/dist/{chunk-VK72MICB.cjs → chunk-GAWIUMAK.cjs} +8 -8
- package/dist/{chunk-VK72MICB.cjs.map → chunk-GAWIUMAK.cjs.map} +1 -1
- package/dist/{chunk-3NWZJCWL.js → chunk-GPSNBZPX.js} +5 -5
- package/dist/chunk-GPSNBZPX.js.map +1 -0
- package/dist/{chunk-MGYBMQAX.cjs → chunk-HFWO37RY.cjs} +9 -9
- package/dist/chunk-HFWO37RY.cjs.map +1 -0
- package/dist/{chunk-U7GBOQXX.js → chunk-HMB2RIEE.js} +5 -5
- package/dist/chunk-HMB2RIEE.js.map +1 -0
- package/dist/{chunk-RLH3PS3Y.js → chunk-ILCWDAKD.js} +3 -3
- package/dist/{chunk-RLH3PS3Y.js.map → chunk-ILCWDAKD.js.map} +1 -1
- package/dist/{chunk-L37ZPX6D.js → chunk-IRUIWMH6.js} +5 -5
- package/dist/chunk-IRUIWMH6.js.map +1 -0
- package/dist/{chunk-B7IV2PB3.cjs → chunk-JNQ4NL3R.cjs} +9 -9
- package/dist/chunk-JNQ4NL3R.cjs.map +1 -0
- package/dist/{chunk-FSKUEB7P.js → chunk-K5TPJVOK.js} +3 -3
- package/dist/{chunk-FSKUEB7P.js.map → chunk-K5TPJVOK.js.map} +1 -1
- package/dist/{chunk-5M624BRW.js → chunk-KTCP23W6.js} +4 -4
- package/dist/chunk-KTCP23W6.js.map +1 -0
- package/dist/{chunk-2L46SAT7.js → chunk-LIY7MYRG.js} +30 -5
- package/dist/chunk-LIY7MYRG.js.map +1 -0
- package/dist/{chunk-AA45U5KV.js → chunk-LK2A3HBT.js} +5 -5
- package/dist/chunk-LK2A3HBT.js.map +1 -0
- package/dist/{chunk-GMLJDDHZ.js → chunk-MPQECPE3.js} +3 -3
- package/dist/{chunk-GMLJDDHZ.js.map → chunk-MPQECPE3.js.map} +1 -1
- package/dist/{chunk-T6LXFMBR.cjs → chunk-MY4KMVJ5.cjs} +9 -9
- package/dist/{chunk-T6LXFMBR.cjs.map → chunk-MY4KMVJ5.cjs.map} +1 -1
- package/dist/chunk-MYXLKVJE.js +889 -0
- package/dist/chunk-MYXLKVJE.js.map +1 -0
- package/dist/{chunk-N7NZQVIV.cjs → chunk-NG7DRWWT.cjs} +7 -7
- package/dist/chunk-NG7DRWWT.cjs.map +1 -0
- package/dist/{chunk-MZQY2FTP.cjs → chunk-NGKUI7XE.cjs} +13 -13
- package/dist/chunk-NGKUI7XE.cjs.map +1 -0
- package/dist/{chunk-D2IP3MWJ.cjs → chunk-OAIMES5S.cjs} +219 -59
- package/dist/chunk-OAIMES5S.cjs.map +1 -0
- package/dist/{chunk-XKDBNAHH.cjs → chunk-OAL5RS2X.cjs} +11 -11
- package/dist/chunk-OAL5RS2X.cjs.map +1 -0
- package/dist/{chunk-FTKL3UAN.cjs → chunk-OFEROCC5.cjs} +6 -6
- package/dist/{chunk-FTKL3UAN.cjs.map → chunk-OFEROCC5.cjs.map} +1 -1
- package/dist/{chunk-IAE4VRB7.cjs → chunk-OUN3MWRQ.cjs} +35 -10
- package/dist/chunk-OUN3MWRQ.cjs.map +1 -0
- package/dist/{chunk-TIHVTKXS.cjs → chunk-PQCHNZHM.cjs} +11 -11
- package/dist/chunk-PQCHNZHM.cjs.map +1 -0
- package/dist/{chunk-BMEMMYVF.js → chunk-PVPTFMJJ.js} +5 -5
- package/dist/{chunk-BMEMMYVF.js.map → chunk-PVPTFMJJ.js.map} +1 -1
- package/dist/{chunk-LCEMO7NI.js → chunk-QERWC7U6.js} +3 -3
- package/dist/{chunk-LCEMO7NI.js.map → chunk-QERWC7U6.js.map} +1 -1
- package/dist/{chunk-2PRCN5OJ.cjs → chunk-QKJUAMRK.cjs} +6 -6
- package/dist/{chunk-2PRCN5OJ.cjs.map → chunk-QKJUAMRK.cjs.map} +1 -1
- package/dist/{chunk-WS2AL7GY.cjs → chunk-R6ZDSXN7.cjs} +34 -8
- package/dist/chunk-R6ZDSXN7.cjs.map +1 -0
- package/dist/{chunk-FKVYS4RB.js → chunk-RFEKSP62.js} +15 -8
- package/dist/chunk-RFEKSP62.js.map +1 -0
- package/dist/{chunk-FKAA5FNG.cjs → chunk-RHTVKBRC.cjs} +10 -10
- package/dist/chunk-RHTVKBRC.cjs.map +1 -0
- package/dist/{chunk-QRTYX5KO.js → chunk-RJIPFWW7.js} +5 -5
- package/dist/chunk-RJIPFWW7.js.map +1 -0
- package/dist/{chunk-GL3M7MAM.js → chunk-RN7NNB6I.js} +4 -4
- package/dist/chunk-RN7NNB6I.js.map +1 -0
- package/dist/{chunk-VGGKMTO6.js → chunk-RQJRVKAH.js} +4 -4
- package/dist/chunk-RQJRVKAH.js.map +1 -0
- package/dist/{chunk-AAKS22M3.cjs → chunk-RWQH5EO5.cjs} +12 -12
- package/dist/{chunk-AAKS22M3.cjs.map → chunk-RWQH5EO5.cjs.map} +1 -1
- package/dist/{chunk-SKREYNRK.cjs → chunk-SXVMEC6N.cjs} +45 -35
- package/dist/chunk-SXVMEC6N.cjs.map +1 -0
- package/dist/{chunk-4ABM7UYD.js → chunk-TVDQNLGJ.js} +4 -4
- package/dist/chunk-TVDQNLGJ.js.map +1 -0
- package/dist/{chunk-QXQSJ3FZ.js → chunk-TWSWD4PU.js} +5 -5
- package/dist/chunk-TWSWD4PU.js.map +1 -0
- package/dist/chunk-UFMPALRH.js +126 -0
- package/dist/chunk-UFMPALRH.js.map +1 -0
- package/dist/{chunk-3TLJCGGQ.cjs → chunk-UMIJYYF3.cjs} +230 -99
- package/dist/chunk-UMIJYYF3.cjs.map +1 -0
- package/dist/{chunk-DZKYVTV3.js → chunk-UZH6PVHD.js} +5 -5
- package/dist/{chunk-DZKYVTV3.js.map → chunk-UZH6PVHD.js.map} +1 -1
- package/dist/{chunk-ARQLGTTV.js → chunk-V45C74EB.js} +5 -5
- package/dist/{chunk-ARQLGTTV.js.map → chunk-V45C74EB.js.map} +1 -1
- package/dist/{chunk-EAKXLFOR.cjs → chunk-VBEZS3Q4.cjs} +11 -11
- package/dist/chunk-VBEZS3Q4.cjs.map +1 -0
- package/dist/{chunk-IXFSJBJS.js → chunk-WJP6CRML.js} +4 -14
- package/dist/chunk-WJP6CRML.js.map +1 -0
- package/dist/{chunk-KEMT7F5H.cjs → chunk-WVQVGQJO.cjs} +9 -9
- package/dist/chunk-WVQVGQJO.cjs.map +1 -0
- package/dist/chunk-WYIIWTIR.cjs +128 -0
- package/dist/chunk-WYIIWTIR.cjs.map +1 -0
- package/dist/{chunk-EYN74SQ5.js → chunk-XE5ZYFGM.js} +5 -5
- package/dist/chunk-XE5ZYFGM.js.map +1 -0
- package/dist/{chunk-S6NGWPXC.js → chunk-XKERO5K2.js} +4 -4
- package/dist/chunk-XKERO5K2.js.map +1 -0
- package/dist/chunk-XN6YS55F.cjs +891 -0
- package/dist/chunk-XN6YS55F.cjs.map +1 -0
- package/dist/{chunk-JT6H7G52.js → chunk-XWCY67K5.js} +5 -5
- package/dist/chunk-XWCY67K5.js.map +1 -0
- package/dist/{chunk-SC5BGA2N.cjs → chunk-XWN43PZF.cjs} +8 -8
- package/dist/chunk-XWN43PZF.cjs.map +1 -0
- package/dist/{chunk-Y4HJCMB4.cjs → chunk-YDQDZWZ7.cjs} +7 -7
- package/dist/chunk-YDQDZWZ7.cjs.map +1 -0
- package/dist/{chunk-VJQCHBS6.js → chunk-YJHB2GHQ.js} +15 -5
- package/dist/chunk-YJHB2GHQ.js.map +1 -0
- package/dist/{chunk-IUYPKYOU.js → chunk-YOLF5DYU.js} +9 -5
- package/dist/chunk-YOLF5DYU.js.map +1 -0
- package/dist/{chunk-ALRCYQQX.cjs → chunk-YX6RW6ZW.cjs} +10 -7
- package/dist/chunk-YX6RW6ZW.cjs.map +1 -0
- package/dist/{chunk-27E6G2GT.js → chunk-YZQROIJY.js} +4 -4
- package/dist/chunk-YZQROIJY.js.map +1 -0
- package/dist/{chunk-M6JYSINX.cjs → chunk-ZFSFOD5W.cjs} +8 -8
- package/dist/chunk-ZFSFOD5W.cjs.map +1 -0
- package/dist/{chunk-EFRBTSUO.cjs → chunk-ZTUKOCJN.cjs} +4 -4
- package/dist/{chunk-EFRBTSUO.cjs.map → chunk-ZTUKOCJN.cjs.map} +1 -1
- package/dist/{chunk-MVJKRPX7.js → chunk-ZY7ETQD6.js} +3 -3
- package/dist/{chunk-MVJKRPX7.js.map → chunk-ZY7ETQD6.js.map} +1 -1
- package/dist/{combo-type-wodyLq1f.d.cts → combo-type-CCrfKcTc.d.cts} +1 -1
- package/dist/{combo-type-BdSohVyy.d.ts → combo-type-Drb7xHSH.d.ts} +1 -1
- package/dist/combo.cjs +9 -9
- package/dist/combo.d.cts +4 -4
- package/dist/combo.d.ts +4 -4
- package/dist/combo.js +4 -4
- package/dist/{custom-type-B6w1n5Ua.d.cts → custom-type-CUdaJtsU.d.cts} +1 -1
- package/dist/{custom-type-XFjuPwCr.d.ts → custom-type-DeCdYBIK.d.ts} +1 -1
- package/dist/custom.cjs +10 -10
- package/dist/custom.d.cts +4 -4
- package/dist/custom.d.ts +4 -4
- package/dist/custom.js +5 -5
- package/dist/donut.cjs +11 -10
- package/dist/donut.cjs.map +1 -1
- package/dist/donut.d.cts +4 -4
- package/dist/donut.d.ts +4 -4
- package/dist/donut.js +6 -5
- package/dist/donut.js.map +1 -1
- package/dist/{dumbbell-type-w424KzI2.d.cts → dumbbell-type--8jqwUbP.d.cts} +1 -1
- package/dist/{dumbbell-type-DPSE0OTg.d.ts → dumbbell-type-FrAcyybz.d.ts} +1 -1
- package/dist/dumbbell.cjs +10 -10
- package/dist/dumbbell.d.cts +4 -4
- package/dist/dumbbell.d.ts +4 -4
- package/dist/dumbbell.js +5 -5
- package/dist/{engine-CNukbv7k.d.ts → engine-7vdmtmTm.d.cts} +20 -0
- package/dist/{engine-CNukbv7k.d.cts → engine-7vdmtmTm.d.ts} +20 -0
- package/dist/{factory-dbngWV4d.d.cts → factory-DVmPQ-5P.d.cts} +1 -1
- package/dist/{factory-jRzNNxwj.d.ts → factory-DXvw-FCZ.d.ts} +1 -1
- package/dist/{funnel-type-CMXGQq4T.d.ts → funnel-type-BhtkYPBR.d.ts} +1 -1
- package/dist/{funnel-type-BeVl3ohX.d.cts → funnel-type-BqLhbGkI.d.cts} +1 -1
- package/dist/funnel.cjs +10 -10
- package/dist/funnel.d.cts +4 -4
- package/dist/funnel.d.ts +4 -4
- package/dist/funnel.js +5 -5
- package/dist/{gauge-type-DmjDdfsY.d.cts → gauge-type-NeAO1otO.d.cts} +1 -1
- package/dist/{gauge-type-BpDBwCeD.d.ts → gauge-type-h6z_4lnL.d.ts} +1 -1
- package/dist/gauge.cjs +10 -10
- package/dist/gauge.d.cts +4 -4
- package/dist/gauge.d.ts +4 -4
- package/dist/gauge.js +5 -5
- package/dist/geo.cjs +12 -12
- package/dist/geo.d.cts +4 -4
- package/dist/geo.d.ts +4 -4
- package/dist/geo.js +5 -5
- package/dist/graph-type-Bg04GFeS.d.ts +15 -0
- package/dist/graph-type-DF-vww8T.d.cts +15 -0
- package/dist/graph.cjs +63 -10
- package/dist/graph.cjs.map +1 -1
- package/dist/graph.d.cts +65 -5
- package/dist/graph.d.ts +65 -5
- package/dist/graph.js +58 -6
- package/dist/graph.js.map +1 -1
- package/dist/{heatmap-type-q6nNhVTr.d.ts → heatmap-type-BAxcLZ1S.d.ts} +1 -1
- package/dist/{heatmap-type-D0shkxK7.d.cts → heatmap-type-CkmoO1Vi.d.cts} +1 -1
- package/dist/heatmap.cjs +10 -10
- package/dist/heatmap.d.cts +4 -4
- package/dist/heatmap.d.ts +4 -4
- package/dist/heatmap.js +5 -5
- package/dist/{histogram-type-BWil-Rb7.d.cts → histogram-type-BMxwKNZD.d.cts} +1 -1
- package/dist/{histogram-type-CF593WSp.d.ts → histogram-type-Bz1r_8dr.d.ts} +1 -1
- package/dist/histogram.cjs +9 -9
- package/dist/histogram.d.cts +4 -4
- package/dist/histogram.d.ts +4 -4
- package/dist/histogram.js +4 -4
- package/dist/{horizontal-bar-type-0mqnyMUR.d.cts → horizontal-bar-type-CPMqObyF.d.cts} +1 -1
- package/dist/{horizontal-bar-type-DAlrxY0h.d.ts → horizontal-bar-type-oNPstB_X.d.ts} +1 -1
- package/dist/horizontal-bar.cjs +9 -9
- package/dist/horizontal-bar.d.cts +4 -4
- package/dist/horizontal-bar.d.ts +4 -4
- package/dist/horizontal-bar.js +4 -4
- package/dist/index.cjs +180 -179
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +47 -47
- package/dist/index.d.ts +47 -47
- package/dist/index.js +92 -91
- package/dist/index.js.map +1 -1
- package/dist/{kagi-type-Y5XUVm3h.d.ts → kagi-type-DLvdmNEs.d.ts} +1 -1
- package/dist/{kagi-type-aG-Q1bWk.d.cts → kagi-type-DolumABK.d.cts} +1 -1
- package/dist/kagi.cjs +10 -10
- package/dist/kagi.d.cts +4 -4
- package/dist/kagi.d.ts +4 -4
- package/dist/kagi.js +5 -5
- package/dist/{line-type-Diw0nXj7.d.ts → line-type-CQ_Sbwde.d.ts} +1 -1
- package/dist/{line-type-B8lgTFjb.d.cts → line-type-DU-iLYyU.d.cts} +1 -1
- package/dist/line.cjs +9 -9
- package/dist/line.d.cts +4 -4
- package/dist/line.d.ts +4 -4
- package/dist/line.js +4 -4
- package/dist/{lines-type-CGrg_mDi.d.cts → lines-type-BZF5YnFG.d.cts} +1 -1
- package/dist/{lines-type-V-seVNZ4.d.ts → lines-type-CkKW7kQN.d.ts} +1 -1
- package/dist/lines.cjs +10 -10
- package/dist/lines.d.cts +4 -4
- package/dist/lines.d.ts +4 -4
- package/dist/lines.js +5 -5
- package/dist/{lollipop-type-CoTzKLSu.d.cts → lollipop-type-BUeY0pGU.d.cts} +1 -1
- package/dist/{lollipop-type-Ygc4rRql.d.ts → lollipop-type-DY7z1meu.d.ts} +1 -1
- package/dist/lollipop.cjs +9 -9
- package/dist/lollipop.d.cts +4 -4
- package/dist/lollipop.d.ts +4 -4
- package/dist/lollipop.js +4 -4
- package/dist/{matrix-type-Crb_NwUJ.d.cts → matrix-type-DZBt3yku.d.cts} +1 -1
- package/dist/{matrix-type-Dag1VLCY.d.ts → matrix-type-DkaWmxKb.d.ts} +1 -1
- package/dist/matrix.cjs +10 -10
- package/dist/matrix.d.cts +4 -4
- package/dist/matrix.d.ts +4 -4
- package/dist/matrix.js +5 -5
- package/dist/{ohlc-type-BQBHvVJO.d.cts → ohlc-type-C6NE-Bb3.d.cts} +1 -1
- package/dist/{ohlc-type-CGR-vRGL.d.ts → ohlc-type-eQd0E8lm.d.ts} +1 -1
- package/dist/ohlc.cjs +9 -9
- package/dist/ohlc.d.cts +4 -4
- package/dist/ohlc.d.ts +4 -4
- package/dist/ohlc.js +4 -4
- package/dist/{parallel-type-D-S-EqeC.d.cts → parallel-type-Cn2B_2-r.d.cts} +1 -1
- package/dist/{parallel-type-6t6xyHMg.d.ts → parallel-type-D4B96-R-.d.ts} +1 -1
- package/dist/parallel.cjs +10 -10
- package/dist/parallel.d.cts +4 -4
- package/dist/parallel.d.ts +4 -4
- package/dist/parallel.js +5 -5
- package/dist/{pictorialbar-type-A-8mTX1N.d.ts → pictorialbar-type-CoClaroO.d.ts} +1 -1
- package/dist/{pictorialbar-type-CnJEH9GZ.d.cts → pictorialbar-type-jiWGSHOU.d.cts} +1 -1
- package/dist/pictorialbar.cjs +10 -10
- package/dist/pictorialbar.d.cts +4 -4
- package/dist/pictorialbar.d.ts +4 -4
- package/dist/pictorialbar.js +5 -5
- package/dist/{pie-type-S7kUKGRS.d.ts → pie-type-0inQl-lu.d.ts} +1 -1
- package/dist/{pie-type-duX5xkfQ.d.cts → pie-type-9iaid0XE.d.cts} +1 -1
- package/dist/pie.cjs +11 -10
- package/dist/pie.cjs.map +1 -1
- package/dist/pie.d.cts +4 -4
- package/dist/pie.d.ts +4 -4
- package/dist/pie.js +6 -5
- package/dist/pie.js.map +1 -1
- package/dist/{polar-type-CI6-I8Yg.d.cts → polar-type-BraqKI4A.d.ts} +2 -1
- package/dist/{polar-type-Dj21GIc9.d.ts → polar-type-DsB9FOAO.d.cts} +2 -1
- package/dist/polar.cjs +11 -10
- package/dist/polar.cjs.map +1 -1
- package/dist/polar.d.cts +4 -4
- package/dist/polar.d.ts +4 -4
- package/dist/polar.js +6 -5
- package/dist/polar.js.map +1 -1
- package/dist/{radar-type-CYjZHuKm.d.ts → radar-type-C0JiXn53.d.ts} +1 -1
- package/dist/{radar-type-Dgyr13Zd.d.cts → radar-type-DaLjHpgO.d.cts} +1 -1
- package/dist/radar.cjs +10 -10
- package/dist/radar.d.cts +4 -4
- package/dist/radar.d.ts +4 -4
- package/dist/radar.js +5 -5
- package/dist/{radialbar-type-CLZ8XgST.d.ts → radialbar-type-DMzib3wW.d.ts} +1 -1
- package/dist/{radialbar-type-C_SBXoaa.d.cts → radialbar-type-YtZDe2x4.d.cts} +1 -1
- package/dist/radialbar.cjs +10 -10
- package/dist/radialbar.d.cts +4 -4
- package/dist/radialbar.d.ts +4 -4
- package/dist/radialbar.js +5 -5
- package/dist/{range-type-_LbMV4tl.d.ts → range-type-RlwPvBxs.d.ts} +1 -1
- package/dist/{range-type-CkriEnLm.d.cts → range-type-imi4626F.d.cts} +1 -1
- package/dist/range.cjs +9 -9
- package/dist/range.d.cts +4 -4
- package/dist/range.d.ts +4 -4
- package/dist/range.js +4 -4
- package/dist/{renko-type-ejoXt2ro.d.ts → renko-type-Bv23hPuk.d.ts} +1 -1
- package/dist/{renko-type-43OXCtZ3.d.cts → renko-type-DEe4vBKT.d.cts} +1 -1
- package/dist/renko.cjs +10 -10
- package/dist/renko.d.cts +4 -4
- package/dist/renko.d.ts +4 -4
- package/dist/renko.js +5 -5
- package/dist/{sankey-type-DfkTUnXB.d.cts → sankey-type-B0LCLees.d.cts} +1 -1
- package/dist/{sankey-type-CN7PL5MQ.d.ts → sankey-type-Gr2owHtQ.d.ts} +1 -1
- package/dist/sankey.cjs +10 -10
- package/dist/sankey.d.cts +4 -4
- package/dist/sankey.d.ts +4 -4
- package/dist/sankey.js +5 -5
- package/dist/{scatter-type-CD7X1pZb.d.cts → scatter-type-C0vMtH11.d.cts} +1 -1
- package/dist/{scatter-type-D3HdPkZ6.d.ts → scatter-type-DPCIXt3X.d.ts} +1 -1
- package/dist/scatter.cjs +9 -9
- package/dist/scatter.d.cts +4 -4
- package/dist/scatter.d.ts +4 -4
- package/dist/scatter.js +4 -4
- package/dist/{sparkline-type-qt3yoLs7.d.cts → sparkline-type-BDDpw4DS.d.cts} +1 -1
- package/dist/{sparkline-type-COW3izgF.d.ts → sparkline-type-BtSsuoh4.d.ts} +1 -1
- package/dist/sparkline.cjs +9 -9
- package/dist/sparkline.d.cts +4 -4
- package/dist/sparkline.d.ts +4 -4
- package/dist/sparkline.js +4 -4
- package/dist/{stacked-bar-type-C-5pmb-D.d.ts → stacked-bar-type-5_GXIxLN.d.ts} +1 -1
- package/dist/{stacked-bar-type-Ct6HK2A0.d.cts → stacked-bar-type-BF4R1zEK.d.cts} +1 -1
- package/dist/stacked-bar.cjs +9 -9
- package/dist/stacked-bar.d.cts +4 -4
- package/dist/stacked-bar.d.ts +4 -4
- package/dist/stacked-bar.js +4 -4
- package/dist/{step-type-BSL-CUny.d.cts → step-type-CZJO5PE4.d.cts} +1 -1
- package/dist/{step-type-Cleoshov.d.ts → step-type-CoBGeRRR.d.ts} +1 -1
- package/dist/step.cjs +10 -10
- package/dist/step.d.cts +4 -4
- package/dist/step.d.ts +4 -4
- package/dist/step.js +5 -5
- package/dist/{sunburst-type-ZFw2w6m8.d.ts → sunburst-type-CAcFLV8s.d.ts} +1 -1
- package/dist/{sunburst-type-BOztb_Px.d.cts → sunburst-type-DgP1x1nn.d.cts} +1 -1
- package/dist/sunburst.cjs +11 -10
- package/dist/sunburst.cjs.map +1 -1
- package/dist/sunburst.d.cts +4 -4
- package/dist/sunburst.d.ts +4 -4
- package/dist/sunburst.js +6 -5
- package/dist/sunburst.js.map +1 -1
- package/dist/{themeriver-type-B5PYChcC.d.ts → themeriver-type-BxLJux1v.d.ts} +1 -1
- package/dist/{themeriver-type-BnRSsyal.d.cts → themeriver-type-CGn5zE2F.d.cts} +1 -1
- package/dist/themeriver.cjs +10 -10
- package/dist/themeriver.d.cts +4 -4
- package/dist/themeriver.d.ts +4 -4
- package/dist/themeriver.js +5 -5
- package/dist/{tree-type-B-bOSg0l.d.ts → tree-type-Dyw9F7oq.d.ts} +1 -1
- package/dist/{tree-type-Cz84wHnR.d.cts → tree-type-xf-pj4pG.d.cts} +1 -1
- package/dist/tree.cjs +10 -10
- package/dist/tree.d.cts +4 -4
- package/dist/tree.d.ts +4 -4
- package/dist/tree.js +5 -5
- package/dist/{treemap-type-DYDj-rWv.d.ts → treemap-type-B4ty-Vge.d.ts} +1 -1
- package/dist/{treemap-type-OBCGexiK.d.cts → treemap-type-CeLgbJFQ.d.cts} +1 -1
- package/dist/treemap.cjs +10 -10
- package/dist/treemap.d.cts +4 -4
- package/dist/treemap.d.ts +4 -4
- package/dist/treemap.js +5 -5
- package/dist/{volume-type-C9wRmKR6.d.ts → volume-type-2ZgLIkPV.d.ts} +1 -1
- package/dist/{volume-type-CfERBN5g.d.cts → volume-type-Dvnr4sC9.d.cts} +1 -1
- package/dist/volume.cjs +9 -9
- package/dist/volume.d.cts +4 -4
- package/dist/volume.d.ts +4 -4
- package/dist/volume.js +4 -4
- package/dist/{waterfall-type-hm5ylGgW.d.cts → waterfall-type-D_6Db7Zy.d.cts} +1 -1
- package/dist/{waterfall-type-CpdVtBi_.d.ts → waterfall-type-DsC5vlAP.d.ts} +1 -1
- package/dist/waterfall.cjs +9 -9
- package/dist/waterfall.d.cts +4 -4
- package/dist/waterfall.d.ts +4 -4
- package/dist/waterfall.js +4 -4
- package/dist/world-regions-C0JUJCGT.d.ts +25 -0
- package/dist/world-regions-gUFRPji8.d.cts +25 -0
- package/package.json +11 -7
- package/dist/chunk-27E6G2GT.js.map +0 -1
- package/dist/chunk-2KMMVJEE.cjs.map +0 -1
- package/dist/chunk-2L46SAT7.js.map +0 -1
- package/dist/chunk-3N447NTJ.cjs.map +0 -1
- package/dist/chunk-3NWZJCWL.js.map +0 -1
- package/dist/chunk-3QXN7JBV.js.map +0 -1
- package/dist/chunk-3TLJCGGQ.cjs.map +0 -1
- package/dist/chunk-43WDYYVH.cjs.map +0 -1
- package/dist/chunk-4ABM7UYD.js.map +0 -1
- package/dist/chunk-5LQ26P4J.cjs.map +0 -1
- package/dist/chunk-5M624BRW.js.map +0 -1
- package/dist/chunk-6WJJ26J5.js.map +0 -1
- package/dist/chunk-7HOU6XMW.js.map +0 -1
- package/dist/chunk-7JN6GXML.cjs.map +0 -1
- package/dist/chunk-7MXBXWVD.js.map +0 -1
- package/dist/chunk-AA45U5KV.js.map +0 -1
- package/dist/chunk-ALRCYQQX.cjs.map +0 -1
- package/dist/chunk-B7IV2PB3.cjs.map +0 -1
- package/dist/chunk-BMTVFAX2.js.map +0 -1
- package/dist/chunk-CCHMQZIB.js.map +0 -1
- package/dist/chunk-CHERQT4B.js.map +0 -1
- package/dist/chunk-CJEMSKW3.js.map +0 -1
- package/dist/chunk-D2IP3MWJ.cjs.map +0 -1
- package/dist/chunk-DAH76GIX.cjs.map +0 -1
- package/dist/chunk-DKVRRL3F.js.map +0 -1
- package/dist/chunk-DZHP4UUE.cjs.map +0 -1
- package/dist/chunk-DZW35WR2.js.map +0 -1
- package/dist/chunk-EAKXLFOR.cjs.map +0 -1
- package/dist/chunk-EYN74SQ5.js.map +0 -1
- package/dist/chunk-FEQKBVCZ.cjs.map +0 -1
- package/dist/chunk-FIAKZSRR.cjs.map +0 -1
- package/dist/chunk-FKAA5FNG.cjs.map +0 -1
- package/dist/chunk-FKVYS4RB.js.map +0 -1
- package/dist/chunk-FQG4DRJS.cjs.map +0 -1
- package/dist/chunk-GI7PBJSK.js.map +0 -1
- package/dist/chunk-GL3M7MAM.js.map +0 -1
- package/dist/chunk-GQR7IHER.js.map +0 -1
- package/dist/chunk-GUVPVNPD.cjs.map +0 -1
- package/dist/chunk-IAE4VRB7.cjs.map +0 -1
- package/dist/chunk-ID7GYRYL.cjs.map +0 -1
- package/dist/chunk-IUYPKYOU.js.map +0 -1
- package/dist/chunk-IXFSJBJS.js.map +0 -1
- package/dist/chunk-JT6H7G52.js.map +0 -1
- package/dist/chunk-K2EZ4SS4.js.map +0 -1
- package/dist/chunk-K7UR7GYC.cjs.map +0 -1
- package/dist/chunk-KEMT7F5H.cjs.map +0 -1
- package/dist/chunk-KHQRHTTN.js.map +0 -1
- package/dist/chunk-KUFDELQM.cjs.map +0 -1
- package/dist/chunk-L37ZPX6D.js.map +0 -1
- package/dist/chunk-M6JYSINX.cjs.map +0 -1
- package/dist/chunk-MGYBMQAX.cjs.map +0 -1
- package/dist/chunk-MZCKMTQE.cjs +0 -210
- package/dist/chunk-MZCKMTQE.cjs.map +0 -1
- package/dist/chunk-MZQY2FTP.cjs.map +0 -1
- package/dist/chunk-N7NZQVIV.cjs.map +0 -1
- package/dist/chunk-NML7F34A.js.map +0 -1
- package/dist/chunk-NQGZMWNT.js +0 -208
- package/dist/chunk-NQGZMWNT.js.map +0 -1
- package/dist/chunk-NZWFBAFQ.js.map +0 -1
- package/dist/chunk-PCTMS2PX.cjs.map +0 -1
- package/dist/chunk-QCR6L55R.js.map +0 -1
- package/dist/chunk-QRTYX5KO.js.map +0 -1
- package/dist/chunk-QXQSJ3FZ.js.map +0 -1
- package/dist/chunk-S64PTNT7.cjs.map +0 -1
- package/dist/chunk-S6NGWPXC.js.map +0 -1
- package/dist/chunk-SC5BGA2N.cjs.map +0 -1
- package/dist/chunk-SKREYNRK.cjs.map +0 -1
- package/dist/chunk-SLJNRP7O.cjs.map +0 -1
- package/dist/chunk-TIHVTKXS.cjs.map +0 -1
- package/dist/chunk-TVPS2NJH.cjs.map +0 -1
- package/dist/chunk-U7GBOQXX.js.map +0 -1
- package/dist/chunk-VGGKMTO6.js.map +0 -1
- package/dist/chunk-VJQCHBS6.js.map +0 -1
- package/dist/chunk-WS2AL7GY.cjs.map +0 -1
- package/dist/chunk-XKDBNAHH.cjs.map +0 -1
- package/dist/chunk-Y4HJCMB4.cjs.map +0 -1
- package/dist/chunk-YMJQUKKX.js.map +0 -1
- package/dist/graph-type-DkdAB6Vc.d.cts +0 -5
- package/dist/graph-type-ul9xwdf5.d.ts +0 -5
- package/dist/world-regions-D-TCHPZP.d.cts +0 -38
- package/dist/world-regions-DjMvYgFu.d.ts +0 -38
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/combo/combo-type.ts"],"names":[],"mappings":"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","file":"chunk-K2EZ4SS4.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Combo / Mixed chart — overlays bar + line on the same axes.\n *\n * Convention: series with `fill: true` or series at index 0 render as bars.\n * Remaining series render as lines with points.\n * Use the series `fill` flag to control: fill=false (or omitted after first) → line.\n *\n * Simple heuristic:\n * - series[0] → bars\n * - series[1..N] → lines\n */\nexport const comboChartType: ChartTypePlugin = {\n type: 'combo',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length === 0) return nodes\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Bars for series[0]\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue // skip missing data\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const isPositive = barSeries.values[i]! >= 0\n const y = isPositive ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const barFill = `url(#chartts-bar-${barSeries.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n if (r > 0 && h > r * 2) {\n const d = isPositive\n ? `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`\n : `M${formatNum(barX)},${formatNum(y)}V${formatNum(y + h - r)}Q${formatNum(barX)},${formatNum(y + h)},${formatNum(barX + r)},${formatNum(y + h)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y + h)},${formatNum(barX + barWidth)},${formatNum(y + h - r)}V${formatNum(y)}Z`\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n }\n }\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${barSeries.index}`,\n 'data-series-name': barSeries.name,\n }))\n\n // Lines for series[1..N]\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = options.colors[series.index % options.colors.length]!\n const lineNodes: RenderNode[] = []\n\n // Build line path\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) { started = false; continue } // break line at NaN\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n if (!started) {\n pb.moveTo(px, py)\n started = true\n } else {\n pb.lineTo(px, py)\n }\n }\n\n lineNodes.push(path(pb.build(), {\n class: 'chartts-line chartts-combo-line',\n stroke: color,\n strokeWidth: 2,\n fill: 'none',\n }))\n\n // Points\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n lineNodes.push(circle(px, py, 4, {\n class: 'chartts-point chartts-combo-point',\n fill: color,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(lineNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.series.length === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n // Check bar hits first (series[0])\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const y = barSeries.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0 }\n return best\n }\n }\n\n // Check line point hits (series[1..N])\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n const dx = mx - px\n const dy = my - py\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist && dist < 20) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/combo/combo-type.ts"],"names":["prepareData","getBandwidth","formatNum","path","rect","group","PathBuilder","circle"],"mappings":"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","file":"chunk-K7UR7GYC.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Combo / Mixed chart — overlays bar + line on the same axes.\n *\n * Convention: series with `fill: true` or series at index 0 render as bars.\n * Remaining series render as lines with points.\n * Use the series `fill` flag to control: fill=false (or omitted after first) → line.\n *\n * Simple heuristic:\n * - series[0] → bars\n * - series[1..N] → lines\n */\nexport const comboChartType: ChartTypePlugin = {\n type: 'combo',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length === 0) return nodes\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Bars for series[0]\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue // skip missing data\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const isPositive = barSeries.values[i]! >= 0\n const y = isPositive ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const barFill = `url(#chartts-bar-${barSeries.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n if (r > 0 && h > r * 2) {\n const d = isPositive\n ? `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`\n : `M${formatNum(barX)},${formatNum(y)}V${formatNum(y + h - r)}Q${formatNum(barX)},${formatNum(y + h)},${formatNum(barX + r)},${formatNum(y + h)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y + h)},${formatNum(barX + barWidth)},${formatNum(y + h - r)}V${formatNum(y)}Z`\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n }\n }\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${barSeries.index}`,\n 'data-series-name': barSeries.name,\n }))\n\n // Lines for series[1..N]\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = options.colors[series.index % options.colors.length]!\n const lineNodes: RenderNode[] = []\n\n // Build line path\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) { started = false; continue } // break line at NaN\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n if (!started) {\n pb.moveTo(px, py)\n started = true\n } else {\n pb.lineTo(px, py)\n }\n }\n\n lineNodes.push(path(pb.build(), {\n class: 'chartts-line chartts-combo-line',\n stroke: color,\n strokeWidth: 2,\n fill: 'none',\n }))\n\n // Points\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n lineNodes.push(circle(px, py, 4, {\n class: 'chartts-point chartts-combo-point',\n fill: color,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(lineNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.series.length === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n // Check bar hits first (series[0])\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const y = barSeries.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0 }\n return best\n }\n }\n\n // Check line point hits (series[1..N])\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n const dx = mx - px\n const dy = my - py\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist && dist < 20) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/renko/renko-type.ts"],"names":["prepareNoAxes","rect","group"],"mappings":";;;;;;AAiCO,IAAM,cAAA,GAAkC;AAAA,EAC7C,IAAA,EAAM,OAAA;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,OAAOA,+BAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,OAAA,EAAQ,GAAI,GAAA;AAChC,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,MAAA,GAAS,GAAG,OAAO,KAAA;AAEhD,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,OAAA,GAAU,KAAK,OAAA,IAAW,mCAAA;AAChC,IAAA,MAAM,SAAA,GAAY,KAAK,SAAA,IAAa,+BAAA;AACpC,IAAA,MAAM,GAAA,GAAM,KAAK,GAAA,IAAO,CAAA;AACxB,IAAA,MAAM,YAAA,GAAe,KAAK,YAAA,IAAgB,CAAA;AAE1C,IAAA,MAAM,SAAS,MAAA,CAAO,MAAA;AAGtB,IAAA,IAAI,YAAY,IAAA,CAAK,SAAA;AACrB,IAAA,IAAI,CAAC,SAAA,EAAW;AACd,MAAA,IAAI,WAAA,GAAc,CAAA;AAClB,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,QAAA,WAAA,IAAe,IAAA,CAAK,IAAI,MAAA,CAAO,CAAC,IAAK,MAAA,CAAO,CAAA,GAAI,CAAC,CAAE,CAAA;AAAA,MACrD;AACA,MAAA,MAAM,SAAA,GAAY,WAAA,IAAe,MAAA,CAAO,MAAA,GAAS,CAAA,CAAA;AACjD,MAAA,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,GAAA,EAAA,CAAM,KAAK,GAAA,CAAI,GAAG,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,GAAG,MAAM,KAAK,EAAE,CAAA;AAAA,IACxF;AAGA,IAAA,MAAM,MAAA,GAAS,kBAAA,CAAmB,MAAA,EAAQ,SAAS,CAAA;AACnD,IAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,KAAA;AAGhC,IAAA,IAAI,QAAA,GAAW,QAAA;AACf,IAAA,IAAI,QAAA,GAAW,CAAA,QAAA;AACf,IAAA,KAAA,MAAW,KAAK,MAAA,EAAQ;AACtB,MAAA,QAAA,GAAW,KAAK,GAAA,CAAI,QAAA,EAAU,CAAA,CAAE,IAAA,EAAM,EAAE,KAAK,CAAA;AAC7C,MAAA,QAAA,GAAW,KAAK,GAAA,CAAI,QAAA,EAAU,CAAA,CAAE,IAAA,EAAM,EAAE,KAAK,CAAA;AAAA,IAC/C;AACA,IAAA,MAAM,UAAA,GAAa,WAAW,QAAA,IAAY,CAAA;AAG1C,IAAA,MAAM,OAAA,GAAU,EAAA;AAChB,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,KAAA,GAAQ,OAAA,GAAU,CAAA;AAC3C,IAAA,MAAM,YAAA,GAAe,IAAA,CAAK,MAAA,GAAS,OAAA,GAAU,CAAA;AAC7C,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA;AAAA,MAAA,CACrB,WAAA,GAAc,GAAA,IAAO,MAAA,CAAO,MAAA,GAAS,MAAM,MAAA,CAAO,MAAA;AAAA,MACnD;AAAA,KACF;AAEA,IAAA,MAAM,kBAAkB,MAAA,CAAO,MAAA,GAAS,UAAA,GAAA,CAAc,MAAA,CAAO,SAAS,CAAA,IAAK,GAAA;AAC3E,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,CAAA,GAAA,CAAK,IAAA,CAAK,QAAQ,eAAA,IAAmB,CAAA;AAEzD,IAAA,MAAM,IAAA,GAAO,CAAC,CAAA,KAAc,IAAA,CAAK,IAAI,OAAA,GAAA,CAAW,CAAA,GAAA,CAAK,CAAA,GAAI,QAAA,IAAY,UAAA,IAAc,YAAA;AACnF,IAAA,MAAM,gBAAA,GAAoB,YAAY,UAAA,GAAc,YAAA;AAEpD,IAAA,MAAM,aAA2B,EAAC;AAElC,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,MAAA,MAAM,CAAA,GAAI,OAAO,CAAC,CAAA;AAClB,MAAA,MAAM,CAAA,GAAI,MAAA,GAAS,CAAA,IAAK,UAAA,GAAa,GAAA,CAAA;AACrC,MAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAK,GAAA,CAAI,EAAE,IAAA,EAAM,CAAA,CAAE,KAAK,CAAC,CAAA;AAC3C,MAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,gBAAA,EAAkB,CAAC,CAAA;AAEtC,MAAA,UAAA,CAAW,IAAA,CAAKC,sBAAA,CAAK,CAAA,EAAG,IAAA,EAAM,YAAY,CAAA,EAAG;AAAA,QAC3C,EAAA,EAAI,YAAA;AAAA,QAAc,EAAA,EAAI,YAAA;AAAA,QACtB,KAAA,EAAO,qBAAA;AAAA,QACP,IAAA,EAAM,CAAA,CAAE,IAAA,GAAO,OAAA,GAAU,SAAA;AAAA,QACzB,WAAA,EAAa,CAAA,CAAE,IAAA,GAAO,GAAA,GAAM,GAAA;AAAA,QAC5B,MAAA,EAAQ,CAAA,CAAE,IAAA,GAAO,OAAA,GAAU,SAAA;AAAA,QAC3B,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,SAAS,CAAA,GAAI,CAAC,KAAK,CAAA,CAAE,IAAA,GAAO,OAAO,MAAM,CAAA,CAAA,EAAI,EAAE,IAAA,CAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,MAAA,EAAI,EAAE,KAAA,CAAM,OAAA,CAAQ,CAAC,CAAC,CAAA;AAAA,OAChG,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,UAAA,EAAY;AAAA,MAC3B,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,IAAA,EAAM,IAAA,EAAK,GAAI,GAAA;AACvB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,IAAA;AAEpB,IAAA,MAAM,IAAA,GAAA,CAAQ,EAAA,GAAK,IAAA,CAAK,CAAA,IAAK,IAAA,CAAK,KAAA;AAClC,IAAA,MAAM,MAAM,IAAA,CAAK,KAAA,CAAM,QAAQ,MAAA,CAAO,MAAA,CAAO,SAAS,CAAA,CAAE,CAAA;AACxD,IAAA,IAAI,GAAA,IAAO,CAAA,IAAK,GAAA,GAAM,MAAA,CAAO,OAAO,MAAA,EAAQ;AAC1C,MAAA,OAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,GAAA,EAAK,UAAU,EAAA,EAAG;AAAA,IACzD;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AACF;AAKA,SAAS,kBAAA,CAAmB,QAAkB,SAAA,EAAiC;AAC7E,EAAA,MAAM,SAAuB,EAAC;AAC9B,EAAA,IAAI,MAAA,CAAO,MAAA,GAAS,CAAA,IAAK,SAAA,IAAa,GAAG,OAAO,MAAA;AAEhD,EAAA,IAAI,eAAe,IAAA,CAAK,KAAA,CAAM,OAAO,CAAC,CAAA,GAAK,SAAS,CAAA,GAAI,SAAA;AAExD,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,MAAM,CAAA,GAAI,OAAO,CAAC,CAAA;AAClB,IAAA,MAAM,OAAO,CAAA,GAAI,YAAA;AAEjB,IAAA,IAAI,IAAA,CAAK,GAAA,CAAI,IAAI,CAAA,IAAK,SAAA,EAAW;AAC/B,MAAA,MAAM,YAAY,IAAA,CAAK,KAAA,CAAM,KAAK,GAAA,CAAI,IAAI,IAAI,SAAS,CAAA;AACvD,MAAA,MAAM,OAAO,IAAA,GAAO,CAAA;AAEpB,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,SAAA,EAAW,CAAA,EAAA,EAAK;AAClC,QAAA,MAAM,IAAA,GAAO,YAAA;AACb,QAAA,YAAA,IAAgB,IAAA,GAAO,YAAY,CAAC,SAAA;AACpC,QAAA,MAAA,CAAO,KAAK,EAAE,IAAA,EAAM,KAAA,EAAO,YAAA,EAAc,MAAM,CAAA;AAAA,MACjD;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,MAAA;AACT","file":"chunk-KEMT7F5H.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect } from '../../render/tree'\n\nexport interface RenkoOptions {\n /** Brick size in data units. Auto-calculated from ATR if omitted. */\n brickSize?: number\n /** Up brick color. Default green. */\n upColor?: string\n /** Down brick color. Default red. */\n downColor?: string\n /** Gap between bricks in pixels. Default 1. */\n gap?: number\n /** Corner radius for bricks. Default 2. */\n borderRadius?: number\n}\n\ninterface RenkoBrick {\n open: number\n close: number\n isUp: boolean\n}\n\n/**\n * Renko chart — brick-based reversal chart.\n *\n * Uniform bricks form only when price moves by the brick size.\n * Up bricks (green) for rising prices, down bricks (red) for falling.\n * Filters out noise and shows pure price action.\n */\nexport const renkoChartType: ChartTypePlugin = {\n type: 'renko',\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, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length < 2) return nodes\n\n const opts = options as unknown as RenkoOptions\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const gap = opts.gap ?? 1\n const borderRadius = opts.borderRadius ?? 2\n\n const values = series.values\n\n // Auto-calculate brick size: ATR-like approach (average absolute change)\n let brickSize = opts.brickSize\n if (!brickSize) {\n let totalChange = 0\n for (let i = 1; i < values.length; i++) {\n totalChange += Math.abs(values[i]! - values[i - 1]!)\n }\n const avgChange = totalChange / (values.length - 1)\n brickSize = Math.max(avgChange * 1.5, (Math.max(...values) - Math.min(...values)) / 20)\n }\n\n // Build bricks\n const bricks = computeRenkoBricks(values, brickSize)\n if (bricks.length === 0) return nodes\n\n // Find price range from bricks\n let minPrice = Infinity\n let maxPrice = -Infinity\n for (const b of bricks) {\n minPrice = Math.min(minPrice, b.open, b.close)\n maxPrice = Math.max(maxPrice, b.open, b.close)\n }\n const priceRange = maxPrice - minPrice || 1\n\n // Layout: each brick gets equal horizontal space\n const padding = 16\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const brickWidth = Math.min(\n (usableWidth - gap * (bricks.length - 1)) / bricks.length,\n 30,\n )\n\n const totalBrickWidth = bricks.length * brickWidth + (bricks.length - 1) * gap\n const xStart = area.x + (area.width - totalBrickWidth) / 2\n\n const mapY = (v: number) => area.y + padding + (1 - (v - minPrice) / priceRange) * usableHeight\n const brickPixelHeight = (brickSize / priceRange) * usableHeight\n\n const brickNodes: RenderNode[] = []\n\n for (let i = 0; i < bricks.length; i++) {\n const b = bricks[i]!\n const x = xStart + i * (brickWidth + gap)\n const yTop = mapY(Math.max(b.open, b.close))\n const h = Math.max(brickPixelHeight, 3)\n\n brickNodes.push(rect(x, yTop, brickWidth, h, {\n rx: borderRadius, ry: borderRadius,\n class: 'chartts-renko-brick',\n fill: b.isUp ? upColor : downColor,\n fillOpacity: b.isUp ? 0.9 : 0.9,\n stroke: b.isUp ? upColor : downColor,\n strokeWidth: 1,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `Brick ${i + 1}: ${b.isUp ? 'Up' : 'Down'} ${b.open.toFixed(1)}→${b.close.toFixed(1)}`,\n }))\n }\n\n nodes.push(group(brickNodes, {\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, area } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const frac = (mx - area.x) / area.width\n const idx = Math.round(frac * (series.values.length - 1))\n if (idx >= 0 && idx < series.values.length) {\n return { seriesIndex: 0, pointIndex: idx, distance: 10 }\n }\n return null\n },\n}\n\n/**\n * Compute renko bricks from raw price data.\n */\nfunction computeRenkoBricks(values: number[], brickSize: number): RenkoBrick[] {\n const bricks: RenkoBrick[] = []\n if (values.length < 2 || brickSize <= 0) return bricks\n\n let currentPrice = Math.round(values[0]! / brickSize) * brickSize\n\n for (let i = 1; i < values.length; i++) {\n const v = values[i]!\n const diff = v - currentPrice\n\n if (Math.abs(diff) >= brickSize) {\n const numBricks = Math.floor(Math.abs(diff) / brickSize)\n const isUp = diff > 0\n\n for (let j = 0; j < numBricks; j++) {\n const open = currentPrice\n currentPrice += isUp ? brickSize : -brickSize\n bricks.push({ open, close: currentPrice, isUp })\n }\n }\n }\n\n return bricks\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/polar/polar-type.ts"],"names":[],"mappings":"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","file":"chunk-KHQRHTTN.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 * Polar / Radial bar chart (Nightingale rose diagram).\n *\n * Each category is a wedge whose radius is proportional to its value.\n * Uses the first series' values as wedge sizes.\n */\nexport const polarChartType: ChartTypePlugin = {\n type: 'polar',\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 - 16\n const angleStep = (Math.PI * 2) / count\n const padAngle = 0.02 // radians gap between wedges\n\n // Draw concentric grid rings\n const ringCount = 3\n for (let r = 1; r <= ringCount; r++) {\n const ringR = (outerR * r) / ringCount\n const pb = new PathBuilder()\n // Full circle as a path\n pb.moveTo(cx + ringR, cy)\n pb.arc(ringR, ringR, 0, false, true, cx - ringR, cy)\n pb.arc(ringR, ringR, 0, false, true, cx + ringR, cy)\n\n nodes.push(path(pb.build(), {\n class: 'chartts-polar-grid',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n fill: 'none',\n opacity: 0.3,\n }))\n }\n\n // Draw wedges\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const wedgeR = (value / maxVal) * outerR\n const startAngle = -Math.PI / 2 + i * angleStep + padAngle / 2\n const endAngle = -Math.PI / 2 + (i + 1) * angleStep - padAngle / 2\n\n if (endAngle <= startAngle || wedgeR < 1) continue\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n\n const pb = new PathBuilder()\n const x1 = cx + wedgeR * Math.cos(startAngle)\n const y1 = cy + wedgeR * Math.sin(startAngle)\n const x2 = cx + wedgeR * Math.cos(endAngle)\n const y2 = cy + wedgeR * Math.sin(endAngle)\n const largeArc = angleStep - padAngle > Math.PI\n\n pb.moveTo(cx, cy)\n pb.lineTo(x1, y1)\n pb.arc(wedgeR, wedgeR, 0, largeArc, true, x2, y2)\n pb.close()\n\n const wedgeNodes: RenderNode[] = [\n path(pb.build(), {\n class: 'chartts-polar-wedge',\n fill: color,\n fillOpacity: 0.75,\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] ?? `Item ${i + 1}`}: ${values[i]}`,\n }),\n ]\n\n // Label at the outer edge\n const midAngle = (startAngle + endAngle) / 2\n const labelR = outerR + 10\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n wedgeNodes.push(text(lx, ly, String(data.labels[i] ?? ''), {\n class: 'chartts-polar-label',\n fill: theme.textMuted,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(wedgeNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Item ${i + 1}`),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const 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) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 16\n const angleStep = (Math.PI * 2) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n if (dist > outerR) return null\n\n let angle = Math.atan2(dy, dx)\n // Normalize to start from -PI/2\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n const offset = angle + Math.PI / 2\n const normalizedAngle = offset < 0 ? offset + Math.PI * 2 : offset\n const idx = Math.floor(normalizedAngle / angleStep)\n\n if (idx >= 0 && idx < count) {\n const wedgeR = (Math.abs(values[idx]!) / maxVal) * outerR\n if (dist <= wedgeR) {\n return { seriesIndex: 0, pointIndex: idx, distance: dist }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/funnel/funnel-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-KUFDELQM.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\nexport interface FunnelOptions {\n /** Gap between steps in px. Default 2. */\n stepGap?: number\n /** Show percentage labels. Default true. */\n showLabels?: boolean\n /** Show value labels. Default true. */\n showValues?: boolean\n}\n\n/**\n * Funnel chart — tapered horizontal bars representing conversion steps.\n * Uses the first series. Values should be descending (largest to smallest).\n */\nexport const funnelChartType: ChartTypePlugin = {\n type: 'funnel',\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 fOpts = options as unknown as FunnelOptions\n const stepGap = fOpts.stepGap ?? 4\n const showLabels = fOpts.showLabels ?? true\n const showValues = fOpts.showValues ?? true\n\n const values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n if (maxVal === 0) return nodes\n\n const stepCount = values.length\n const totalGap = stepGap * (stepCount - 1)\n const stepHeight = (area.height - totalGap) / stepCount\n const centerX = area.x + area.width / 2\n\n for (let i = 0; i < stepCount; i++) {\n const val = Math.abs(values[i]!)\n const nextVal = i < stepCount - 1 ? Math.abs(values[i + 1]!) : val * 0.7\n\n const topWidth = (val / maxVal) * area.width\n const bottomWidth = (nextVal / maxVal) * area.width\n const y = area.y + i * (stepHeight + stepGap)\n\n const color = options.colors[i % options.colors.length]!\n\n // Trapezoid path\n const pb = new PathBuilder()\n pb.moveTo(centerX - topWidth / 2, y)\n pb.lineTo(centerX + topWidth / 2, y)\n pb.lineTo(centerX + bottomWidth / 2, y + stepHeight)\n pb.lineTo(centerX - bottomWidth / 2, y + stepHeight)\n pb.close()\n\n const stepNodes: RenderNode[] = []\n\n const colorIndex = i % options.colors.length\n stepNodes.push(path(pb.build(), {\n class: 'chartts-funnel-step',\n fill: `url(#chartts-bar-${colorIndex})`,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? `Step ${i + 1}`}: ${values[i]}`,\n }))\n\n // Label text\n const textY = y + stepHeight / 2\n if (showLabels) {\n const label = String(data.labels[i] ?? `Step ${i + 1}`)\n const pct = maxVal > 0 ? Math.round((val / maxVal) * 100) : 0\n\n const labelStr = showValues\n ? `${label}: ${values[i]} (${pct}%)`\n : `${label} (${pct}%)`\n\n stepNodes.push(text(centerX, textY, labelStr, {\n class: 'chartts-funnel-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n nodes.push(group(stepNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Step ${i + 1}`),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, _mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const fOpts = options as unknown as FunnelOptions\n const stepGap = fOpts.stepGap ?? 2\n const stepCount = series.values.length\n const totalGap = stepGap * (stepCount - 1)\n const stepHeight = (area.height - totalGap) / stepCount\n\n for (let i = 0; i < stepCount; i++) {\n const y = area.y + i * (stepHeight + stepGap)\n if (my >= y && my <= y + stepHeight) {\n return { seriesIndex: 0, pointIndex: i, distance: 0 }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/candlestick/candlestick-type.ts"],"names":[],"mappings":"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","file":"chunk-L37ZPX6D.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect } 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, 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) }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/candlestick/candlestick-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-M6JYSINX.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, 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) }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/bar/horizontal-bar-type.ts"],"names":["prepareData","createHorizontalMapper","text","formatNum","path","rect","group"],"mappings":"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","file":"chunk-MGYBMQAX.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, text } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Horizontal bar chart — bars grow left-to-right.\n *\n * Uses the xScale for categories (mapped to y positions) and yScale for values\n * (mapped to x positions), but transposes the rendering.\n */\nexport const horizontalBarChartType: ChartTypePlugin = {\n type: 'horizontal-bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, options, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Reserve space for category labels on the left\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n // In horizontal mode:\n // - Y axis becomes categories\n // - X axis becomes value axis (use yScale for values mapped to x positions)\n const categoryHeight = area.height / pointCount\n const barGap = options.barGap\n const groupHeight = categoryHeight * (1 - barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n // Category labels on the left\n for (let i = 0; i < pointCount; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n nodes.push(text(area.x + labelWidth - 6, catCenter, String(data.labels[i] ?? ''), {\n class: 'chartts-hbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n for (const series of data.series) {\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n const isPositive = series.values[i]! >= 0\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barHeight / 2, w / 2)\n\n if (r > 0 && w > r * 2) {\n // Rounded right end for positive, left end for negative\n const d = isPositive\n ? `M${formatNum(x)},${formatNum(barY)}H${formatNum(x + w - r)}Q${formatNum(x + w)},${formatNum(barY)},${formatNum(x + w)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x + w)},${formatNum(barY + barHeight)},${formatNum(x + w - r)},${formatNum(barY + barHeight)}H${formatNum(x)}Z`\n : `M${formatNum(x + w)},${formatNum(barY)}H${formatNum(x + r)}Q${formatNum(x)},${formatNum(barY)},${formatNum(x)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x)},${formatNum(barY + barHeight)},${formatNum(x + r)},${formatNum(barY + barHeight)}H${formatNum(x + w)}Z`\n\n barNodes.push(path(d, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n } else {\n barNodes.push(rect(x, barY, w, barHeight, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n }\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const categoryHeight = area.height / pointCount\n const groupHeight = categoryHeight * (1 - options.barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n\n if (mx >= x - 2 && mx <= x + w + 2 && my >= barY - 2 && my <= barY + barHeight + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n"]}
|
package/dist/chunk-MZCKMTQE.cjs
DELETED
|
@@ -1,210 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var chunkHOPFELRP_cjs = require('./chunk-HOPFELRP.cjs');
|
|
4
|
-
var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
|
|
5
|
-
|
|
6
|
-
// src/charts/graph/graph-type.ts
|
|
7
|
-
var graphChartType = {
|
|
8
|
-
type: "graph",
|
|
9
|
-
getScaleTypes() {
|
|
10
|
-
return { x: "categorical", y: "linear" };
|
|
11
|
-
},
|
|
12
|
-
prepareData(data, options) {
|
|
13
|
-
return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
|
|
14
|
-
},
|
|
15
|
-
render(ctx) {
|
|
16
|
-
const { data, area, theme, options } = ctx;
|
|
17
|
-
const nodes = [];
|
|
18
|
-
const { graphNodes, graphEdges } = parseGraphData(data);
|
|
19
|
-
if (graphNodes.length === 0) return nodes;
|
|
20
|
-
forceLayout(graphNodes, graphEdges, area, 80);
|
|
21
|
-
for (let ei = 0; ei < graphEdges.length; ei++) {
|
|
22
|
-
const edge = graphEdges[ei];
|
|
23
|
-
const src = graphNodes[edge.source];
|
|
24
|
-
const tgt = graphNodes[edge.target];
|
|
25
|
-
nodes.push(chunk3TLJCGGQ_cjs.line(src.x, src.y, tgt.x, tgt.y, {
|
|
26
|
-
class: "chartts-graph-edge",
|
|
27
|
-
stroke: theme.gridColor,
|
|
28
|
-
strokeWidth: Math.max(1, Math.min(3, edge.weight * 0.5)),
|
|
29
|
-
opacity: 0.5
|
|
30
|
-
}));
|
|
31
|
-
}
|
|
32
|
-
const maxVal = Math.max(...graphNodes.map((n) => n.value), 1);
|
|
33
|
-
const minR = 5;
|
|
34
|
-
const maxR = Math.min(20, Math.min(area.width, area.height) * 0.06);
|
|
35
|
-
for (let ni = 0; ni < graphNodes.length; ni++) {
|
|
36
|
-
const gn = graphNodes[ni];
|
|
37
|
-
const color = options.colors[ni % options.colors.length];
|
|
38
|
-
const r = minR + gn.value / maxVal * (maxR - minR);
|
|
39
|
-
const nodeGroup = [];
|
|
40
|
-
nodeGroup.push(chunk3TLJCGGQ_cjs.circle(gn.x, gn.y, r, {
|
|
41
|
-
class: "chartts-graph-node",
|
|
42
|
-
fill: color,
|
|
43
|
-
fillOpacity: 0.85,
|
|
44
|
-
stroke: color,
|
|
45
|
-
strokeWidth: 1.5,
|
|
46
|
-
"data-series": ni,
|
|
47
|
-
"data-index": 0,
|
|
48
|
-
tabindex: 0,
|
|
49
|
-
role: "img",
|
|
50
|
-
ariaLabel: `${gn.name}: ${gn.value}`
|
|
51
|
-
}));
|
|
52
|
-
nodeGroup.push(chunk3TLJCGGQ_cjs.text(gn.x, gn.y - r - 5, gn.name, {
|
|
53
|
-
class: "chartts-graph-label",
|
|
54
|
-
fill: theme.textColor,
|
|
55
|
-
textAnchor: "middle",
|
|
56
|
-
dominantBaseline: "auto",
|
|
57
|
-
fontSize: theme.fontSizeSmall,
|
|
58
|
-
fontFamily: theme.fontFamily
|
|
59
|
-
}));
|
|
60
|
-
nodes.push(chunk3TLJCGGQ_cjs.group(nodeGroup, {
|
|
61
|
-
class: `chartts-series chartts-series-${ni}`,
|
|
62
|
-
"data-series-name": gn.name
|
|
63
|
-
}));
|
|
64
|
-
}
|
|
65
|
-
return nodes;
|
|
66
|
-
},
|
|
67
|
-
hitTest(ctx, mx, my) {
|
|
68
|
-
const { data, area, options } = ctx;
|
|
69
|
-
const { graphNodes, graphEdges } = parseGraphData(data);
|
|
70
|
-
if (graphNodes.length === 0) return null;
|
|
71
|
-
forceLayout(graphNodes, graphEdges, area, 80);
|
|
72
|
-
const maxVal = Math.max(...graphNodes.map((n) => n.value), 1);
|
|
73
|
-
const minR = 5;
|
|
74
|
-
const maxR = Math.min(20, Math.min(area.width, area.height) * 0.06);
|
|
75
|
-
let best = null;
|
|
76
|
-
let bestDist = Infinity;
|
|
77
|
-
for (let ni = 0; ni < graphNodes.length; ni++) {
|
|
78
|
-
const gn = graphNodes[ni];
|
|
79
|
-
const r = minR + gn.value / maxVal * (maxR - minR);
|
|
80
|
-
const dist = Math.sqrt((mx - gn.x) ** 2 + (my - gn.y) ** 2);
|
|
81
|
-
if (dist < bestDist && dist < r + 8) {
|
|
82
|
-
bestDist = dist;
|
|
83
|
-
best = { seriesIndex: ni, pointIndex: 0, distance: dist };
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
return best;
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
function parseGraphData(data, _options) {
|
|
90
|
-
const graphNodes = [];
|
|
91
|
-
const graphEdges = [];
|
|
92
|
-
const nodeMap = /* @__PURE__ */ new Map();
|
|
93
|
-
function getOrCreateNode(name, value = 1) {
|
|
94
|
-
if (nodeMap.has(name)) return nodeMap.get(name);
|
|
95
|
-
const idx = graphNodes.length;
|
|
96
|
-
nodeMap.set(name, idx);
|
|
97
|
-
graphNodes.push({
|
|
98
|
-
name,
|
|
99
|
-
index: idx,
|
|
100
|
-
value,
|
|
101
|
-
x: 0,
|
|
102
|
-
y: 0,
|
|
103
|
-
vx: 0,
|
|
104
|
-
vy: 0
|
|
105
|
-
});
|
|
106
|
-
return idx;
|
|
107
|
-
}
|
|
108
|
-
const hasArrows = data.series.some((s) => s.name.includes("\u2192") || s.name.includes("->"));
|
|
109
|
-
if (hasArrows) {
|
|
110
|
-
for (const series of data.series) {
|
|
111
|
-
const parts = series.name.split(/\s*(?:→|->)\s*/);
|
|
112
|
-
if (parts.length < 2) continue;
|
|
113
|
-
const srcName = parts[0].trim();
|
|
114
|
-
const tgtName = parts[1].trim();
|
|
115
|
-
const weight = series.values[0] ?? 1;
|
|
116
|
-
const src = getOrCreateNode(srcName);
|
|
117
|
-
const tgt = getOrCreateNode(tgtName);
|
|
118
|
-
graphEdges.push({ source: src, target: tgt, weight });
|
|
119
|
-
graphNodes[src].value += weight;
|
|
120
|
-
graphNodes[tgt].value += weight;
|
|
121
|
-
}
|
|
122
|
-
} else {
|
|
123
|
-
for (let i = 0; i < data.labels.length; i++) {
|
|
124
|
-
getOrCreateNode(String(data.labels[i]), Math.abs(data.series[0]?.values[i] ?? 1));
|
|
125
|
-
}
|
|
126
|
-
if (data.series.length > 1 && data.series.length === data.labels.length) {
|
|
127
|
-
for (let si = 0; si < data.series.length; si++) {
|
|
128
|
-
for (let j = 0; j < data.series[si].values.length; j++) {
|
|
129
|
-
const val = data.series[si].values[j];
|
|
130
|
-
if (val > 0 && si !== j) {
|
|
131
|
-
graphEdges.push({ source: si, target: j, weight: val });
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return { graphNodes, graphEdges };
|
|
138
|
-
}
|
|
139
|
-
function forceLayout(nodes, edges, area, iterations) {
|
|
140
|
-
const cx = area.x + area.width / 2;
|
|
141
|
-
const cy = area.y + area.height / 2;
|
|
142
|
-
const n = nodes.length;
|
|
143
|
-
if (n === 0) return;
|
|
144
|
-
for (let i = 0; i < n; i++) {
|
|
145
|
-
const angle = 2 * Math.PI * i / n;
|
|
146
|
-
const r = Math.min(area.width, area.height) * 0.3;
|
|
147
|
-
nodes[i].x = cx + r * Math.cos(angle);
|
|
148
|
-
nodes[i].y = cy + r * Math.sin(angle);
|
|
149
|
-
nodes[i].vx = 0;
|
|
150
|
-
nodes[i].vy = 0;
|
|
151
|
-
}
|
|
152
|
-
const k = Math.sqrt(area.width * area.height / Math.max(n, 1));
|
|
153
|
-
const repulsion = k * k;
|
|
154
|
-
for (let iter = 0; iter < iterations; iter++) {
|
|
155
|
-
const temp = 0.1 * (1 - iter / iterations) * Math.min(area.width, area.height) * 0.5;
|
|
156
|
-
for (const node of nodes) {
|
|
157
|
-
node.vx = 0;
|
|
158
|
-
node.vy = 0;
|
|
159
|
-
}
|
|
160
|
-
for (let i = 0; i < n; i++) {
|
|
161
|
-
for (let j = i + 1; j < n; j++) {
|
|
162
|
-
const dx = nodes[i].x - nodes[j].x;
|
|
163
|
-
const dy = nodes[i].y - nodes[j].y;
|
|
164
|
-
const dist = Math.max(Math.sqrt(dx * dx + dy * dy), 1);
|
|
165
|
-
const force = repulsion / (dist * dist);
|
|
166
|
-
const fx = dx / dist * force;
|
|
167
|
-
const fy = dy / dist * force;
|
|
168
|
-
nodes[i].vx += fx;
|
|
169
|
-
nodes[i].vy += fy;
|
|
170
|
-
nodes[j].vx -= fx;
|
|
171
|
-
nodes[j].vy -= fy;
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
for (const edge of edges) {
|
|
175
|
-
const src = nodes[edge.source];
|
|
176
|
-
const tgt = nodes[edge.target];
|
|
177
|
-
const dx = tgt.x - src.x;
|
|
178
|
-
const dy = tgt.y - src.y;
|
|
179
|
-
const dist = Math.max(Math.sqrt(dx * dx + dy * dy), 1);
|
|
180
|
-
const force = dist * dist / k;
|
|
181
|
-
const fx = dx / dist * force * 0.1;
|
|
182
|
-
const fy = dy / dist * force * 0.1;
|
|
183
|
-
src.vx += fx;
|
|
184
|
-
src.vy += fy;
|
|
185
|
-
tgt.vx -= fx;
|
|
186
|
-
tgt.vy -= fy;
|
|
187
|
-
}
|
|
188
|
-
for (const node of nodes) {
|
|
189
|
-
const dx = cx - node.x;
|
|
190
|
-
const dy = cy - node.y;
|
|
191
|
-
node.vx += dx * 0.01;
|
|
192
|
-
node.vy += dy * 0.01;
|
|
193
|
-
}
|
|
194
|
-
for (const node of nodes) {
|
|
195
|
-
const speed = Math.sqrt(node.vx * node.vx + node.vy * node.vy);
|
|
196
|
-
if (speed > 0) {
|
|
197
|
-
const capped = Math.min(speed, temp);
|
|
198
|
-
node.x += node.vx / speed * capped;
|
|
199
|
-
node.y += node.vy / speed * capped;
|
|
200
|
-
}
|
|
201
|
-
const margin = 20;
|
|
202
|
-
node.x = Math.max(area.x + margin, Math.min(area.x + area.width - margin, node.x));
|
|
203
|
-
node.y = Math.max(area.y + margin, Math.min(area.y + area.height - margin, node.y));
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
exports.graphChartType = graphChartType;
|
|
209
|
-
//# sourceMappingURL=chunk-MZCKMTQE.cjs.map
|
|
210
|
-
//# sourceMappingURL=chunk-MZCKMTQE.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/graph/graph-type.ts"],"names":["prepareNoAxes","line","circle","text","group"],"mappings":"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","file":"chunk-MZCKMTQE.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, circle, text, line } from '../../render/tree'\n\n/**\n * Graph / Network chart — node-link diagram with force-directed layout.\n *\n * Data convention:\n * - labels: node names\n * - series[0].values: node values (controls circle radius)\n * - Edge encoding: series names contain \"→\" or \"->\" (e.g., \"A → B\")\n * with values[0] = edge weight. Same as Sankey convention.\n *\n * Alternative: adjacency matrix\n * - series[i].values[j] > 0 means there's an edge from node i to node j.\n *\n * Uses a simple force simulation (no external deps):\n * - Repulsion between all nodes (Coulomb's law)\n * - Attraction along edges (Hooke's law)\n * - Gravity toward center\n */\n\ninterface GraphNode {\n name: string\n index: number\n value: number\n x: number\n y: number\n vx: number\n vy: number\n}\n\ninterface GraphEdge {\n source: number\n target: number\n weight: number\n}\n\nexport const graphChartType: ChartTypePlugin = {\n type: 'graph',\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 { graphNodes, graphEdges } = parseGraphData(data, options)\n if (graphNodes.length === 0) return nodes\n\n // Run force simulation\n forceLayout(graphNodes, graphEdges, area, 80)\n\n // Render edges\n for (let ei = 0; ei < graphEdges.length; ei++) {\n const edge = graphEdges[ei]!\n const src = graphNodes[edge.source]!\n const tgt = graphNodes[edge.target]!\n\n nodes.push(line(src.x, src.y, tgt.x, tgt.y, {\n class: 'chartts-graph-edge',\n stroke: theme.gridColor,\n strokeWidth: Math.max(1, Math.min(3, edge.weight * 0.5)),\n opacity: 0.5,\n }))\n }\n\n // Compute node radii\n const maxVal = Math.max(...graphNodes.map(n => n.value), 1)\n const minR = 5\n const maxR = Math.min(20, Math.min(area.width, area.height) * 0.06)\n\n // Render nodes\n for (let ni = 0; ni < graphNodes.length; ni++) {\n const gn = graphNodes[ni]!\n const color = options.colors[ni % options.colors.length]!\n const r = minR + (gn.value / maxVal) * (maxR - minR)\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(circle(gn.x, gn.y, r, {\n class: 'chartts-graph-node',\n fill: color,\n fillOpacity: 0.85,\n stroke: color,\n strokeWidth: 1.5,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${gn.name}: ${gn.value}`,\n }))\n\n // Label\n nodeGroup.push(text(gn.x, gn.y - r - 5, gn.name, {\n class: 'chartts-graph-label',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${ni}`,\n 'data-series-name': gn.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { graphNodes, graphEdges } = parseGraphData(data, options)\n if (graphNodes.length === 0) return null\n\n forceLayout(graphNodes, graphEdges, area, 80)\n\n const maxVal = Math.max(...graphNodes.map(n => n.value), 1)\n const minR = 5\n const maxR = Math.min(20, Math.min(area.width, area.height) * 0.06)\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (let ni = 0; ni < graphNodes.length; ni++) {\n const gn = graphNodes[ni]!\n const r = minR + (gn.value / maxVal) * (maxR - minR)\n const dist = Math.sqrt((mx - gn.x) ** 2 + (my - gn.y) ** 2)\n if (dist < bestDist && dist < r + 8) {\n bestDist = dist\n best = { seriesIndex: ni, pointIndex: 0, distance: dist }\n }\n }\n\n return best\n },\n}\n\n// ---------------------------------------------------------------------------\n// Data parsing\n// ---------------------------------------------------------------------------\n\nfunction parseGraphData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { graphNodes: GraphNode[]; graphEdges: GraphEdge[] } {\n const graphNodes: GraphNode[] = []\n const graphEdges: GraphEdge[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string, value = 1): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = graphNodes.length\n nodeMap.set(name, idx)\n graphNodes.push({\n name, index: idx, value,\n x: 0, y: 0, vx: 0, vy: 0,\n })\n return idx\n }\n\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Edge list format\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const srcName = parts[0]!.trim()\n const tgtName = parts[1]!.trim()\n const weight = series.values[0] ?? 1\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n graphEdges.push({ source: src, target: tgt, weight })\n graphNodes[src]!.value += weight\n graphNodes[tgt]!.value += weight\n }\n } else {\n // Adjacency matrix or node list\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]), Math.abs(data.series[0]?.values[i] ?? 1))\n }\n\n // If multiple series with matching dimensions, treat as adjacency matrix\n if (data.series.length > 1 && data.series.length === data.labels.length) {\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0 && si !== j) {\n graphEdges.push({ source: si, target: j, weight: val })\n }\n }\n }\n }\n }\n\n return { graphNodes, graphEdges }\n}\n\n// ---------------------------------------------------------------------------\n// Force-directed layout (simple Fruchterman-Reingold style)\n// ---------------------------------------------------------------------------\n\nfunction forceLayout(\n nodes: GraphNode[],\n edges: GraphEdge[],\n area: { x: number; y: number; width: number; height: number },\n iterations: number,\n): void {\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const n = nodes.length\n\n if (n === 0) return\n\n // Initialize positions in a circle\n for (let i = 0; i < n; i++) {\n const angle = (2 * Math.PI * i) / n\n const r = Math.min(area.width, area.height) * 0.3\n nodes[i]!.x = cx + r * Math.cos(angle)\n nodes[i]!.y = cy + r * Math.sin(angle)\n nodes[i]!.vx = 0\n nodes[i]!.vy = 0\n }\n\n const k = Math.sqrt((area.width * area.height) / Math.max(n, 1))\n const repulsion = k * k\n\n for (let iter = 0; iter < iterations; iter++) {\n const temp = 0.1 * (1 - iter / iterations) * Math.min(area.width, area.height) * 0.5\n\n // Reset velocities\n for (const node of nodes) {\n node.vx = 0\n node.vy = 0\n }\n\n // Repulsion between all pairs\n for (let i = 0; i < n; i++) {\n for (let j = i + 1; j < n; j++) {\n const dx = nodes[i]!.x - nodes[j]!.x\n const dy = nodes[i]!.y - nodes[j]!.y\n const dist = Math.max(Math.sqrt(dx * dx + dy * dy), 1)\n const force = repulsion / (dist * dist)\n const fx = (dx / dist) * force\n const fy = (dy / dist) * force\n nodes[i]!.vx += fx\n nodes[i]!.vy += fy\n nodes[j]!.vx -= fx\n nodes[j]!.vy -= fy\n }\n }\n\n // Attraction along edges\n for (const edge of edges) {\n const src = nodes[edge.source]!\n const tgt = nodes[edge.target]!\n const dx = tgt.x - src.x\n const dy = tgt.y - src.y\n const dist = Math.max(Math.sqrt(dx * dx + dy * dy), 1)\n const force = (dist * dist) / k\n const fx = (dx / dist) * force * 0.1\n const fy = (dy / dist) * force * 0.1\n src.vx += fx\n src.vy += fy\n tgt.vx -= fx\n tgt.vy -= fy\n }\n\n // Gravity toward center\n for (const node of nodes) {\n const dx = cx - node.x\n const dy = cy - node.y\n node.vx += dx * 0.01\n node.vy += dy * 0.01\n }\n\n // Apply velocities with temperature damping\n for (const node of nodes) {\n const speed = Math.sqrt(node.vx * node.vx + node.vy * node.vy)\n if (speed > 0) {\n const capped = Math.min(speed, temp)\n node.x += (node.vx / speed) * capped\n node.y += (node.vy / speed) * capped\n }\n\n // Constrain to area\n const margin = 20\n node.x = Math.max(area.x + margin, Math.min(area.x + area.width - margin, node.x))\n node.y = Math.max(area.y + margin, Math.min(area.y + area.height - margin, node.y))\n }\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/lines/lines-type.ts"],"names":["prepareNoAxes","PathBuilder","path","circle","text","group"],"mappings":"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","file":"chunk-MZQY2FTP.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { circle, text, group } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { path } from '../../render/tree'\n\n/**\n * Lines (flow lines) chart — curved connection lines between named points.\n *\n * Data convention:\n * - labels: point/city names\n * - series use arrow notation: \"A → B\" with values[0] = flow magnitude\n *\n * Options:\n * - points: array of {name, x, y} defining positions in 0..1 normalized space\n * - showNodes: show circles at point positions (default true)\n * - showArrows: show arrowheads (default true)\n * - showLabels: show point name labels (default true)\n * - curvature: bezier curve amount 0..1 (default 0.3)\n */\n\nexport interface LinesPoint {\n name: string\n x: number // 0..1 normalized\n y: number // 0..1 normalized\n}\n\nexport interface LinesOptions {\n points?: LinesPoint[]\n showNodes?: boolean\n showArrows?: boolean\n showLabels?: boolean\n curvature?: number\n}\n\ninterface ParsedFlow {\n source: string\n target: string\n value: number\n}\n\nexport const linesChartType: ChartTypePlugin = {\n type: 'lines',\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 lOpts = options as unknown as LinesOptions\n const showNodes = lOpts.showNodes !== false\n const showArrows = lOpts.showArrows !== false\n const showLabels = lOpts.showLabels !== false\n const curvature = lOpts.curvature ?? 0.3\n\n // Build point positions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n } else {\n // Auto-layout: arrange points in a circle\n const names = new Set<string>()\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n names.add(parts[0]!.trim())\n names.add(parts[1]!.trim())\n }\n }\n // Also add labels\n for (const l of data.labels) names.add(String(l))\n\n const nameArr = [...names]\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const r = Math.min(area.width, area.height) / 2 - 40\n\n nameArr.forEach((name, i) => {\n const angle = (i / nameArr.length) * Math.PI * 2 - Math.PI / 2\n pointMap.set(name, {\n x: cx + r * Math.cos(angle),\n y: cy + r * Math.sin(angle),\n })\n })\n }\n\n // Parse flows from series\n const flows: ParsedFlow[] = []\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n flows.push({\n source: parts[0]!.trim(),\n target: parts[1]!.trim(),\n value: s.values[0] ?? 1,\n })\n }\n }\n\n if (flows.length === 0 && pointMap.size === 0) return nodes\n\n // Max flow for line width scaling\n const maxFlow = Math.max(...flows.map(f => Math.abs(f.value)), 1)\n\n // Render flow lines\n for (let fi = 0; fi < flows.length; fi++) {\n const flow = flows[fi]!\n const src = pointMap.get(flow.source)\n const tgt = pointMap.get(flow.target)\n if (!src || !tgt) continue\n\n const color = options.colors[fi % options.colors.length]!\n const lineWidth = 1 + (Math.abs(flow.value) / maxFlow) * 4\n\n // Curved bezier\n const dx = tgt.x - src.x\n const dy = tgt.y - src.y\n const mx = (src.x + tgt.x) / 2\n const my = (src.y + tgt.y) / 2\n const cpx = mx - dy * curvature\n const cpy = my + dx * curvature\n\n const pb = new PathBuilder()\n pb.moveTo(src.x, src.y)\n pb.quadTo(cpx, cpy, tgt.x, tgt.y)\n\n nodes.push(path(pb.build(), {\n class: 'chartts-lines-flow',\n fill: 'none',\n stroke: color,\n strokeWidth: lineWidth,\n strokeOpacity: 0.6,\n strokeLinecap: 'round',\n 'data-series': fi,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${flow.source} → ${flow.target}: ${flow.value}`,\n }))\n\n // Arrowhead at target\n if (showArrows) {\n const t = 0.95 // position along curve for arrow direction\n const ax = (1 - t) * (1 - t) * src.x + 2 * (1 - t) * t * cpx + t * t * tgt.x\n const ay = (1 - t) * (1 - t) * src.y + 2 * (1 - t) * t * cpy + t * t * tgt.y\n const angle = Math.atan2(tgt.y - ay, tgt.x - ax)\n const arrowSize = 6 + lineWidth\n\n const apb = new PathBuilder()\n apb.moveTo(tgt.x, tgt.y)\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle - 0.4),\n tgt.y - arrowSize * Math.sin(angle - 0.4),\n )\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle + 0.4),\n tgt.y - arrowSize * Math.sin(angle + 0.4),\n )\n apb.close()\n\n nodes.push(path(apb.build(), {\n class: 'chartts-lines-arrow',\n fill: color,\n fillOpacity: 0.8,\n }))\n }\n }\n\n // Render nodes\n if (showNodes) {\n const nodeNodes: RenderNode[] = []\n let idx = 0\n for (const [name, pos] of pointMap) {\n const color = options.colors[idx % options.colors.length]!\n\n nodeNodes.push(circle(pos.x, pos.y, 6, {\n class: 'chartts-lines-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 2,\n 'data-series': idx,\n 'data-index': 0,\n }))\n\n if (showLabels) {\n nodeNodes.push(text(pos.x, pos.y - 14, name, {\n class: 'chartts-lines-label',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n idx++\n }\n nodes.push(group(nodeNodes, { class: 'chartts-lines-nodes' }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { options } = ctx\n const lOpts = options as unknown as LinesOptions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n const { area } = ctx\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n }\n\n let idx = 0\n for (const [, pos] of pointMap) {\n const dx = mx - pos.x\n const dy = my - pos.y\n const dist = Math.sqrt(dx * dx + dy * dy)\n if (dist < 12) {\n return { seriesIndex: idx, pointIndex: 0, distance: dist }\n }\n idx++\n }\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/bubble/bubble-type.ts"],"names":["prepareData","circle","group"],"mappings":"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","file":"chunk-N7NZQVIV.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, circle } from '../../render/tree'\n\nexport interface BubbleOptions {\n /** Sizes array per series. Each entry maps 1:1 to values. */\n sizes?: number[][]\n /** Min bubble radius in px. Default 4. */\n minRadius?: number\n /** Max bubble radius in px. Default 30. */\n maxRadius?: number\n}\n\n/**\n * Bubble chart — scatter with variable-radius circles.\n * Pass sizes via options: `{ sizes: [[10, 20, 5, ...], ...] }`\n */\nexport const bubbleChartType: ChartTypePlugin = {\n type: 'bubble',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n // Find global size range for normalization\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n const dots: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n dots.push(circle(x, y, r, {\n class: 'chartts-bubble',\n fill: series.color,\n fillOpacity: 0.5,\n stroke: series.color,\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]} (size: ${rawSize})`,\n }))\n }\n\n nodes.push(group(dots, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < r + 4 && dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/bar/horizontal-bar-type.ts"],"names":[],"mappings":"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","file":"chunk-NML7F34A.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, text } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Horizontal bar chart — bars grow left-to-right.\n *\n * Uses the xScale for categories (mapped to y positions) and yScale for values\n * (mapped to x positions), but transposes the rendering.\n */\nexport const horizontalBarChartType: ChartTypePlugin = {\n type: 'horizontal-bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, options, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Reserve space for category labels on the left\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n // In horizontal mode:\n // - Y axis becomes categories\n // - X axis becomes value axis (use yScale for values mapped to x positions)\n const categoryHeight = area.height / pointCount\n const barGap = options.barGap\n const groupHeight = categoryHeight * (1 - barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n // Category labels on the left\n for (let i = 0; i < pointCount; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n nodes.push(text(area.x + labelWidth - 6, catCenter, String(data.labels[i] ?? ''), {\n class: 'chartts-hbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n for (const series of data.series) {\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n const isPositive = series.values[i]! >= 0\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barHeight / 2, w / 2)\n\n if (r > 0 && w > r * 2) {\n // Rounded right end for positive, left end for negative\n const d = isPositive\n ? `M${formatNum(x)},${formatNum(barY)}H${formatNum(x + w - r)}Q${formatNum(x + w)},${formatNum(barY)},${formatNum(x + w)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x + w)},${formatNum(barY + barHeight)},${formatNum(x + w - r)},${formatNum(barY + barHeight)}H${formatNum(x)}Z`\n : `M${formatNum(x + w)},${formatNum(barY)}H${formatNum(x + r)}Q${formatNum(x)},${formatNum(barY)},${formatNum(x)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x)},${formatNum(barY + barHeight)},${formatNum(x + r)},${formatNum(barY + barHeight)}H${formatNum(x + w)}Z`\n\n barNodes.push(path(d, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n } else {\n barNodes.push(rect(x, barY, w, barHeight, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n }\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const categoryHeight = area.height / pointCount\n const groupHeight = categoryHeight * (1 - options.barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n\n if (mx >= x - 2 && mx <= x + w + 2 && my >= barY - 2 && my <= barY + barHeight + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n"]}
|