@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,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
|
|
4
|
-
var
|
|
4
|
+
var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/histogram/histogram-type.ts
|
|
7
7
|
var histogramChartType = {
|
|
@@ -10,7 +10,7 @@ var histogramChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
const prepared =
|
|
13
|
+
const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
|
|
14
14
|
if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
|
|
15
15
|
prepared.bounds.yMin = 0;
|
|
16
16
|
}
|
|
@@ -35,7 +35,7 @@ var histogramChartType = {
|
|
|
35
35
|
if (h < 0.5) continue;
|
|
36
36
|
const colorIndex = i % options.colors.length;
|
|
37
37
|
const barFill = `url(#chartts-bar-${colorIndex})`;
|
|
38
|
-
barNodes.push(
|
|
38
|
+
barNodes.push(chunkUMIJYYF3_cjs.rect(barX, y, barWidth, h, {
|
|
39
39
|
rx: 2,
|
|
40
40
|
ry: 2,
|
|
41
41
|
class: "chartts-bar chartts-histogram-bar",
|
|
@@ -49,7 +49,7 @@ var histogramChartType = {
|
|
|
49
49
|
ariaLabel: `${data.labels[i]}: ${value}`
|
|
50
50
|
}));
|
|
51
51
|
}
|
|
52
|
-
nodes.push(
|
|
52
|
+
nodes.push(chunkUMIJYYF3_cjs.group(barNodes, {
|
|
53
53
|
class: "chartts-series chartts-series-0",
|
|
54
54
|
"data-series-name": series.name
|
|
55
55
|
}));
|
|
@@ -69,7 +69,7 @@ var histogramChartType = {
|
|
|
69
69
|
const y = series.values[i] >= 0 ? vy : baseline;
|
|
70
70
|
const h = Math.abs(vy - baseline);
|
|
71
71
|
if (mx >= barX - 1 && mx <= barX + barWidth + 1 && my >= y - 2 && my <= y + h + 2) {
|
|
72
|
-
return { seriesIndex: 0, pointIndex: i, distance: 0 };
|
|
72
|
+
return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx, y: vy };
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
return null;
|
|
@@ -77,5 +77,5 @@ var histogramChartType = {
|
|
|
77
77
|
};
|
|
78
78
|
|
|
79
79
|
exports.histogramChartType = histogramChartType;
|
|
80
|
-
//# sourceMappingURL=chunk-
|
|
81
|
-
//# sourceMappingURL=chunk-
|
|
80
|
+
//# sourceMappingURL=chunk-7ZPHLIFP.cjs.map
|
|
81
|
+
//# sourceMappingURL=chunk-7ZPHLIFP.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/histogram/histogram-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":";;;;;;AAgBO,IAAM,kBAAA,GAAsC;AAAA,EACjD,IAAA,EAAM,WAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,MAAM,QAAA,GAAWA,6BAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAC1C,IAAA,IAAI,QAAQ,IAAA,KAAS,MAAA,IAAa,QAAA,CAAS,MAAA,CAAO,OAAO,CAAA,EAAG;AAC1D,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,CAAA;AAAA,IACzB;AACA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,OAAA,EAAS,MAAA,EAAQ,QAAO,GAAI,GAAA;AAC1C,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,KAAW,GAAG,OAAO,KAAA;AAElD,IAAA,MAAM,EAAA,GAAKC,+BAAa,MAAM,CAAA;AAE9B,IAAA,MAAM,QAAA,GAAW,EAAA;AACjB,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,GAAA,CAAI,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,MAAA,CAAO,SAAA,EAAU,CAAE,CAAC,CAAW,CAAC,CAAA;AAExE,IAAA,MAAM,WAAyB,EAAC;AAEhC,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,MAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA;AAC7B,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,MAAM,IAAA,GAAO,KAAK,QAAA,GAAW,CAAA;AAC7B,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,KAAK,CAAA;AAE3B,MAAA,MAAM,CAAA,GAAI,KAAA,IAAS,CAAA,GAAI,EAAA,GAAK,QAAA;AAC5B,MAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,GAAK,QAAQ,CAAA;AAChC,MAAA,IAAI,IAAI,GAAA,EAAK;AAEb,MAAA,MAAM,UAAA,GAAa,CAAA,GAAI,OAAA,CAAQ,MAAA,CAAO,MAAA;AACtC,MAAA,MAAM,OAAA,GAAU,oBAAoB,UAAU,CAAA,CAAA,CAAA;AAE9C,MAAA,QAAA,CAAS,IAAA,CAAKC,sBAAA,CAAK,IAAA,EAAM,CAAA,EAAG,UAAU,CAAA,EAAG;AAAA,QACvC,EAAA,EAAI,CAAA;AAAA,QAAG,EAAA,EAAI,CAAA;AAAA,QACX,KAAA,EAAO,mCAAA;AAAA,QACP,IAAA,EAAM,OAAA;AAAA,QACN,QAAQ,MAAA,CAAO,KAAA;AAAA,QACf,WAAA,EAAa,GAAA;AAAA,QACb,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc,CAAA;AAAA,QACd,QAAA,EAAU,CAAA;AAAA,QACV,IAAA,EAAM,KAAA;AAAA,QACN,WAAW,CAAA,EAAG,IAAA,CAAK,OAAO,CAAC,CAAC,KAAK,KAAK,CAAA;AAAA,OACvC,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,QAAA,EAAU;AAAA,MACzB,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,EAAA,EAA8B;AACpE,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAO,GAAI,GAAA;AACjC,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,MAAA,KAAW,GAAG,OAAO,IAAA;AAElD,IAAA,MAAM,EAAA,GAAKF,+BAAa,MAAM,CAAA;AAC9B,IAAA,MAAM,QAAA,GAAW,EAAA;AACjB,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,GAAA,CAAI,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,MAAA,CAAO,SAAA,EAAU,CAAE,CAAC,CAAW,CAAC,CAAA;AAExE,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,MAAA,MAAM,EAAA,GAAK,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACvB,MAAA,MAAM,IAAA,GAAO,KAAK,QAAA,GAAW,CAAA;AAC7B,MAAA,MAAM,KAAK,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACvC,MAAA,MAAM,IAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,IAAM,IAAI,EAAA,GAAK,QAAA;AACxC,MAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,GAAK,QAAQ,CAAA;AAEhC,MAAA,IAAI,EAAA,IAAM,IAAA,GAAO,CAAA,IAAK,EAAA,IAAM,IAAA,GAAO,QAAA,GAAW,CAAA,IAAK,EAAA,IAAM,CAAA,GAAI,CAAA,IAAK,EAAA,IAAM,CAAA,GAAI,IAAI,CAAA,EAAG;AACjF,QAAA,OAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,CAAA,EAAG,UAAU,CAAA,EAAG,CAAA,EAAG,EAAA,EAAI,CAAA,EAAG,EAAA,EAAG;AAAA,MACpE;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-7ZPHLIFP.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\n/**\n * Histogram chart — bars touch each other (no gap), representing frequency distribution.\n *\n * Uses the same data format as bar chart. The key differences:\n * - Zero gap between bars\n * - Bars fill the full bandwidth\n * - Designed for continuous data ranges\n */\nexport const histogramChartType: ChartTypePlugin = {\n type: 'histogram',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const bw = getBandwidth(xScale)\n // Histograms have no gap — bars touch\n const barWidth = bw\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const value = series.values[i]!\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(value)\n\n const y = value >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n if (h < 0.5) continue\n\n const colorIndex = i % options.colors.length\n const barFill = `url(#chartts-bar-${colorIndex})`\n\n barNodes.push(rect(barX, y, barWidth, h, {\n rx: 2, ry: 2,\n class: 'chartts-bar chartts-histogram-bar',\n fill: barFill,\n stroke: series.color,\n strokeWidth: 0.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: ${value}`,\n }))\n }\n\n nodes.push(group(barNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(series.values[i]!)\n const y = series.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 1 && mx <= barX + barWidth + 1 && my >= y - 2 && my <= y + h + 2) {\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx, y: vy }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
|
|
4
|
-
var
|
|
4
|
+
var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/lollipop/lollipop-type.ts
|
|
7
7
|
var lollipopChartType = {
|
|
@@ -10,7 +10,7 @@ var lollipopChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
const prepared =
|
|
13
|
+
const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
|
|
14
14
|
if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
|
|
15
15
|
prepared.bounds.yMin = 0;
|
|
16
16
|
}
|
|
@@ -25,7 +25,7 @@ var lollipopChartType = {
|
|
|
25
25
|
const bw = chunkNHGKZMD7_cjs.getBandwidth(xScale);
|
|
26
26
|
const groupWidth = bw * 0.8;
|
|
27
27
|
const stemGap = groupWidth / seriesCount;
|
|
28
|
-
const dotR = Math.min(
|
|
28
|
+
const dotR = Math.min(8, stemGap * 0.4);
|
|
29
29
|
const baselineY = yScale.map(0);
|
|
30
30
|
for (const series of data.series) {
|
|
31
31
|
const seriesNodes = [];
|
|
@@ -33,16 +33,23 @@ var lollipopChartType = {
|
|
|
33
33
|
const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap;
|
|
34
34
|
const vy = yScale.map(series.values[i]);
|
|
35
35
|
const color = options.colors[series.index % options.colors.length];
|
|
36
|
-
seriesNodes.push(
|
|
36
|
+
seriesNodes.push(chunkUMIJYYF3_cjs.line(cx, baselineY, cx, vy, {
|
|
37
37
|
class: "chartts-lollipop-stem",
|
|
38
38
|
stroke: color,
|
|
39
|
-
strokeWidth: 2
|
|
39
|
+
strokeWidth: 2.5,
|
|
40
|
+
strokeLinecap: "round",
|
|
41
|
+
strokeOpacity: 0.6
|
|
40
42
|
}));
|
|
41
|
-
seriesNodes.push(
|
|
43
|
+
seriesNodes.push(chunkUMIJYYF3_cjs.circle(cx, vy, dotR * 2, {
|
|
44
|
+
class: "chartts-lollipop-glow",
|
|
45
|
+
fill: color,
|
|
46
|
+
fillOpacity: 0.12
|
|
47
|
+
}));
|
|
48
|
+
seriesNodes.push(chunkUMIJYYF3_cjs.circle(cx, vy, dotR, {
|
|
42
49
|
class: "chartts-lollipop-dot",
|
|
43
50
|
fill: color,
|
|
44
|
-
stroke:
|
|
45
|
-
strokeWidth:
|
|
51
|
+
stroke: `var(--chartts-bg, #fff)`,
|
|
52
|
+
strokeWidth: 2.5,
|
|
46
53
|
"data-series": series.index,
|
|
47
54
|
"data-index": i,
|
|
48
55
|
tabindex: 0,
|
|
@@ -50,7 +57,7 @@ var lollipopChartType = {
|
|
|
50
57
|
ariaLabel: `${series.name}: ${series.values[i]}`
|
|
51
58
|
}));
|
|
52
59
|
}
|
|
53
|
-
nodes.push(
|
|
60
|
+
nodes.push(chunkUMIJYYF3_cjs.group(seriesNodes, {
|
|
54
61
|
class: `chartts-series chartts-series-${series.index}`,
|
|
55
62
|
"data-series-name": series.name
|
|
56
63
|
}));
|
|
@@ -76,7 +83,7 @@ var lollipopChartType = {
|
|
|
76
83
|
const dist = Math.sqrt(dx * dx + dy * dy);
|
|
77
84
|
if (dist < bestDist) {
|
|
78
85
|
bestDist = dist;
|
|
79
|
-
best = { seriesIndex: series.index, pointIndex: i, distance: dist };
|
|
86
|
+
best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy };
|
|
80
87
|
}
|
|
81
88
|
}
|
|
82
89
|
}
|
|
@@ -85,5 +92,5 @@ var lollipopChartType = {
|
|
|
85
92
|
};
|
|
86
93
|
|
|
87
94
|
exports.lollipopChartType = lollipopChartType;
|
|
88
|
-
//# sourceMappingURL=chunk-
|
|
89
|
-
//# sourceMappingURL=chunk-
|
|
95
|
+
//# sourceMappingURL=chunk-AG7VY6MJ.cjs.map
|
|
96
|
+
//# sourceMappingURL=chunk-AG7VY6MJ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-AG7VY6MJ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(8, stemGap * 0.4)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line — rounded cap, slightly thicker\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2.5,\n strokeLinecap: 'round',\n strokeOpacity: 0.6,\n }))\n\n // Ambient glow behind dot\n seriesNodes.push(circle(cx, vy, dotR * 2, {\n class: 'chartts-lollipop-glow',\n fill: color,\n fillOpacity: 0.12,\n }))\n\n // Dot — bigger, with theme-aware stroke\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\n fill: color,\n stroke: `var(--chartts-bg, #fff)`,\n strokeWidth: 2.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { rect, text, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-MPQECPE3.js';
|
|
2
|
+
import { rect, text, group } from './chunk-DX4FBN3I.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/treemap/treemap-type.ts
|
|
5
5
|
var treemapChartType = {
|
|
@@ -79,7 +79,7 @@ var treemapChartType = {
|
|
|
79
79
|
for (let k = 0; k < items.length; k++) {
|
|
80
80
|
const r = rects[k];
|
|
81
81
|
if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {
|
|
82
|
-
return { seriesIndex: 0, pointIndex: items[k].index, distance: 0 };
|
|
82
|
+
return { seriesIndex: 0, pointIndex: items[k].index, distance: 0, x: r.x + r.w / 2, y: r.y + r.h / 2 };
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
return null;
|
|
@@ -147,5 +147,5 @@ function layoutRow(values, start, x, y, w, h, rects) {
|
|
|
147
147
|
}
|
|
148
148
|
|
|
149
149
|
export { treemapChartType };
|
|
150
|
-
//# sourceMappingURL=chunk-
|
|
151
|
-
//# sourceMappingURL=chunk-
|
|
150
|
+
//# sourceMappingURL=chunk-ASNAQ35U.js.map
|
|
151
|
+
//# sourceMappingURL=chunk-ASNAQ35U.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["rowThickness"],"mappings":"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","file":"chunk-ASNAQ35U.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Treemap chart — rectangular space-filling visualization.\n *\n * Uses the first series' values as areas. Labels are cell labels.\n * Implements a simple squarified treemap layout.\n */\nexport const treemapChartType: ChartTypePlugin = {\n type: 'treemap',\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 // Build items sorted by value descending\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n const total = items.reduce((s, d) => s + d.value, 0)\n const gap = 2\n\n // Layout using slice-and-dice (simpler, works well)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const item = items[k]!\n const r = rects[k]!\n const colorIndex = item.index % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`)\n\n const cellNodes: RenderNode[] = []\n\n cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {\n class: 'chartts-treemap-cell',\n fill: color,\n fillOpacity: 0.75,\n rx: 5,\n ry: 5,\n 'data-series': 0,\n 'data-index': item.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${series.values[item.index]}`,\n }))\n\n // Only show label if cell is big enough\n if (r.w > 30 && r.h > 20) {\n const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3)\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {\n class: 'chartts-treemap-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n\n // Show value below label\n if (r.h > 35) {\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {\n class: 'chartts-treemap-value',\n fill: 'rgba(255,255,255,0.7)',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: fontSize * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${item.index}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return null\n const total = items.reduce((s, d) => s + d.value, 0)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const r = rects[k]!\n if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {\n return { seriesIndex: 0, pointIndex: items[k]!.index, distance: 0, x: r.x + r.w / 2, y: r.y + r.h / 2 }\n }\n }\n\n return null\n },\n}\n\ninterface Rect { x: number; y: number; w: number; h: number }\n\n/**\n * Squarified treemap layout.\n * Takes normalized values (sum to 1) and fills a rectangle.\n */\nfunction squarify(values: number[], x: number, y: number, w: number, h: number): Rect[] {\n const rects: Rect[] = []\n layoutRow(values, 0, x, y, w, h, rects)\n return rects\n}\n\nfunction layoutRow(\n values: number[], start: number,\n x: number, y: number, w: number, h: number,\n rects: Rect[],\n): void {\n if (start >= values.length) return\n if (values.length - start === 1) {\n rects.push({ x, y, w, h })\n return\n }\n\n const isWide = w >= h\n\n // Greedily add items to the current row until aspect ratio gets worse\n let rowSum = 0\n let bestWorst = Infinity\n let rowEnd = start\n\n for (let i = start; i < values.length; i++) {\n const newSum = rowSum + values[i]!\n\n // Compute row takes up fraction of the short side\n const rowFraction = newSum\n const rowThickness = isWide ? w * rowFraction : h * rowFraction\n const count = i - start + 1\n\n if (rowThickness <= 0) { rowSum = newSum; rowEnd = i + 1; continue }\n\n // Worst aspect ratio in this row\n let worst = 0\n for (let j = start; j <= i; j++) {\n const cellFrac = values[j]! / newSum\n const cellLen = isWide ? h * cellFrac : w * cellFrac\n const ar = Math.max(rowThickness / cellLen, cellLen / rowThickness)\n if (ar > worst) worst = ar\n }\n\n if (count === 1 || worst <= bestWorst) {\n bestWorst = worst\n rowSum = newSum\n rowEnd = i + 1\n } else {\n break\n }\n }\n\n if (rowEnd === start) rowEnd = start + 1\n const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0)\n\n // Lay out this row\n const rowThickness = isWide ? w * finalSum : h * finalSum\n let offset = 0\n\n for (let i = start; i < rowEnd; i++) {\n const frac = finalSum > 0 ? values[i]! / finalSum : 0\n const cellLen = isWide ? h * frac : w * frac\n\n if (isWide) {\n rects.push({ x, y: y + offset, w: rowThickness, h: cellLen })\n } else {\n rects.push({ x: x + offset, y, w: cellLen, h: rowThickness })\n }\n offset += cellLen\n }\n\n // Recurse for remaining items\n if (isWide) {\n layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects)\n } else {\n layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects)\n }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { PathBuilder, path, text, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-MPQECPE3.js';
|
|
2
|
+
import { PathBuilder, path, text, group } from './chunk-DX4FBN3I.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/kagi/kagi-type.ts
|
|
5
5
|
var kagiChartType = {
|
|
@@ -75,14 +75,14 @@ var kagiChartType = {
|
|
|
75
75
|
}));
|
|
76
76
|
return nodes;
|
|
77
77
|
},
|
|
78
|
-
hitTest(ctx, mx,
|
|
78
|
+
hitTest(ctx, mx, my) {
|
|
79
79
|
const { data, area } = ctx;
|
|
80
80
|
const series = data.series[0];
|
|
81
81
|
if (!series || series.values.length < 2) return null;
|
|
82
82
|
const frac = (mx - area.x) / area.width;
|
|
83
83
|
const idx = Math.round(frac * (series.values.length - 1));
|
|
84
84
|
if (idx >= 0 && idx < series.values.length) {
|
|
85
|
-
return { seriesIndex: 0, pointIndex: idx, distance: 10 };
|
|
85
|
+
return { seriesIndex: 0, pointIndex: idx, distance: 10, x: mx, y: my };
|
|
86
86
|
}
|
|
87
87
|
return null;
|
|
88
88
|
}
|
|
@@ -150,5 +150,5 @@ function computeKagiSegments(values, reversal) {
|
|
|
150
150
|
}
|
|
151
151
|
|
|
152
152
|
export { kagiChartType };
|
|
153
|
-
//# sourceMappingURL=chunk-
|
|
154
|
-
//# sourceMappingURL=chunk-
|
|
153
|
+
//# sourceMappingURL=chunk-BT5H3WMI.js.map
|
|
154
|
+
//# sourceMappingURL=chunk-BT5H3WMI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/kagi/kagi-type.ts"],"names":[],"mappings":"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","file":"chunk-BT5H3WMI.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\nexport interface KagiOptions {\n /** Reversal amount. If < 1, treated as percentage of range. Default 0.04 (4%). */\n reversalAmount?: number\n /** Yang (up-trend) color. Default green. */\n yangColor?: string\n /** Yin (down-trend) color. Default red. */\n yinColor?: string\n /** Yang line width (thick). Default 3. */\n yangWidth?: number\n /** Yin line width (thin). Default 1.5. */\n yinWidth?: number\n /** Show price labels at turning points. Default false. */\n showLabels?: boolean\n}\n\ninterface KagiSegment {\n startY: number\n endY: number\n x: number\n isYang: boolean // thick = up trend\n priceStart: number\n priceEnd: number\n}\n\n/**\n * Kagi chart — Japanese reversal chart.\n *\n * Lines change direction only on significant price moves.\n * Thick lines (yang) = up trend, thin lines (yin) = down trend.\n * Thickness changes when price breaks prior high/low.\n */\nexport const kagiChartType: ChartTypePlugin = {\n type: 'kagi',\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, theme } = 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 KagiOptions\n const yangColor = opts.yangColor ?? 'var(--color-emerald-500, #10b981)'\n const yinColor = opts.yinColor ?? 'var(--color-red-500, #ef4444)'\n const yangWidth = opts.yangWidth ?? 3\n const yinWidth = opts.yinWidth ?? 1.5\n const showLabels = opts.showLabels ?? false\n\n const values = series.values\n const vMin = Math.min(...values)\n const vMax = Math.max(...values)\n const vRange = vMax - vMin || 1\n\n // Reversal amount\n let reversal = opts.reversalAmount ?? 0.04\n if (reversal < 1) reversal = reversal * vRange\n\n // Build kagi segments\n const segments = computeKagiSegments(values, reversal)\n if (segments.length === 0) return nodes\n\n // Map to pixel coordinates\n const padding = 20\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const colWidth = segments.length > 1 ? usableWidth / (segments.length - 1) : usableWidth\n\n const mapY = (v: number) => area.y + padding + (1 - (v - vMin) / vRange) * usableHeight\n const actualColWidth = Math.min(colWidth, 20)\n const totalWidth = actualColWidth * (segments.length - 1)\n const xOffset = area.x + (area.width - totalWidth) / 2\n\n const kagiNodes: RenderNode[] = []\n\n // Draw segments\n for (let i = 0; i < segments.length; i++) {\n const seg = segments[i]!\n const x = xOffset + i * actualColWidth\n const y1 = mapY(seg.priceStart)\n const y2 = mapY(seg.priceEnd)\n const color = seg.isYang ? yangColor : yinColor\n const width = seg.isYang ? yangWidth : yinWidth\n\n // Vertical segment\n const pb = new PathBuilder()\n pb.moveTo(x, y1).lineTo(x, y2)\n\n // Horizontal connector to next segment\n if (i < segments.length - 1) {\n const nextX = xOffset + (i + 1) * actualColWidth\n pb.lineTo(nextX, y2)\n }\n\n kagiNodes.push(path(pb.build(), {\n class: 'chartts-kagi-line',\n stroke: color,\n strokeWidth: width,\n strokeLinecap: 'round',\n strokeLinejoin: 'round',\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Price labels at turning points\n if (showLabels && (i === 0 || i === segments.length - 1)) {\n kagiNodes.push(text(x, y2 + (seg.priceEnd > seg.priceStart ? -8 : 14), seg.priceEnd.toFixed(1), {\n class: 'chartts-kagi-label',\n fill: theme.textMuted,\n fontSize: theme.fontSizeSmall,\n textAnchor: 'middle',\n }))\n }\n }\n\n nodes.push(group(kagiNodes, {\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 || series.values.length < 2) return null\n\n // Approximate: map mouse X to data index\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, x: mx, y: my }\n }\n return null\n },\n}\n\n/**\n * Compute kagi line segments from raw price data.\n */\nfunction computeKagiSegments(values: number[], reversal: number): KagiSegment[] {\n const segments: KagiSegment[] = []\n if (values.length < 2) return segments\n\n let direction: 'up' | 'down' = values[1]! >= values[0]! ? 'up' : 'down'\n let currentStart = values[0]!\n let currentEnd = values[1]!\n let priorHigh = Math.max(values[0]!, values[1]!)\n let priorLow = Math.min(values[0]!, values[1]!)\n let isYang = direction === 'up'\n\n for (let i = 2; i < values.length; i++) {\n const v = values[i]!\n\n if (direction === 'up') {\n if (v >= currentEnd) {\n // Continue up\n currentEnd = v\n if (v > priorHigh) isYang = true\n } else if (currentEnd - v >= reversal) {\n // Reversal down\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorHigh = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'down'\n if (v < priorLow) isYang = false\n }\n } else {\n if (v <= currentEnd) {\n // Continue down\n currentEnd = v\n if (v < priorLow) isYang = false\n } else if (v - currentEnd >= reversal) {\n // Reversal up\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorLow = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'up'\n if (v > priorHigh) isYang = true\n }\n }\n }\n\n // Push final segment\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n\n return segments\n}\n"]}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
var
|
|
3
|
+
var chunkWYIIWTIR_cjs = require('./chunk-WYIIWTIR.cjs');
|
|
4
|
+
var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
|
|
5
|
+
var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
|
|
5
6
|
|
|
6
7
|
// src/charts/sunburst/sunburst-type.ts
|
|
7
8
|
var sunburstChartType = {
|
|
@@ -10,7 +11,7 @@ var sunburstChartType = {
|
|
|
10
11
|
return { x: "categorical", y: "linear" };
|
|
11
12
|
},
|
|
12
13
|
prepareData(data, options) {
|
|
13
|
-
return
|
|
14
|
+
return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
|
|
14
15
|
},
|
|
15
16
|
render(ctx) {
|
|
16
17
|
const { data, area, theme, options } = ctx;
|
|
@@ -40,32 +41,28 @@ var sunburstChartType = {
|
|
|
40
41
|
const r1 = r0 + ringWidth - 1;
|
|
41
42
|
const sliceAngle = node.endAngle - node.startAngle;
|
|
42
43
|
if (sliceAngle < 5e-3) return;
|
|
43
|
-
const
|
|
44
|
-
const
|
|
45
|
-
const
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
const
|
|
49
|
-
const
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
pb.arc(r0, r0, 0, largeArc, false, x2i, y2i);
|
|
61
|
-
pb.close();
|
|
44
|
+
const gapPx = 3;
|
|
45
|
+
const halfGap = gapPx / 2;
|
|
46
|
+
const outerPadAngle = halfGap / r1;
|
|
47
|
+
const innerPadAngle = r0 > 0 ? halfGap / r0 : 0;
|
|
48
|
+
if (sliceAngle < outerPadAngle * 2 + 5e-3) return;
|
|
49
|
+
const cr = Math.min(4, ringWidth * 0.2);
|
|
50
|
+
const d = chunkWYIIWTIR_cjs.roundedSlicePath(
|
|
51
|
+
cx,
|
|
52
|
+
cy,
|
|
53
|
+
r1,
|
|
54
|
+
r0,
|
|
55
|
+
node.startAngle + outerPadAngle,
|
|
56
|
+
node.endAngle - outerPadAngle,
|
|
57
|
+
node.startAngle + innerPadAngle,
|
|
58
|
+
node.endAngle - innerPadAngle,
|
|
59
|
+
cr
|
|
60
|
+
);
|
|
62
61
|
const opacity = 1 - (node.depth - 1) * 0.15;
|
|
63
|
-
nodes.push(
|
|
62
|
+
nodes.push(chunkUMIJYYF3_cjs.path(d, {
|
|
64
63
|
class: "chartts-sunburst-sector",
|
|
65
64
|
fill: color,
|
|
66
65
|
fillOpacity: Math.max(0.4, opacity),
|
|
67
|
-
stroke: theme.background === "transparent" ? "#fff" : theme.background,
|
|
68
|
-
strokeWidth: 0.5,
|
|
69
66
|
"data-series": 0,
|
|
70
67
|
"data-index": colorIdx,
|
|
71
68
|
tabindex: 0,
|
|
@@ -73,12 +70,12 @@ var sunburstChartType = {
|
|
|
73
70
|
ariaLabel: `${node.name}: ${node.totalValue}`
|
|
74
71
|
}));
|
|
75
72
|
if (sliceAngle > 0.3 && ringWidth > 20) {
|
|
76
|
-
const midAngle = (
|
|
73
|
+
const midAngle = (node.startAngle + node.endAngle) / 2;
|
|
77
74
|
const labelR = (r0 + r1) / 2;
|
|
78
75
|
const lx = cx + labelR * Math.cos(midAngle);
|
|
79
76
|
const ly = cy + labelR * Math.sin(midAngle);
|
|
80
77
|
const fontSize = Math.min(theme.fontSizeSmall, ringWidth * 0.35);
|
|
81
|
-
nodes.push(
|
|
78
|
+
nodes.push(chunkUMIJYYF3_cjs.text(lx, ly, node.name, {
|
|
82
79
|
class: "chartts-sunburst-label",
|
|
83
80
|
fill: "#fff",
|
|
84
81
|
textAnchor: "middle",
|
|
@@ -118,7 +115,7 @@ var sunburstChartType = {
|
|
|
118
115
|
const depth = Math.floor(depthFloat) + 1;
|
|
119
116
|
const hit = findSector(root, depth, angle);
|
|
120
117
|
if (hit) {
|
|
121
|
-
return { seriesIndex: 0, pointIndex: hit, distance: 0 };
|
|
118
|
+
return { seriesIndex: 0, pointIndex: hit, distance: 0, x: mx, y: my };
|
|
122
119
|
}
|
|
123
120
|
return null;
|
|
124
121
|
}
|
|
@@ -214,5 +211,5 @@ function findSector(node, targetDepth, angle) {
|
|
|
214
211
|
}
|
|
215
212
|
|
|
216
213
|
exports.sunburstChartType = sunburstChartType;
|
|
217
|
-
//# sourceMappingURL=chunk-
|
|
218
|
-
//# sourceMappingURL=chunk-
|
|
214
|
+
//# sourceMappingURL=chunk-BYB3LQAT.cjs.map
|
|
215
|
+
//# sourceMappingURL=chunk-BYB3LQAT.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/sunburst/sunburst-type.ts"],"names":["prepareNoAxes","roundedSlicePath","path","text"],"mappings":"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","file":"chunk-BYB3LQAT.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { roundedSlicePath } from '../../utils/slice-path'\n\n/**\n * Sunburst chart — hierarchical radial visualization.\n *\n * Data convention:\n * - labels: leaf node names\n * - series[0].values: leaf values (sizes)\n * - Hierarchy is encoded via label separators: \"A/B/C\" means root→A→B→C\n * If no separators, falls back to flat ring layout (single ring).\n *\n * The chart draws concentric rings from center outward, one ring per depth level.\n */\n\ninterface SunburstNode {\n name: string\n fullPath: string\n value: number\n children: SunburstNode[]\n depth: number\n startAngle: number\n endAngle: number\n // Computed during layout\n totalValue: number\n}\n\nexport const sunburstChartType: ChartTypePlugin = {\n type: 'sunburst',\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 // Build tree from labels\n const root = buildTree(data.labels, series.values)\n if (root.totalValue === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const maxRadius = Math.min(area.width, area.height) / 2 - 4\n const innerRadius = maxRadius * 0.15\n\n // Compute max depth for ring sizing\n const maxDepth = getMaxDepth(root)\n const ringWidth = (maxRadius - innerRadius) / Math.max(maxDepth, 1)\n\n // Layout angles recursively\n layoutAngles(root, -Math.PI / 2, -Math.PI / 2 + Math.PI * 2)\n\n // Render all non-root nodes\n let colorIdx = 0\n const renderNode = (node: SunburstNode, parentColorIdx: number) => {\n if (node.depth === 0) {\n // Root — render children with cycling colors\n for (let i = 0; i < node.children.length; i++) {\n renderNode(node.children[i]!, i)\n }\n return\n }\n\n const ci = node.depth === 1 ? parentColorIdx : parentColorIdx\n const color = options.colors[ci % options.colors.length]!\n const r0 = innerRadius + (node.depth - 1) * ringWidth\n const r1 = r0 + ringWidth - 1 // 1px gap between rings\n\n const sliceAngle = node.endAngle - node.startAngle\n if (sliceAngle < 0.005) return // Skip tiny slices\n\n // Uniform pixel gap: different angular offsets at different radii\n const gapPx = 3\n const halfGap = gapPx / 2\n const outerPadAngle = halfGap / r1\n const innerPadAngle = r0 > 0 ? halfGap / r0 : 0\n\n if (sliceAngle < outerPadAngle * 2 + 0.005) return\n\n const cr = Math.min(4, ringWidth * 0.2)\n\n const d = roundedSlicePath(\n cx, cy, r1, r0,\n node.startAngle + outerPadAngle, node.endAngle - outerPadAngle,\n node.startAngle + innerPadAngle, node.endAngle - innerPadAngle,\n cr,\n )\n\n const opacity = 1 - (node.depth - 1) * 0.15\n\n nodes.push(path(d, {\n class: 'chartts-sunburst-sector',\n fill: color,\n fillOpacity: Math.max(0.4, opacity),\n 'data-series': 0,\n 'data-index': colorIdx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${node.totalValue}`,\n }))\n\n // Label for larger sectors\n if (sliceAngle > 0.3 && ringWidth > 20) {\n const midAngle = (node.startAngle + node.endAngle) / 2\n const labelR = (r0 + r1) / 2\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n\n const fontSize = Math.min(theme.fontSizeSmall, ringWidth * 0.35)\n nodes.push(text(lx, ly, node.name, {\n class: 'chartts-sunburst-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n colorIdx++\n\n // Render children\n for (let i = 0; i < node.children.length; i++) {\n renderNode(node.children[i]!, parentColorIdx)\n }\n }\n\n renderNode(root, 0)\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 cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const maxRadius = Math.min(area.width, area.height) / 2 - 4\n const innerRadius = maxRadius * 0.15\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist > maxRadius || dist < innerRadius) return null\n\n const root = buildTree(data.labels, series.values)\n const maxDepth = getMaxDepth(root)\n const ringWidth = (maxRadius - innerRadius) / Math.max(maxDepth, 1)\n\n layoutAngles(root, -Math.PI / 2, -Math.PI / 2 + Math.PI * 2)\n\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n // Find which ring (depth) the point is in\n const depthFloat = (dist - innerRadius) / ringWidth\n const depth = Math.floor(depthFloat) + 1\n\n // Find sector at this depth and angle\n const hit = findSector(root, depth, angle)\n if (hit) {\n return { seriesIndex: 0, pointIndex: hit, distance: 0, x: mx, y: my }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Tree building\n// ---------------------------------------------------------------------------\n\nfunction buildTree(labels: (string | number | Date)[], values: number[]): SunburstNode {\n const root: SunburstNode = {\n name: 'root', fullPath: '', value: 0,\n children: [], depth: 0, startAngle: 0, endAngle: 0, totalValue: 0,\n }\n\n for (let i = 0; i < labels.length; i++) {\n const label = String(labels[i] ?? `Item ${i}`)\n const value = Math.abs(values[i] ?? 0)\n if (value <= 0) continue\n\n const parts = label.includes('/') ? label.split('/') : [label]\n let current = root\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]!.trim()\n let child = current.children.find(c => c.name === part)\n\n if (!child) {\n child = {\n name: part,\n fullPath: parts.slice(0, p + 1).join('/'),\n value: 0,\n children: [],\n depth: p + 1,\n startAngle: 0,\n endAngle: 0,\n totalValue: 0,\n }\n current.children.push(child)\n }\n\n if (p === parts.length - 1) {\n child.value = value\n }\n current = child\n }\n }\n\n // Compute totals bottom-up\n computeTotals(root)\n\n return root\n}\n\nfunction computeTotals(node: SunburstNode): number {\n if (node.children.length === 0) {\n node.totalValue = node.value\n return node.totalValue\n }\n let sum = 0\n for (const child of node.children) {\n sum += computeTotals(child)\n }\n node.totalValue = Math.max(sum, node.value)\n return node.totalValue\n}\n\nfunction layoutAngles(node: SunburstNode, start: number, end: number): void {\n node.startAngle = start\n node.endAngle = end\n\n if (node.children.length === 0 || node.totalValue === 0) return\n\n let current = start\n for (const child of node.children) {\n const fraction = child.totalValue / node.totalValue\n const childEnd = current + fraction * (end - start)\n layoutAngles(child, current, childEnd)\n current = childEnd\n }\n}\n\nfunction getMaxDepth(node: SunburstNode): number {\n if (node.children.length === 0) return node.depth\n let max = node.depth\n for (const child of node.children) {\n max = Math.max(max, getMaxDepth(child))\n }\n return max\n}\n\nfunction findSector(node: SunburstNode, targetDepth: number, angle: number): number | null {\n if (node.depth === targetDepth) {\n if (angle >= node.startAngle && angle < node.endAngle) {\n return node.depth // Return something non-null to indicate a hit\n }\n return null\n }\n\n for (const child of node.children) {\n if (angle >= child.startAngle && angle < child.endAngle) {\n const result = findSector(child, targetDepth, angle)\n if (result !== null) return result\n }\n }\n\n return null\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { getBandwidth } from './chunk-E6PR75X7.js';
|
|
2
2
|
import { formatNum } from './chunk-OGSZO22B.js';
|
|
3
|
-
import {
|
|
3
|
+
import { rect, path, group, prepareData } from './chunk-DX4FBN3I.js';
|
|
4
4
|
|
|
5
5
|
// src/charts/bar/bar-type.ts
|
|
6
6
|
var barChartType = {
|
|
@@ -70,6 +70,32 @@ var barChartType = {
|
|
|
70
70
|
}
|
|
71
71
|
return nodes;
|
|
72
72
|
},
|
|
73
|
+
getHighlightNodes(ctx, hit) {
|
|
74
|
+
const { data, xScale, yScale, options } = ctx;
|
|
75
|
+
const seriesCount = data.series.length;
|
|
76
|
+
const bw = getBandwidth(xScale);
|
|
77
|
+
const groupWidth = bw * (1 - options.barGap);
|
|
78
|
+
const barWidth = groupWidth / seriesCount;
|
|
79
|
+
const groupOffset = -groupWidth / 2;
|
|
80
|
+
const baseline = yScale.map(Math.max(0, yScale.getDomain()[0]));
|
|
81
|
+
const series = data.series[hit.seriesIndex];
|
|
82
|
+
if (!series) return [];
|
|
83
|
+
const i = hit.pointIndex;
|
|
84
|
+
const cx = xScale.map(i);
|
|
85
|
+
const barX = cx + groupOffset + series.index * barWidth;
|
|
86
|
+
const vy = yScale.map(series.values[i]);
|
|
87
|
+
const y = series.values[i] >= 0 ? vy : baseline;
|
|
88
|
+
const h = Math.abs(vy - baseline);
|
|
89
|
+
return [
|
|
90
|
+
rect(barX - 1, y - 1, barWidth + 2, h + 2, {
|
|
91
|
+
class: "chartts-highlight-bar",
|
|
92
|
+
fill: "none",
|
|
93
|
+
stroke: series.color,
|
|
94
|
+
strokeWidth: 2,
|
|
95
|
+
strokeOpacity: 0.8
|
|
96
|
+
})
|
|
97
|
+
];
|
|
98
|
+
},
|
|
73
99
|
hitTest(ctx, mx, my) {
|
|
74
100
|
const { data, xScale, yScale, options } = ctx;
|
|
75
101
|
const seriesCount = data.series.length;
|
|
@@ -93,7 +119,7 @@ var barChartType = {
|
|
|
93
119
|
const dist = 0;
|
|
94
120
|
if (dist < bestDist) {
|
|
95
121
|
bestDist = dist;
|
|
96
|
-
best = { seriesIndex: series.index, pointIndex: i, distance: dist };
|
|
122
|
+
best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy };
|
|
97
123
|
}
|
|
98
124
|
}
|
|
99
125
|
}
|
|
@@ -103,5 +129,5 @@ var barChartType = {
|
|
|
103
129
|
};
|
|
104
130
|
|
|
105
131
|
export { barChartType };
|
|
106
|
-
//# sourceMappingURL=chunk-
|
|
107
|
-
//# sourceMappingURL=chunk-
|
|
132
|
+
//# sourceMappingURL=chunk-CCMLOCTH.js.map
|
|
133
|
+
//# sourceMappingURL=chunk-CCMLOCTH.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/bar/bar-type.ts"],"names":[],"mappings":"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","file":"chunk-CCMLOCTH.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 } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\nexport const barChartType: ChartTypePlugin = {\n type: 'bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n\n // Bar charts should always include 0 in the y-axis range\n // unless the user explicitly set yMin/yMax\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\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * (1 - options.barGap)\n const barWidth = groupWidth / seriesCount\n const groupOffset = -groupWidth / 2\n\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\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 cx = xScale.map(i)\n const barX = cx + groupOffset + series.index * barWidth\n const vy = yScale.map(series.values[i]!)\n\n // Handle positive and negative values\n const y = series.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n const isPositive = series.values[i]! >= 0\n\n const barFill = `url(#chartts-bar-${series.index})`\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\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${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 getHighlightNodes(ctx: RenderContext, hit: HitResult): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const seriesCount = data.series.length\n const bw = getBandwidth(xScale)\n const groupWidth = bw * (1 - options.barGap)\n const barWidth = groupWidth / seriesCount\n const groupOffset = -groupWidth / 2\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const series = data.series[hit.seriesIndex]\n if (!series) return []\n const i = hit.pointIndex\n const cx = xScale.map(i)\n const barX = cx + groupOffset + series.index * barWidth\n const vy = yScale.map(series.values[i]!)\n const y = series.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n // Bright outline around the hovered bar\n return [\n rect(barX - 1, y - 1, barWidth + 2, h + 2, {\n class: 'chartts-highlight-bar',\n fill: 'none',\n stroke: series.color,\n strokeWidth: 2,\n strokeOpacity: 0.8,\n }),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * (1 - options.barGap)\n const barWidth = groupWidth / seriesCount\n const groupOffset = -groupWidth / 2\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n const barX = cx + groupOffset + series.index * barWidth\n const vy = yScale.map(series.values[i]!)\n const y = series.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n // Check if mouse is inside bar bounds (with small padding)\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n const dist = 0\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy }\n }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
|
|
4
4
|
|
|
5
5
|
// src/utils/prepare.ts
|
|
6
6
|
function prepareNoAxes(data, options) {
|
|
7
|
-
return
|
|
7
|
+
return chunkUMIJYYF3_cjs.prepareData(data, {
|
|
8
8
|
...options,
|
|
9
9
|
xAxis: false,
|
|
10
10
|
yAxis: false,
|
|
@@ -15,5 +15,5 @@ function prepareNoAxes(data, options) {
|
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
exports.prepareNoAxes = prepareNoAxes;
|
|
18
|
-
//# sourceMappingURL=chunk-
|
|
19
|
-
//# sourceMappingURL=chunk-
|
|
18
|
+
//# sourceMappingURL=chunk-CDS2NXGT.cjs.map
|
|
19
|
+
//# sourceMappingURL=chunk-CDS2NXGT.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/prepare.ts"],"names":["prepareData"],"mappings":";;;;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAOA,8BAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/utils/prepare.ts"],"names":["prepareData"],"mappings":";;;;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAOA,8BAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-CDS2NXGT.cjs","sourcesContent":["import type { ChartData, ResolvedOptions, PreparedData } from '../types'\nimport { prepareData } from '../data/prepare'\n\n/**\n * Prepare data with axes, grid, and legend suppressed.\n * Used by chart types that render their own layout (pie, gauge, treemap, etc.).\n */\nexport function prepareNoAxes(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n}\n"]}
|