@chartts/core 0.1.0
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/dist/area-type-B3CtuIIP.d.cts +9 -0
- package/dist/area-type-DmB6fTVf.d.ts +9 -0
- package/dist/area.cjs +34 -0
- package/dist/area.cjs.map +1 -0
- package/dist/area.d.cts +8 -0
- package/dist/area.d.ts +8 -0
- package/dist/area.js +13 -0
- package/dist/area.js.map +1 -0
- package/dist/bar-type-Bne_khsO.d.ts +5 -0
- package/dist/bar-type-CkI-kkrC.d.cts +5 -0
- package/dist/bar.cjs +34 -0
- package/dist/bar.cjs.map +1 -0
- package/dist/bar.d.cts +8 -0
- package/dist/bar.d.ts +8 -0
- package/dist/bar.js +13 -0
- package/dist/bar.js.map +1 -0
- package/dist/baseline-type-B1O4XHT3.d.ts +25 -0
- package/dist/baseline-type-BAPrZJ5W.d.cts +25 -0
- package/dist/baseline.cjs +32 -0
- package/dist/baseline.cjs.map +1 -0
- package/dist/baseline.d.cts +8 -0
- package/dist/baseline.d.ts +8 -0
- package/dist/baseline.js +11 -0
- package/dist/baseline.js.map +1 -0
- package/dist/boxplot-type-CEWf7p5X.d.ts +5 -0
- package/dist/boxplot-type-Da8_smoe.d.cts +5 -0
- package/dist/boxplot.cjs +33 -0
- package/dist/boxplot.cjs.map +1 -0
- package/dist/boxplot.d.cts +8 -0
- package/dist/boxplot.d.ts +8 -0
- package/dist/boxplot.js +12 -0
- package/dist/boxplot.js.map +1 -0
- package/dist/bubble-type-Dxb2JCKv.d.cts +9 -0
- package/dist/bubble-type-pru5MgB7.d.ts +9 -0
- package/dist/bubble.cjs +32 -0
- package/dist/bubble.cjs.map +1 -0
- package/dist/bubble.d.cts +8 -0
- package/dist/bubble.d.ts +8 -0
- package/dist/bubble.js +11 -0
- package/dist/bubble.js.map +1 -0
- package/dist/bullet-type-CPEYkEvt.d.ts +15 -0
- package/dist/bullet-type-khCmwFqH.d.cts +15 -0
- package/dist/bullet.cjs +33 -0
- package/dist/bullet.cjs.map +1 -0
- package/dist/bullet.d.cts +8 -0
- package/dist/bullet.d.ts +8 -0
- package/dist/bullet.js +12 -0
- package/dist/bullet.js.map +1 -0
- package/dist/calendar-type-Br5mpdea.d.cts +15 -0
- package/dist/calendar-type-yJWPY6qT.d.ts +15 -0
- package/dist/calendar.cjs +33 -0
- package/dist/calendar.cjs.map +1 -0
- package/dist/calendar.d.cts +8 -0
- package/dist/calendar.d.ts +8 -0
- package/dist/calendar.js +12 -0
- package/dist/calendar.js.map +1 -0
- package/dist/candlestick-type-CazXUb77.d.cts +22 -0
- package/dist/candlestick-type-CtLZy_uC.d.ts +22 -0
- package/dist/candlestick.cjs +33 -0
- package/dist/candlestick.cjs.map +1 -0
- package/dist/candlestick.d.cts +8 -0
- package/dist/candlestick.d.ts +8 -0
- package/dist/candlestick.js +12 -0
- package/dist/candlestick.js.map +1 -0
- package/dist/chord-type-ChIZaOZd.d.cts +5 -0
- package/dist/chord-type-ruvHboZl.d.ts +5 -0
- package/dist/chord.cjs +33 -0
- package/dist/chord.cjs.map +1 -0
- package/dist/chord.d.cts +8 -0
- package/dist/chord.d.ts +8 -0
- package/dist/chord.js +12 -0
- package/dist/chord.js.map +1 -0
- package/dist/chunk-22LR6CFM.js +176 -0
- package/dist/chunk-22LR6CFM.js.map +1 -0
- package/dist/chunk-2TWYS3BT.cjs +199 -0
- package/dist/chunk-2TWYS3BT.cjs.map +1 -0
- package/dist/chunk-3BRQGYDX.js +4859 -0
- package/dist/chunk-3BRQGYDX.js.map +1 -0
- package/dist/chunk-3TTTELGB.cjs +146 -0
- package/dist/chunk-3TTTELGB.cjs.map +1 -0
- package/dist/chunk-3XVGEBR4.js +17 -0
- package/dist/chunk-3XVGEBR4.js.map +1 -0
- package/dist/chunk-4HK4RM3X.cjs +128 -0
- package/dist/chunk-4HK4RM3X.cjs.map +1 -0
- package/dist/chunk-4VG47RLS.js +130 -0
- package/dist/chunk-4VG47RLS.js.map +1 -0
- package/dist/chunk-4YJPBUX2.cjs +68 -0
- package/dist/chunk-4YJPBUX2.cjs.map +1 -0
- package/dist/chunk-5QOQR5FE.cjs +19 -0
- package/dist/chunk-5QOQR5FE.cjs.map +1 -0
- package/dist/chunk-66HSJRRH.js +112 -0
- package/dist/chunk-66HSJRRH.js.map +1 -0
- package/dist/chunk-6KNBJ4CE.js +144 -0
- package/dist/chunk-6KNBJ4CE.js.map +1 -0
- package/dist/chunk-6LKN3HRX.js +79 -0
- package/dist/chunk-6LKN3HRX.js.map +1 -0
- package/dist/chunk-6N66T7VQ.js +103 -0
- package/dist/chunk-6N66T7VQ.js.map +1 -0
- package/dist/chunk-6YKFTEX4.js +336 -0
- package/dist/chunk-6YKFTEX4.js.map +1 -0
- package/dist/chunk-7CGXK7KT.js +124 -0
- package/dist/chunk-7CGXK7KT.js.map +1 -0
- package/dist/chunk-7HDAYWK3.cjs +358 -0
- package/dist/chunk-7HDAYWK3.cjs.map +1 -0
- package/dist/chunk-7SEHTEMR.js +91 -0
- package/dist/chunk-7SEHTEMR.js.map +1 -0
- package/dist/chunk-7YV56WPE.js +157 -0
- package/dist/chunk-7YV56WPE.js.map +1 -0
- package/dist/chunk-B54L2CPW.cjs +165 -0
- package/dist/chunk-B54L2CPW.cjs.map +1 -0
- package/dist/chunk-BC6KW2OG.js +197 -0
- package/dist/chunk-BC6KW2OG.js.map +1 -0
- package/dist/chunk-BEYG2HQ4.cjs +178 -0
- package/dist/chunk-BEYG2HQ4.cjs.map +1 -0
- package/dist/chunk-BR3KTAGW.js +113 -0
- package/dist/chunk-BR3KTAGW.js.map +1 -0
- package/dist/chunk-BRSHEDTZ.js +30 -0
- package/dist/chunk-BRSHEDTZ.js.map +1 -0
- package/dist/chunk-BXX2EPFE.cjs +160 -0
- package/dist/chunk-BXX2EPFE.cjs.map +1 -0
- package/dist/chunk-BYXRFTEI.cjs +114 -0
- package/dist/chunk-BYXRFTEI.cjs.map +1 -0
- package/dist/chunk-CMEXNS5V.js +158 -0
- package/dist/chunk-CMEXNS5V.js.map +1 -0
- package/dist/chunk-D2SV6YT3.js +47 -0
- package/dist/chunk-D2SV6YT3.js.map +1 -0
- package/dist/chunk-DL7P72FA.cjs +273 -0
- package/dist/chunk-DL7P72FA.cjs.map +1 -0
- package/dist/chunk-DNQ6N3VG.js +208 -0
- package/dist/chunk-DNQ6N3VG.js.map +1 -0
- package/dist/chunk-E2S7RAT2.js +126 -0
- package/dist/chunk-E2S7RAT2.js.map +1 -0
- package/dist/chunk-E6PR75X7.js +15 -0
- package/dist/chunk-E6PR75X7.js.map +1 -0
- package/dist/chunk-EGQ4JCFU.cjs +109 -0
- package/dist/chunk-EGQ4JCFU.cjs.map +1 -0
- package/dist/chunk-ETPZGEL7.cjs +105 -0
- package/dist/chunk-ETPZGEL7.cjs.map +1 -0
- package/dist/chunk-FFJ6BVEY.cjs +132 -0
- package/dist/chunk-FFJ6BVEY.cjs.map +1 -0
- package/dist/chunk-FKYNRMPX.js +133 -0
- package/dist/chunk-FKYNRMPX.js.map +1 -0
- package/dist/chunk-FRWC6GUR.cjs +126 -0
- package/dist/chunk-FRWC6GUR.cjs.map +1 -0
- package/dist/chunk-FUZFNUCJ.js +104 -0
- package/dist/chunk-FUZFNUCJ.js.map +1 -0
- package/dist/chunk-GM3ZO5WV.js +13 -0
- package/dist/chunk-GM3ZO5WV.js.map +1 -0
- package/dist/chunk-GNRRK7TZ.cjs +149 -0
- package/dist/chunk-GNRRK7TZ.cjs.map +1 -0
- package/dist/chunk-H2AE7JMU.js +128 -0
- package/dist/chunk-H2AE7JMU.js.map +1 -0
- package/dist/chunk-H4RNJ7FK.cjs +115 -0
- package/dist/chunk-H4RNJ7FK.cjs.map +1 -0
- package/dist/chunk-HB4EGHJ7.cjs +153 -0
- package/dist/chunk-HB4EGHJ7.cjs.map +1 -0
- package/dist/chunk-HDWWUEPD.js +122 -0
- package/dist/chunk-HDWWUEPD.js.map +1 -0
- package/dist/chunk-HOOOCSU4.js +216 -0
- package/dist/chunk-HOOOCSU4.js.map +1 -0
- package/dist/chunk-J6NPRKT4.cjs +49 -0
- package/dist/chunk-J6NPRKT4.cjs.map +1 -0
- package/dist/chunk-JO6U4YR4.js +355 -0
- package/dist/chunk-JO6U4YR4.js.map +1 -0
- package/dist/chunk-KE7ILTM4.cjs +162 -0
- package/dist/chunk-KE7ILTM4.cjs.map +1 -0
- package/dist/chunk-KSRROKYC.cjs +135 -0
- package/dist/chunk-KSRROKYC.cjs.map +1 -0
- package/dist/chunk-KVI6DN3R.js +147 -0
- package/dist/chunk-KVI6DN3R.js.map +1 -0
- package/dist/chunk-L54BZYAI.cjs +111 -0
- package/dist/chunk-L54BZYAI.cjs.map +1 -0
- package/dist/chunk-LB4MV5CG.js +109 -0
- package/dist/chunk-LB4MV5CG.js.map +1 -0
- package/dist/chunk-LEJGLR2P.cjs +106 -0
- package/dist/chunk-LEJGLR2P.cjs.map +1 -0
- package/dist/chunk-LU35QDPN.cjs +30 -0
- package/dist/chunk-LU35QDPN.cjs.map +1 -0
- package/dist/chunk-LUTU4WW3.js +151 -0
- package/dist/chunk-LUTU4WW3.js.map +1 -0
- package/dist/chunk-M4AQD6WX.cjs +220 -0
- package/dist/chunk-M4AQD6WX.cjs.map +1 -0
- package/dist/chunk-M4UST3UU.cjs +159 -0
- package/dist/chunk-M4UST3UU.cjs.map +1 -0
- package/dist/chunk-MLD5ZIDO.cjs +359 -0
- package/dist/chunk-MLD5ZIDO.cjs.map +1 -0
- package/dist/chunk-MLX3EO2C.js +107 -0
- package/dist/chunk-MLX3EO2C.js.map +1 -0
- package/dist/chunk-MVWERW4G.cjs +28 -0
- package/dist/chunk-MVWERW4G.cjs.map +1 -0
- package/dist/chunk-MYPCA25Y.cjs +115 -0
- package/dist/chunk-MYPCA25Y.cjs.map +1 -0
- package/dist/chunk-N6IVODRJ.js +114 -0
- package/dist/chunk-N6IVODRJ.js.map +1 -0
- package/dist/chunk-NFD6VAVM.js +155 -0
- package/dist/chunk-NFD6VAVM.js.map +1 -0
- package/dist/chunk-NHGKZMD7.cjs +18 -0
- package/dist/chunk-NHGKZMD7.cjs.map +1 -0
- package/dist/chunk-NMLDPXOL.js +167 -0
- package/dist/chunk-NMLDPXOL.js.map +1 -0
- package/dist/chunk-NONU7KUN.cjs +32 -0
- package/dist/chunk-NONU7KUN.cjs.map +1 -0
- package/dist/chunk-NQSC7CKN.js +130 -0
- package/dist/chunk-NQSC7CKN.js.map +1 -0
- package/dist/chunk-NYVFC2SF.js +87 -0
- package/dist/chunk-NYVFC2SF.js.map +1 -0
- package/dist/chunk-O5KGKQSU.js +218 -0
- package/dist/chunk-O5KGKQSU.js.map +1 -0
- package/dist/chunk-OGSZO22B.js +26 -0
- package/dist/chunk-OGSZO22B.js.map +1 -0
- package/dist/chunk-Q2BDB5ZA.cjs +218 -0
- package/dist/chunk-Q2BDB5ZA.cjs.map +1 -0
- package/dist/chunk-Q6U5D2ZB.cjs +210 -0
- package/dist/chunk-Q6U5D2ZB.cjs.map +1 -0
- package/dist/chunk-QAYX6XN3.js +26 -0
- package/dist/chunk-QAYX6XN3.js.map +1 -0
- package/dist/chunk-QHJHYV3H.cjs +15 -0
- package/dist/chunk-QHJHYV3H.cjs.map +1 -0
- package/dist/chunk-QIJZZOX7.js +249 -0
- package/dist/chunk-QIJZZOX7.js.map +1 -0
- package/dist/chunk-QLRK46YY.cjs +93 -0
- package/dist/chunk-QLRK46YY.cjs.map +1 -0
- package/dist/chunk-QZ4ZYTP6.js +124 -0
- package/dist/chunk-QZ4ZYTP6.js.map +1 -0
- package/dist/chunk-RCVRZCCC.cjs +156 -0
- package/dist/chunk-RCVRZCCC.cjs.map +1 -0
- package/dist/chunk-ROYZ7W4M.cjs +81 -0
- package/dist/chunk-ROYZ7W4M.cjs.map +1 -0
- package/dist/chunk-SJS4ISBA.js +163 -0
- package/dist/chunk-SJS4ISBA.js.map +1 -0
- package/dist/chunk-SKVCPG5R.cjs +124 -0
- package/dist/chunk-SKVCPG5R.cjs.map +1 -0
- package/dist/chunk-SQJAKZ4W.js +113 -0
- package/dist/chunk-SQJAKZ4W.js.map +1 -0
- package/dist/chunk-SUNC3CPV.js +79 -0
- package/dist/chunk-SUNC3CPV.js.map +1 -0
- package/dist/chunk-SWYCVF46.js +145 -0
- package/dist/chunk-SWYCVF46.js.map +1 -0
- package/dist/chunk-SZVK6RRQ.js +98 -0
- package/dist/chunk-SZVK6RRQ.js.map +1 -0
- package/dist/chunk-TOS2RYHQ.js +154 -0
- package/dist/chunk-TOS2RYHQ.js.map +1 -0
- package/dist/chunk-TTOX27BZ.cjs +116 -0
- package/dist/chunk-TTOX27BZ.cjs.map +1 -0
- package/dist/chunk-TW6KPQIS.js +160 -0
- package/dist/chunk-TW6KPQIS.js.map +1 -0
- package/dist/chunk-UN7K3YQG.cjs +81 -0
- package/dist/chunk-UN7K3YQG.cjs.map +1 -0
- package/dist/chunk-UQBDGCS6.cjs +89 -0
- package/dist/chunk-UQBDGCS6.cjs.map +1 -0
- package/dist/chunk-VPI7UGB3.cjs +130 -0
- package/dist/chunk-VPI7UGB3.cjs.map +1 -0
- package/dist/chunk-X2JNB5UN.js +271 -0
- package/dist/chunk-X2JNB5UN.js.map +1 -0
- package/dist/chunk-XBIM73HV.cjs +126 -0
- package/dist/chunk-XBIM73HV.cjs.map +1 -0
- package/dist/chunk-XHQWWR5M.cjs +4892 -0
- package/dist/chunk-XHQWWR5M.cjs.map +1 -0
- package/dist/chunk-Y2JZHX3P.cjs +169 -0
- package/dist/chunk-Y2JZHX3P.cjs.map +1 -0
- package/dist/chunk-Y4P4VY7A.cjs +251 -0
- package/dist/chunk-Y4P4VY7A.cjs.map +1 -0
- package/dist/chunk-Y54XVNXB.cjs +157 -0
- package/dist/chunk-Y54XVNXB.cjs.map +1 -0
- package/dist/chunk-Z6E3XVP2.cjs +132 -0
- package/dist/chunk-Z6E3XVP2.cjs.map +1 -0
- package/dist/chunk-ZDYCIP6N.cjs +100 -0
- package/dist/chunk-ZDYCIP6N.cjs.map +1 -0
- package/dist/chunk-ZDZQG3GH.cjs +148 -0
- package/dist/chunk-ZDZQG3GH.cjs.map +1 -0
- package/dist/chunk-ZL25X5WW.js +66 -0
- package/dist/chunk-ZL25X5WW.js.map +1 -0
- package/dist/combo-type-BdSohVyy.d.ts +16 -0
- package/dist/combo-type-wodyLq1f.d.cts +16 -0
- package/dist/combo.cjs +34 -0
- package/dist/combo.cjs.map +1 -0
- package/dist/combo.d.cts +8 -0
- package/dist/combo.d.ts +8 -0
- package/dist/combo.js +13 -0
- package/dist/combo.js.map +1 -0
- package/dist/custom-type-B6w1n5Ua.d.cts +23 -0
- package/dist/custom-type-XFjuPwCr.d.ts +23 -0
- package/dist/custom.cjs +33 -0
- package/dist/custom.cjs.map +1 -0
- package/dist/custom.d.cts +8 -0
- package/dist/custom.d.ts +8 -0
- package/dist/custom.js +12 -0
- package/dist/custom.js.map +1 -0
- package/dist/donut.cjs +33 -0
- package/dist/donut.cjs.map +1 -0
- package/dist/donut.d.cts +8 -0
- package/dist/donut.d.ts +8 -0
- package/dist/donut.js +12 -0
- package/dist/donut.js.map +1 -0
- package/dist/dumbbell-type-DPSE0OTg.d.ts +12 -0
- package/dist/dumbbell-type-w424KzI2.d.cts +12 -0
- package/dist/dumbbell.cjs +34 -0
- package/dist/dumbbell.cjs.map +1 -0
- package/dist/dumbbell.d.cts +8 -0
- package/dist/dumbbell.d.ts +8 -0
- package/dist/dumbbell.js +13 -0
- package/dist/dumbbell.js.map +1 -0
- package/dist/engine-CNukbv7k.d.cts +426 -0
- package/dist/engine-CNukbv7k.d.ts +426 -0
- package/dist/factory-dbngWV4d.d.cts +8 -0
- package/dist/factory-jRzNNxwj.d.ts +8 -0
- package/dist/finance.cjs +92 -0
- package/dist/finance.cjs.map +1 -0
- package/dist/finance.d.cts +192 -0
- package/dist/finance.d.ts +192 -0
- package/dist/finance.js +3 -0
- package/dist/finance.js.map +1 -0
- package/dist/funnel-type-BeVl3ohX.d.cts +9 -0
- package/dist/funnel-type-CMXGQq4T.d.ts +9 -0
- package/dist/funnel.cjs +33 -0
- package/dist/funnel.cjs.map +1 -0
- package/dist/funnel.d.cts +8 -0
- package/dist/funnel.d.ts +8 -0
- package/dist/funnel.js +12 -0
- package/dist/funnel.js.map +1 -0
- package/dist/gauge-type-BpDBwCeD.d.ts +11 -0
- package/dist/gauge-type-DmjDdfsY.d.cts +11 -0
- package/dist/gauge.cjs +33 -0
- package/dist/gauge.cjs.map +1 -0
- package/dist/gauge.d.cts +8 -0
- package/dist/gauge.d.ts +8 -0
- package/dist/gauge.js +12 -0
- package/dist/gauge.js.map +1 -0
- package/dist/geo.cjs +41 -0
- package/dist/geo.cjs.map +1 -0
- package/dist/geo.d.cts +8 -0
- package/dist/geo.d.ts +8 -0
- package/dist/geo.js +12 -0
- package/dist/geo.js.map +1 -0
- package/dist/graph-type-DkdAB6Vc.d.cts +5 -0
- package/dist/graph-type-ul9xwdf5.d.ts +5 -0
- package/dist/graph.cjs +33 -0
- package/dist/graph.cjs.map +1 -0
- package/dist/graph.d.cts +8 -0
- package/dist/graph.d.ts +8 -0
- package/dist/graph.js +12 -0
- package/dist/graph.js.map +1 -0
- package/dist/heatmap-type-D0shkxK7.d.cts +12 -0
- package/dist/heatmap-type-q6nNhVTr.d.ts +12 -0
- package/dist/heatmap.cjs +33 -0
- package/dist/heatmap.cjs.map +1 -0
- package/dist/heatmap.d.cts +8 -0
- package/dist/heatmap.d.ts +8 -0
- package/dist/heatmap.js +12 -0
- package/dist/heatmap.js.map +1 -0
- package/dist/histogram-type-BWil-Rb7.d.cts +13 -0
- package/dist/histogram-type-CF593WSp.d.ts +13 -0
- package/dist/histogram.cjs +33 -0
- package/dist/histogram.cjs.map +1 -0
- package/dist/histogram.d.cts +8 -0
- package/dist/histogram.d.ts +8 -0
- package/dist/histogram.js +12 -0
- package/dist/histogram.js.map +1 -0
- package/dist/horizontal-bar-type-0mqnyMUR.d.cts +11 -0
- package/dist/horizontal-bar-type-DAlrxY0h.d.ts +11 -0
- package/dist/horizontal-bar.cjs +34 -0
- package/dist/horizontal-bar.cjs.map +1 -0
- package/dist/horizontal-bar.d.cts +8 -0
- package/dist/horizontal-bar.d.ts +8 -0
- package/dist/horizontal-bar.js +13 -0
- package/dist/horizontal-bar.js.map +1 -0
- package/dist/index.cjs +1604 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +594 -0
- package/dist/index.d.ts +594 -0
- package/dist/index.js +1201 -0
- package/dist/index.js.map +1 -0
- package/dist/kagi-type-Y5XUVm3h.d.ts +26 -0
- package/dist/kagi-type-aG-Q1bWk.d.cts +26 -0
- package/dist/kagi.cjs +33 -0
- package/dist/kagi.cjs.map +1 -0
- package/dist/kagi.d.cts +8 -0
- package/dist/kagi.d.ts +8 -0
- package/dist/kagi.js +12 -0
- package/dist/kagi.js.map +1 -0
- package/dist/line-type-B8lgTFjb.d.cts +5 -0
- package/dist/line-type-Diw0nXj7.d.ts +5 -0
- package/dist/line.cjs +33 -0
- package/dist/line.cjs.map +1 -0
- package/dist/line.d.cts +8 -0
- package/dist/line.d.ts +8 -0
- package/dist/line.js +12 -0
- package/dist/line.js.map +1 -0
- package/dist/lines-type-CGrg_mDi.d.cts +31 -0
- package/dist/lines-type-V-seVNZ4.d.ts +31 -0
- package/dist/lines.cjs +33 -0
- package/dist/lines.cjs.map +1 -0
- package/dist/lines.d.cts +8 -0
- package/dist/lines.d.ts +8 -0
- package/dist/lines.js +12 -0
- package/dist/lines.js.map +1 -0
- package/dist/lollipop-type-CoTzKLSu.d.cts +11 -0
- package/dist/lollipop-type-Ygc4rRql.d.ts +11 -0
- package/dist/lollipop.cjs +33 -0
- package/dist/lollipop.cjs.map +1 -0
- package/dist/lollipop.d.cts +8 -0
- package/dist/lollipop.d.ts +8 -0
- package/dist/lollipop.js +12 -0
- package/dist/lollipop.js.map +1 -0
- package/dist/matrix-type-Crb_NwUJ.d.cts +26 -0
- package/dist/matrix-type-Dag1VLCY.d.ts +26 -0
- package/dist/matrix.cjs +33 -0
- package/dist/matrix.cjs.map +1 -0
- package/dist/matrix.d.cts +8 -0
- package/dist/matrix.d.ts +8 -0
- package/dist/matrix.js +12 -0
- package/dist/matrix.js.map +1 -0
- package/dist/ohlc-type-BQBHvVJO.d.cts +28 -0
- package/dist/ohlc-type-CGR-vRGL.d.ts +28 -0
- package/dist/ohlc.cjs +33 -0
- package/dist/ohlc.cjs.map +1 -0
- package/dist/ohlc.d.cts +8 -0
- package/dist/ohlc.d.ts +8 -0
- package/dist/ohlc.js +12 -0
- package/dist/ohlc.js.map +1 -0
- package/dist/parallel-type-6t6xyHMg.d.ts +14 -0
- package/dist/parallel-type-D-S-EqeC.d.cts +14 -0
- package/dist/parallel.cjs +33 -0
- package/dist/parallel.cjs.map +1 -0
- package/dist/parallel.d.cts +8 -0
- package/dist/parallel.d.ts +8 -0
- package/dist/parallel.js +12 -0
- package/dist/parallel.js.map +1 -0
- package/dist/pictorialbar-type-A-8mTX1N.d.ts +5 -0
- package/dist/pictorialbar-type-CnJEH9GZ.d.cts +5 -0
- package/dist/pictorialbar.cjs +33 -0
- package/dist/pictorialbar.cjs.map +1 -0
- package/dist/pictorialbar.d.cts +8 -0
- package/dist/pictorialbar.d.ts +8 -0
- package/dist/pictorialbar.js +12 -0
- package/dist/pictorialbar.js.map +1 -0
- package/dist/pie-type-S7kUKGRS.d.ts +7 -0
- package/dist/pie-type-duX5xkfQ.d.cts +7 -0
- package/dist/pie.cjs +33 -0
- package/dist/pie.cjs.map +1 -0
- package/dist/pie.d.cts +8 -0
- package/dist/pie.d.ts +8 -0
- package/dist/pie.js +12 -0
- package/dist/pie.js.map +1 -0
- package/dist/polar-type-CI6-I8Yg.d.cts +11 -0
- package/dist/polar-type-Dj21GIc9.d.ts +11 -0
- package/dist/polar.cjs +33 -0
- package/dist/polar.cjs.map +1 -0
- package/dist/polar.d.cts +8 -0
- package/dist/polar.d.ts +8 -0
- package/dist/polar.js +12 -0
- package/dist/polar.js.map +1 -0
- package/dist/radar-type-CYjZHuKm.d.ts +9 -0
- package/dist/radar-type-Dgyr13Zd.d.cts +9 -0
- package/dist/radar.cjs +33 -0
- package/dist/radar.cjs.map +1 -0
- package/dist/radar.d.cts +8 -0
- package/dist/radar.d.ts +8 -0
- package/dist/radar.js +12 -0
- package/dist/radar.js.map +1 -0
- package/dist/radialbar-type-CLZ8XgST.d.ts +11 -0
- package/dist/radialbar-type-C_SBXoaa.d.cts +11 -0
- package/dist/radialbar.cjs +33 -0
- package/dist/radialbar.cjs.map +1 -0
- package/dist/radialbar.d.cts +8 -0
- package/dist/radialbar.d.ts +8 -0
- package/dist/radialbar.js +12 -0
- package/dist/radialbar.js.map +1 -0
- package/dist/range-type-CkriEnLm.d.cts +26 -0
- package/dist/range-type-_LbMV4tl.d.ts +26 -0
- package/dist/range.cjs +32 -0
- package/dist/range.cjs.map +1 -0
- package/dist/range.d.cts +8 -0
- package/dist/range.d.ts +8 -0
- package/dist/range.js +11 -0
- package/dist/range.js.map +1 -0
- package/dist/renko-type-43OXCtZ3.d.cts +24 -0
- package/dist/renko-type-ejoXt2ro.d.ts +24 -0
- package/dist/renko.cjs +33 -0
- package/dist/renko.cjs.map +1 -0
- package/dist/renko.d.cts +8 -0
- package/dist/renko.d.ts +8 -0
- package/dist/renko.js +12 -0
- package/dist/renko.js.map +1 -0
- package/dist/sankey-type-CN7PL5MQ.d.ts +5 -0
- package/dist/sankey-type-DfkTUnXB.d.cts +5 -0
- package/dist/sankey.cjs +33 -0
- package/dist/sankey.cjs.map +1 -0
- package/dist/sankey.d.cts +8 -0
- package/dist/sankey.d.ts +8 -0
- package/dist/sankey.js +12 -0
- package/dist/sankey.js.map +1 -0
- package/dist/scatter-type-CD7X1pZb.d.cts +5 -0
- package/dist/scatter-type-D3HdPkZ6.d.ts +5 -0
- package/dist/scatter.cjs +32 -0
- package/dist/scatter.cjs.map +1 -0
- package/dist/scatter.d.cts +8 -0
- package/dist/scatter.d.ts +8 -0
- package/dist/scatter.js +11 -0
- package/dist/scatter.js.map +1 -0
- package/dist/sparkline-type-COW3izgF.d.ts +9 -0
- package/dist/sparkline-type-qt3yoLs7.d.cts +9 -0
- package/dist/sparkline.cjs +33 -0
- package/dist/sparkline.cjs.map +1 -0
- package/dist/sparkline.d.cts +8 -0
- package/dist/sparkline.d.ts +8 -0
- package/dist/sparkline.js +12 -0
- package/dist/sparkline.js.map +1 -0
- package/dist/stacked-bar-type-C-5pmb-D.d.ts +8 -0
- package/dist/stacked-bar-type-Ct6HK2A0.d.cts +8 -0
- package/dist/stacked-bar.cjs +34 -0
- package/dist/stacked-bar.cjs.map +1 -0
- package/dist/stacked-bar.d.cts +8 -0
- package/dist/stacked-bar.d.ts +8 -0
- package/dist/stacked-bar.js +13 -0
- package/dist/stacked-bar.js.map +1 -0
- package/dist/step-type-BSL-CUny.d.cts +11 -0
- package/dist/step-type-Cleoshov.d.ts +11 -0
- package/dist/step.cjs +34 -0
- package/dist/step.cjs.map +1 -0
- package/dist/step.d.cts +8 -0
- package/dist/step.d.ts +8 -0
- package/dist/step.js +13 -0
- package/dist/step.js.map +1 -0
- package/dist/sunburst-type-BOztb_Px.d.cts +5 -0
- package/dist/sunburst-type-ZFw2w6m8.d.ts +5 -0
- package/dist/sunburst.cjs +33 -0
- package/dist/sunburst.cjs.map +1 -0
- package/dist/sunburst.d.cts +8 -0
- package/dist/sunburst.d.ts +8 -0
- package/dist/sunburst.js +12 -0
- package/dist/sunburst.js.map +1 -0
- package/dist/themeriver-type-B5PYChcC.d.ts +15 -0
- package/dist/themeriver-type-BnRSsyal.d.cts +15 -0
- package/dist/themeriver.cjs +33 -0
- package/dist/themeriver.cjs.map +1 -0
- package/dist/themeriver.d.cts +8 -0
- package/dist/themeriver.d.ts +8 -0
- package/dist/themeriver.js +12 -0
- package/dist/themeriver.js.map +1 -0
- package/dist/tree-type-B-bOSg0l.d.ts +5 -0
- package/dist/tree-type-Cz84wHnR.d.cts +5 -0
- package/dist/tree.cjs +33 -0
- package/dist/tree.cjs.map +1 -0
- package/dist/tree.d.cts +8 -0
- package/dist/tree.d.ts +8 -0
- package/dist/tree.js +12 -0
- package/dist/tree.js.map +1 -0
- package/dist/treemap-type-DYDj-rWv.d.ts +11 -0
- package/dist/treemap-type-OBCGexiK.d.cts +11 -0
- package/dist/treemap.cjs +33 -0
- package/dist/treemap.cjs.map +1 -0
- package/dist/treemap.d.cts +8 -0
- package/dist/treemap.d.ts +8 -0
- package/dist/treemap.js +12 -0
- package/dist/treemap.js.map +1 -0
- package/dist/volume-type-C9wRmKR6.d.ts +21 -0
- package/dist/volume-type-CfERBN5g.d.cts +21 -0
- package/dist/volume.cjs +33 -0
- package/dist/volume.cjs.map +1 -0
- package/dist/volume.d.cts +8 -0
- package/dist/volume.d.ts +8 -0
- package/dist/volume.js +12 -0
- package/dist/volume.js.map +1 -0
- package/dist/waterfall-type-CpdVtBi_.d.ts +10 -0
- package/dist/waterfall-type-hm5ylGgW.d.cts +10 -0
- package/dist/waterfall.cjs +33 -0
- package/dist/waterfall.cjs.map +1 -0
- package/dist/waterfall.d.cts +8 -0
- package/dist/waterfall.d.ts +8 -0
- package/dist/waterfall.js +12 -0
- package/dist/waterfall.js.map +1 -0
- package/dist/world-regions-Cfvxpbx0.d.ts +50 -0
- package/dist/world-regions-cMulhqDW.d.cts +50 -0
- package/package.json +262 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/bullet/bullet-type.ts
|
|
7
|
+
var bulletChartType = {
|
|
8
|
+
type: "bullet",
|
|
9
|
+
getScaleTypes() {
|
|
10
|
+
return { x: "categorical", y: "linear" };
|
|
11
|
+
},
|
|
12
|
+
prepareData(data, options) {
|
|
13
|
+
return chunk5QOQR5FE_cjs.prepareNoAxes(data, options);
|
|
14
|
+
},
|
|
15
|
+
render(ctx) {
|
|
16
|
+
const { data, area, theme, options } = ctx;
|
|
17
|
+
const nodes = [];
|
|
18
|
+
const actual = data.series[0];
|
|
19
|
+
if (!actual || actual.values.length === 0) return nodes;
|
|
20
|
+
const target = data.series[1];
|
|
21
|
+
const count = actual.values.length;
|
|
22
|
+
const labelWidth = Math.min(80, area.width * 0.2);
|
|
23
|
+
const chartX = area.x + labelWidth;
|
|
24
|
+
const chartW = area.width - labelWidth;
|
|
25
|
+
const rowHeight = area.height / count;
|
|
26
|
+
const barHeight = Math.min(rowHeight * 0.4, 20);
|
|
27
|
+
const rangeHeight = Math.min(rowHeight * 0.7, 32);
|
|
28
|
+
let maxVal = 0;
|
|
29
|
+
for (const v of actual.values) {
|
|
30
|
+
if (Math.abs(v) > maxVal) maxVal = Math.abs(v);
|
|
31
|
+
}
|
|
32
|
+
if (target) {
|
|
33
|
+
for (const v of target.values) {
|
|
34
|
+
if (Math.abs(v) > maxVal) maxVal = Math.abs(v);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
maxVal = maxVal * 1.2;
|
|
38
|
+
if (maxVal === 0) maxVal = 1;
|
|
39
|
+
for (let i = 0; i < count; i++) {
|
|
40
|
+
const cy = area.y + rowHeight * (i + 0.5);
|
|
41
|
+
const val = actual.values[i];
|
|
42
|
+
const label = String(data.labels[i] ?? `Item ${i + 1}`);
|
|
43
|
+
const color = options.colors[i % options.colors.length];
|
|
44
|
+
const bulletNodes = [];
|
|
45
|
+
bulletNodes.push(chunkXHQWWR5M_cjs.text(area.x + labelWidth - 8, cy, label, {
|
|
46
|
+
class: "chartts-bullet-label",
|
|
47
|
+
fill: theme.textMuted,
|
|
48
|
+
textAnchor: "end",
|
|
49
|
+
dominantBaseline: "central",
|
|
50
|
+
fontSize: theme.fontSizeSmall,
|
|
51
|
+
fontFamily: theme.fontFamily
|
|
52
|
+
}));
|
|
53
|
+
const bands = [1, 0.75, 0.5];
|
|
54
|
+
const opacities = [0.1, 0.18, 0.28];
|
|
55
|
+
for (let b = 0; b < bands.length; b++) {
|
|
56
|
+
const bw = chartW * bands[b];
|
|
57
|
+
bulletNodes.push(chunkXHQWWR5M_cjs.rect(chartX, cy - rangeHeight / 2, bw, rangeHeight, {
|
|
58
|
+
rx: 4,
|
|
59
|
+
ry: 4,
|
|
60
|
+
class: "chartts-bullet-range",
|
|
61
|
+
fill: theme.textColor,
|
|
62
|
+
opacity: opacities[b]
|
|
63
|
+
}));
|
|
64
|
+
}
|
|
65
|
+
const barW = Math.abs(val) / maxVal * chartW;
|
|
66
|
+
bulletNodes.push(chunkXHQWWR5M_cjs.rect(chartX, cy - barHeight / 2, barW, barHeight, {
|
|
67
|
+
rx: 3,
|
|
68
|
+
ry: 3,
|
|
69
|
+
class: "chartts-bullet-bar",
|
|
70
|
+
fill: color,
|
|
71
|
+
"data-series": 0,
|
|
72
|
+
"data-index": i,
|
|
73
|
+
tabindex: 0,
|
|
74
|
+
role: "img",
|
|
75
|
+
ariaLabel: `${label}: ${val}${target ? `, target: ${target.values[i]}` : ""}`
|
|
76
|
+
}));
|
|
77
|
+
if (target && target.values[i] != null) {
|
|
78
|
+
const tx = chartX + Math.abs(target.values[i]) / maxVal * chartW;
|
|
79
|
+
const markerH = rangeHeight * 0.9;
|
|
80
|
+
bulletNodes.push(chunkXHQWWR5M_cjs.line(tx, cy - markerH / 2, tx, cy + markerH / 2, {
|
|
81
|
+
class: "chartts-bullet-target",
|
|
82
|
+
stroke: theme.textColor,
|
|
83
|
+
strokeWidth: 2.5
|
|
84
|
+
}));
|
|
85
|
+
}
|
|
86
|
+
nodes.push(chunkXHQWWR5M_cjs.group(bulletNodes, {
|
|
87
|
+
class: `chartts-series chartts-series-${i}`,
|
|
88
|
+
"data-series-name": label
|
|
89
|
+
}));
|
|
90
|
+
}
|
|
91
|
+
return nodes;
|
|
92
|
+
},
|
|
93
|
+
hitTest(ctx, mx, my) {
|
|
94
|
+
const { data, area } = ctx;
|
|
95
|
+
const actual = data.series[0];
|
|
96
|
+
if (!actual || actual.values.length === 0) return null;
|
|
97
|
+
const count = actual.values.length;
|
|
98
|
+
const labelWidth = Math.min(80, area.width * 0.2);
|
|
99
|
+
const rowHeight = area.height / count;
|
|
100
|
+
if (mx < area.x + labelWidth) return null;
|
|
101
|
+
for (let i = 0; i < count; i++) {
|
|
102
|
+
const cy = area.y + rowHeight * (i + 0.5);
|
|
103
|
+
const rangeHeight = Math.min(rowHeight * 0.7, 32);
|
|
104
|
+
if (my >= cy - rangeHeight / 2 && my <= cy + rangeHeight / 2) {
|
|
105
|
+
return { seriesIndex: 0, pointIndex: i, distance: 0 };
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return null;
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
exports.bulletChartType = bulletChartType;
|
|
113
|
+
//# sourceMappingURL=chunk-BYXRFTEI.cjs.map
|
|
114
|
+
//# sourceMappingURL=chunk-BYXRFTEI.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/bullet/bullet-type.ts"],"names":["prepareNoAxes","text","rect","line","group"],"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,OAAOA,+BAAA,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,KAAKC,sBAAA,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,KAAKC,sBAAA,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,KAAKA,sBAAA,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,CAAKC,uBAAK,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,CAAKC,wBAAM,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-BYXRFTEI.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"]}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { prepareNoAxes } from './chunk-3XVGEBR4.js';
|
|
2
|
+
import { PathBuilder, path, text, circle, group } from './chunk-3BRQGYDX.js';
|
|
3
|
+
|
|
4
|
+
// src/charts/radar/radar-type.ts
|
|
5
|
+
var radarChartType = {
|
|
6
|
+
type: "radar",
|
|
7
|
+
getScaleTypes() {
|
|
8
|
+
return { x: "categorical", y: "linear" };
|
|
9
|
+
},
|
|
10
|
+
prepareData(data, options) {
|
|
11
|
+
return prepareNoAxes(data, options);
|
|
12
|
+
},
|
|
13
|
+
render(ctx) {
|
|
14
|
+
const { data, area, theme } = ctx;
|
|
15
|
+
const nodes = [];
|
|
16
|
+
const labelCount = data.labels.length;
|
|
17
|
+
if (labelCount < 3) return nodes;
|
|
18
|
+
const cx = area.x + area.width / 2;
|
|
19
|
+
const cy = area.y + area.height / 2;
|
|
20
|
+
const radius = Math.min(area.width, area.height) / 2 - 24;
|
|
21
|
+
let maxVal = 0;
|
|
22
|
+
for (const series of data.series) {
|
|
23
|
+
for (const v of series.values) {
|
|
24
|
+
if (Math.abs(v) > maxVal) maxVal = Math.abs(v);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (maxVal === 0) maxVal = 1;
|
|
28
|
+
const angleStep = Math.PI * 2 / labelCount;
|
|
29
|
+
const startAngle = -Math.PI / 2;
|
|
30
|
+
const gridLevels = 3;
|
|
31
|
+
for (let level = 1; level <= gridLevels; level++) {
|
|
32
|
+
const r = radius * level / gridLevels;
|
|
33
|
+
const pb = new PathBuilder();
|
|
34
|
+
for (let i = 0; i <= labelCount; i++) {
|
|
35
|
+
const angle = startAngle + i % labelCount * angleStep;
|
|
36
|
+
const x = cx + r * Math.cos(angle);
|
|
37
|
+
const y = cy + r * Math.sin(angle);
|
|
38
|
+
if (i === 0) pb.moveTo(x, y);
|
|
39
|
+
else pb.lineTo(x, y);
|
|
40
|
+
}
|
|
41
|
+
nodes.push(path(pb.build(), {
|
|
42
|
+
class: "chartts-radar-grid",
|
|
43
|
+
stroke: theme.gridColor,
|
|
44
|
+
strokeWidth: theme.gridWidth,
|
|
45
|
+
fillOpacity: 0,
|
|
46
|
+
fill: "none"
|
|
47
|
+
}));
|
|
48
|
+
}
|
|
49
|
+
for (let i = 0; i < labelCount; i++) {
|
|
50
|
+
const angle = startAngle + i * angleStep;
|
|
51
|
+
const x = cx + radius * Math.cos(angle);
|
|
52
|
+
const y = cy + radius * Math.sin(angle);
|
|
53
|
+
nodes.push({
|
|
54
|
+
type: "line",
|
|
55
|
+
x1: cx,
|
|
56
|
+
y1: cy,
|
|
57
|
+
x2: x,
|
|
58
|
+
y2: y,
|
|
59
|
+
attrs: {
|
|
60
|
+
class: "chartts-radar-axis",
|
|
61
|
+
stroke: theme.gridColor,
|
|
62
|
+
strokeWidth: theme.gridWidth
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
const labelR = radius + 14;
|
|
66
|
+
const lx = cx + labelR * Math.cos(angle);
|
|
67
|
+
const ly = cy + labelR * Math.sin(angle);
|
|
68
|
+
const anchor = Math.abs(Math.cos(angle)) < 0.01 ? "middle" : Math.cos(angle) > 0 ? "start" : "end";
|
|
69
|
+
nodes.push(text(lx, ly, String(data.labels[i]), {
|
|
70
|
+
class: "chartts-radar-label",
|
|
71
|
+
fill: theme.textMuted,
|
|
72
|
+
textAnchor: anchor,
|
|
73
|
+
dominantBaseline: "central",
|
|
74
|
+
fontSize: theme.fontSizeSmall,
|
|
75
|
+
fontFamily: theme.fontFamily
|
|
76
|
+
}));
|
|
77
|
+
}
|
|
78
|
+
for (const series of data.series) {
|
|
79
|
+
const pb = new PathBuilder();
|
|
80
|
+
const points = [];
|
|
81
|
+
for (let i = 0; i < labelCount; i++) {
|
|
82
|
+
const val = series.values[i] ?? 0;
|
|
83
|
+
const r = Math.abs(val) / maxVal * radius;
|
|
84
|
+
const angle = startAngle + i * angleStep;
|
|
85
|
+
const x = cx + r * Math.cos(angle);
|
|
86
|
+
const y = cy + r * Math.sin(angle);
|
|
87
|
+
points.push({ x, y });
|
|
88
|
+
if (i === 0) pb.moveTo(x, y);
|
|
89
|
+
else pb.lineTo(x, y);
|
|
90
|
+
}
|
|
91
|
+
pb.close();
|
|
92
|
+
const seriesNodes = [];
|
|
93
|
+
seriesNodes.push(path(pb.build(), {
|
|
94
|
+
class: "chartts-radar-area",
|
|
95
|
+
fill: series.color,
|
|
96
|
+
fillOpacity: 0.2,
|
|
97
|
+
stroke: series.color,
|
|
98
|
+
strokeWidth: theme.lineWidth,
|
|
99
|
+
"data-series": series.index
|
|
100
|
+
}));
|
|
101
|
+
for (let i = 0; i < points.length; i++) {
|
|
102
|
+
seriesNodes.push(circle(points[i].x, points[i].y, theme.pointRadius, {
|
|
103
|
+
class: "chartts-radar-point",
|
|
104
|
+
fill: series.color,
|
|
105
|
+
"data-series": series.index,
|
|
106
|
+
"data-index": i,
|
|
107
|
+
tabindex: 0,
|
|
108
|
+
role: "img",
|
|
109
|
+
ariaLabel: `${series.name} ${data.labels[i]}: ${series.values[i]}`
|
|
110
|
+
}));
|
|
111
|
+
}
|
|
112
|
+
nodes.push(group(seriesNodes, {
|
|
113
|
+
class: `chartts-series chartts-series-${series.index}`,
|
|
114
|
+
"data-series-name": series.name
|
|
115
|
+
}));
|
|
116
|
+
}
|
|
117
|
+
return nodes;
|
|
118
|
+
},
|
|
119
|
+
hitTest(ctx, mx, my) {
|
|
120
|
+
const { data, area } = ctx;
|
|
121
|
+
const labelCount = data.labels.length;
|
|
122
|
+
if (labelCount < 3) return null;
|
|
123
|
+
const cx = area.x + area.width / 2;
|
|
124
|
+
const cy = area.y + area.height / 2;
|
|
125
|
+
const radius = Math.min(area.width, area.height) / 2 - 24;
|
|
126
|
+
const angleStep = Math.PI * 2 / labelCount;
|
|
127
|
+
const startAngle = -Math.PI / 2;
|
|
128
|
+
let maxVal = 0;
|
|
129
|
+
for (const series of data.series) {
|
|
130
|
+
for (const v of series.values) {
|
|
131
|
+
if (Math.abs(v) > maxVal) maxVal = Math.abs(v);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
if (maxVal === 0) return null;
|
|
135
|
+
let best = null;
|
|
136
|
+
let bestDist = Infinity;
|
|
137
|
+
const hitRadius = 15;
|
|
138
|
+
for (const series of data.series) {
|
|
139
|
+
for (let i = 0; i < labelCount; i++) {
|
|
140
|
+
const val = series.values[i] ?? 0;
|
|
141
|
+
const r = Math.abs(val) / maxVal * radius;
|
|
142
|
+
const angle = startAngle + i * angleStep;
|
|
143
|
+
const px = cx + r * Math.cos(angle);
|
|
144
|
+
const py = cy + r * Math.sin(angle);
|
|
145
|
+
const dist = Math.sqrt((mx - px) ** 2 + (my - py) ** 2);
|
|
146
|
+
if (dist < bestDist && dist < hitRadius) {
|
|
147
|
+
bestDist = dist;
|
|
148
|
+
best = { seriesIndex: series.index, pointIndex: i, distance: dist };
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return best;
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
export { radarChartType };
|
|
157
|
+
//# sourceMappingURL=chunk-CMEXNS5V.js.map
|
|
158
|
+
//# sourceMappingURL=chunk-CMEXNS5V.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/radar/radar-type.ts"],"names":[],"mappings":"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","file":"chunk-CMEXNS5V.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 * Radar / Spider chart — plots multi-dimensional data on radial axes.\n * Each category becomes an axis radiating from center.\n */\nexport const radarChartType: ChartTypePlugin = {\n type: 'radar',\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 const labelCount = data.labels.length\n if (labelCount < 3) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n\n // Find the max value across all series for scaling\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) maxVal = 1\n\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2 // start from top\n\n // Draw grid rings (3 levels)\n const gridLevels = 3\n for (let level = 1; level <= gridLevels; level++) {\n const r = (radius * level) / gridLevels\n const pb = new PathBuilder()\n for (let i = 0; i <= labelCount; i++) {\n const angle = startAngle + (i % labelCount) * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n nodes.push(path(pb.build(), {\n class: 'chartts-radar-grid',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n fillOpacity: 0,\n fill: 'none',\n }))\n }\n\n // Draw axis lines from center to each vertex\n for (let i = 0; i < labelCount; i++) {\n const angle = startAngle + i * angleStep\n const x = cx + radius * Math.cos(angle)\n const y = cy + radius * Math.sin(angle)\n\n nodes.push({\n type: 'line',\n x1: cx,\n y1: cy,\n x2: x,\n y2: y,\n attrs: {\n class: 'chartts-radar-axis',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n },\n })\n\n // Label at vertex\n const labelR = radius + 14\n const lx = cx + labelR * Math.cos(angle)\n const ly = cy + labelR * Math.sin(angle)\n const anchor = Math.abs(Math.cos(angle)) < 0.01 ? 'middle' as const\n : Math.cos(angle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, String(data.labels[i]!), {\n class: 'chartts-radar-label',\n fill: theme.textMuted,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series polygons\n for (const series of data.series) {\n const pb = new PathBuilder()\n const points: { x: number; y: number }[] = []\n\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n points.push({ x, y })\n\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n pb.close()\n\n const seriesNodes: RenderNode[] = []\n\n // Fill\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-radar-area',\n fill: series.color,\n fillOpacity: 0.2,\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': series.index,\n }))\n\n // Points\n for (let i = 0; i < points.length; i++) {\n seriesNodes.push(circle(points[i]!.x, points[i]!.y, theme.pointRadius, {\n class: 'chartts-radar-point',\n fill: series.color,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} ${data.labels[i]}: ${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, area } = ctx\n const labelCount = data.labels.length\n if (labelCount < 3) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2\n\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n const hitRadius = 15\n\n for (const series of data.series) {\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const px = cx + r * Math.cos(angle)\n const py = cy + r * Math.sin(angle)\n const dist = Math.sqrt((mx - px) ** 2 + (my - py) ** 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"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { prepareNoAxes } from './chunk-3XVGEBR4.js';
|
|
2
|
+
import { text } from './chunk-3BRQGYDX.js';
|
|
3
|
+
|
|
4
|
+
// src/charts/custom/custom-type.ts
|
|
5
|
+
var customChartType = {
|
|
6
|
+
type: "custom",
|
|
7
|
+
getScaleTypes(_data, options) {
|
|
8
|
+
const cOpts = options;
|
|
9
|
+
return cOpts?.scaleTypes ?? { x: "categorical", y: "linear" };
|
|
10
|
+
},
|
|
11
|
+
prepareData(data, options) {
|
|
12
|
+
return prepareNoAxes(data, options);
|
|
13
|
+
},
|
|
14
|
+
render(ctx) {
|
|
15
|
+
const cOpts = ctx.options;
|
|
16
|
+
if (cOpts.renderFn) {
|
|
17
|
+
return cOpts.renderFn(ctx);
|
|
18
|
+
}
|
|
19
|
+
const { area, theme } = ctx;
|
|
20
|
+
return [
|
|
21
|
+
text(
|
|
22
|
+
area.x + area.width / 2,
|
|
23
|
+
area.y + area.height / 2,
|
|
24
|
+
"Custom chart \u2014 provide renderFn in options",
|
|
25
|
+
{
|
|
26
|
+
class: "chartts-custom-placeholder",
|
|
27
|
+
fill: theme.textMuted,
|
|
28
|
+
textAnchor: "middle",
|
|
29
|
+
dominantBaseline: "central",
|
|
30
|
+
fontSize: theme.fontSize,
|
|
31
|
+
fontFamily: theme.fontFamily
|
|
32
|
+
}
|
|
33
|
+
)
|
|
34
|
+
];
|
|
35
|
+
},
|
|
36
|
+
hitTest(ctx, mx, my) {
|
|
37
|
+
const cOpts = ctx.options;
|
|
38
|
+
if (cOpts.hitTestFn) {
|
|
39
|
+
return cOpts.hitTestFn(ctx, mx, my);
|
|
40
|
+
}
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export { customChartType };
|
|
46
|
+
//# sourceMappingURL=chunk-D2SV6YT3.js.map
|
|
47
|
+
//# sourceMappingURL=chunk-D2SV6YT3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/custom/custom-type.ts"],"names":[],"mappings":";;;;AAwBO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,CAAc,OAAmB,OAAA,EAA2D;AAC1F,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,OAAO,OAAO,UAAA,IAAc,EAAE,CAAA,EAAG,aAAA,EAAe,GAAG,QAAA,EAAS;AAAA,EAC9D,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,QAAQ,GAAA,CAAI,OAAA;AAElB,IAAA,IAAI,MAAM,QAAA,EAAU;AAClB,MAAA,OAAO,KAAA,CAAM,SAAS,GAAG,CAAA;AAAA,IAC3B;AAGA,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,GAAA;AACxB,IAAA,OAAO;AAAA,MACL,IAAA;AAAA,QACE,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,QACtB,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS,CAAA;AAAA,QACvB,iDAAA;AAAA,QACA;AAAA,UACE,KAAA,EAAO,4BAAA;AAAA,UACP,MAAM,KAAA,CAAM,SAAA;AAAA,UACZ,UAAA,EAAY,QAAA;AAAA,UACZ,gBAAA,EAAkB,SAAA;AAAA,UAClB,UAAU,KAAA,CAAM,QAAA;AAAA,UAChB,YAAY,KAAA,CAAM;AAAA;AACpB;AACF,KACF;AAAA,EACF,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,QAAQ,GAAA,CAAI,OAAA;AAClB,IAAA,IAAI,MAAM,SAAA,EAAW;AACnB,MAAA,OAAO,KAAA,CAAM,SAAA,CAAU,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,IACpC;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-D2SV6YT3.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { text } from '../../render/tree'\n\n/**\n * Custom chart — meta chart type that delegates rendering to a user function.\n *\n * Options:\n * - renderFn: (ctx: RenderContext) => RenderNode[]\n * - hitTestFn: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n * - scaleTypes: { x: ScaleType; y: ScaleType } (default categorical/linear)\n *\n * If no renderFn is provided, renders a placeholder message.\n */\n\nexport interface CustomChartOptions {\n renderFn?: (ctx: RenderContext) => RenderNode[]\n hitTestFn?: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n scaleTypes?: { x: ScaleType; y: ScaleType }\n}\n\nexport const customChartType: ChartTypePlugin = {\n type: 'custom',\n\n getScaleTypes(_data?: ChartData, options?: ResolvedOptions): { x: ScaleType; y: ScaleType } {\n const cOpts = options as unknown as CustomChartOptions | undefined\n return cOpts?.scaleTypes ?? { 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 cOpts = ctx.options as unknown as CustomChartOptions\n\n if (cOpts.renderFn) {\n return cOpts.renderFn(ctx)\n }\n\n // Placeholder when no render function is provided\n const { area, theme } = ctx\n return [\n text(\n area.x + area.width / 2,\n area.y + area.height / 2,\n 'Custom chart — provide renderFn in options',\n {\n class: 'chartts-custom-placeholder',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSize,\n fontFamily: theme.fontFamily,\n },\n ),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const cOpts = ctx.options as unknown as CustomChartOptions\n if (cOpts.hitTestFn) {\n return cOpts.hitTestFn(ctx, mx, my)\n }\n return null\n },\n}\n"]}
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/tree/tree-type.ts
|
|
7
|
+
var treeChartType = {
|
|
8
|
+
type: "tree",
|
|
9
|
+
getScaleTypes() {
|
|
10
|
+
return { x: "categorical", y: "linear" };
|
|
11
|
+
},
|
|
12
|
+
prepareData(data, options) {
|
|
13
|
+
return chunk5QOQR5FE_cjs.prepareNoAxes(data, options);
|
|
14
|
+
},
|
|
15
|
+
render(ctx) {
|
|
16
|
+
const { data, area, theme, options } = ctx;
|
|
17
|
+
const nodes = [];
|
|
18
|
+
const series = data.series[0];
|
|
19
|
+
if (!series || series.values.length === 0) return nodes;
|
|
20
|
+
const treeOpts = options;
|
|
21
|
+
const layout = treeOpts.treeLayout ?? "top-down";
|
|
22
|
+
const nodeRadius = treeOpts.nodeRadius ?? 6;
|
|
23
|
+
const showLabels = treeOpts.showLabels ?? true;
|
|
24
|
+
const root = buildTree(data.labels, series.values);
|
|
25
|
+
if (!root) return nodes;
|
|
26
|
+
computeLeafCounts(root);
|
|
27
|
+
const maxDepth = getMaxDepth(root);
|
|
28
|
+
const isHorizontal = layout === "left-right";
|
|
29
|
+
if (isHorizontal) {
|
|
30
|
+
const levelWidth = area.width / Math.max(maxDepth + 1, 1);
|
|
31
|
+
layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth);
|
|
32
|
+
} else {
|
|
33
|
+
const levelHeight = area.height / Math.max(maxDepth + 1, 1);
|
|
34
|
+
layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight);
|
|
35
|
+
}
|
|
36
|
+
const edgeNodes = [];
|
|
37
|
+
renderEdges(root, edgeNodes, theme, isHorizontal);
|
|
38
|
+
nodes.push(...edgeNodes);
|
|
39
|
+
let nodeIdx = 0;
|
|
40
|
+
const renderTreeNode = (node) => {
|
|
41
|
+
const color = options.colors[node.depth % options.colors.length];
|
|
42
|
+
const nodeGroup = [];
|
|
43
|
+
nodeGroup.push(chunkXHQWWR5M_cjs.circle(node.x, node.y, nodeRadius, {
|
|
44
|
+
class: "chartts-tree-node",
|
|
45
|
+
fill: color,
|
|
46
|
+
stroke: theme.background === "transparent" ? "#fff" : theme.background,
|
|
47
|
+
strokeWidth: 1.5,
|
|
48
|
+
"data-series": 0,
|
|
49
|
+
"data-index": nodeIdx,
|
|
50
|
+
tabindex: 0,
|
|
51
|
+
role: "img",
|
|
52
|
+
ariaLabel: `${node.name}: ${node.value}`
|
|
53
|
+
}));
|
|
54
|
+
if (showLabels) {
|
|
55
|
+
const fontSize = theme.fontSizeSmall;
|
|
56
|
+
let labelX, labelY;
|
|
57
|
+
let anchor;
|
|
58
|
+
if (isHorizontal) {
|
|
59
|
+
labelX = node.x;
|
|
60
|
+
labelY = node.y - nodeRadius - 4;
|
|
61
|
+
anchor = "middle";
|
|
62
|
+
} else {
|
|
63
|
+
labelX = node.x + nodeRadius + 4;
|
|
64
|
+
labelY = node.y;
|
|
65
|
+
anchor = "start";
|
|
66
|
+
if (node.depth === 0) {
|
|
67
|
+
labelX = node.x;
|
|
68
|
+
labelY = node.y - nodeRadius - 4;
|
|
69
|
+
anchor = "middle";
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
nodeGroup.push(chunkXHQWWR5M_cjs.text(labelX, labelY, node.name, {
|
|
73
|
+
class: "chartts-tree-label",
|
|
74
|
+
fill: theme.textColor,
|
|
75
|
+
textAnchor: anchor,
|
|
76
|
+
dominantBaseline: "central",
|
|
77
|
+
fontSize,
|
|
78
|
+
fontFamily: theme.fontFamily
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
nodes.push(chunkXHQWWR5M_cjs.group(nodeGroup, {
|
|
82
|
+
class: `chartts-series chartts-series-${nodeIdx}`,
|
|
83
|
+
"data-series-name": node.name
|
|
84
|
+
}));
|
|
85
|
+
nodeIdx++;
|
|
86
|
+
for (const child of node.children) {
|
|
87
|
+
renderTreeNode(child);
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
renderTreeNode(root);
|
|
91
|
+
return nodes;
|
|
92
|
+
},
|
|
93
|
+
hitTest(ctx, mx, my) {
|
|
94
|
+
const { data, area, options } = ctx;
|
|
95
|
+
const series = data.series[0];
|
|
96
|
+
if (!series || series.values.length === 0) return null;
|
|
97
|
+
const treeOpts = options;
|
|
98
|
+
const layout = treeOpts.treeLayout ?? "top-down";
|
|
99
|
+
const nodeRadius = treeOpts.nodeRadius ?? 6;
|
|
100
|
+
const hitRadius = nodeRadius + 5;
|
|
101
|
+
const root = buildTree(data.labels, series.values);
|
|
102
|
+
if (!root) return null;
|
|
103
|
+
computeLeafCounts(root);
|
|
104
|
+
const maxDepth = getMaxDepth(root);
|
|
105
|
+
const isHorizontal = layout === "left-right";
|
|
106
|
+
if (isHorizontal) {
|
|
107
|
+
const levelWidth = area.width / Math.max(maxDepth + 1, 1);
|
|
108
|
+
layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth);
|
|
109
|
+
} else {
|
|
110
|
+
const levelHeight = area.height / Math.max(maxDepth + 1, 1);
|
|
111
|
+
layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight);
|
|
112
|
+
}
|
|
113
|
+
let best = null;
|
|
114
|
+
let bestDist = Infinity;
|
|
115
|
+
let idx = 0;
|
|
116
|
+
const checkNode = (node) => {
|
|
117
|
+
const dist = Math.sqrt((mx - node.x) ** 2 + (my - node.y) ** 2);
|
|
118
|
+
if (dist < bestDist && dist < hitRadius) {
|
|
119
|
+
bestDist = dist;
|
|
120
|
+
best = { seriesIndex: 0, pointIndex: idx, distance: dist };
|
|
121
|
+
}
|
|
122
|
+
idx++;
|
|
123
|
+
for (const child of node.children) {
|
|
124
|
+
checkNode(child);
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
checkNode(root);
|
|
128
|
+
return best;
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
function buildTree(labels, values) {
|
|
132
|
+
const root = {
|
|
133
|
+
name: "Root",
|
|
134
|
+
value: 0,
|
|
135
|
+
children: [],
|
|
136
|
+
depth: 0,
|
|
137
|
+
index: 0,
|
|
138
|
+
x: 0,
|
|
139
|
+
y: 0,
|
|
140
|
+
leafCount: 0
|
|
141
|
+
};
|
|
142
|
+
const hasHierarchy = labels.some((l) => String(l).includes("/"));
|
|
143
|
+
if (hasHierarchy) {
|
|
144
|
+
for (let i = 0; i < labels.length; i++) {
|
|
145
|
+
const parts = String(labels[i] ?? "").split("/");
|
|
146
|
+
const value = Math.abs(values[i] ?? 1);
|
|
147
|
+
let current = root;
|
|
148
|
+
for (let p = 0; p < parts.length; p++) {
|
|
149
|
+
const part = parts[p].trim();
|
|
150
|
+
if (!part) continue;
|
|
151
|
+
let child = current.children.find((c) => c.name === part);
|
|
152
|
+
if (!child) {
|
|
153
|
+
child = {
|
|
154
|
+
name: part,
|
|
155
|
+
value: 0,
|
|
156
|
+
children: [],
|
|
157
|
+
depth: current.depth + 1,
|
|
158
|
+
index: i,
|
|
159
|
+
x: 0,
|
|
160
|
+
y: 0,
|
|
161
|
+
leafCount: 0
|
|
162
|
+
};
|
|
163
|
+
current.children.push(child);
|
|
164
|
+
}
|
|
165
|
+
if (p === parts.length - 1) {
|
|
166
|
+
child.value = value;
|
|
167
|
+
}
|
|
168
|
+
current = child;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
} else {
|
|
172
|
+
root.name = String(labels[0] ?? "Root");
|
|
173
|
+
root.value = Math.abs(values[0] ?? 1);
|
|
174
|
+
for (let i = 1; i < labels.length; i++) {
|
|
175
|
+
root.children.push({
|
|
176
|
+
name: String(labels[i] ?? `Node ${i}`),
|
|
177
|
+
value: Math.abs(values[i] ?? 1),
|
|
178
|
+
children: [],
|
|
179
|
+
depth: 1,
|
|
180
|
+
index: i,
|
|
181
|
+
x: 0,
|
|
182
|
+
y: 0,
|
|
183
|
+
leafCount: 0
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
if (root.children.length === 0 && labels.length > 0) {
|
|
188
|
+
root.name = String(labels[0] ?? "Root");
|
|
189
|
+
root.value = Math.abs(values[0] ?? 1);
|
|
190
|
+
}
|
|
191
|
+
return root;
|
|
192
|
+
}
|
|
193
|
+
function computeLeafCounts(node) {
|
|
194
|
+
if (node.children.length === 0) {
|
|
195
|
+
node.leafCount = 1;
|
|
196
|
+
return 1;
|
|
197
|
+
}
|
|
198
|
+
let count = 0;
|
|
199
|
+
for (const child of node.children) {
|
|
200
|
+
count += computeLeafCounts(child);
|
|
201
|
+
}
|
|
202
|
+
node.leafCount = count;
|
|
203
|
+
return count;
|
|
204
|
+
}
|
|
205
|
+
function getMaxDepth(node) {
|
|
206
|
+
if (node.children.length === 0) return node.depth;
|
|
207
|
+
let max = node.depth;
|
|
208
|
+
for (const child of node.children) {
|
|
209
|
+
max = Math.max(max, getMaxDepth(child));
|
|
210
|
+
}
|
|
211
|
+
return max;
|
|
212
|
+
}
|
|
213
|
+
function layoutVertical(node, topY, leftX, rightX, levelHeight) {
|
|
214
|
+
node.y = topY + node.depth * levelHeight + levelHeight / 2;
|
|
215
|
+
const totalLeaves = node.leafCount || 1;
|
|
216
|
+
const slotWidth = (rightX - leftX) / totalLeaves;
|
|
217
|
+
if (node.children.length === 0) {
|
|
218
|
+
node.x = leftX + slotWidth / 2;
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
let currentX = leftX;
|
|
222
|
+
for (const child of node.children) {
|
|
223
|
+
const childWidth = child.leafCount / totalLeaves * (rightX - leftX);
|
|
224
|
+
layoutVertical(child, topY, currentX, currentX + childWidth, levelHeight);
|
|
225
|
+
currentX += childWidth;
|
|
226
|
+
}
|
|
227
|
+
const firstChild = node.children[0];
|
|
228
|
+
const lastChild = node.children[node.children.length - 1];
|
|
229
|
+
node.x = (firstChild.x + lastChild.x) / 2;
|
|
230
|
+
}
|
|
231
|
+
function layoutHorizontal(node, leftX, topY, bottomY, levelWidth) {
|
|
232
|
+
node.x = leftX + node.depth * levelWidth + levelWidth / 2;
|
|
233
|
+
const totalLeaves = node.leafCount || 1;
|
|
234
|
+
const slotHeight = (bottomY - topY) / totalLeaves;
|
|
235
|
+
if (node.children.length === 0) {
|
|
236
|
+
node.y = topY + slotHeight / 2;
|
|
237
|
+
return;
|
|
238
|
+
}
|
|
239
|
+
let currentY = topY;
|
|
240
|
+
for (const child of node.children) {
|
|
241
|
+
const childHeight = child.leafCount / totalLeaves * (bottomY - topY);
|
|
242
|
+
layoutHorizontal(child, leftX, currentY, currentY + childHeight, levelWidth);
|
|
243
|
+
currentY += childHeight;
|
|
244
|
+
}
|
|
245
|
+
const firstChild = node.children[0];
|
|
246
|
+
const lastChild = node.children[node.children.length - 1];
|
|
247
|
+
node.y = (firstChild.y + lastChild.y) / 2;
|
|
248
|
+
}
|
|
249
|
+
function renderEdges(node, nodes, theme, isHorizontal) {
|
|
250
|
+
for (const child of node.children) {
|
|
251
|
+
const pb = new chunkXHQWWR5M_cjs.PathBuilder();
|
|
252
|
+
if (isHorizontal) {
|
|
253
|
+
const midX = (node.x + child.x) / 2;
|
|
254
|
+
pb.moveTo(node.x, node.y);
|
|
255
|
+
pb.curveTo(midX, node.y, midX, child.y, child.x, child.y);
|
|
256
|
+
} else {
|
|
257
|
+
const midY = (node.y + child.y) / 2;
|
|
258
|
+
pb.moveTo(node.x, node.y);
|
|
259
|
+
pb.curveTo(node.x, midY, child.x, midY, child.x, child.y);
|
|
260
|
+
}
|
|
261
|
+
nodes.push(chunkXHQWWR5M_cjs.path(pb.build(), {
|
|
262
|
+
class: "chartts-tree-edge",
|
|
263
|
+
stroke: theme.gridColor,
|
|
264
|
+
strokeWidth: 1.5,
|
|
265
|
+
fill: "none"
|
|
266
|
+
}));
|
|
267
|
+
renderEdges(child, nodes, theme, isHorizontal);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
exports.treeChartType = treeChartType;
|
|
272
|
+
//# sourceMappingURL=chunk-DL7P72FA.cjs.map
|
|
273
|
+
//# sourceMappingURL=chunk-DL7P72FA.cjs.map
|