const fullData = [ { x: new Date('2025-04-04'), y: 16641.02 }, { x: new Date('2025-04-05'), y: 16726.75 }, { x: new Date('2025-04-06'), y: 16780.66 }, { x: new Date('2025-04-07'), y: 16757.56 }, { x: new Date('2025-04-08'), y: 16668.82 }, { x: new Date('2025-04-09'), y: 16957.19 }, { x: new Date('2025-04-10'), y: 16874.10 }, { x: new Date('2025-04-11'), y: 16847.80 }, { x: new Date('2025-04-12'), y: 16795.78 }, { x: new Date('2025-04-13'), y: 16801.18 }, { x: new Date('2025-04-14'), y: 16807.83 }, { x: new Date('2025-04-15'), y: 16780.85 }, { x: new Date('2025-04-16'), y: 16824.06 }, { x: new Date('2025-04-17'), y: 16805.78 }, { x: new Date('2025-04-18'), y: 16865.89 }, { x: new Date('2025-04-19'), y: 16858.44 }, { x: new Date('2025-04-20'), y: 16855.00 }, { x: new Date('2025-04-21'), y: 16856.27 }, { x: new Date('2025-04-22'), y: 16833.54 }, { x: new Date('2025-04-23'), y: 16865.94 }, { x: new Date('2025-04-24'), y: 16881.76 }, { x: new Date('2025-04-26'), y: 16850.73 }, { x: new Date('2025-04-27'), y: 16850.58 }, { x: new Date('2025-04-28'), y: 16837.12 }, { x: new Date('2025-05-02'), y: 16631.61 }, { x: new Date('2025-05-05'), y: 16476.97 }, { x: new Date('2025-05-06'), y: 16476.97 }, { x: new Date('2025-05-08'), y: 16440.65 }, { x: new Date('2025-05-09'), y: 16535.73 }, { x: new Date('2025-05-10'), y: 16555.64 }, { x: new Date('2025-05-11'), y: 16548.45 }, { x: new Date('2025-05-12'), y: 16552.04 }, { x: new Date('2025-05-13'), y: 16595.36 }, { x: new Date('2025-05-14'), y: 16556.57 }, { x: new Date('2025-05-15'), y: 16575.57 }, { x: new Date('2025-05-16'), y: 16505.70 }, { x: new Date('2025-05-17'), y: 16467.57 }, { x: new Date('2025-05-19'), y: 16479.29 }, { x: new Date('2025-05-20'), y: 16451.85 }, { x: new Date('2025-05-21'), y: 16419.94 }, { x: new Date('2025-05-22'), y: 16396.17 }, { x: new Date('2025-05-24'), y: 16229.86 }, { x: new Date('2025-05-26'), y: 16238.87 }, { x: new Date('2025-05-27'), y: 16232.40 }, { x: new Date('2025-06-04'), y: 16327.81 }, { x: new Date('2025-06-05'), y: 16298.45 }, { x: new Date('2025-06-06'), y: 16267.92 }, { x: new Date('2025-06-07'), y: 16303.44 }, { x: new Date('2025-06-08'), y: 16299.97 }, { x: new Date('2025-06-10'), y: 16284.64 }, { x: new Date('2025-06-11'), y: 16272.80 }, { x: new Date('2025-06-12'), y: 16269.33 }, { x: new Date('2025-06-13'), y: 16225.91 }, { x: new Date('2025-06-14'), y: 16322.73 }, { x: new Date('2025-06-15'), y: 16317.90 }, { x: new Date('2025-06-16'), y: 16303.51 }, { x: new Date('2025-06-17'), y: 16295.26 }, { x: new Date('2025-06-18'), y: 16290.56 }, { x: new Date('2025-06-20'), y: 16383.51 }, { x: new Date('2025-06-21'), y: 16393.15 }, { x: new Date('2025-06-22'), y: 16401.81 }, { x: new Date('2025-06-23'), y: 16411.70 }, { x: new Date('2025-06-24'), y: 16497.82 }, { x: new Date('2025-06-25'), y: 16326.42 }, { x: new Date('2025-06-26'), y: 16311.88 }, { x: new Date('2025-06-27'), y: 16217.50 }, { x: new Date('2025-06-28'), y: 16239.22 }, { x: new Date('2025-06-29'), y: 16236.09 }, { x: new Date('2025-06-30'), y: 16230.20 }, { x: new Date('2025-07-01'), y: 16214.17 }, { x: new Date('2025-07-02'), y: 16213.29 }, { x: new Date('2025-07-04'), y: 16204.39 }, { x: new Date('2025-07-05'), y: 16198.49 }, { x: new Date('2025-07-06'), y: 16196.74 }, { x: new Date('2025-07-07'), y: 16197.31 }, { x: new Date('2025-07-08'), y: 16253.61 }, { x: new Date('2025-07-09'), y: 16262.08 }, { x: new Date('2025-07-10'), y: 16263.74 }, { x: new Date('2025-07-12'), y: 16235.22 }, { x: new Date('2025-07-13'), y: 16234.84 }, { x: new Date('2025-07-14'), y: 16238.56 }, { x: new Date('2025-07-16'), y: 16277.69 }, { x: new Date('2025-07-17'), y: 16307.22 }, { x: new Date('2025-07-19'), y: 16316.69 }, { x: new Date('2025-07-20'), y: 16317.39 }, { x: new Date('2025-07-21'), y: 16295.98 }, { x: new Date('2025-07-22'), y: 16315.93 }, { x: new Date('2025-07-23'), y: 16287.94 }, { x: new Date('2025-07-24'), y: 16272.49 }, { x: new Date('2025-07-25'), y: 16283.17 }, { x: new Date('2025-07-26'), y: 16337.02 }, { x: new Date('2025-07-27'), y: 16333.41 }, { x: new Date('2025-07-29'), y: 16370.24 }, { x: new Date('2025-07-30'), y: 16394.58 }, { x: new Date('2025-07-31'), y: 16430.53 }, { x: new Date('2025-08-01'), y: 16485.89 }, { x: new Date('2025-08-02'), y: 16441.54 }, { x: new Date('2025-08-03'), y: 16455.27 }, { x: new Date('2025-08-04'), y: 16438.85 }, { x: new Date('2025-08-05'), y: 16384.80 }, { x: new Date('2025-08-06'), y: 16392.85 }, { x: new Date('2025-08-07'), y: 16359.01 }, { x: new Date('2025-08-08'), y: 16321.75 }, { x: new Date('2025-08-09'), y: 16301.93 }, { x: new Date('2025-08-10'), y: 16297.21 }, { x: new Date('2025-08-11'), y: 16279.02 }, { x: new Date('2025-08-12'), y: 16278.75 }, { x: new Date('2025-08-13'), y: 16264.78 }, { x: new Date('2025-08-14'), y: 16145.04 }, { x: new Date('2025-08-15'), y: 16136.08 }, { x: new Date('2025-08-16'), y: 16161.78 }, { x: new Date('2025-08-18'), y: 16184.77 }, { x: new Date('2025-08-19'), y: 16208.45 }, { x: new Date('2025-08-20'), y: 16272.49 }, { x: new Date('2025-08-21'), y: 16287.92 }, { x: new Date('2025-08-22'), y: 16328.25 }, { x: new Date('2025-08-23'), y: 16299.39 }, { x: new Date('2025-08-24'), y: 16295.91 }, { x: new Date('2025-08-25'), y: 16296.53 }, { x: new Date('2025-08-26'), y: 16265.13 }, { x: new Date('2025-08-27'), y: 16302.90 }, { x: new Date('2025-08-28'), y: 16394.37 }, { x: new Date('2025-08-29'), y: 16351.23 }, { x: new Date('2025-08-30'), y: 16484.66 }, { x: new Date('2025-08-31'), y: 16482.03 }, { x: new Date('2025-09-01'), y: 16467.12 }, { x: new Date('2025-09-02'), y: 16434.79 }, { x: new Date('2025-09-03'), y: 16424.06 }, { x: new Date('2025-09-04'), y: 16441.31 }, { x: new Date('2025-09-05'), y: 16450.16 }, { x: new Date('2025-09-06'), y: 16422.70 }, { x: new Date('2025-09-07'), y: 16416.56 }, { x: new Date('2025-09-08'), y: 16405.59 }, { x: new Date('2025-09-09'), y: 16398.71 }, { x: new Date('2025-09-10'), y: 16460.44 }, { x: new Date('2025-09-11'), y: 16474.31 }, { x: new Date('2025-09-12'), y: 16460.10 }, { x: new Date('2025-09-13'), y: 16380.55 }, { x: new Date('2025-09-14'), y: 16394.08 }, { x: new Date('2025-09-15'), y: 16406.51 }, { x: new Date('2025-09-16'), y: 16405.57 }, { x: new Date('2025-09-17'), y: 16411.06 }, { x: new Date('2025-09-18'), y: 16430.60 }, { x: new Date('2025-09-20'), y: 16633.48 }, { x: new Date('2025-09-21'), y: 16628.10 }, { x: new Date('2025-09-22'), y: 16642.72 }, { x: new Date('2025-09-23'), y: 16616.27 }, { x: new Date('2025-09-24'), y: 16668.28 }, { x: new Date('2025-09-25'), y: 16716.00 }, { x: new Date('2025-09-26'), y: 16777.30 }, { x: new Date('2025-09-27'), y: 16737.53 }, { x: new Date('2025-09-28'), y: 16734.79 }, { x: new Date('2025-09-29'), y: 16720.53 }, { x: new Date('2025-09-30'), y: 16644.68 }, { x: new Date('2025-10-01'), y: 16678.39 }, { x: new Date('2025-10-02'), y: 16627.56 }, { x: new Date('2025-10-03'), y: 16614.70 }, { x: new Date('2025-10-04'), y: 16580.72 }, { x: new Date('2025-10-05'), y: 16575.37 }, { x: new Date('2025-10-07'), y: 16600.58 }, { x: new Date('2025-10-08'), y: 16593.73 }, { x: new Date('2025-10-09'), y: 16597.01 }, { x: new Date('2025-10-10'), y: 16553.53 }, { x: new Date('2025-10-11'), y: 16562.74 }, { x: new Date('2025-10-12'), y: 16563.50 }, { x: new Date('2025-10-13'), y: 16588.99 }, { x: new Date('2025-10-14'), y: 16568.78 }, { x: new Date('2025-10-15'), y: 16587.44 }, { x: new Date('2025-10-16'), y: 16580.57 }, { x: new Date('2025-10-17'), y: 16574.72 }, { x: new Date('2025-10-18'), y: 16566.66 }, { x: new Date('2025-10-20'), y: 16569.79 }, { x: new Date('2025-10-21'), y: 16585.02 }, { x: new Date('2025-10-22'), y: 16582.08 }, { x: new Date('2025-10-23'), y: 16617.22 }, { x: new Date('2025-10-24'), y: 16630.66 }, { x: new Date('2025-10-25'), y: 16624.65 }, { x: new Date('2025-10-26'), y: 16624.65 }, { x: new Date('2025-10-27'), y: 16621.98 }, { x: new Date('2025-10-28'), y: 16614.20 }, { x: new Date('2025-10-29'), y: 16627.09 }, { x: new Date('2025-10-30'), y: 16611.41 }, { x: new Date('2025-10-31'), y: 16589.39 }, { x: new Date('2025-11-01'), y: 16647.27 }, { x: new Date('2025-11-02'), y: 16648.58 }, { x: new Date('2025-11-03'), y: 16639.80 }, { x: new Date('2025-11-04'), y: 16693.96 }, { x: new Date('2025-11-05'), y: 16724.67 }, { x: new Date('2025-11-06'), y: 16679.44 }, { x: new Date('2025-11-07'), y: 16695.37 }, { x: new Date('2025-11-08'), y: 16676.99 }, { x: new Date('2025-11-09'), y: 16698.85 }, { x: new Date('2025-11-10'), y: 16694.35 }, { x: new Date('2025-11-11'), y: 16689.52 }, { x: new Date('2025-11-12'), y: 16686.71 }, { x: new Date('2025-11-13'), y: 16705.57 }, { x: new Date('2025-11-14'), y: 16723.68 }, { x: new Date('2025-11-15'), y: 16716.75 }, { x: new Date('2025-11-16'), y: 16713.32 }, { x: new Date('2025-11-17'), y: 16713.32 }, { x: new Date('2025-11-18'), y: 16714.40 }, { x: new Date('2025-11-19'), y: 16735.70 }, { x: new Date('2025-11-20'), y: 16728.06 }, { x: new Date('2025-11-21'), y: 16717.89 }, { x: new Date('2025-11-22'), y: 16748.86 }, { x: new Date('2025-11-23'), y: 16724.07 }, { x: new Date('2025-11-24'), y: 16724.07 }, { x: new Date('2025-11-25'), y: 16653.69 }, { x: new Date('2025-11-26'), y: 16653.69 }, { x: new Date('2025-11-27'), y: 16626.66 }, { x: new Date('2025-11-28'), y: 16671.35 }, { x: new Date('2025-11-29'), y: 16655.27 }, { x: new Date('2025-11-30'), y: 16652.14 }, { x: new Date('2025-12-01'), y: 16651.75 }, { x: new Date('2025-12-02'), y: 16625.93 }, { x: new Date('2025-12-03'), y: 16630.22 }, { x: new Date('2025-12-04'), y: 16617.79 }, { x: new Date('2025-12-05'), y: 16645.90 }, { x: new Date('2025-12-06'), y: 16679.21 }, { x: new Date('2025-12-07'), y: 16679.20 }, { x: new Date('2025-12-08'), y: 16674.35 }, { x: new Date('2025-12-09'), y: 16689.07 }, { x: new Date('2025-12-10'), y: 16676.74 }, { x: new Date('2025-12-11'), y: 16676.30 }, { x: new Date('2025-12-12'), y: 16654.49 }, { x: new Date('2025-12-13'), y: 16635.32 }, { x: new Date('2025-12-14'), y: 16641.59 }, { x: new Date('2025-12-15'), y: 16649.97 }, { x: new Date('2025-12-16'), y: 16655.25 }, { x: new Date('2025-12-17'), y: 16688.54 }, { x: new Date('2025-12-18'), y: 16669.21 }, { x: new Date('2025-12-19'), y: 16729.20 }, { x: new Date('2025-12-20'), y: 16746.52 }, { x: new Date('2025-12-21'), y: 16739.10 }, { x: new Date('2025-12-22'), y: 16729.63 }, { x: new Date('2025-12-23'), y: 16775.29 }, { x: new Date('2025-12-24'), y: 16761.36 }, { x: new Date('2025-12-25'), y: 16739.40 }, { x: new Date('2025-12-26'), y: 16749.05 }, { x: new Date('2025-12-27'), y: 16775.79 }, { x: new Date('2025-12-29'), y: 16770.21 }, { x: new Date('2025-12-30'), y: 16774.72 }, { x: new Date('2025-12-31'), y: 16755.11 }, { x: new Date('2026-01-01'), y: 16736.46 }, { x: new Date('2026-01-02'), y: 16703.55 }, { x: new Date('2026-01-03'), y: 16695.27 }, { x: new Date('2026-01-04'), y: 16725.82 }, { x: new Date('2026-01-05'), y: 16724.08 }, { x: new Date('2026-01-06'), y: 16716.13 }, { x: new Date('2026-01-07'), y: 16752.09 }, { x: new Date('2026-01-08'), y: 16768.82 }, { x: new Date('2026-01-09'), y: 16787.94 }, { x: new Date('2026-01-10'), y: 16792.37 }, { x: new Date('2026-01-11'), y: 16816.53 }, { x: new Date('2026-01-12'), y: 16817.18 }, { x: new Date('2026-01-13'), y: 16837.25 }, { x: new Date('2026-01-14'), y: 16879.98 }, { x: new Date('2026-01-15'), y: 16879.48 }, { x: new Date('2026-01-16'), y: 16878.59 }, { x: new Date('2026-01-17'), y: 16903.76 }, { x: new Date('2026-01-18'), y: 16922.78 }, { x: new Date('2026-01-19'), y: 16918.66 }, { x: new Date('2026-01-20'), y: 16911.92 }, { x: new Date('2026-01-21'), y: 16970.62 }, { x: new Date('2026-01-22'), y: 16963.70 }, { x: new Date('2026-01-23'), y: 16920.91 }, { x: new Date('2026-01-24'), y: 16853.14 }, { x: new Date('2026-01-25'), y: 16796.11 }, { x: new Date('2026-01-26'), y: 16801.14 }, { x: new Date('2026-01-27'), y: 16806.51 }, { x: new Date('2026-01-28'), y: 16752.21 }, { x: new Date('2026-01-29'), y: 16749.62 }, { x: new Date('2026-01-30'), y: 16739.36 }, { x: new Date('2026-01-31'), y: 16755.87 }, { x: new Date('2026-02-01'), y: 16773.42 }, { x: new Date('2026-02-02'), y: 16775.92 }, { x: new Date('2026-02-03'), y: 16781.70 }, { x: new Date('2026-02-04'), y: 16806.06 }, { x: new Date('2026-02-05'), y: 16780.92 }, { x: new Date('2026-02-06'), y: 16803.92 }, { x: new Date('2026-02-07'), y: 16860.23 }, { x: new Date('2026-02-08'), y: 16857.85 }, { x: new Date('2026-02-09'), y: 16859.75 }, { x: new Date('2026-02-10'), y: 16861.33 }, { x: new Date('2026-02-11'), y: 16794.32 }, { x: new Date('2026-02-12'), y: 16769.53 }, { x: new Date('2026-02-13'), y: 16783.87 }, { x: new Date('2026-02-14'), y: 16814.48 }, { x: new Date('2026-02-15'), y: 16826.28 }, { x: new Date('2026-02-16'), y: 16826.65 }, { x: new Date('2026-02-17'), y: 16832.79 }, { x: new Date('2026-02-18'), y: 16837.79 }, { x: new Date('2026-02-19'), y: 16842.78 }, { x: new Date('2026-02-20'), y: 16895.02 }, { x: new Date('2026-02-21'), y: 16900.94 }, { x: new Date('2026-02-22'), y: 16879.29 }, { x: new Date('2026-02-23'), y: 16878.67 }, { x: new Date('2026-02-24'), y: 16871.15 }, { x: new Date('2026-02-25'), y: 16788.68 }, { x: new Date('2026-02-26'), y: 16848.06 }, { x: new Date('2026-02-27'), y: 16774.65 }, { x: new Date('2026-02-28'), y: 16750.64 }, { x: new Date('2026-03-01'), y: 16800.41 }, { x: new Date('2026-03-02'), y: 16790.17 }, { x: new Date('2026-03-03'), y: 16789.18 }, { x: new Date('2026-03-04'), y: 16871.40 }, { x: new Date('2026-03-05'), y: 16888.08 }, { x: new Date('2026-03-06'), y: 16870.90 }, { x: new Date('2026-03-07'), y: 16911.26 }, { x: new Date('2026-03-08'), y: 16939.69 }, { x: new Date('2026-03-09'), y: 16937.51 }, { x: new Date('2026-03-10'), y: 16939.42 }, { x: new Date('2026-03-11'), y: 16929.33 }, { x: new Date('2026-03-12'), y: 16880.44 }, { x: new Date('2026-03-13'), y: 16860.90 }, { x: new Date('2026-03-14'), y: 16880.27 }, { x: new Date('2026-03-15'), y: 16937.71 }, { x: new Date('2026-03-16'), y: 16934.93 }, { x: new Date('2026-03-17'), y: 16942.35 }, { x: new Date('2026-03-18'), y: 16979.65 }, { x: new Date('2026-03-19'), y: 16961.16 }, { x: new Date('2026-03-20'), y: 16982.00 }, { x: new Date('2026-03-21'), y: 16962.27 }, { x: new Date('2026-03-22'), y: 16969.17 }, { x: new Date('2026-03-23'), y: 16964.39 }, { x: new Date('2026-03-24'), y: 16972.18 }, { x: new Date('2026-03-25'), y: 16927.16 }, { x: new Date('2026-03-26'), y: 16958.99 }, { x: new Date('2026-03-27'), y: 16869.30 }, { x: new Date('2026-03-28'), y: 16909.67 }, { x: new Date('2026-03-29'), y: 16962.36 }, { x: new Date('2026-03-30'), y: 16963.01 }, { x: new Date('2026-03-31'), y: 16976.47 }, { x: new Date('2026-04-01'), y: 16998.06 }, { x: new Date('2026-04-02'), y: 16964.81 }, { x: new Date('2026-04-03'), y: 16950.47 }, { x: new Date('2026-04-04'), y: 16990.20 }, { x: new Date('2026-04-05'), y: 17003.50 }, { x: new Date('2026-04-06'), y: 17000.47 }, { x: new Date('2026-04-07'), y: 17003.11 }, { x: new Date('2026-04-08'), y: 17040.82 }, { x: new Date('2026-04-09'), y: 17073.04 }, { x: new Date('2026-04-10'), y: 17010.54 }, { x: new Date('2026-04-11'), y: 17083.38 }, { x: new Date('2026-04-12'), y: 17090.11 }, { x: new Date('2026-04-13'), y: 17090.84 }, { x: new Date('2026-04-14'), y: 17092.69 }, { x: new Date('2026-04-15'), y: 17108.86 }, { x: new Date('2026-04-16'), y: 17143.18 }, { x: new Date('2026-04-17'), y: 17159.05 }]; const options = { chart: { type: 'area', height: 300, toolbar: { show: false }, zoom: { enabled: false } }, series: [{ name: '', data: fullData }], xaxis: { type: 'datetime' }, yaxis: { tickAmount: 7, labels: { formatter: val => `${val.toLocaleString('id-ID')}`, offsetX: -17 } }, grid: { padding: { left: -10, right: 0 } }, tooltip: { x: { format: 'dd MMM yyyy' }, y: { formatter: val => `Rp ${val.toLocaleString('id-ID')}` } }, stroke: { curve: 'smooth', width: 2 }, fill: { type: 'gradient', gradient: { shadeIntensity: 1, opacityFrom: 0.8, opacityTo: 0, stops: [0, 90, 100] } }, colors: ['#007bff'], legend: { show: false }, dataLabels: { enabled: false } }; const chart = new ApexCharts(document.querySelector("#chart"), options); chart.render(); function updateChart(months) { const sortedData = [...fullData].sort((a, b) => a.x - b.x); const latestDate = sortedData[sortedData.length - 1].x; const start = new Date(latestDate); start.setMonth(start.getMonth() - months); const startTime = start.getTime(); const filtered = fullData.filter(item => item.x >= startTime && item.x <= latestDate ); chart.updateSeries([{ name: '', data: filtered }], true); chart.updateOptions({ xaxis: { type: 'datetime', min: startTime, max: latestDate } }); } document.querySelectorAll('.filter-btn').forEach(btn => { btn.addEventListener('click', () => { document.querySelectorAll('.filter-btn').forEach(b => b.classList.remove('active')); btn.classList.add('active'); const months = parseInt(btn.dataset.months); updateChart(months); }); }); updateChart(1);