@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,336 @@
|
|
|
1
|
+
// src/finance/moving-averages.ts
|
|
2
|
+
function sma(values, period) {
|
|
3
|
+
const n = values.length;
|
|
4
|
+
const out = new Array(n);
|
|
5
|
+
if (period < 1 || period > n) {
|
|
6
|
+
out.fill(NaN);
|
|
7
|
+
return out;
|
|
8
|
+
}
|
|
9
|
+
let sum = 0;
|
|
10
|
+
for (let i = 0; i < n; i++) {
|
|
11
|
+
sum += values[i];
|
|
12
|
+
if (i < period - 1) {
|
|
13
|
+
out[i] = NaN;
|
|
14
|
+
} else {
|
|
15
|
+
if (i >= period) sum -= values[i - period];
|
|
16
|
+
out[i] = sum / period;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return out;
|
|
20
|
+
}
|
|
21
|
+
function ema(values, period) {
|
|
22
|
+
const n = values.length;
|
|
23
|
+
const out = new Array(n);
|
|
24
|
+
if (period < 1 || period > n) {
|
|
25
|
+
out.fill(NaN);
|
|
26
|
+
return out;
|
|
27
|
+
}
|
|
28
|
+
const k = 2 / (period + 1);
|
|
29
|
+
let sum = 0;
|
|
30
|
+
for (let i = 0; i < period; i++) {
|
|
31
|
+
sum += values[i];
|
|
32
|
+
out[i] = i < period - 1 ? NaN : sum / period;
|
|
33
|
+
}
|
|
34
|
+
let prev = out[period - 1];
|
|
35
|
+
for (let i = period; i < n; i++) {
|
|
36
|
+
prev = values[i] * k + prev * (1 - k);
|
|
37
|
+
out[i] = prev;
|
|
38
|
+
}
|
|
39
|
+
return out;
|
|
40
|
+
}
|
|
41
|
+
function wma(values, period) {
|
|
42
|
+
const n = values.length;
|
|
43
|
+
const out = new Array(n);
|
|
44
|
+
if (period < 1 || period > n) {
|
|
45
|
+
out.fill(NaN);
|
|
46
|
+
return out;
|
|
47
|
+
}
|
|
48
|
+
const denom = period * (period + 1) / 2;
|
|
49
|
+
for (let i = 0; i < period - 1; i++) out[i] = NaN;
|
|
50
|
+
for (let i = period - 1; i < n; i++) {
|
|
51
|
+
let wSum = 0;
|
|
52
|
+
for (let j = 0; j < period; j++) {
|
|
53
|
+
wSum += values[i - period + 1 + j] * (j + 1);
|
|
54
|
+
}
|
|
55
|
+
out[i] = wSum / denom;
|
|
56
|
+
}
|
|
57
|
+
return out;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// src/finance/oscillators.ts
|
|
61
|
+
function rsi(values, period = 14) {
|
|
62
|
+
const n = values.length;
|
|
63
|
+
const out = new Array(n).fill(NaN);
|
|
64
|
+
if (period < 1 || n < period + 1) return out;
|
|
65
|
+
let gainSum = 0;
|
|
66
|
+
let lossSum = 0;
|
|
67
|
+
for (let i = 1; i <= period; i++) {
|
|
68
|
+
const delta = values[i] - values[i - 1];
|
|
69
|
+
if (delta > 0) gainSum += delta;
|
|
70
|
+
else lossSum -= delta;
|
|
71
|
+
}
|
|
72
|
+
let avgGain = gainSum / period;
|
|
73
|
+
let avgLoss = lossSum / period;
|
|
74
|
+
out[period] = avgLoss === 0 ? 100 : 100 - 100 / (1 + avgGain / avgLoss);
|
|
75
|
+
for (let i = period + 1; i < n; i++) {
|
|
76
|
+
const delta = values[i] - values[i - 1];
|
|
77
|
+
const gain = delta > 0 ? delta : 0;
|
|
78
|
+
const loss = delta < 0 ? -delta : 0;
|
|
79
|
+
avgGain = (avgGain * (period - 1) + gain) / period;
|
|
80
|
+
avgLoss = (avgLoss * (period - 1) + loss) / period;
|
|
81
|
+
out[i] = avgLoss === 0 ? 100 : 100 - 100 / (1 + avgGain / avgLoss);
|
|
82
|
+
}
|
|
83
|
+
return out;
|
|
84
|
+
}
|
|
85
|
+
function stochastic(high, low, close, kPeriod = 14, dPeriod = 3) {
|
|
86
|
+
const n = close.length;
|
|
87
|
+
const k = new Array(n).fill(NaN);
|
|
88
|
+
const d = new Array(n).fill(NaN);
|
|
89
|
+
for (let i = kPeriod - 1; i < n; i++) {
|
|
90
|
+
let hh = -Infinity;
|
|
91
|
+
let ll = Infinity;
|
|
92
|
+
for (let j = i - kPeriod + 1; j <= i; j++) {
|
|
93
|
+
if (high[j] > hh) hh = high[j];
|
|
94
|
+
if (low[j] < ll) ll = low[j];
|
|
95
|
+
}
|
|
96
|
+
const range = hh - ll;
|
|
97
|
+
k[i] = range === 0 ? 50 : 100 * (close[i] - ll) / range;
|
|
98
|
+
}
|
|
99
|
+
const firstK = kPeriod - 1;
|
|
100
|
+
for (let i = firstK + dPeriod - 1; i < n; i++) {
|
|
101
|
+
let sum = 0;
|
|
102
|
+
for (let j = i - dPeriod + 1; j <= i; j++) sum += k[j];
|
|
103
|
+
d[i] = sum / dPeriod;
|
|
104
|
+
}
|
|
105
|
+
return { k, d };
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// src/finance/macd.ts
|
|
109
|
+
function macd(values, fastPeriod = 12, slowPeriod = 26, signalPeriod = 9) {
|
|
110
|
+
const n = values.length;
|
|
111
|
+
const fastEma = ema(values, fastPeriod);
|
|
112
|
+
const slowEma = ema(values, slowPeriod);
|
|
113
|
+
const macdLine = new Array(n);
|
|
114
|
+
for (let i = 0; i < n; i++) {
|
|
115
|
+
macdLine[i] = isNaN(fastEma[i]) || isNaN(slowEma[i]) ? NaN : fastEma[i] - slowEma[i];
|
|
116
|
+
}
|
|
117
|
+
let firstValid = -1;
|
|
118
|
+
for (let i = 0; i < n; i++) {
|
|
119
|
+
if (!isNaN(macdLine[i])) {
|
|
120
|
+
firstValid = i;
|
|
121
|
+
break;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
const signalLine = new Array(n).fill(NaN);
|
|
125
|
+
const histogram = new Array(n).fill(NaN);
|
|
126
|
+
if (firstValid >= 0) {
|
|
127
|
+
const validSlice = macdLine.slice(firstValid);
|
|
128
|
+
const signalEma = ema(validSlice, signalPeriod);
|
|
129
|
+
for (let i = 0; i < validSlice.length; i++) {
|
|
130
|
+
signalLine[firstValid + i] = signalEma[i];
|
|
131
|
+
if (!isNaN(macdLine[firstValid + i]) && !isNaN(signalEma[i])) {
|
|
132
|
+
histogram[firstValid + i] = macdLine[firstValid + i] - signalEma[i];
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
return { macd: macdLine, signal: signalLine, histogram };
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// src/finance/bollinger.ts
|
|
140
|
+
function bollingerBands(values, period = 20, k = 2) {
|
|
141
|
+
const n = values.length;
|
|
142
|
+
const middle = sma(values, period);
|
|
143
|
+
const upper = new Array(n);
|
|
144
|
+
const lower = new Array(n);
|
|
145
|
+
for (let i = 0; i < n; i++) {
|
|
146
|
+
if (isNaN(middle[i])) {
|
|
147
|
+
upper[i] = NaN;
|
|
148
|
+
lower[i] = NaN;
|
|
149
|
+
continue;
|
|
150
|
+
}
|
|
151
|
+
let sumSq = 0;
|
|
152
|
+
const mean = middle[i];
|
|
153
|
+
for (let j = i - period + 1; j <= i; j++) {
|
|
154
|
+
const diff = values[j] - mean;
|
|
155
|
+
sumSq += diff * diff;
|
|
156
|
+
}
|
|
157
|
+
const std = Math.sqrt(sumSq / period);
|
|
158
|
+
upper[i] = mean + k * std;
|
|
159
|
+
lower[i] = mean - k * std;
|
|
160
|
+
}
|
|
161
|
+
return { upper, middle, lower };
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// src/finance/volatility.ts
|
|
165
|
+
function atr(high, low, close, period = 14) {
|
|
166
|
+
const n = high.length;
|
|
167
|
+
const out = new Array(n).fill(NaN);
|
|
168
|
+
if (period < 1 || n < period + 1) return out;
|
|
169
|
+
const tr = new Array(n);
|
|
170
|
+
tr[0] = high[0] - low[0];
|
|
171
|
+
for (let i = 1; i < n; i++) {
|
|
172
|
+
const hl = high[i] - low[i];
|
|
173
|
+
const hpc = Math.abs(high[i] - close[i - 1]);
|
|
174
|
+
const lpc = Math.abs(low[i] - close[i - 1]);
|
|
175
|
+
tr[i] = Math.max(hl, hpc, lpc);
|
|
176
|
+
}
|
|
177
|
+
let sum = 0;
|
|
178
|
+
for (let i = 1; i <= period; i++) sum += tr[i];
|
|
179
|
+
out[period] = sum / period;
|
|
180
|
+
let prev = out[period];
|
|
181
|
+
for (let i = period + 1; i < n; i++) {
|
|
182
|
+
prev = (prev * (period - 1) + tr[i]) / period;
|
|
183
|
+
out[i] = prev;
|
|
184
|
+
}
|
|
185
|
+
return out;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
// src/finance/volume.ts
|
|
189
|
+
function vwap(price, volume) {
|
|
190
|
+
const n = price.length;
|
|
191
|
+
const out = new Array(n);
|
|
192
|
+
let cumPV = 0;
|
|
193
|
+
let cumV = 0;
|
|
194
|
+
for (let i = 0; i < n; i++) {
|
|
195
|
+
cumPV += price[i] * volume[i];
|
|
196
|
+
cumV += volume[i];
|
|
197
|
+
out[i] = cumV === 0 ? price[i] : cumPV / cumV;
|
|
198
|
+
}
|
|
199
|
+
return out;
|
|
200
|
+
}
|
|
201
|
+
function obv(close, volume) {
|
|
202
|
+
const n = close.length;
|
|
203
|
+
const out = new Array(n);
|
|
204
|
+
out[0] = 0;
|
|
205
|
+
for (let i = 1; i < n; i++) {
|
|
206
|
+
if (close[i] > close[i - 1]) out[i] = out[i - 1] + volume[i];
|
|
207
|
+
else if (close[i] < close[i - 1]) out[i] = out[i - 1] - volume[i];
|
|
208
|
+
else out[i] = out[i - 1];
|
|
209
|
+
}
|
|
210
|
+
return out;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
// src/finance/returns.ts
|
|
214
|
+
function simpleReturns(prices) {
|
|
215
|
+
const n = prices.length;
|
|
216
|
+
const out = new Array(n);
|
|
217
|
+
out[0] = NaN;
|
|
218
|
+
for (let i = 1; i < n; i++) {
|
|
219
|
+
out[i] = (prices[i] - prices[i - 1]) / prices[i - 1];
|
|
220
|
+
}
|
|
221
|
+
return out;
|
|
222
|
+
}
|
|
223
|
+
function logReturns(prices) {
|
|
224
|
+
const n = prices.length;
|
|
225
|
+
const out = new Array(n);
|
|
226
|
+
out[0] = NaN;
|
|
227
|
+
for (let i = 1; i < n; i++) {
|
|
228
|
+
out[i] = Math.log(prices[i] / prices[i - 1]);
|
|
229
|
+
}
|
|
230
|
+
return out;
|
|
231
|
+
}
|
|
232
|
+
function cumulativeReturns(prices) {
|
|
233
|
+
const n = prices.length;
|
|
234
|
+
const out = new Array(n);
|
|
235
|
+
const p0 = prices[0];
|
|
236
|
+
for (let i = 0; i < n; i++) {
|
|
237
|
+
out[i] = (prices[i] - p0) / p0;
|
|
238
|
+
}
|
|
239
|
+
return out;
|
|
240
|
+
}
|
|
241
|
+
function drawdown(prices) {
|
|
242
|
+
const n = prices.length;
|
|
243
|
+
const out = new Array(n);
|
|
244
|
+
let peak = -Infinity;
|
|
245
|
+
for (let i = 0; i < n; i++) {
|
|
246
|
+
if (prices[i] > peak) peak = prices[i];
|
|
247
|
+
out[i] = (prices[i] - peak) / peak;
|
|
248
|
+
}
|
|
249
|
+
return out;
|
|
250
|
+
}
|
|
251
|
+
function maxDrawdown(prices) {
|
|
252
|
+
const dd = drawdown(prices);
|
|
253
|
+
let min = 0;
|
|
254
|
+
for (const v of dd) if (v < min) min = v;
|
|
255
|
+
return min;
|
|
256
|
+
}
|
|
257
|
+
function sharpeRatio(returns, riskFreeRate = 0, annualizationFactor = 252) {
|
|
258
|
+
const valid = returns.filter((v) => !isNaN(v));
|
|
259
|
+
if (valid.length < 2) return NaN;
|
|
260
|
+
const excess = valid.map((r) => r - riskFreeRate / annualizationFactor);
|
|
261
|
+
const mean = excess.reduce((s, v) => s + v, 0) / excess.length;
|
|
262
|
+
const variance = excess.reduce((s, v) => s + (v - mean) ** 2, 0) / (excess.length - 1);
|
|
263
|
+
const std = Math.sqrt(variance);
|
|
264
|
+
return std === 0 ? 0 : mean / std * Math.sqrt(annualizationFactor);
|
|
265
|
+
}
|
|
266
|
+
function volatility(returns, rollingPeriod, annualizationFactor = 252) {
|
|
267
|
+
const valid = returns.filter((v) => !isNaN(v));
|
|
268
|
+
if (rollingPeriod != null) {
|
|
269
|
+
const n = returns.length;
|
|
270
|
+
const out = new Array(n).fill(NaN);
|
|
271
|
+
for (let i = rollingPeriod - 1; i < n; i++) {
|
|
272
|
+
const window = [];
|
|
273
|
+
for (let j = i - rollingPeriod + 1; j <= i; j++) {
|
|
274
|
+
if (!isNaN(returns[j])) window.push(returns[j]);
|
|
275
|
+
}
|
|
276
|
+
if (window.length < 2) continue;
|
|
277
|
+
const mean2 = window.reduce((s, v) => s + v, 0) / window.length;
|
|
278
|
+
const variance2 = window.reduce((s, v) => s + (v - mean2) ** 2, 0) / (window.length - 1);
|
|
279
|
+
out[i] = Math.sqrt(variance2) * Math.sqrt(annualizationFactor);
|
|
280
|
+
}
|
|
281
|
+
return out;
|
|
282
|
+
}
|
|
283
|
+
if (valid.length < 2) return NaN;
|
|
284
|
+
const mean = valid.reduce((s, v) => s + v, 0) / valid.length;
|
|
285
|
+
const variance = valid.reduce((s, v) => s + (v - mean) ** 2, 0) / (valid.length - 1);
|
|
286
|
+
return Math.sqrt(variance) * Math.sqrt(annualizationFactor);
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
// src/finance/builders.ts
|
|
290
|
+
function toOHLC(timestamps, prices, interval, volumes) {
|
|
291
|
+
const buckets = /* @__PURE__ */ new Map();
|
|
292
|
+
for (let i = 0; i < timestamps.length; i++) {
|
|
293
|
+
const key = Math.floor(timestamps[i] / interval) * interval;
|
|
294
|
+
const p = prices[i];
|
|
295
|
+
const v = volumes ? volumes[i] : 0;
|
|
296
|
+
const b = buckets.get(key);
|
|
297
|
+
if (b) {
|
|
298
|
+
if (p > b.high) b.high = p;
|
|
299
|
+
if (p < b.low) b.low = p;
|
|
300
|
+
b.close = p;
|
|
301
|
+
b.vol += v;
|
|
302
|
+
} else {
|
|
303
|
+
buckets.set(key, { open: p, high: p, low: p, close: p, vol: v, ts: key });
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
const sorted = [...buckets.values()].sort((a, b) => a.ts - b.ts);
|
|
307
|
+
const labels = [];
|
|
308
|
+
const open = [];
|
|
309
|
+
const high = [];
|
|
310
|
+
const low = [];
|
|
311
|
+
const close = [];
|
|
312
|
+
const volume = [];
|
|
313
|
+
for (const bar of sorted) {
|
|
314
|
+
const d = new Date(bar.ts);
|
|
315
|
+
labels.push(`${d.getMonth() + 1}/${d.getDate()}`);
|
|
316
|
+
open.push(bar.open);
|
|
317
|
+
high.push(bar.high);
|
|
318
|
+
low.push(bar.low);
|
|
319
|
+
close.push(bar.close);
|
|
320
|
+
volume.push(bar.vol);
|
|
321
|
+
}
|
|
322
|
+
return volumes ? { labels, open, high, low, close, volume } : { labels, open, high, low, close };
|
|
323
|
+
}
|
|
324
|
+
function volumeDirections(values) {
|
|
325
|
+
return values.map((v, i) => i === 0 ? "up" : v >= values[i - 1] ? "up" : "down");
|
|
326
|
+
}
|
|
327
|
+
function toBollingerData(close, period = 20, k = 2) {
|
|
328
|
+
return bollingerBands(close, period, k);
|
|
329
|
+
}
|
|
330
|
+
function toMACDData(close, fastPeriod = 12, slowPeriod = 26, signalPeriod = 9) {
|
|
331
|
+
return macd(close, fastPeriod, slowPeriod, signalPeriod);
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
export { atr, bollingerBands, cumulativeReturns, drawdown, ema, logReturns, macd, maxDrawdown, obv, rsi, sharpeRatio, simpleReturns, sma, stochastic, toBollingerData, toMACDData, toOHLC, volatility, volumeDirections, vwap, wma };
|
|
335
|
+
//# sourceMappingURL=chunk-6YKFTEX4.js.map
|
|
336
|
+
//# sourceMappingURL=chunk-6YKFTEX4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/finance/moving-averages.ts","../src/finance/oscillators.ts","../src/finance/macd.ts","../src/finance/bollinger.ts","../src/finance/volatility.ts","../src/finance/volume.ts","../src/finance/returns.ts","../src/finance/builders.ts"],"names":["mean","variance"],"mappings":"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","file":"chunk-6YKFTEX4.js","sourcesContent":["/**\n * Moving average indicators — SMA, EMA, WMA.\n * Pure functions, zero dependencies.\n */\n\n/**\n * Simple Moving Average.\n * O(n) using running sum. First (period-1) values are NaN.\n */\nexport function sma(values: number[], period: number): number[] {\n const n = values.length\n const out = new Array<number>(n)\n if (period < 1 || period > n) { out.fill(NaN); return out }\n\n let sum = 0\n for (let i = 0; i < n; i++) {\n sum += values[i]!\n if (i < period - 1) {\n out[i] = NaN\n } else {\n if (i >= period) sum -= values[i - period]!\n out[i] = sum / period\n }\n }\n return out\n}\n\n/**\n * Exponential Moving Average.\n * Seeded with SMA of first `period` values. Smoothing k = 2/(period+1).\n * First (period-1) values are NaN. O(n).\n */\nexport function ema(values: number[], period: number): number[] {\n const n = values.length\n const out = new Array<number>(n)\n if (period < 1 || period > n) { out.fill(NaN); return out }\n\n const k = 2 / (period + 1)\n\n // Seed: SMA of first `period` values\n let sum = 0\n for (let i = 0; i < period; i++) {\n sum += values[i]!\n out[i] = i < period - 1 ? NaN : sum / period\n }\n\n // EMA from period onward\n let prev = out[period - 1]!\n for (let i = period; i < n; i++) {\n prev = values[i]! * k + prev * (1 - k)\n out[i] = prev\n }\n return out\n}\n\n/**\n * Weighted Moving Average.\n * Weights increase linearly: [1, 2, ..., period].\n * First (period-1) values are NaN. O(n*period).\n */\nexport function wma(values: number[], period: number): number[] {\n const n = values.length\n const out = new Array<number>(n)\n if (period < 1 || period > n) { out.fill(NaN); return out }\n\n const denom = (period * (period + 1)) / 2\n\n for (let i = 0; i < period - 1; i++) out[i] = NaN\n\n for (let i = period - 1; i < n; i++) {\n let wSum = 0\n for (let j = 0; j < period; j++) {\n wSum += values[i - period + 1 + j]! * (j + 1)\n }\n out[i] = wSum / denom\n }\n return out\n}\n","/**\n * Oscillator indicators — RSI, Stochastic.\n * Pure functions, zero dependencies.\n */\n\nimport type { StochasticResult } from './types'\n\n/**\n * Relative Strength Index (Wilder's smoothing).\n * Returns 0-100 scaled values. First `period` values are NaN.\n * Default period: 14. O(n).\n */\nexport function rsi(values: number[], period: number = 14): number[] {\n const n = values.length\n const out = new Array<number>(n).fill(NaN)\n if (period < 1 || n < period + 1) return out\n\n // Compute deltas\n let gainSum = 0\n let lossSum = 0\n for (let i = 1; i <= period; i++) {\n const delta = values[i]! - values[i - 1]!\n if (delta > 0) gainSum += delta\n else lossSum -= delta\n }\n\n let avgGain = gainSum / period\n let avgLoss = lossSum / period\n\n out[period] = avgLoss === 0 ? 100 : 100 - 100 / (1 + avgGain / avgLoss)\n\n // Wilder's smoothing for subsequent values\n for (let i = period + 1; i < n; i++) {\n const delta = values[i]! - values[i - 1]!\n const gain = delta > 0 ? delta : 0\n const loss = delta < 0 ? -delta : 0\n avgGain = (avgGain * (period - 1) + gain) / period\n avgLoss = (avgLoss * (period - 1) + loss) / period\n out[i] = avgLoss === 0 ? 100 : 100 - 100 / (1 + avgGain / avgLoss)\n }\n return out\n}\n\n/**\n * Stochastic Oscillator.\n * %K = 100 * (close - lowestLow) / (highestHigh - lowestLow) over kPeriod.\n * %D = SMA(%K, dPeriod).\n * Default: kPeriod=14, dPeriod=3.\n */\nexport function stochastic(\n high: number[],\n low: number[],\n close: number[],\n kPeriod: number = 14,\n dPeriod: number = 3,\n): StochasticResult {\n const n = close.length\n const k = new Array<number>(n).fill(NaN)\n const d = new Array<number>(n).fill(NaN)\n\n // Compute %K\n for (let i = kPeriod - 1; i < n; i++) {\n let hh = -Infinity\n let ll = Infinity\n for (let j = i - kPeriod + 1; j <= i; j++) {\n if (high[j]! > hh) hh = high[j]!\n if (low[j]! < ll) ll = low[j]!\n }\n const range = hh - ll\n k[i] = range === 0 ? 50 : 100 * (close[i]! - ll) / range\n }\n\n // Compute %D = SMA(%K, dPeriod)\n const firstK = kPeriod - 1\n for (let i = firstK + dPeriod - 1; i < n; i++) {\n let sum = 0\n for (let j = i - dPeriod + 1; j <= i; j++) sum += k[j]!\n d[i] = sum / dPeriod\n }\n\n return { k, d }\n}\n","/**\n * MACD (Moving Average Convergence Divergence).\n * Depends on EMA from moving-averages.\n */\n\nimport { ema } from './moving-averages'\nimport type { MACDResult } from './types'\n\n/**\n * Compute MACD.\n * MACD line = EMA(fast) - EMA(slow).\n * Signal = EMA(MACD line, signalPeriod).\n * Histogram = MACD - Signal.\n * Default: fast=12, slow=26, signal=9.\n */\nexport function macd(\n values: number[],\n fastPeriod: number = 12,\n slowPeriod: number = 26,\n signalPeriod: number = 9,\n): MACDResult {\n const n = values.length\n const fastEma = ema(values, fastPeriod)\n const slowEma = ema(values, slowPeriod)\n\n // MACD line\n const macdLine = new Array<number>(n)\n for (let i = 0; i < n; i++) {\n macdLine[i] = isNaN(fastEma[i]!) || isNaN(slowEma[i]!) ? NaN : fastEma[i]! - slowEma[i]!\n }\n\n // Signal line = EMA of MACD (skip NaN warmup)\n // Find first non-NaN in macdLine\n let firstValid = -1\n for (let i = 0; i < n; i++) {\n if (!isNaN(macdLine[i]!)) { firstValid = i; break }\n }\n\n const signalLine = new Array<number>(n).fill(NaN)\n const histogram = new Array<number>(n).fill(NaN)\n\n if (firstValid >= 0) {\n const validSlice = macdLine.slice(firstValid)\n const signalEma = ema(validSlice, signalPeriod)\n for (let i = 0; i < validSlice.length; i++) {\n signalLine[firstValid + i] = signalEma[i]!\n if (!isNaN(macdLine[firstValid + i]!) && !isNaN(signalEma[i]!)) {\n histogram[firstValid + i] = macdLine[firstValid + i]! - signalEma[i]!\n }\n }\n }\n\n return { macd: macdLine, signal: signalLine, histogram }\n}\n","/**\n * Bollinger Bands.\n * Depends on SMA from moving-averages.\n */\n\nimport { sma } from './moving-averages'\nimport type { BollingerResult } from './types'\n\n/**\n * Compute Bollinger Bands.\n * Middle = SMA(period). Upper = middle + k*stddev. Lower = middle - k*stddev.\n * Default: period=20, k=2.\n * First (period-1) values are NaN.\n */\nexport function bollingerBands(\n values: number[],\n period: number = 20,\n k: number = 2,\n): BollingerResult {\n const n = values.length\n const middle = sma(values, period)\n const upper = new Array<number>(n)\n const lower = new Array<number>(n)\n\n for (let i = 0; i < n; i++) {\n if (isNaN(middle[i]!)) {\n upper[i] = NaN\n lower[i] = NaN\n continue\n }\n // Rolling standard deviation\n let sumSq = 0\n const mean = middle[i]!\n for (let j = i - period + 1; j <= i; j++) {\n const diff = values[j]! - mean\n sumSq += diff * diff\n }\n const std = Math.sqrt(sumSq / period)\n upper[i] = mean + k * std\n lower[i] = mean - k * std\n }\n\n return { upper, middle, lower }\n}\n","/**\n * Average True Range (ATR).\n * Pure function, zero dependencies.\n */\n\n/**\n * Average True Range using Wilder's smoothing.\n * True Range = max(high-low, |high-prevClose|, |low-prevClose|).\n * First `period` values are NaN. Default period: 14. O(n).\n */\nexport function atr(\n high: number[],\n low: number[],\n close: number[],\n period: number = 14,\n): number[] {\n const n = high.length\n const out = new Array<number>(n).fill(NaN)\n if (period < 1 || n < period + 1) return out\n\n // True Range array\n const tr = new Array<number>(n)\n tr[0] = high[0]! - low[0]!\n for (let i = 1; i < n; i++) {\n const hl = high[i]! - low[i]!\n const hpc = Math.abs(high[i]! - close[i - 1]!)\n const lpc = Math.abs(low[i]! - close[i - 1]!)\n tr[i] = Math.max(hl, hpc, lpc)\n }\n\n // First ATR = simple average of first `period` TRs (starting from index 1)\n let sum = 0\n for (let i = 1; i <= period; i++) sum += tr[i]!\n out[period] = sum / period\n\n // Wilder's smoothing\n let prev = out[period]!\n for (let i = period + 1; i < n; i++) {\n prev = (prev * (period - 1) + tr[i]!) / period\n out[i] = prev\n }\n return out\n}\n","/**\n * Volume-based indicators — VWAP, OBV.\n * Pure functions, zero dependencies.\n */\n\n/**\n * Volume Weighted Average Price.\n * VWAP[i] = cumulative(price*volume) / cumulative(volume).\n * Full length output (no NaN padding). O(n).\n */\nexport function vwap(price: number[], volume: number[]): number[] {\n const n = price.length\n const out = new Array<number>(n)\n let cumPV = 0\n let cumV = 0\n for (let i = 0; i < n; i++) {\n cumPV += price[i]! * volume[i]!\n cumV += volume[i]!\n out[i] = cumV === 0 ? price[i]! : cumPV / cumV\n }\n return out\n}\n\n/**\n * On-Balance Volume.\n * Starts at 0. If close > prevClose, add volume. If close < prevClose, subtract.\n * Full length output. O(n).\n */\nexport function obv(close: number[], volume: number[]): number[] {\n const n = close.length\n const out = new Array<number>(n)\n out[0] = 0\n for (let i = 1; i < n; i++) {\n if (close[i]! > close[i - 1]!) out[i] = out[i - 1]! + volume[i]!\n else if (close[i]! < close[i - 1]!) out[i] = out[i - 1]! - volume[i]!\n else out[i] = out[i - 1]!\n }\n return out\n}\n","/**\n * Portfolio & returns analytics.\n * Pure functions, zero dependencies.\n */\n\n/** Simple percentage returns. First value is NaN. */\nexport function simpleReturns(prices: number[]): number[] {\n const n = prices.length\n const out = new Array<number>(n)\n out[0] = NaN\n for (let i = 1; i < n; i++) {\n out[i] = (prices[i]! - prices[i - 1]!) / prices[i - 1]!\n }\n return out\n}\n\n/** Log returns. First value is NaN. */\nexport function logReturns(prices: number[]): number[] {\n const n = prices.length\n const out = new Array<number>(n)\n out[0] = NaN\n for (let i = 1; i < n; i++) {\n out[i] = Math.log(prices[i]! / prices[i - 1]!)\n }\n return out\n}\n\n/** Cumulative returns (growth from initial price). First value is 0. */\nexport function cumulativeReturns(prices: number[]): number[] {\n const n = prices.length\n const out = new Array<number>(n)\n const p0 = prices[0]!\n for (let i = 0; i < n; i++) {\n out[i] = (prices[i]! - p0) / p0\n }\n return out\n}\n\n/** Drawdown at each point (always <= 0). */\nexport function drawdown(prices: number[]): number[] {\n const n = prices.length\n const out = new Array<number>(n)\n let peak = -Infinity\n for (let i = 0; i < n; i++) {\n if (prices[i]! > peak) peak = prices[i]!\n out[i] = (prices[i]! - peak) / peak\n }\n return out\n}\n\n/** Maximum drawdown (single number, deepest trough). Always <= 0. */\nexport function maxDrawdown(prices: number[]): number {\n const dd = drawdown(prices)\n let min = 0\n for (const v of dd) if (v < min) min = v\n return min\n}\n\n/**\n * Annualized Sharpe ratio.\n * sharpe = mean(excess) / std(excess) * sqrt(annualizationFactor).\n * Filters out NaN values from returns array.\n */\nexport function sharpeRatio(\n returns: number[],\n riskFreeRate: number = 0,\n annualizationFactor: number = 252,\n): number {\n const valid = returns.filter(v => !isNaN(v))\n if (valid.length < 2) return NaN\n\n const excess = valid.map(r => r - riskFreeRate / annualizationFactor)\n const mean = excess.reduce((s, v) => s + v, 0) / excess.length\n const variance = excess.reduce((s, v) => s + (v - mean) ** 2, 0) / (excess.length - 1)\n const std = Math.sqrt(variance)\n return std === 0 ? 0 : (mean / std) * Math.sqrt(annualizationFactor)\n}\n\n/**\n * Volatility (standard deviation of returns).\n * If rollingPeriod provided: returns number[] with NaN padding.\n * Otherwise returns single annualized number.\n */\nexport function volatility(\n returns: number[],\n rollingPeriod?: number,\n annualizationFactor: number = 252,\n): number | number[] {\n const valid = returns.filter(v => !isNaN(v))\n\n if (rollingPeriod != null) {\n const n = returns.length\n const out = new Array<number>(n).fill(NaN)\n for (let i = rollingPeriod - 1; i < n; i++) {\n // Collect valid values in window\n const window: number[] = []\n for (let j = i - rollingPeriod + 1; j <= i; j++) {\n if (!isNaN(returns[j]!)) window.push(returns[j]!)\n }\n if (window.length < 2) continue\n const mean = window.reduce((s, v) => s + v, 0) / window.length\n const variance = window.reduce((s, v) => s + (v - mean) ** 2, 0) / (window.length - 1)\n out[i] = Math.sqrt(variance) * Math.sqrt(annualizationFactor)\n }\n return out\n }\n\n // Overall annualized volatility\n if (valid.length < 2) return NaN\n const mean = valid.reduce((s, v) => s + v, 0) / valid.length\n const variance = valid.reduce((s, v) => s + (v - mean) ** 2, 0) / (valid.length - 1)\n return Math.sqrt(variance) * Math.sqrt(annualizationFactor)\n}\n","/**\n * Financial data builders — bridge indicator output to chart data formats.\n */\n\nimport { bollingerBands } from './bollinger'\nimport { macd } from './macd'\nimport type { BollingerResult, MACDResult, OHLCAggregation } from './types'\n\n/**\n * Aggregate tick-level data into OHLC bars.\n * @param timestamps - epoch milliseconds\n * @param prices - price at each tick\n * @param interval - bar size in milliseconds\n * @param volumes - optional volume at each tick\n */\nexport function toOHLC(\n timestamps: number[],\n prices: number[],\n interval: number,\n volumes?: number[],\n): OHLCAggregation {\n const buckets = new Map<number, { open: number; high: number; low: number; close: number; vol: number; ts: number }>()\n\n for (let i = 0; i < timestamps.length; i++) {\n const key = Math.floor(timestamps[i]! / interval) * interval\n const p = prices[i]!\n const v = volumes ? volumes[i]! : 0\n const b = buckets.get(key)\n if (b) {\n if (p > b.high) b.high = p\n if (p < b.low) b.low = p\n b.close = p\n b.vol += v\n } else {\n buckets.set(key, { open: p, high: p, low: p, close: p, vol: v, ts: key })\n }\n }\n\n const sorted = [...buckets.values()].sort((a, b) => a.ts - b.ts)\n const labels: string[] = []\n const open: number[] = []\n const high: number[] = []\n const low: number[] = []\n const close: number[] = []\n const volume: number[] = []\n\n for (const bar of sorted) {\n const d = new Date(bar.ts)\n labels.push(`${d.getMonth() + 1}/${d.getDate()}`)\n open.push(bar.open)\n high.push(bar.high)\n low.push(bar.low)\n close.push(bar.close)\n volume.push(bar.vol)\n }\n\n return volumes\n ? { labels, open, high, low, close, volume }\n : { labels, open, high, low, close }\n}\n\n/**\n * Determine volume bar directions from consecutive close prices.\n * Returns 'up'|'down' array for Volume chart's `directions` option.\n */\nexport function volumeDirections(values: number[]): ('up' | 'down')[] {\n return values.map((v, i) => i === 0 ? 'up' as const : (v >= values[i - 1]! ? 'up' as const : 'down' as const))\n}\n\n/**\n * Compute Bollinger Bands in Range chart format.\n * Output: { upper, lower, middle } — middle goes into series[0].values,\n * upper/lower into the range option.\n */\nexport function toBollingerData(\n close: number[],\n period: number = 20,\n k: number = 2,\n): BollingerResult {\n return bollingerBands(close, period, k)\n}\n\n/**\n * Compute MACD in Combo chart format.\n * series[0] = histogram (bars), series[1] = MACD line, series[2] = signal line.\n */\nexport function toMACDData(\n close: number[],\n fastPeriod: number = 12,\n slowPeriod: number = 26,\n signalPeriod: number = 9,\n): MACDResult {\n return macd(close, fastPeriod, slowPeriod, signalPeriod)\n}\n"]}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { getBandwidth } from './chunk-E6PR75X7.js';
|
|
2
|
+
import { rect, group, prepareData } from './chunk-3BRQGYDX.js';
|
|
3
|
+
|
|
4
|
+
// src/charts/waterfall/waterfall-type.ts
|
|
5
|
+
var waterfallChartType = {
|
|
6
|
+
type: "waterfall",
|
|
7
|
+
getScaleTypes() {
|
|
8
|
+
return { x: "categorical", y: "linear" };
|
|
9
|
+
},
|
|
10
|
+
prepareData(data, options) {
|
|
11
|
+
const prepared = prepareData(data, options);
|
|
12
|
+
const wOpts = options;
|
|
13
|
+
const series = data.series[0];
|
|
14
|
+
if (!series) return prepared;
|
|
15
|
+
const totals = new Set(wOpts.totals ?? [series.values.length - 1]);
|
|
16
|
+
let running = 0;
|
|
17
|
+
let yMin = 0;
|
|
18
|
+
let yMax = 0;
|
|
19
|
+
for (let i = 0; i < series.values.length; i++) {
|
|
20
|
+
if (totals.has(i)) {
|
|
21
|
+
running = series.values[i];
|
|
22
|
+
} else {
|
|
23
|
+
running += series.values[i];
|
|
24
|
+
}
|
|
25
|
+
if (running < yMin) yMin = running;
|
|
26
|
+
if (running > yMax) yMax = running;
|
|
27
|
+
}
|
|
28
|
+
prepared.bounds.yMin = Math.min(0, yMin);
|
|
29
|
+
prepared.bounds.yMax = Math.max(0, yMax);
|
|
30
|
+
return prepared;
|
|
31
|
+
},
|
|
32
|
+
render(ctx) {
|
|
33
|
+
const { data, xScale, yScale, options, theme } = ctx;
|
|
34
|
+
const nodes = [];
|
|
35
|
+
const series = data.series[0];
|
|
36
|
+
if (!series || series.values.length === 0) return nodes;
|
|
37
|
+
const wOpts = options;
|
|
38
|
+
const totals = new Set(wOpts.totals ?? [series.values.length - 1]);
|
|
39
|
+
const upColor = wOpts.upColor ?? "var(--color-emerald-500, #10b981)";
|
|
40
|
+
const downColor = wOpts.downColor ?? "var(--color-red-500, #ef4444)";
|
|
41
|
+
const totalColor = wOpts.totalColor ?? "var(--color-blue-500, #3b82f6)";
|
|
42
|
+
const showConnectors = wOpts.connectors ?? true;
|
|
43
|
+
const bw = getBandwidth(xScale);
|
|
44
|
+
const barWidth = bw * 0.6;
|
|
45
|
+
const barNodes = [];
|
|
46
|
+
const connectorNodes = [];
|
|
47
|
+
let running = 0;
|
|
48
|
+
let prevTop = yScale.map(0);
|
|
49
|
+
for (let i = 0; i < series.values.length; i++) {
|
|
50
|
+
const val = series.values[i];
|
|
51
|
+
const cx = xScale.map(i);
|
|
52
|
+
const isTotal = totals.has(i);
|
|
53
|
+
let barTop;
|
|
54
|
+
let barBottom;
|
|
55
|
+
let color;
|
|
56
|
+
if (isTotal) {
|
|
57
|
+
running = val;
|
|
58
|
+
barTop = yScale.map(Math.max(0, val));
|
|
59
|
+
barBottom = yScale.map(Math.min(0, val));
|
|
60
|
+
color = totalColor;
|
|
61
|
+
} else {
|
|
62
|
+
const from = running;
|
|
63
|
+
running += val;
|
|
64
|
+
barTop = yScale.map(Math.max(from, running));
|
|
65
|
+
barBottom = yScale.map(Math.min(from, running));
|
|
66
|
+
color = val >= 0 ? upColor : downColor;
|
|
67
|
+
}
|
|
68
|
+
const barH = Math.max(barBottom - barTop, 1);
|
|
69
|
+
barNodes.push(rect(cx - barWidth / 2, barTop, barWidth, barH, {
|
|
70
|
+
rx: 3,
|
|
71
|
+
ry: 3,
|
|
72
|
+
class: "chartts-waterfall-bar",
|
|
73
|
+
fill: color,
|
|
74
|
+
"data-series": 0,
|
|
75
|
+
"data-index": i,
|
|
76
|
+
tabindex: 0,
|
|
77
|
+
role: "img",
|
|
78
|
+
ariaLabel: `${data.labels[i] ?? i}: ${val}${isTotal ? " (total)" : ""}`
|
|
79
|
+
}));
|
|
80
|
+
if (showConnectors && i > 0 && !isTotal) {
|
|
81
|
+
connectorNodes.push({
|
|
82
|
+
type: "line",
|
|
83
|
+
x1: xScale.map(i - 1) + barWidth / 2,
|
|
84
|
+
y1: prevTop,
|
|
85
|
+
x2: cx - barWidth / 2,
|
|
86
|
+
y2: prevTop,
|
|
87
|
+
attrs: {
|
|
88
|
+
class: "chartts-waterfall-connector",
|
|
89
|
+
stroke: theme.gridColor,
|
|
90
|
+
strokeWidth: 1,
|
|
91
|
+
strokeDasharray: "3,2"
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
prevTop = barTop;
|
|
96
|
+
}
|
|
97
|
+
if (connectorNodes.length > 0) {
|
|
98
|
+
nodes.push(group(connectorNodes, { class: "chartts-waterfall-connectors" }));
|
|
99
|
+
}
|
|
100
|
+
nodes.push(group(barNodes, {
|
|
101
|
+
class: "chartts-series chartts-series-0",
|
|
102
|
+
"data-series-name": series.name
|
|
103
|
+
}));
|
|
104
|
+
return nodes;
|
|
105
|
+
},
|
|
106
|
+
hitTest(ctx, mx, _my) {
|
|
107
|
+
const { data, xScale } = ctx;
|
|
108
|
+
const series = data.series[0];
|
|
109
|
+
if (!series) return null;
|
|
110
|
+
const bw = getBandwidth(xScale);
|
|
111
|
+
const barWidth = bw * 0.6;
|
|
112
|
+
for (let i = 0; i < series.values.length; i++) {
|
|
113
|
+
const cx = xScale.map(i);
|
|
114
|
+
if (mx >= cx - barWidth / 2 - 4 && mx <= cx + barWidth / 2 + 4) {
|
|
115
|
+
return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) };
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return null;
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
export { waterfallChartType };
|
|
123
|
+
//# sourceMappingURL=chunk-7CGXK7KT.js.map
|
|
124
|
+
//# sourceMappingURL=chunk-7CGXK7KT.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/waterfall/waterfall-type.ts"],"names":[],"mappings":"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","file":"chunk-7CGXK7KT.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface WaterfallOptions {\n /** Indices that represent totals (absolute, not cumulative). Default: last index. */\n totals?: number[]\n /** Up color. Default emerald. */\n upColor?: string\n /** Down color. Default red. */\n downColor?: string\n /** Total color. Default blue. */\n totalColor?: string\n /** Show connector lines between bars. Default true. */\n connectors?: boolean\n}\n\n/**\n * Waterfall chart — running totals with floating bars.\n * Each value is a delta from the previous running total.\n * Positive = up (green), negative = down (red), totals = absolute (blue).\n */\nexport const waterfallChartType: ChartTypePlugin = {\n type: 'waterfall',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n\n const wOpts = options as unknown as WaterfallOptions\n const series = data.series[0]\n if (!series) return prepared\n\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n\n // Compute running totals to find proper y bounds\n let running = 0\n let yMin = 0\n let yMax = 0\n for (let i = 0; i < series.values.length; i++) {\n if (totals.has(i)) {\n running = series.values[i]!\n } else {\n running += series.values[i]!\n }\n if (running < yMin) yMin = running\n if (running > yMax) yMax = running\n }\n\n // Include 0 in range\n prepared.bounds.yMin = Math.min(0, yMin)\n prepared.bounds.yMax = Math.max(0, yMax)\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const wOpts = options as unknown as WaterfallOptions\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n const upColor = wOpts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = wOpts.downColor ?? 'var(--color-red-500, #ef4444)'\n const totalColor = wOpts.totalColor ?? 'var(--color-blue-500, #3b82f6)'\n const showConnectors = wOpts.connectors ?? true\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n const barNodes: RenderNode[] = []\n const connectorNodes: RenderNode[] = []\n\n let running = 0\n let prevTop = yScale.map(0)\n\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const cx = xScale.map(i)\n const isTotal = totals.has(i)\n\n let barTop: number\n let barBottom: number\n let color: string\n\n if (isTotal) {\n // Total bar: from 0 to the value\n running = val\n barTop = yScale.map(Math.max(0, val))\n barBottom = yScale.map(Math.min(0, val))\n color = totalColor\n } else {\n // Delta bar: from running to running + val\n const from = running\n running += val\n barTop = yScale.map(Math.max(from, running))\n barBottom = yScale.map(Math.min(from, running))\n color = val >= 0 ? upColor : downColor\n }\n\n const barH = Math.max(barBottom - barTop, 1)\n\n barNodes.push(rect(cx - barWidth / 2, barTop, barWidth, barH, {\n rx: 3, ry: 3,\n class: 'chartts-waterfall-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${val}${isTotal ? ' (total)' : ''}`,\n }))\n\n // Connector line from previous bar's end to this bar's start\n if (showConnectors && i > 0 && !isTotal) {\n connectorNodes.push({\n type: 'line',\n x1: xScale.map(i - 1) + barWidth / 2,\n y1: prevTop,\n x2: cx - barWidth / 2,\n y2: prevTop,\n attrs: {\n class: 'chartts-waterfall-connector',\n stroke: theme.gridColor,\n strokeWidth: 1,\n strokeDasharray: '3,2',\n },\n })\n }\n\n prevTop = barTop\n }\n\n if (connectorNodes.length > 0) {\n nodes.push(group(connectorNodes, { class: 'chartts-waterfall-connectors' }))\n }\n\n nodes.push(group(barNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, _my: number): HitResult | null {\n const { data, xScale } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - barWidth / 2 - 4 && mx <= cx + barWidth / 2 + 4) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) }\n }\n }\n\n return null\n },\n}\n"]}
|