@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/radialbar/radialbar-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-DZHP4UUE.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const values = series.values\n const count = values.length\n let maxVal = 0\n for (const v of values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (maxVal === 0) maxVal = 1\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring)\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n return { seriesIndex: 0, pointIndex: i, distance: 0 }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\n const x1 = cx + r * Math.cos(startAngle)\n const y1 = cy + r * Math.sin(startAngle)\n const x2 = cx + r * Math.cos(endAngle)\n const y2 = cy + r * Math.sin(endAngle)\n const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/bullet/bullet-type.ts"],"names":[],"mappings":";;;;AAiBO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,KAAA,EAAO,SAAQ,GAAI,GAAA;AACvC,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,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,MAAM,KAAA,GAAQ,OAAO,MAAA,CAAO,MAAA;AAC5B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,MAAA,GAAS,KAAK,CAAA,GAAI,UAAA;AACxB,IAAA,MAAM,MAAA,GAAS,KAAK,KAAA,GAAQ,UAAA;AAE5B,IAAA,MAAM,SAAA,GAAY,KAAK,MAAA,GAAS,KAAA;AAChC,IAAA,MAAM,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAC9C,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAGhD,IAAA,IAAI,MAAA,GAAS,CAAA;AACb,IAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,MAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,IAC/C;AACA,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC/C;AAAA,IACF;AAEA,IAAA,MAAA,GAAS,MAAA,GAAS,GAAA;AAClB,IAAA,IAAI,MAAA,KAAW,GAAG,MAAA,GAAS,CAAA;AAE3B,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,EAAO,CAAA,EAAA,EAAK;AAC9B,MAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,SAAA,IAAa,CAAA,GAAI,GAAA,CAAA;AACrC,MAAA,MAAM,GAAA,GAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA;AAC3B,MAAA,MAAM,KAAA,GAAQ,OAAO,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAA,KAAA,EAAQ,CAAA,GAAI,CAAC,CAAA,CAAE,CAAA;AACtD,MAAA,MAAM,QAAQ,OAAA,CAAQ,MAAA,CAAO,CAAA,GAAI,OAAA,CAAQ,OAAO,MAAM,CAAA;AACtD,MAAA,MAAM,cAA4B,EAAC;AAGnC,MAAA,WAAA,CAAY,KAAK,IAAA,CAAK,IAAA,CAAK,IAAI,UAAA,GAAa,CAAA,EAAG,IAAI,KAAA,EAAO;AAAA,QACxD,KAAA,EAAO,sBAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,KAAA;AAAA,QACZ,gBAAA,EAAkB,SAAA;AAAA,QAClB,UAAU,KAAA,CAAM,aAAA;AAAA,QAChB,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAGF,MAAA,MAAM,KAAA,GAAQ,CAAC,CAAA,EAAK,IAAA,EAAM,GAAG,CAAA;AAC7B,MAAA,MAAM,SAAA,GAAY,CAAC,GAAA,EAAK,IAAA,EAAM,IAAI,CAAA;AAClC,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,QAAQ,CAAA,EAAA,EAAK;AACrC,QAAA,MAAM,EAAA,GAAK,MAAA,GAAS,KAAA,CAAM,CAAC,CAAA;AAC3B,QAAA,WAAA,CAAY,KAAK,IAAA,CAAK,MAAA,EAAQ,KAAK,WAAA,GAAc,CAAA,EAAG,IAAI,WAAA,EAAa;AAAA,UACnE,EAAA,EAAI,CAAA;AAAA,UAAG,EAAA,EAAI,CAAA;AAAA,UACX,KAAA,EAAO,sBAAA;AAAA,UACP,MAAM,KAAA,CAAM,SAAA;AAAA,UACZ,OAAA,EAAS,UAAU,CAAC;AAAA,SACrB,CAAC,CAAA;AAAA,MACJ;AAGA,MAAA,MAAM,IAAA,GAAQ,IAAA,CAAK,GAAA,CAAI,GAAG,IAAI,MAAA,GAAU,MAAA;AACxC,MAAA,WAAA,CAAY,KAAK,IAAA,CAAK,MAAA,EAAQ,KAAK,SAAA,GAAY,CAAA,EAAG,MAAM,SAAA,EAAW;AAAA,QACjE,EAAA,EAAI,CAAA;AAAA,QAAG,EAAA,EAAI,CAAA;AAAA,QACX,KAAA,EAAO,oBAAA;AAAA,QACP,IAAA,EAAM,KAAA;AAAA,QACN,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc,CAAA;AAAA,QACd,QAAA,EAAU,CAAA;AAAA,QACV,IAAA,EAAM,KAAA;AAAA,QACN,SAAA,EAAW,CAAA,EAAG,KAAK,CAAA,EAAA,EAAK,GAAG,CAAA,EAAG,MAAA,GAAS,CAAA,UAAA,EAAa,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,KAAK,EAAE,CAAA;AAAA,OAC5E,CAAC,CAAA;AAGF,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,CAAC,KAAK,IAAA,EAAM;AACtC,QAAA,MAAM,EAAA,GAAK,SAAU,IAAA,CAAK,GAAA,CAAI,OAAO,MAAA,CAAO,CAAC,CAAE,CAAA,GAAI,MAAA,GAAU,MAAA;AAC7D,QAAA,MAAM,UAAU,WAAA,GAAc,GAAA;AAC9B,QAAA,WAAA,CAAY,IAAA,CAAK,KAAK,EAAA,EAAI,EAAA,GAAK,UAAU,CAAA,EAAG,EAAA,EAAI,EAAA,GAAK,OAAA,GAAU,CAAA,EAAG;AAAA,UAChE,KAAA,EAAO,uBAAA;AAAA,UACP,QAAQ,KAAA,CAAM,SAAA;AAAA,UACd,WAAA,EAAa;AAAA,SACd,CAAC,CAAA;AAAA,MACJ;AAEA,MAAA,KAAA,CAAM,IAAA,CAAK,MAAM,WAAA,EAAa;AAAA,QAC5B,KAAA,EAAO,iCAAiC,CAAC,CAAA,CAAA;AAAA,QACzC,kBAAA,EAAoB;AAAA,OACrB,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAK,GAAI,GAAA;AACvB,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,KAAA,GAAQ,OAAO,MAAA,CAAO,MAAA;AAC5B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,SAAA,GAAY,KAAK,MAAA,GAAS,KAAA;AAEhC,IAAA,IAAI,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,UAAA,EAAY,OAAO,IAAA;AAErC,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,EAAO,CAAA,EAAA,EAAK;AAC9B,MAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,SAAA,IAAa,CAAA,GAAI,GAAA,CAAA;AACrC,MAAA,MAAM,WAAA,GAAc,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAEhD,MAAA,IAAI,MAAM,EAAA,GAAK,WAAA,GAAc,KAAK,EAAA,IAAM,EAAA,GAAK,cAAc,CAAA,EAAG;AAC5D,QAAA,OAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,CAAA,EAAG,UAAU,CAAA,EAAE;AAAA,MACtD;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-DZW35WR2.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, line, text } from '../../render/tree'\n\n/**\n * Bullet chart — compact horizontal gauge.\n *\n * Data format: each label is a metric.\n * - series[0]: actual values\n * - series[1] (optional): target values (shown as a marker line)\n *\n * Qualitative ranges (poor/satisfactory/good) are auto-generated\n * from the max value.\n */\nexport const bulletChartType: ChartTypePlugin = {\n type: 'bullet',\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 actual = data.series[0]\n if (!actual || actual.values.length === 0) return nodes\n\n const target = data.series[1]\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n const rowHeight = area.height / count\n const barHeight = Math.min(rowHeight * 0.4, 20)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n // Find global max for scaling\n let maxVal = 0\n for (const v of actual.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (target) {\n for (const v of target.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n // Extend max to give headroom for ranges\n maxVal = maxVal * 1.2\n if (maxVal === 0) maxVal = 1\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const val = actual.values[i]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n const color = options.colors[i % options.colors.length]!\n const bulletNodes: RenderNode[] = []\n\n // Label\n bulletNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-bullet-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Qualitative ranges (3 bands: poor, satisfactory, good)\n const bands = [1.0, 0.75, 0.5]\n const opacities = [0.1, 0.18, 0.28]\n for (let b = 0; b < bands.length; b++) {\n const bw = chartW * bands[b]!\n bulletNodes.push(rect(chartX, cy - rangeHeight / 2, bw, rangeHeight, {\n rx: 4, ry: 4,\n class: 'chartts-bullet-range',\n fill: theme.textColor,\n opacity: opacities[b],\n }))\n }\n\n // Actual value bar\n const barW = (Math.abs(val) / maxVal) * chartW\n bulletNodes.push(rect(chartX, cy - barHeight / 2, barW, barHeight, {\n rx: 3, ry: 3,\n class: 'chartts-bullet-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${val}${target ? `, target: ${target.values[i]}` : ''}`,\n }))\n\n // Target marker\n if (target && target.values[i] != null) {\n const tx = chartX + (Math.abs(target.values[i]!) / maxVal) * chartW\n const markerH = rangeHeight * 0.9\n bulletNodes.push(line(tx, cy - markerH / 2, tx, cy + markerH / 2, {\n class: 'chartts-bullet-target',\n stroke: theme.textColor,\n strokeWidth: 2.5,\n }))\n }\n\n nodes.push(group(bulletNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const actual = data.series[0]\n if (!actual || actual.values.length === 0) return null\n\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const rowHeight = area.height / count\n\n if (mx < area.x + labelWidth) return null\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n if (my >= cy - rangeHeight / 2 && my <= cy + rangeHeight / 2) {\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/pictorialbar/pictorialbar-type.ts"],"names":["prepareNoAxes","path","text","group"],"mappings":"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","file":"chunk-EAKXLFOR.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'\n\n/**\n * PictorialBar chart — bar chart where bars are filled with repeated symbols.\n *\n * Data convention:\n * - labels: category names\n * - series[0].values: bar values\n *\n * The bars are made of stacked symbols (circles, diamonds, or custom shapes)\n * creating a pictograph/isotype visualization.\n */\n\nexport interface PictorialBarOptions {\n /** Symbol shape. Default 'circle'. */\n symbol?: 'circle' | 'diamond' | 'square' | 'triangle' | 'star'\n /** Symbol size in px. Default 12. */\n symbolSize?: number\n /** Gap between symbols. Default 2. */\n symbolGap?: number\n /** Show value labels. Default true. */\n showValues?: boolean\n}\n\n// SVG path data for symbols (centered at 0,0, size 1x1)\nconst SYMBOL_PATHS: Record<string, string> = {\n circle: 'M0.5,0A0.5,0.5,0,1,1,-0.5,0A0.5,0.5,0,1,1,0.5,0Z',\n diamond: 'M0,-0.5L0.5,0L0,-0.5L-0.5,0Z',\n square: 'M-0.4,-0.4L0.4,-0.4L0.4,0.4L-0.4,0.4Z',\n triangle: 'M0,-0.5L0.5,0.4L-0.5,0.4Z',\n star: 'M0,-0.5L0.15,-0.15L0.5,-0.15L0.22,0.07L0.31,0.45L0,0.22L-0.31,0.45L-0.22,0.07L-0.5,-0.15L-0.15,-0.15Z',\n}\n\nexport const pictorialBarChartType: ChartTypePlugin = {\n type: 'pictorialbar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const pOpts = options as unknown as PictorialBarOptions\n const symbolShape = pOpts.symbol ?? 'circle'\n const symbolSize = pOpts.symbolSize ?? 14\n const symbolGap = pOpts.symbolGap ?? 2\n const showValues = pOpts.showValues ?? true\n\n const values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n if (maxVal === 0) return nodes\n\n const barCount = values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n const symbolStep = symbolSize + symbolGap\n const maxSymbols = Math.floor((area.height - 30) / symbolStep)\n\n for (let i = 0; i < barCount; i++) {\n const val = Math.abs(values[i]!)\n const symbolCount = Math.max(1, Math.round((val / maxVal) * maxSymbols))\n const color = options.colors[i % options.colors.length]!\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n const barNodes: RenderNode[] = []\n\n for (let s = 0; s < symbolCount; s++) {\n const sy = area.y + area.height - 20 - s * symbolStep - symbolSize / 2\n\n if (symbolShape === 'circle') {\n barNodes.push({\n type: 'circle',\n cx,\n cy: sy,\n r: symbolSize / 2,\n attrs: {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n },\n })\n } else {\n // Use path-based symbols\n const symbolPath = SYMBOL_PATHS[symbolShape] ?? SYMBOL_PATHS.circle!\n barNodes.push(path(symbolPath, {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n transform: `translate(${cx},${sy}) scale(${symbolSize})`,\n 'data-series': 0,\n 'data-index': i,\n }))\n }\n }\n\n // Value label above bar\n if (showValues) {\n const topY = area.y + area.height - 20 - (symbolCount - 1) * symbolStep - symbolSize\n barNodes.push(text(cx, topY - 8, String(values[i]!), {\n class: 'chartts-pictorialbar-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n // Category label below\n barNodes.push(text(cx, area.y + area.height - 4, String(data.labels[i] ?? `Cat ${i + 1}`), {\n class: 'chartts-pictorialbar-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Cat ${i + 1}`),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const pOpts = ctx.options as unknown as PictorialBarOptions\n const symbolSize = pOpts.symbolSize ?? 14\n\n const barCount = series.values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n for (let i = 0; i < barCount; i++) {\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n if (Math.abs(mx - cx) < barWidth / 2 + 5) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/sankey/sankey-type.ts"],"names":[],"mappings":"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","file":"chunk-EYN74SQ5.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, rect, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Sankey / flow diagram.\n *\n * Data convention:\n * - labels: node names (unique). First N are source layer, rest are target layer.\n * - series[i]: a flow. series[i].name = \"Source → Target\", series[i].values = [flowValue]\n *\n * Alternative (simpler): encode flows as a flat list.\n * - labels: all unique node names\n * - series[0].values: flat list of flow values\n * - options.links: array of { source: number, target: number, value: number }\n *\n * This implementation auto-detects the format:\n * If series names contain \"→\" or \"->\", parse as source→target flows.\n * Otherwise treat as adjacency: series[i] = from node i, values[j] = flow to node j.\n */\n\ninterface SankeyNode {\n name: string\n index: number\n column: number\n y: number\n height: number\n totalIn: number\n totalOut: number\n}\n\ninterface SankeyLink {\n source: number\n target: number\n value: number\n sy: number // source y offset\n ty: number // target y offset\n width: number\n}\n\nexport const sankeyChartType: ChartTypePlugin = {\n type: 'sankey',\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0 || sankeyLinks.length === 0) return nodes\n\n // Layout\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Position nodes within columns\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Compute link positions\n computeLinkPositions(sankeyNodes, sankeyLinks)\n\n // Render links (curved bands)\n for (let li = 0; li < sankeyLinks.length; li++) {\n const link = sankeyLinks[li]!\n const src = sankeyNodes[link.source]!\n const tgt = sankeyNodes[link.target]!\n const x0 = src.y !== undefined ? getNodeX(src, columns, area, nodeWidth) + nodeWidth : 0\n const x1 = tgt.y !== undefined ? getNodeX(tgt, columns, area, nodeWidth) : 0\n const y0 = src.y + link.sy\n const y1 = tgt.y + link.ty\n const w = link.width\n\n const pb = new PathBuilder()\n const cx = (x0 + x1) / 2\n pb.moveTo(x0, y0)\n pb.curveTo(cx, y0, cx, y1, x1, y1)\n pb.vTo(y1 + w)\n pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w)\n pb.close()\n\n const color = options.colors[link.source % options.colors.length]!\n\n nodes.push(path(pb.build(), {\n class: 'chartts-sankey-link',\n fill: color,\n fillOpacity: 0.3,\n 'data-series': link.source,\n 'data-index': li,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${src.name} → ${tgt.name}: ${link.value}`,\n }))\n }\n\n // Render nodes (rectangles + labels)\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n const color = options.colors[ni % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(rect(x, node.y, nodeWidth, Math.max(node.height, 2), {\n rx: 3, ry: 3,\n class: 'chartts-sankey-node',\n fill: color,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${Math.max(node.totalIn, node.totalOut)}`,\n }))\n\n // Label\n const isLeft = node.column < columns.length / 2\n const labelX = isLeft ? x + nodeWidth + 6 : x - 6\n const anchor = isLeft ? 'start' : 'end'\n\n nodeGroup.push(text(labelX, node.y + node.height / 2, node.name, {\n class: 'chartts-sankey-label',\n fill: theme.textColor,\n textAnchor: anchor as 'start' | 'end',\n dominantBaseline: 'central',\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': node.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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0) return null\n\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Re-layout (same as render)\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Check node hits\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n if (mx >= x && mx <= x + nodeWidth && my >= node.y && my <= node.y + node.height) {\n return { seriesIndex: ni, pointIndex: 0, distance: 0 }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\nfunction parseSankeyData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { sankeyNodes: SankeyNode[]; sankeyLinks: SankeyLink[] } {\n const sankeyNodes: SankeyNode[] = []\n const sankeyLinks: SankeyLink[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = sankeyNodes.length\n nodeMap.set(name, idx)\n sankeyNodes.push({\n name,\n index: idx,\n column: -1,\n y: 0,\n height: 0,\n totalIn: 0,\n totalOut: 0,\n })\n return idx\n }\n\n // Check if series names contain arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Format: each series is a flow \"Source → Target\"\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 value = series.values[0] ?? 0\n if (value <= 0) continue\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n sankeyLinks.push({ source: src, target: tgt, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[src]!.totalOut += value\n sankeyNodes[tgt]!.totalIn += value\n }\n } else {\n // Format: adjacency matrix. labels = node names, series[i].values[j] = flow i→j\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]))\n }\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const value = data.series[si]!.values[j]!\n if (value <= 0 || si === j) continue\n if (si >= sankeyNodes.length || j >= sankeyNodes.length) continue\n sankeyLinks.push({ source: si, target: j, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[si]!.totalOut += value\n sankeyNodes[j]!.totalIn += value\n }\n }\n }\n\n return { sankeyNodes, sankeyLinks }\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutColumns(\n nodes: SankeyNode[],\n links: SankeyLink[],\n _area: { width: number; height: number },\n): number[] {\n // Assign columns via topological ordering (longest path from source)\n const adj = new Map<number, number[]>()\n const inDegree = new Map<number, number>()\n\n for (const n of nodes) {\n adj.set(n.index, [])\n inDegree.set(n.index, 0)\n }\n for (const l of links) {\n adj.get(l.source)!.push(l.target)\n inDegree.set(l.target, (inDegree.get(l.target) ?? 0) + 1)\n }\n\n // BFS for column assignment\n const queue: number[] = []\n for (const n of nodes) {\n if ((inDegree.get(n.index) ?? 0) === 0) {\n n.column = 0\n queue.push(n.index)\n }\n }\n\n while (queue.length > 0) {\n const idx = queue.shift()!\n const node = nodes[idx]!\n for (const tgt of adj.get(idx)!) {\n const tgtNode = nodes[tgt]!\n tgtNode.column = Math.max(tgtNode.column, node.column + 1)\n // Only add to queue once all predecessors processed\n const allPredsDone = links\n .filter(l => l.target === tgt)\n .every(l => nodes[l.source]!.column >= 0)\n if (allPredsDone && !queue.includes(tgt)) {\n queue.push(tgt)\n }\n }\n }\n\n // Handle any unassigned nodes (cycles or disconnected)\n for (const n of nodes) {\n if (n.column < 0) n.column = 0\n }\n\n // Set initial heights proportional to flow\n for (const n of nodes) {\n n.height = Math.max(n.totalIn, n.totalOut, 1)\n }\n\n // Get unique columns sorted\n const cols = [...new Set(nodes.map(n => n.column))].sort((a, b) => a - b)\n return cols\n}\n\nfunction getNodeX(\n node: SankeyNode,\n columns: number[],\n area: { x: number; width: number },\n nodeWidth: number,\n): number {\n const maxCol = Math.max(...columns, 1)\n if (maxCol === 0) return area.x\n const usableWidth = area.width - nodeWidth\n return area.x + (node.column / maxCol) * usableWidth\n}\n\nfunction computeLinkPositions(nodes: SankeyNode[], links: SankeyLink[]): void {\n // Total flow for normalization\n const sourceOffsets = new Map<number, number>()\n const targetOffsets = new Map<number, number>()\n\n for (const n of nodes) {\n sourceOffsets.set(n.index, 0)\n targetOffsets.set(n.index, 0)\n }\n\n // Sort links by target position for visual clarity\n links.sort((a, b) => {\n const na = nodes[a.target]!\n const nb = nodes[b.target]!\n return na.y - nb.y || na.column - nb.column\n })\n\n for (const link of links) {\n const src = nodes[link.source]!\n const tgt = nodes[link.target]!\n\n const srcTotal = Math.max(src.totalOut, 1)\n const tgtTotal = Math.max(tgt.totalIn, 1)\n\n link.width = (link.value / srcTotal) * src.height\n const tgtWidth = (link.value / tgtTotal) * tgt.height\n\n link.sy = sourceOffsets.get(link.source)!\n link.ty = targetOffsets.get(link.target)!\n\n sourceOffsets.set(link.source, link.sy + link.width)\n targetOffsets.set(link.target, link.ty + tgtWidth)\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/range/range-type.ts"],"names":["prepareData","PathBuilder","path","circle","CSS_PREFIX","group"],"mappings":"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","file":"chunk-FEQKBVCZ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface RangeOptions {\n /** Upper and lower bound arrays. */\n range?: {\n upper: number[]\n lower: number[]\n }\n /** Band fill color. Default uses series color with opacity. */\n bandColor?: string\n /** Band fill opacity. Default 0.2. */\n bandOpacity?: number\n /** Show center line (series[0].values). Default true. */\n showCenter?: boolean\n /** Show data points on center line. Default false. */\n showPoints?: boolean\n}\n\n/**\n * Range / Band chart — shaded area between upper and lower bounds.\n *\n * Used for: Bollinger bands, confidence intervals, forecast ranges,\n * bid-ask spread visualization.\n */\nexport const rangeChartType: ChartTypePlugin = {\n type: 'range',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as RangeOptions\n const range = opts.range\n const prepared = prepareData(data, options)\n\n if (range) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < range.upper.length; i++) {\n const u = range.upper[i]!\n const l = range.lower[i]!\n if (!isNaN(u) && u > yMax) yMax = u\n if (!isNaN(l) && l < yMin) yMin = l\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, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as RangeOptions\n const range = opts.range\n if (!range) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const showCenter = opts.showCenter ?? true\n const showPoints = opts.showPoints ?? false\n const bandOpacity = opts.bandOpacity ?? 0.2\n\n const seriesNodes: RenderNode[] = []\n\n // Build band polygon: upper path forward, lower path backward\n const pb = new PathBuilder()\n const n = range.upper.length\n\n // Upper path (left to right) — skip NaN\n let bandStarted = false\n for (let i = 0; i < n; i++) {\n if (isNaN(range.upper[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.upper[i]!)\n if (!bandStarted) { pb.moveTo(x, y); bandStarted = true }\n else pb.lineTo(x, y)\n }\n\n // Lower path (right to left) — skip NaN\n for (let i = n - 1; i >= 0; i--) {\n if (isNaN(range.lower[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.lower[i]!)\n pb.lineTo(x, y)\n }\n if (bandStarted) pb.close()\n\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-range-band',\n fill: opts.bandColor ?? series.color,\n fillOpacity: bandOpacity,\n 'data-series': 0,\n }))\n\n // Upper bound line\n const upperPath = buildLinePath(range.upper, xScale, yScale)\n seriesNodes.push(path(upperPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Lower bound line\n const lowerPath = buildLinePath(range.lower, xScale, yScale)\n seriesNodes.push(path(lowerPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Center line\n if (showCenter && series.values.length > 0) {\n const centerPath = buildLinePath(series.values, xScale, yScale)\n seriesNodes.push(path(centerPath, {\n class: 'chartts-range-center',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': 0,\n }))\n\n if (showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n seriesNodes.push(circle(x, y, theme.pointRadius, {\n class: 'chartts-point',\n fill: series.color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${series.values[i]} [${range.lower[i]}–${range.upper[i]}]`,\n }))\n }\n }\n }\n\n nodes.push(group(seriesNodes, {\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) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: i, distance: dist }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n): string {\n if (values.length === 0) return ''\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) { started = false; continue }\n const x = xScale.map(i)\n const y = yScale.map(values[i]!)\n if (!started) { pb.moveTo(x, y); started = true }\n else pb.lineTo(x, y)\n }\n return pb.build()\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-FIAKZSRR.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(6, stemGap * 0.35)\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\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2,\n }))\n\n // Dot\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\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(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 }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["prepareNoAxes","rect","text","group","rowThickness"],"mappings":"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","file":"chunk-FKAA5FNG.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, 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 }\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 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":[],"mappings":"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","file":"chunk-FKVYS4RB.js","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(6, stemGap * 0.35)\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\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2,\n }))\n\n // Dot\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\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(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 }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/pie/pie-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-FQG4DRJS.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 PieOptions {\n /** Inner radius ratio (0 = pie, 0.5+ = donut). Default 0. */\n innerRadius?: number\n /** Padding angle in degrees between slices. Default 1. */\n padAngle?: number\n /** Show value labels on slices. Default true. */\n showLabels?: boolean\n}\n\nexport const pieChartType: ChartTypePlugin = {\n type: 'pie',\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 } = ctx\n const nodes: RenderNode[] = []\n\n // Pie uses the first series' values as slice sizes\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const values = series.values\n const total = values.reduce((sum, v) => sum + Math.abs(v), 0)\n if (total === 0) return nodes\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 - 2\n const innerRatio = (ctx.options as unknown as PieOptions).innerRadius ?? 0\n const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio))\n const padAngleDeg = (ctx.options as unknown as PieOptions).padAngle ?? 2\n const padAngle = (padAngleDeg * Math.PI) / 180\n const showLabels = (ctx.options as unknown as PieOptions).showLabels ?? true\n\n let startAngle = -Math.PI / 2\n\n for (let i = 0; i < values.length; i++) {\n const value = Math.abs(values[i]!)\n const sliceAngle = (value / total) * Math.PI * 2\n const endAngle = startAngle + sliceAngle\n\n // Apply pad angle\n const actualStart = startAngle + padAngle / 2\n const actualEnd = endAngle - padAngle / 2\n\n if (actualEnd <= actualStart) {\n startAngle = endAngle\n continue\n }\n\n // Build slice path\n const pb = new PathBuilder()\n const x1o = cx + outerR * Math.cos(actualStart)\n const y1o = cy + outerR * Math.sin(actualStart)\n const x2o = cx + outerR * Math.cos(actualEnd)\n const y2o = cy + outerR * Math.sin(actualEnd)\n const largeArc = sliceAngle > Math.PI\n\n if (innerR > 0) {\n // Donut\n const x1i = cx + innerR * Math.cos(actualEnd)\n const y1i = cy + innerR * Math.sin(actualEnd)\n const x2i = cx + innerR * Math.cos(actualStart)\n const y2i = cy + innerR * Math.sin(actualStart)\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n } else {\n // Pie\n pb.moveTo(cx, cy)\n pb.lineTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.close()\n }\n\n const colorIndex = i % ctx.options.colors.length\n const sliceNodes: RenderNode[] = [\n path(pb.build(), {\n class: 'chartts-slice',\n fill: `url(#chartts-pie-${colorIndex})`,\n stroke: theme.background,\n strokeWidth: 3,\n style: 'stroke-linejoin:round;stroke-linecap:round;',\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? `Slice ${i + 1}`}: ${values[i]}`,\n }),\n ]\n\n // Label\n if (showLabels && sliceAngle > 0.3) {\n const midAngle = (actualStart + actualEnd) / 2\n const labelR = innerR > 0 ? (outerR + innerR) / 2 : outerR * 0.65\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const pct = Math.round((value / total) * 100)\n\n sliceNodes.push(text(lx, ly, `${pct}%`, {\n class: 'chartts-slice-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n nodes.push(group(sliceNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Slice ${i + 1}`),\n }))\n\n startAngle = endAngle\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 cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 2\n const innerRatio = (ctx.options as unknown as PieOptions).innerRadius ?? 0\n const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio))\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist > outerR || dist < innerR) 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 values = series.values\n const total = values.reduce((sum, v) => sum + Math.abs(v), 0)\n if (total === 0) return null\n\n let startAngle = -Math.PI / 2\n for (let i = 0; i < values.length; i++) {\n const sliceAngle = (Math.abs(values[i]!) / total) * Math.PI * 2\n const endAngle = startAngle + sliceAngle\n\n if (angle >= startAngle && angle < endAngle) {\n return { seriesIndex: 0, pointIndex: i, distance: 0 }\n }\n\n startAngle = endAngle\n }\n\n return null\n },\n}\n\n/** Donut chart = pie with innerRadius */\nexport const donutChartType: ChartTypePlugin = {\n ...pieChartType,\n type: 'donut',\n render(ctx: RenderContext): RenderNode[] {\n // Force innerRadius if not set\n const opts = ctx.options as unknown as PieOptions\n if (!opts.innerRadius) {\n (opts as PieOptions).innerRadius = 0.55\n }\n return pieChartType.render(ctx)\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/scatter/scatter-type.ts"],"names":[],"mappings":";;;AAOO,IAAM,gBAAA,GAAoC;AAAA,EAC/C,IAAA,EAAM,SAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,WAAA,CAAY,MAAM,OAAO,CAAA;AAAA,EAClC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,OAAM,GAAI,GAAA;AACxC,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,MAAM,OAAqB,EAAC;AAE5B,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,QAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,QAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AAGtC,QAAA,IAAA,CAAK,KAAK,MAAA,CAAO,CAAA,EAAG,IAAI,KAAA,CAAM,WAAA,GAAc,OAAO,GAAA,EAAK;AAAA,UACtD,KAAA,EAAO,kBAAA;AAAA,UACP,IAAA,EAAM,CAAA,mBAAA,EAAsB,MAAA,CAAO,KAAK,CAAA,CAAA;AAAA,SACzC,CAAC,CAAA;AAEF,QAAA,IAAA,CAAK,KAAK,MAAA,CAAO,CAAA,EAAG,CAAA,EAAG,KAAA,CAAM,cAAc,GAAA,EAAK;AAAA,UAC9C,KAAA,EAAO,aAAA;AAAA,UACP,MAAM,MAAA,CAAO,KAAA;AAAA,UACb,WAAA,EAAa,GAAA;AAAA,UACb,QAAQ,MAAA,CAAO,KAAA;AAAA,UACf,WAAA,EAAa,GAAA;AAAA,UACb,eAAe,MAAA,CAAO,KAAA;AAAA,UACtB,YAAA,EAAc,CAAA;AAAA,UACd,QAAA,EAAU,CAAA;AAAA,UACV,IAAA,EAAM,KAAA;AAAA,UACN,SAAA,EAAW,GAAG,MAAA,CAAO,IAAI,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,SAC/C,CAAC,CAAA;AAAA,MACJ;AAEA,MAAA,KAAA,CAAM,IAAA,CAAK,MAAM,IAAA,EAAM;AAAA,QACrB,KAAA,EAAO,CAAA,8BAAA,EAAiC,MAAA,CAAO,KAAK,CAAA,CAAA;AAAA,QACpD,oBAAoB,MAAA,CAAO;AAAA,OAC5B,CAAC,CAAA;AAAA,IACJ;AAEA,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,EAAQ,OAAM,GAAI,GAAA;AACxC,IAAA,IAAI,IAAA,GAAyB,IAAA;AAC7B,IAAA,IAAI,QAAA,GAAW,QAAA;AACf,IAAA,MAAM,SAAA,GAAY,MAAM,WAAA,GAAc,CAAA;AAEtC,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,QAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,QAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,QAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAA,CAAM,EAAA,GAAK,MAAM,CAAA,GAAA,CAAK,EAAA,GAAK,MAAM,CAAC,CAAA;AACpD,QAAA,IAAI,IAAA,GAAO,QAAA,IAAY,IAAA,GAAO,SAAA,EAAW;AACvC,UAAA,QAAA,GAAW,IAAA;AACX,UAAA,IAAA,GAAO,EAAE,WAAA,EAAa,MAAA,CAAO,OAAO,UAAA,EAAY,CAAA,EAAG,UAAU,IAAA,EAAK;AAAA,QACpE;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-GI7PBJSK.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, circle } from '../../render/tree'\n\nexport const scatterChartType: ChartTypePlugin = {\n type: 'scatter',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n for (const series of data.series) {\n const dots: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n\n // Ambient glow\n dots.push(circle(x, y, (theme.pointRadius + 1.5) * 2.5, {\n class: 'chartts-dot-glow',\n fill: `url(#chartts-pglow-${series.index})`,\n }))\n\n dots.push(circle(x, y, theme.pointRadius + 1.5, {\n class: 'chartts-dot',\n fill: series.color,\n fillOpacity: 0.7,\n stroke: series.color,\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(dots, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, theme } = ctx\n let best: HitResult | null = null\n let bestDist = Infinity\n const hitRadius = theme.pointRadius + 8\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/range/range-type.ts"],"names":[],"mappings":";;;AA+BO,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,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,QAAQ,IAAA,CAAK,KAAA;AACnB,IAAA,MAAM,QAAA,GAAW,WAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAE1C,IAAA,IAAI,KAAA,EAAO;AACT,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,QAAQ,CAAA,EAAA,EAAK;AAC3C,QAAA,MAAM,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAA;AACvB,QAAA,MAAM,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAA;AACvB,QAAA,IAAI,CAAC,KAAA,CAAM,CAAC,CAAA,IAAK,CAAA,GAAI,MAAM,IAAA,GAAO,CAAA;AAClC,QAAA,IAAI,CAAC,KAAA,CAAM,CAAC,CAAA,IAAK,CAAA,GAAI,MAAM,IAAA,GAAO,CAAA;AAAA,MACpC;AACA,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AACvB,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AAAA,IACzB;AAEA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,OAAA,EAAS,OAAM,GAAI,GAAA;AACjD,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,QAAQ,IAAA,CAAK,KAAA;AACnB,IAAA,IAAI,CAAC,OAAO,OAAO,KAAA;AAEnB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,KAAA;AAEpB,IAAA,MAAM,UAAA,GAAa,KAAK,UAAA,IAAc,IAAA;AACtC,IAAA,MAAM,UAAA,GAAa,KAAK,UAAA,IAAc,KAAA;AACtC,IAAA,MAAM,WAAA,GAAc,KAAK,WAAA,IAAe,GAAA;AAExC,IAAA,MAAM,cAA4B,EAAC;AAGnC,IAAA,MAAM,EAAA,GAAK,IAAI,WAAA,EAAY;AAC3B,IAAA,MAAM,CAAA,GAAI,MAAM,KAAA,CAAM,MAAA;AAGtB,IAAA,IAAI,WAAA,GAAc,KAAA;AAClB,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,CAAA,EAAG,CAAA,EAAA,EAAK;AAC1B,MAAA,IAAI,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA,EAAG;AAC5B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA;AACpC,MAAA,IAAI,CAAC,WAAA,EAAa;AAAE,QAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAG,QAAA,WAAA,GAAc,IAAA;AAAA,MAAK,CAAA,MACnD,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,IACrB;AAGA,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,GAAI,CAAA,EAAG,CAAA,IAAK,GAAG,CAAA,EAAA,EAAK;AAC/B,MAAA,IAAI,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA,EAAG;AAC5B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA;AACpC,MAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAA,IAChB;AACA,IAAA,IAAI,WAAA,KAAgB,KAAA,EAAM;AAE1B,IAAA,WAAA,CAAY,IAAA,CAAK,IAAA,CAAK,EAAA,CAAG,KAAA,EAAM,EAAG;AAAA,MAChC,KAAA,EAAO,oBAAA;AAAA,MACP,IAAA,EAAM,IAAA,CAAK,SAAA,IAAa,MAAA,CAAO,KAAA;AAAA,MAC/B,WAAA,EAAa,WAAA;AAAA,MACb,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,MAAM,SAAA,GAAY,aAAA,CAAc,KAAA,CAAM,KAAA,EAAO,QAAQ,MAAM,CAAA;AAC3D,IAAA,WAAA,CAAY,IAAA,CAAK,KAAK,SAAA,EAAW;AAAA,MAC/B,KAAA,EAAO,qBAAA;AAAA,MACP,QAAQ,MAAA,CAAO,KAAA;AAAA,MACf,WAAA,EAAa,CAAA;AAAA,MACb,eAAA,EAAiB,KAAA;AAAA,MACjB,OAAA,EAAS,GAAA;AAAA,MACT,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,MAAM,SAAA,GAAY,aAAA,CAAc,KAAA,CAAM,KAAA,EAAO,QAAQ,MAAM,CAAA;AAC3D,IAAA,WAAA,CAAY,IAAA,CAAK,KAAK,SAAA,EAAW;AAAA,MAC/B,KAAA,EAAO,qBAAA;AAAA,MACP,QAAQ,MAAA,CAAO,KAAA;AAAA,MACf,WAAA,EAAa,CAAA;AAAA,MACb,eAAA,EAAiB,KAAA;AAAA,MACjB,OAAA,EAAS,GAAA;AAAA,MACT,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,IAAI,UAAA,IAAc,MAAA,CAAO,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG;AAC1C,MAAA,MAAM,UAAA,GAAa,aAAA,CAAc,MAAA,CAAO,MAAA,EAAQ,QAAQ,MAAM,CAAA;AAC9D,MAAA,WAAA,CAAY,IAAA,CAAK,KAAK,UAAA,EAAY;AAAA,QAChC,KAAA,EAAO,sBAAA;AAAA,QACP,QAAQ,MAAA,CAAO,KAAA;AAAA,QACf,aAAa,KAAA,CAAM,SAAA;AAAA,QACnB,aAAA,EAAe;AAAA,OAChB,CAAC,CAAA;AAEF,MAAA,IAAI,UAAA,EAAY;AACd,QAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,UAAA,IAAI,KAAA,CAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAC9B,UAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,UAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,UAAA,WAAA,CAAY,IAAA,CAAK,MAAA,CAAO,CAAA,EAAG,CAAA,EAAG,MAAM,WAAA,EAAa;AAAA,YAC/C,KAAA,EAAO,eAAA;AAAA,YACP,MAAM,MAAA,CAAO,KAAA;AAAA,YACb,MAAA,EAAQ,OAAO,UAAU,CAAA,UAAA,CAAA;AAAA,YACzB,WAAA,EAAa,CAAA;AAAA,YACb,aAAA,EAAe,CAAA;AAAA,YACf,YAAA,EAAc,CAAA;AAAA,YACd,QAAA,EAAU,CAAA;AAAA,YACV,IAAA,EAAM,KAAA;AAAA,YACN,SAAA,EAAW,GAAG,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAC,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA,EAAA,EAAK,MAAM,KAAA,CAAM,CAAC,CAAC,CAAA,MAAA,EAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA;AAAA,WAC5F,CAAC,CAAA;AAAA,QACJ;AAAA,MACF;AAAA,IACF;AAEA,IAAA,KAAA,CAAM,IAAA,CAAK,MAAM,WAAA,EAAa;AAAA,MAC5B,KAAA,EAAO,iCAAA;AAAA,MACP,oBAAoB,MAAA,CAAO;AAAA,KAC5B,CAAC,CAAA;AAEF,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,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,QAAQ,OAAO,IAAA;AAEpB,IAAA,IAAI,IAAA,GAAyB,IAAA;AAC7B,IAAA,IAAI,QAAA,GAAW,QAAA;AAEf,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,MAAA,IAAI,KAAA,CAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAC9B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,MAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAA,CAAM,EAAA,GAAK,MAAM,CAAA,GAAA,CAAK,EAAA,GAAK,MAAM,CAAC,CAAA;AACpD,MAAA,IAAI,OAAO,QAAA,EAAU;AACnB,QAAA,QAAA,GAAW,IAAA;AACX,QAAA,IAAA,GAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,CAAA,EAAG,UAAU,IAAA,EAAK;AAAA,MACzD;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,IAAQ,IAAA,CAAK,QAAA,GAAW,EAAA,GAAK,IAAA,GAAO,IAAA;AAAA,EAC7C;AACF;AAEA,SAAS,aAAA,CACP,MAAA,EACA,MAAA,EACA,MAAA,EACQ;AACR,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAA;AAChC,EAAA,MAAM,EAAA,GAAK,IAAI,WAAA,EAAY;AAC3B,EAAA,IAAI,OAAA,GAAU,KAAA;AACd,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,IAAI,KAAA,CAAM,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAAE,MAAA,OAAA,GAAU,KAAA;AAAO,MAAA;AAAA,IAAS;AACnD,IAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,IAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,CAAC,CAAE,CAAA;AAC/B,IAAA,IAAI,CAAC,OAAA,EAAS;AAAE,MAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAG,MAAA,OAAA,GAAU,IAAA;AAAA,IAAK,CAAA,MAC3C,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,EACrB;AACA,EAAA,OAAO,GAAG,KAAA,EAAM;AAClB","file":"chunk-GL3M7MAM.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface RangeOptions {\n /** Upper and lower bound arrays. */\n range?: {\n upper: number[]\n lower: number[]\n }\n /** Band fill color. Default uses series color with opacity. */\n bandColor?: string\n /** Band fill opacity. Default 0.2. */\n bandOpacity?: number\n /** Show center line (series[0].values). Default true. */\n showCenter?: boolean\n /** Show data points on center line. Default false. */\n showPoints?: boolean\n}\n\n/**\n * Range / Band chart — shaded area between upper and lower bounds.\n *\n * Used for: Bollinger bands, confidence intervals, forecast ranges,\n * bid-ask spread visualization.\n */\nexport const rangeChartType: ChartTypePlugin = {\n type: 'range',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as RangeOptions\n const range = opts.range\n const prepared = prepareData(data, options)\n\n if (range) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < range.upper.length; i++) {\n const u = range.upper[i]!\n const l = range.lower[i]!\n if (!isNaN(u) && u > yMax) yMax = u\n if (!isNaN(l) && l < yMin) yMin = l\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, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as RangeOptions\n const range = opts.range\n if (!range) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const showCenter = opts.showCenter ?? true\n const showPoints = opts.showPoints ?? false\n const bandOpacity = opts.bandOpacity ?? 0.2\n\n const seriesNodes: RenderNode[] = []\n\n // Build band polygon: upper path forward, lower path backward\n const pb = new PathBuilder()\n const n = range.upper.length\n\n // Upper path (left to right) — skip NaN\n let bandStarted = false\n for (let i = 0; i < n; i++) {\n if (isNaN(range.upper[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.upper[i]!)\n if (!bandStarted) { pb.moveTo(x, y); bandStarted = true }\n else pb.lineTo(x, y)\n }\n\n // Lower path (right to left) — skip NaN\n for (let i = n - 1; i >= 0; i--) {\n if (isNaN(range.lower[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.lower[i]!)\n pb.lineTo(x, y)\n }\n if (bandStarted) pb.close()\n\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-range-band',\n fill: opts.bandColor ?? series.color,\n fillOpacity: bandOpacity,\n 'data-series': 0,\n }))\n\n // Upper bound line\n const upperPath = buildLinePath(range.upper, xScale, yScale)\n seriesNodes.push(path(upperPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Lower bound line\n const lowerPath = buildLinePath(range.lower, xScale, yScale)\n seriesNodes.push(path(lowerPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Center line\n if (showCenter && series.values.length > 0) {\n const centerPath = buildLinePath(series.values, xScale, yScale)\n seriesNodes.push(path(centerPath, {\n class: 'chartts-range-center',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': 0,\n }))\n\n if (showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n seriesNodes.push(circle(x, y, theme.pointRadius, {\n class: 'chartts-point',\n fill: series.color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${series.values[i]} [${range.lower[i]}–${range.upper[i]}]`,\n }))\n }\n }\n }\n\n nodes.push(group(seriesNodes, {\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) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: i, distance: dist }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n): string {\n if (values.length === 0) return ''\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) { started = false; continue }\n const x = xScale.map(i)\n const y = yScale.map(values[i]!)\n if (!started) { pb.moveTo(x, y); started = true }\n else pb.lineTo(x, y)\n }\n return pb.build()\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/renko/renko-type.ts"],"names":[],"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,OAAO,aAAA,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,CAAK,IAAA,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,CAAK,MAAM,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-GQR7IHER.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 } 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/dumbbell/dumbbell-type.ts"],"names":["prepareNoAxes","createHorizontalMapper","text","line","circle","group"],"mappings":"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","file":"chunk-GUVPVNPD.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, line, circle, text } from '../../render/tree'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Dumbbell / connected dot chart.\n *\n * Two dots per category connected by a line.\n * Horizontal layout — categories on y-axis, values on x-axis.\n * Requires exactly 2 series. Shows before/after or comparison.\n */\nexport const dumbbellChartType: ChartTypePlugin = {\n type: 'dumbbell',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length < 2) return nodes\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return nodes\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n const dotR = Math.min(6, rowHeight * 0.2)\n\n const color1 = options.colors[0]!\n const color2 = options.colors[1 % options.colors.length]!\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const v1 = s1.values[i]!\n const v2 = s2.values[i]!\n const x1 = valueToX(v1)\n const x2 = valueToX(v2)\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n const rowNodes: RenderNode[] = []\n\n // Label\n rowNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-dumbbell-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Connecting line\n rowNodes.push(line(x1, cy, x2, cy, {\n class: 'chartts-dumbbell-connector',\n stroke: theme.gridColor,\n strokeWidth: 2,\n }))\n\n // Dot 1 (series 0)\n rowNodes.push(circle(x1, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color1,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s1.name}: ${v1}`,\n }))\n\n // Dot 2 (series 1)\n rowNodes.push(circle(x2, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color2,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 1,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s2.name}: ${v2}`,\n }))\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, yScale } = ctx\n if (data.series.length < 2) return null\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return null\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n let best: HitResult | null = null\n let bestDist = 15\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n\n for (const [si, series] of [s1, s2].entries()) {\n const vx = valueToX(series.values[i]!)\n const dx = mx - vx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/heatmap/heatmap-type.ts"],"names":["prepareNoAxes","text","rect","group"],"mappings":"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","file":"chunk-IAE4VRB7.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, text } from '../../render/tree'\n\n/**\n * Heatmap chart — displays a matrix of colored cells.\n *\n * Data format: each series is a row, each value is a cell.\n * Labels are column headers, series names are row headers.\n * Cell color intensity is proportional to value.\n */\nexport const heatmapChartType: ChartTypePlugin = {\n type: 'heatmap',\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 rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return nodes\n\n // Find min/max values for color interpolation\n let vMin = Infinity\n let vMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < vMin) vMin = v\n if (v > vMax) vMax = v\n }\n }\n if (vMin === vMax) vMax = vMin + 1\n\n // Layout: leave space for labels\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n const gap = 1.5\n\n // Column labels (top)\n for (let c = 0; c < colCount; c++) {\n const x = gridX + cellW * (c + 0.5)\n nodes.push(text(x, area.y + labelH * 0.5, String(data.labels[c]!), {\n class: 'chartts-heatmap-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels (left) + cells\n for (let r = 0; r < rowCount; r++) {\n const series = data.series[r]!\n const ry = gridY + cellH * r\n\n // Row label\n nodes.push(text(area.x + labelW - 4, ry + cellH / 2, series.name, {\n class: 'chartts-heatmap-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.45),\n fontFamily: theme.fontFamily,\n }))\n\n const cellNodes: RenderNode[] = []\n\n for (let c = 0; c < colCount; c++) {\n const value = series.values[c] ?? 0\n const t = (value - vMin) / (vMax - vMin)\n const color = interpolateColor(options.colors[0]!, t)\n\n cellNodes.push(rect(\n gridX + cellW * c + gap / 2,\n ry + gap / 2,\n cellW - gap,\n cellH - gap,\n {\n class: 'chartts-heatmap-cell',\n fill: color,\n rx: 4,\n ry: 2,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}, ${data.labels[c]}: ${value}`,\n },\n ))\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${r}`,\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 } = ctx\n const rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return null\n\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n\n if (mx < gridX || mx > gridX + gridW || my < gridY || my > gridY + gridH) return null\n\n const col = Math.floor((mx - gridX) / cellW)\n const row = Math.floor((my - gridY) / cellH)\n\n if (row >= 0 && row < rowCount && col >= 0 && col < colCount) {\n return { seriesIndex: row, pointIndex: col, distance: 0 }\n }\n\n return null\n },\n}\n\n/** Interpolate from transparent to the given color based on t (0..1) */\nfunction interpolateColor(baseColor: string, t: number): string {\n // Extract hex fallback from var(--color-xxx, #hex) format\n const hexMatch = baseColor.match(/#([0-9a-fA-F]{6})/)\n if (!hexMatch) return `rgba(59, 130, 246, ${(0.1 + t * 0.9).toFixed(2)})`\n\n const hex = hexMatch[1]!\n const r = parseInt(hex.slice(0, 2), 16)\n const g = parseInt(hex.slice(2, 4), 16)\n const b = parseInt(hex.slice(4, 6), 16)\n\n const opacity = 0.1 + t * 0.9\n return `rgba(${r}, ${g}, ${b}, ${opacity.toFixed(2)})`\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/bullet/bullet-type.ts"],"names":["prepareNoAxes","text","rect","line","group"],"mappings":"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","file":"chunk-ID7GYRYL.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, line, text } from '../../render/tree'\n\n/**\n * Bullet chart — compact horizontal gauge.\n *\n * Data format: each label is a metric.\n * - series[0]: actual values\n * - series[1] (optional): target values (shown as a marker line)\n *\n * Qualitative ranges (poor/satisfactory/good) are auto-generated\n * from the max value.\n */\nexport const bulletChartType: ChartTypePlugin = {\n type: 'bullet',\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 actual = data.series[0]\n if (!actual || actual.values.length === 0) return nodes\n\n const target = data.series[1]\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n const rowHeight = area.height / count\n const barHeight = Math.min(rowHeight * 0.4, 20)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n // Find global max for scaling\n let maxVal = 0\n for (const v of actual.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (target) {\n for (const v of target.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n // Extend max to give headroom for ranges\n maxVal = maxVal * 1.2\n if (maxVal === 0) maxVal = 1\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const val = actual.values[i]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n const color = options.colors[i % options.colors.length]!\n const bulletNodes: RenderNode[] = []\n\n // Label\n bulletNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-bullet-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Qualitative ranges (3 bands: poor, satisfactory, good)\n const bands = [1.0, 0.75, 0.5]\n const opacities = [0.1, 0.18, 0.28]\n for (let b = 0; b < bands.length; b++) {\n const bw = chartW * bands[b]!\n bulletNodes.push(rect(chartX, cy - rangeHeight / 2, bw, rangeHeight, {\n rx: 4, ry: 4,\n class: 'chartts-bullet-range',\n fill: theme.textColor,\n opacity: opacities[b],\n }))\n }\n\n // Actual value bar\n const barW = (Math.abs(val) / maxVal) * chartW\n bulletNodes.push(rect(chartX, cy - barHeight / 2, barW, barHeight, {\n rx: 3, ry: 3,\n class: 'chartts-bullet-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${val}${target ? `, target: ${target.values[i]}` : ''}`,\n }))\n\n // Target marker\n if (target && target.values[i] != null) {\n const tx = chartX + (Math.abs(target.values[i]!) / maxVal) * chartW\n const markerH = rangeHeight * 0.9\n bulletNodes.push(line(tx, cy - markerH / 2, tx, cy + markerH / 2, {\n class: 'chartts-bullet-target',\n stroke: theme.textColor,\n strokeWidth: 2.5,\n }))\n }\n\n nodes.push(group(bulletNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const actual = data.series[0]\n if (!actual || actual.values.length === 0) return null\n\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const rowHeight = area.height / count\n\n if (mx < area.x + labelWidth) return null\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n if (my >= cy - rangeHeight / 2 && my <= cy + rangeHeight / 2) {\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/radialbar/radialbar-type.ts"],"names":[],"mappings":"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","file":"chunk-IUYPKYOU.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radial bar chart — concentric arcs radiating from center.\n *\n * Each category gets its own ring. Arc length is proportional to value.\n * Uses the first series' values.\n */\nexport const radialBarChartType: ChartTypePlugin = {\n type: 'radial-bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const values = series.values\n const count = values.length\n let maxVal = 0\n for (const v of values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (maxVal === 0) maxVal = 1\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n const startAngle = -Math.PI / 2 // 12 o'clock\n\n for (let i = 0; i < count; i++) {\n const value = Math.abs(values[i]!)\n const fraction = value / maxVal\n const sweepAngle = fraction * Math.PI * 2 * 0.95 // max 95% of circle\n const endAngle = startAngle + sweepAngle\n\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n const colorIndex = i % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n // Track arc (full background ring)\n const trackPb = new PathBuilder()\n const trackEnd = startAngle + Math.PI * 2 * 0.95\n strokeArc(trackPb, cx, cy, (rOuter + rInner) / 2, startAngle, trackEnd)\n nodes.push(path(trackPb.build(), {\n class: 'chartts-radialbar-track',\n stroke: theme.gridColor,\n strokeWidth: ringWidth,\n fill: 'none',\n opacity: 0.15,\n }))\n\n // Value arc\n if (sweepAngle > 0.01) {\n const arcPb = new PathBuilder()\n strokeArc(arcPb, cx, cy, (rOuter + rInner) / 2, startAngle, endAngle)\n\n const arcNodes: RenderNode[] = [\n path(arcPb.build(), {\n class: 'chartts-radialbar-arc',\n stroke: color,\n strokeWidth: ringWidth,\n fill: 'none',\n opacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${values[i]}`,\n }),\n ]\n\n // Label on the left side of the ring\n const ringMidR = (rOuter + rInner) / 2\n arcNodes.push(text(cx - outerR - 6, cy - ringMidR + cy - cy, label, {\n class: 'chartts-radialbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, ringWidth * 0.9),\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(arcNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const count = series.values.length\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR * 0.2\n const ringGap = 3\n const ringWidth = (outerR - innerR - ringGap * (count - 1)) / count\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n for (let i = 0; i < count; i++) {\n const rOuter = innerR + (count - i) * (ringWidth + ringGap) - ringGap\n const rInner = rOuter - ringWidth\n\n if (dist >= rInner && dist <= rOuter) {\n return { seriesIndex: 0, pointIndex: i, distance: 0 }\n }\n }\n\n return null\n },\n}\n\nfunction strokeArc(pb: PathBuilder, cx: number, cy: number, r: number, startAngle: number, endAngle: number): void {\n const x1 = cx + r * Math.cos(startAngle)\n const y1 = cy + r * Math.sin(startAngle)\n const x2 = cx + r * Math.cos(endAngle)\n const y2 = cy + r * Math.sin(endAngle)\n const largeArc = (endAngle - startAngle) > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/line/line-type.ts"],"names":[],"mappings":"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","file":"chunk-IXFSJBJS.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\n\nexport const lineChartType: ChartTypePlugin = {\n type: 'line',\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, options, area, xScale, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n // Build line path\n const linePath = buildLinePath(series.values, xScale, yScale, options.curve)\n\n // Area fill (if enabled) — use gradient for premium look\n if (series.fill) {\n const areaPath = buildAreaPath(\n series.values, xScale, yScale, area, options.curve,\n )\n seriesNodes.push(path(areaPath, {\n class: 'chartts-area',\n fill: `url(#chartts-area-${series.index})`,\n 'data-series': series.index,\n }))\n }\n\n // Line glow (soft blur behind the main line)\n const dash = series.style === 'dashed' ? '6,4'\n : series.style === 'dotted' ? '2,3' : undefined\n\n if (!dash) {\n seriesNodes.push(path(linePath, {\n class: 'chartts-line-glow',\n stroke: series.color,\n strokeWidth: theme.lineWidth + 4,\n opacity: 0.2,\n 'data-series': series.index,\n style: 'filter:blur(4px)',\n }))\n }\n\n // Main line\n seriesNodes.push(path(linePath, {\n class: 'chartts-line',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n strokeDasharray: dash,\n 'data-series': series.index,\n }))\n\n // Data points with ambient glow\n if (series.showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n\n // Ambient glow behind point\n seriesNodes.push(circle(x, y, theme.pointRadius * 3, {\n class: 'chartts-point-glow',\n fill: `url(#chartts-pglow-${series.index})`,\n }))\n\n seriesNodes.push(circle(x, y, theme.pointRadius, {\n class: 'chartts-point',\n fill: series.color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\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(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 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 if (isNaN(series.values[i]!)) continue // skip missing data\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\n/** Build a line path string using specified interpolation, skipping NaN gaps */\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build path for each segment\n const builder = curve === 'step' ? buildStepPath\n : curve === 'monotone' ? buildMonotonePath\n : buildLinearPath\n return segments.map(s => builder(s)).join('')\n}\n\n/** Build an area fill path (line path + close along x-axis), skipping NaN gaps */\nfunction buildAreaPath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n area: { y: number; height: number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n const baseline = area.y + area.height\n const builder = curve === 'monotone' ? buildMonotonePath\n : curve === 'step' ? buildStepPath\n : buildLinearPath\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build closed area for each segment\n return segments.map(pts => {\n const linePart = builder(pts)\n const first = pts[0]!\n const last = pts[pts.length - 1]!\n return `${linePart}L${formatNum(last.x)},${formatNum(baseline)}L${formatNum(first.x)},${formatNum(baseline)}Z`\n }).join('')\n}\n\nfunction buildLinearPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n pb.lineTo(points[i]!.x, points[i]!.y)\n }\n return pb.build()\n}\n\nfunction buildStepPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n const midX = (points[i - 1]!.x + points[i]!.x) / 2\n pb.hTo(midX).vTo(points[i]!.y).hTo(points[i]!.x)\n }\n return pb.build()\n}\n\n/**\n * Monotone cubic interpolation (Fritsch–Carlson).\n * Produces smooth curves that never overshoot the data.\n */\nfunction buildMonotonePath(points: { x: number; y: number }[]): string {\n if (points.length < 2) return buildLinearPath(points)\n if (points.length === 2) return buildLinearPath(points)\n\n const n = points.length\n const dx: number[] = []\n const dy: number[] = []\n const m: number[] = []\n\n // Compute slopes\n for (let i = 0; i < n - 1; i++) {\n dx.push(points[i + 1]!.x - points[i]!.x)\n dy.push(points[i + 1]!.y - points[i]!.y)\n m.push(dy[i]! / (dx[i]! || 1))\n }\n\n // Compute tangents (Fritsch–Carlson)\n const tangents: number[] = [m[0]!]\n for (let i = 1; i < n - 1; i++) {\n if (m[i - 1]! * m[i]! <= 0) {\n tangents.push(0)\n } else {\n tangents.push((m[i - 1]! + m[i]!) / 2)\n }\n }\n tangents.push(m[n - 2]!)\n\n // Build path\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n\n for (let i = 0; i < n - 1; i++) {\n const d = dx[i]! / 3\n pb.curveTo(\n points[i]!.x + d,\n points[i]!.y + tangents[i]! * d,\n points[i + 1]!.x - d,\n points[i + 1]!.y - tangents[i + 1]! * d,\n points[i + 1]!.x,\n points[i + 1]!.y,\n )\n }\n\n return pb.build()\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/tree/tree-type.ts"],"names":[],"mappings":"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","file":"chunk-JT6H7G52.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, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Tree chart — hierarchical node-link diagram.\n *\n * Data convention:\n * - labels: node names. Hierarchy encoded via \"Parent/Child/Grandchild\" separators.\n * - series[0].values: node values (sizes for circles, optional).\n *\n * Layout: top-to-bottom by default. Configurable via treeLayout option.\n */\n\ninterface TreeNode {\n name: string\n value: number\n children: TreeNode[]\n depth: number\n index: number\n // Computed during layout\n x: number\n y: number\n leafCount: number\n}\n\nexport interface TreeOptions {\n /** Layout direction. Default 'top-down'. */\n treeLayout?: 'top-down' | 'left-right' | 'radial'\n /** Node radius. Default 6. */\n nodeRadius?: number\n /** Show labels. Default true. */\n showLabels?: boolean\n}\n\nexport const treeChartType: ChartTypePlugin = {\n type: 'tree',\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 treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const showLabels = treeOpts.showLabels ?? true\n\n // Build tree\n const root = buildTree(data.labels, series.values)\n if (!root) return nodes\n\n // Compute leaf counts for spacing\n computeLeafCounts(root)\n\n // Layout nodes\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n // Render edges first (below nodes)\n const edgeNodes: RenderNode[] = []\n renderEdges(root, edgeNodes, theme, isHorizontal)\n nodes.push(...edgeNodes)\n\n // Render nodes\n let nodeIdx = 0\n const renderTreeNode = (node: TreeNode) => {\n const color = options.colors[node.depth % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(circle(node.x, node.y, nodeRadius, {\n class: 'chartts-tree-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': nodeIdx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${node.value}`,\n }))\n\n if (showLabels) {\n const fontSize = theme.fontSizeSmall\n let labelX: number, labelY: number\n let anchor: 'start' | 'middle' | 'end'\n\n if (isHorizontal) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n } else {\n labelX = node.x + nodeRadius + 4\n labelY = node.y\n anchor = 'start'\n // For root, put label above\n if (node.depth === 0) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n }\n }\n\n nodeGroup.push(text(labelX, labelY, node.name, {\n class: 'chartts-tree-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n }))\n }\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${nodeIdx}`,\n 'data-series-name': node.name,\n }))\n\n nodeIdx++\n for (const child of node.children) {\n renderTreeNode(child)\n }\n }\n\n renderTreeNode(root)\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 treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const hitRadius = nodeRadius + 5\n\n const root = buildTree(data.labels, series.values)\n if (!root) return null\n\n computeLeafCounts(root)\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n let best: HitResult | null = null\n let bestDist = Infinity\n let idx = 0\n\n const checkNode = (node: TreeNode) => {\n const dist = Math.sqrt((mx - node.x) ** 2 + (my - node.y) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: idx, distance: dist }\n }\n idx++\n for (const child of node.children) {\n checkNode(child)\n }\n }\n\n checkNode(root)\n return best\n },\n}\n\n// ---------------------------------------------------------------------------\n// Tree building\n// ---------------------------------------------------------------------------\n\nfunction buildTree(labels: (string | number | Date)[], values: number[]): TreeNode | null {\n const root: TreeNode = {\n name: 'Root', value: 0, children: [], depth: 0, index: 0,\n x: 0, y: 0, leafCount: 0,\n }\n\n // Check if labels use \"/\" separators for hierarchy\n const hasHierarchy = labels.some(l => String(l).includes('/'))\n\n if (hasHierarchy) {\n for (let i = 0; i < labels.length; i++) {\n const parts = String(labels[i] ?? '').split('/')\n const value = Math.abs(values[i] ?? 1)\n let current = root\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]!.trim()\n if (!part) continue\n\n let child = current.children.find(c => c.name === part)\n if (!child) {\n child = {\n name: part, value: 0, children: [], depth: current.depth + 1,\n index: i, x: 0, y: 0, leafCount: 0,\n }\n current.children.push(child)\n }\n if (p === parts.length - 1) {\n child.value = value\n }\n current = child\n }\n }\n } else {\n // Flat list — all labels are direct children of root\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n\n for (let i = 1; i < labels.length; i++) {\n root.children.push({\n name: String(labels[i] ?? `Node ${i}`),\n value: Math.abs(values[i] ?? 1),\n children: [],\n depth: 1,\n index: i,\n x: 0, y: 0, leafCount: 0,\n })\n }\n }\n\n if (root.children.length === 0 && labels.length > 0) {\n // Single node\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n }\n\n return root\n}\n\nfunction computeLeafCounts(node: TreeNode): number {\n if (node.children.length === 0) {\n node.leafCount = 1\n return 1\n }\n let count = 0\n for (const child of node.children) {\n count += computeLeafCounts(child)\n }\n node.leafCount = count\n return count\n}\n\nfunction getMaxDepth(node: TreeNode): 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\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutVertical(\n node: TreeNode, topY: number, leftX: number, rightX: number, levelHeight: number,\n): void {\n node.y = topY + node.depth * levelHeight + levelHeight / 2\n const totalLeaves = node.leafCount || 1\n const slotWidth = (rightX - leftX) / totalLeaves\n\n if (node.children.length === 0) {\n node.x = leftX + slotWidth / 2\n return\n }\n\n let currentX = leftX\n for (const child of node.children) {\n const childWidth = (child.leafCount / totalLeaves) * (rightX - leftX)\n layoutVertical(child, topY, currentX, currentX + childWidth, levelHeight)\n currentX += childWidth\n }\n\n // Center parent above children\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.x = (firstChild.x + lastChild.x) / 2\n}\n\nfunction layoutHorizontal(\n node: TreeNode, leftX: number, topY: number, bottomY: number, levelWidth: number,\n): void {\n node.x = leftX + node.depth * levelWidth + levelWidth / 2\n const totalLeaves = node.leafCount || 1\n const slotHeight = (bottomY - topY) / totalLeaves\n\n if (node.children.length === 0) {\n node.y = topY + slotHeight / 2\n return\n }\n\n let currentY = topY\n for (const child of node.children) {\n const childHeight = (child.leafCount / totalLeaves) * (bottomY - topY)\n layoutHorizontal(child, leftX, currentY, currentY + childHeight, levelWidth)\n currentY += childHeight\n }\n\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.y = (firstChild.y + lastChild.y) / 2\n}\n\n// ---------------------------------------------------------------------------\n// Rendering edges\n// ---------------------------------------------------------------------------\n\nfunction renderEdges(\n node: TreeNode,\n nodes: RenderNode[],\n theme: RenderContext['theme'],\n isHorizontal: boolean,\n): void {\n for (const child of node.children) {\n const pb = new PathBuilder()\n if (isHorizontal) {\n const midX = (node.x + child.x) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(midX, node.y, midX, child.y, child.x, child.y)\n } else {\n const midY = (node.y + child.y) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(node.x, midY, child.x, midY, child.x, child.y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-tree-edge',\n stroke: theme.gridColor,\n strokeWidth: 1.5,\n fill: 'none',\n }))\n\n renderEdges(child, nodes, theme, isHorizontal)\n }\n}\n"]}
|