const fullData = [ { x: new Date('2025-04-21'), y: 102.46 }, { x: new Date('2025-04-22'), y: 101.81 }, { x: new Date('2025-04-23'), y: 102.26 }, { x: new Date('2025-04-24'), y: 102.98 }, { x: new Date('2025-04-25'), y: 102.90 }, { x: new Date('2025-04-26'), y: 103.57 }, { x: new Date('2025-04-27'), y: 103.59 }, { x: new Date('2025-04-28'), y: 103.66 }, { x: new Date('2025-05-02'), y: 104.63 }, { x: new Date('2025-05-03'), y: 104.83 }, { x: new Date('2025-05-05'), y: 104.68 }, { x: new Date('2025-05-06'), y: 104.68 }, { x: new Date('2025-05-07'), y: 103.73 }, { x: new Date('2025-05-08'), y: 103.94 }, { x: new Date('2025-05-09'), y: 104.57 }, { x: new Date('2025-05-10'), y: 104.30 }, { x: new Date('2025-05-11'), y: 104.30 }, { x: new Date('2025-05-12'), y: 104.82 }, { x: new Date('2025-05-13'), y: 105.95 }, { x: new Date('2025-05-14'), y: 105.84 }, { x: new Date('2025-05-15'), y: 104.89 }, { x: new Date('2025-05-16'), y: 104.29 }, { x: new Date('2025-05-17'), y: 104.30 }, { x: new Date('2025-05-19'), y: 104.17 }, { x: new Date('2025-05-20'), y: 103.88 }, { x: new Date('2025-05-21'), y: 103.75 }, { x: new Date('2025-05-22'), y: 103.69 }, { x: new Date('2025-05-24'), y: 103.75 }, { x: new Date('2025-05-26'), y: 103.97 }, { x: new Date('2025-05-27'), y: 103.94 }, { x: new Date('2025-05-29'), y: 104.84 }, { x: new Date('2025-06-02'), y: 104.75 }, { x: new Date('2025-06-06'), y: 105.00 }, { x: new Date('2025-06-10'), y: 105.57 }, { x: new Date('2025-06-11'), y: 105.86 }, { x: new Date('2025-06-12'), y: 105.73 }, { x: new Date('2025-06-14'), y: 105.95 }, { x: new Date('2025-06-15'), y: 105.93 }, { x: new Date('2025-06-16'), y: 106.32 }, { x: new Date('2025-06-17'), y: 106.48 }, { x: new Date('2025-06-18'), y: 106.44 }, { x: new Date('2025-06-20'), y: 106.08 }, { x: new Date('2025-06-21'), y: 106.27 }, { x: new Date('2025-06-22'), y: 106.27 }, { x: new Date('2025-06-23'), y: 106.34 }, { x: new Date('2025-06-24'), y: 106.48 }, { x: new Date('2025-06-25'), y: 105.57 }, { x: new Date('2025-06-26'), y: 105.82 }, { x: new Date('2025-06-27'), y: 105.80 }, { x: new Date('2025-06-28'), y: 105.78 }, { x: new Date('2025-06-29'), y: 105.80 }, { x: new Date('2025-06-30'), y: 105.64 }, { x: new Date('2025-07-01'), y: 105.69 }, { x: new Date('2025-07-02'), y: 105.13 }, { x: new Date('2025-07-04'), y: 106.50 }, { x: new Date('2025-07-05'), y: 106.24 }, { x: new Date('2025-07-06'), y: 106.25 }, { x: new Date('2025-07-07'), y: 106.21 }, { x: new Date('2025-07-08'), y: 106.76 }, { x: new Date('2025-07-09'), y: 107.32 }, { x: new Date('2025-07-10'), y: 106.90 }, { x: new Date('2025-07-11'), y: 107.0073 }, { x: new Date('2025-07-12'), y: 107.57 }, { x: new Date('2025-07-13'), y: 107.5385 }, { x: new Date('2025-07-14'), y: 107.5342 }, { x: new Date('2025-07-15'), y: 107.7992 }, { x: new Date('2025-07-16'), y: 108.3725 }, { x: new Date('2025-07-17'), y: 108.1573 }, { x: new Date('2025-07-19'), y: 108.3496 }, { x: new Date('2025-07-20'), y: 108.3799 }, { x: new Date('2025-07-21'), y: 108.2566 }, { x: new Date('2025-07-22'), y: 107.7043 }, { x: new Date('2025-07-23'), y: 107.7594 }, { x: new Date('2025-07-24'), y: 107.6109 }, { x: new Date('2025-07-25'), y: 107.6991 }, { x: new Date('2025-07-26'), y: 107.8028 }, { x: new Date('2025-07-27'), y: 107.8224 }, { x: new Date('2025-07-29'), y: 108.1046 }, { x: new Date('2025-07-30'), y: 107.8948 }, { x: new Date('2025-07-31'), y: 107.9097 }, { x: new Date('2025-08-01'), y: 108.6931 }, { x: new Date('2025-08-02'), y: 107.4984 }, { x: new Date('2025-08-03'), y: 107.62 }, { x: new Date('2025-08-04'), y: 107.0032 }, { x: new Date('2025-08-05'), y: 106.8068 }, { x: new Date('2025-08-07'), y: 107.1655 }, { x: new Date('2025-08-08'), y: 107.0851 }, { x: new Date('2025-08-09'), y: 107.4235 }, { x: new Date('2025-08-10'), y: 107.4250 }, { x: new Date('2025-08-11'), y: 107.3978 }, { x: new Date('2025-08-12'), y: 107.4703 }, { x: new Date('2025-08-13'), y: 107.4236 }, { x: new Date('2025-08-14'), y: 107.0339 }, { x: new Date('2025-08-15'), y: 106.8484 }, { x: new Date('2025-08-16'), y: 106.5079 }, { x: new Date('2025-08-18'), y: 106.5983 }, { x: new Date('2025-08-19'), y: 107.0584 }, { x: new Date('2025-08-20'), y: 106.656 }, { x: new Date('2025-08-21'), y: 106.2215 }, { x: new Date('2025-08-22'), y: 106.6241 }, { x: new Date('2025-08-23'), y: 106.383 }, { x: new Date('2025-08-24'), y: 106.434 }, { x: new Date('2025-08-25'), y: 106.4536 }, { x: new Date('2025-08-26'), y: 106.6341 }, { x: new Date('2025-08-27'), y: 106.537 }, { x: new Date('2025-08-28'), y: 106.8592 }, { x: new Date('2025-08-29'), y: 106.8297 }, { x: new Date('2025-08-30'), y: 106.9959 }, { x: new Date('2025-08-31'), y: 106.9745 }, { x: new Date('2025-09-01'), y: 107.0785 }, { x: new Date('2025-09-02'), y: 106.9967 }, { x: new Date('2025-09-03'), y: 107.6941 }, { x: new Date('2025-09-04'), y: 107.4093 }, { x: new Date('2025-09-05'), y: 107.3995 }, { x: new Date('2025-09-06'), y: 106.7824 }, { x: new Date('2025-09-07'), y: 106.9033 }, { x: new Date('2025-09-08'), y: 107.1884 }, { x: new Date('2025-09-09'), y: 106.8688 }, { x: new Date('2025-09-10'), y: 106.4236 }, { x: new Date('2025-09-11'), y: 106.3471 }, { x: new Date('2025-09-12'), y: 106.4118 }, { x: new Date('2025-09-13'), y: 106.6347 }, { x: new Date('2025-09-14'), y: 106.6402 }, { x: new Date('2025-09-15'), y: 106.7142 }, { x: new Date('2025-09-16'), y: 106.8394 }, { x: new Date('2025-09-17'), y: 106.664 }, { x: new Date('2025-09-18'), y: 106.536 }, { x: new Date('2025-09-19'), y: 107.1566 }, { x: new Date('2025-09-20'), y: 107.3001 }, { x: new Date('2025-09-21'), y: 107.2781 }, { x: new Date('2025-09-22'), y: 107.3896 }, { x: new Date('2025-09-23'), y: 106.9319 }, { x: new Date('2025-09-24'), y: 106.7706 }, { x: new Date('2025-09-25'), y: 107.0417 }, { x: new Date('2025-09-26'), y: 107.3781 }, { x: new Date('2025-09-27'), y: 107.2893 }, { x: new Date('2025-09-28'), y: 107.2951 }, { x: new Date('2025-09-29'), y: 107.2246 }, { x: new Date('2025-09-30'), y: 106.7675 }, { x: new Date('2025-10-01'), y: 106.3033 }, { x: new Date('2025-10-02'), y: 105.5428 }, { x: new Date('2025-10-03'), y: 105.3808 }, { x: new Date('2025-10-04'), y: 105.6388 }, { x: new Date('2025-10-05'), y: 105.6241 }, { x: new Date('2025-10-06'), y: 106.7583 }, { x: new Date('2025-10-06'), y: 106.7583 }, { x: new Date('2025-10-07'), y: 107.681 }, { x: new Date('2025-10-08'), y: 108.547 }, { x: new Date('2025-10-09'), y: 109.3673 }, { x: new Date('2025-10-10'), y: 109.2894 }, { x: new Date('2025-10-11'), y: 108.4675 }, { x: new Date('2025-10-12'), y: 108.5401 }, { x: new Date('2025-10-13'), y: 108.6086 }, { x: new Date('2025-10-14'), y: 108.5575 }, { x: new Date('2025-10-15'), y: 108.109 }, { x: new Date('2025-10-16'), y: 107.6465 }, { x: new Date('2025-10-17'), y: 107.2284 }, { x: new Date('2025-10-18'), y: 107.2953 }, { x: new Date('2025-10-20'), y: 107.2858 }, { x: new Date('2025-10-21'), y: 107.5419 }, { x: new Date('2025-10-22'), y: 108.2337 }, { x: new Date('2025-10-23'), y: 108.504 }, { x: new Date('2025-10-24'), y: 109.0654 }, { x: new Date('2025-10-25'), y: 109.1385 }, { x: new Date('2025-10-26'), y: 109.1385 }, { x: new Date('2025-10-27'), y: 109.1518 }, { x: new Date('2025-10-28'), y: 109.3435 }, { x: new Date('2025-10-29'), y: 109.2568 }, { x: new Date('2025-10-30'), y: 109.0176 }, { x: new Date('2025-10-31'), y: 109.4245 }, { x: new Date('2025-11-01'), y: 110.01412278 }, { x: new Date('2025-11-02'), y: 110.0144 }, { x: new Date('2025-11-03'), y: 110.0064 }, { x: new Date('2025-11-04'), y: 109.7342 }, { x: new Date('2025-11-05'), y: 109.0069 }, { x: new Date('2025-11-06'), y: 109.1217 }, { x: new Date('2025-11-07'), y: 108.71268909 }, { x: new Date('2025-11-08'), y: 108.603 }, { x: new Date('2025-11-09'), y: 109.0242 }, { x: new Date('2025-11-10'), y: 109.0091 }, { x: new Date('2025-11-11'), y: 109.3593 }, { x: new Date('2025-11-12'), y: 109.91 }, { x: new Date('2025-11-13'), y: 109.948 }, { x: new Date('2025-11-14'), y: 110.4858 }, { x: new Date('2025-11-15'), y: 110.2656 }, { x: new Date('2025-11-16'), y: 110.1961 }, { x: new Date('2025-11-17'), y: 110.1961 }, { x: new Date('2025-11-18'), y: 110.2089 }, { x: new Date('2025-11-19'), y: 110.4685 }, { x: new Date('2025-11-20'), y: 111.0699 }, { x: new Date('2025-11-21'), y: 111.6784 }, { x: new Date('2025-11-22'), y: 111.7929 }, { x: new Date('2025-11-23'), y: 111.1921 }, { x: new Date('2025-11-24'), y: 111.1921 }, { x: new Date('2025-11-25'), y: 111.2061 }, { x: new Date('2025-11-26'), y: 111.2061 }, { x: new Date('2025-11-27'), y: 110.7153 }, { x: new Date('2025-11-28'), y: 111.2784 }, { x: new Date('2025-11-29'), y: 111.364 }, { x: new Date('2025-11-30'), y: 111.5966 }, { x: new Date('2025-12-01'), y: 111.6599 }, { x: new Date('2025-12-02'), y: 111.0595 }, { x: new Date('2025-12-03'), y: 111.4963 }, { x: new Date('2025-12-04'), y: 111.2828 }, { x: new Date('2025-12-05'), y: 111.0711 }, { x: new Date('2025-12-06'), y: 111.9786 }, { x: new Date('2025-12-07'), y: 111.9414 }, { x: new Date('2025-12-08'), y: 112.1658 }, { x: new Date('2025-12-09'), y: 112.5457 }, { x: new Date('2025-12-10'), y: 113.1869 }, { x: new Date('2025-12-11'), y: 113.0469 }, { x: new Date('2025-12-12'), y: 112.8673 }, { x: new Date('2025-12-13'), y: 113.1827 }, { x: new Date('2025-12-14'), y: 113.1702 }, { x: new Date('2025-12-15'), y: 113.1718 }, { x: new Date('2025-12-16'), y: 112.6957 }, { x: new Date('2025-12-17'), y: 112.5005 }, { x: new Date('2025-12-18'), y: 112.8234 }, { x: new Date('2025-12-19'), y: 112.962 }, { x: new Date('2025-12-20'), y: 114.1645 }, { x: new Date('2025-12-21'), y: 114.1396 }, { x: new Date('2025-12-22'), y: 114.2467 }, { x: new Date('2025-12-23'), y: 114.1641 }, { x: new Date('2025-12-24'), y: 114.0394 }, { x: new Date('2025-12-25'), y: 114.0267 }, { x: new Date('2025-12-26'), y: 114.0113 }, { x: new Date('2025-12-27'), y: 114.4156 }, { x: new Date('2025-12-29'), y: 114.4562 }, { x: new Date('2025-12-30'), y: 114.4857 }, { x: new Date('2025-12-31'), y: 114.075 }, { x: new Date('2026-01-01'), y: 114.1653 }, { x: new Date('2026-01-02'), y: 114.3201 }, { x: new Date('2026-01-03'), y: 114.322 }, { x: new Date('2026-01-04'), y: 114.2367 }, { x: new Date('2026-01-05'), y: 114.2631 }, { x: new Date('2026-01-06'), y: 114.1791 }, { x: new Date('2026-01-07'), y: 113.7166 }, { x: new Date('2026-01-08'), y: 113.5138 }, { x: new Date('2026-01-09'), y: 113.218 }, { x: new Date('2026-01-10'), y: 113.1382 }, { x: new Date('2026-01-11'), y: 113.5318 }, { x: new Date('2026-01-12'), y: 113.5284 }, { x: new Date('2026-01-13'), y: 113.6619 }, { x: new Date('2026-01-14'), y: 113.8663 }, { x: new Date('2026-01-15'), y: 114.5597 }, { x: new Date('2026-01-16'), y: 114.1736 }, { x: new Date('2026-01-17'), y: 114.1205 }, { x: new Date('2026-01-18'), y: 113.7124 }, { x: new Date('2026-01-19'), y: 113.7447 }, { x: new Date('2026-01-20'), y: 113.503 }, { x: new Date('2026-01-21'), y: 113.9302 }, { x: new Date('2026-01-22'), y: 114.2379 }, { x: new Date('2026-01-23'), y: 114.4159 }, { x: new Date('2026-01-24'), y: 114.8771 }, { x: new Date('2026-01-25'), y: 114.3209 }, { x: new Date('2026-01-26'), y: 114.4847 }, { x: new Date('2026-01-27'), y: 113.583 }, { x: new Date('2026-01-28'), y: 112.466 }, { x: new Date('2026-01-29'), y: 112.2241 }, { x: new Date('2026-01-30'), y: 113.011 }, { x: new Date('2026-01-31'), y: 113.3707 }, { x: new Date('2026-02-01'), y: 113.7725 }, { x: new Date('2026-02-02'), y: 113.7624 }, { x: new Date('2026-02-03'), y: 113.8274 }, { x: new Date('2026-02-04'), y: 113.6988 }, { x: new Date('2026-02-05'), y: 114.1424 }, { x: new Date('2026-02-06'), y: 114.7448 }, { x: new Date('2026-02-07'), y: 114.6015 }, { x: new Date('2026-02-08'), y: 114.9815 }, { x: new Date('2026-02-09'), y: 114.9946 }, { x: new Date('2026-02-10'), y: 115.1184 }, { x: new Date('2026-02-11'), y: 114.9707 }, { x: new Date('2026-02-12'), y: 114.0851 }, { x: new Date('2026-02-13'), y: 112.9815 }, { x: new Date('2026-02-14'), y: 112.3962 }, { x: new Date('2026-02-15'), y: 112.3031 }, { x: new Date('2026-02-16'), y: 112.3501 }, { x: new Date('2026-02-17'), y: 112.2012 }, { x: new Date('2026-02-18'), y: 112.6325 }, { x: new Date('2026-02-19'), y: 112.3383 }, { x: new Date('2026-02-20'), y: 112.904 }, { x: new Date('2026-02-21'), y: 113.2212 }, { x: new Date('2026-02-22'), y: 113.3622 }, { x: new Date('2026-02-23'), y: 113.3896 }, { x: new Date('2026-02-24'), y: 113.1758 }, { x: new Date('2026-02-25'), y: 112.9458 }, { x: new Date('2026-02-26'), y: 113.7141 }, { x: new Date('2026-02-27'), y: 114.283 }, { x: new Date('2026-02-28'), y: 114.0686 }, { x: new Date('2026-03-01'), y: 114.344 }, { x: new Date('2026-03-02'), y: 114.3407 }, { x: new Date('2026-03-03'), y: 114.3797 }, { x: new Date('2026-03-04'), y: 114.9996 }, { x: new Date('2026-03-05'), y: 115.2793 }, { x: new Date('2026-03-06'), y: 115.0669 }, { x: new Date('2026-03-07'), y: 115.2812 }, { x: new Date('2026-03-08'), y: 115.9742 }, { x: new Date('2026-03-09'), y: 115.9213 }, { x: new Date('2026-03-10'), y: 116.4212 }, { x: new Date('2026-03-11'), y: 116.5551 }, { x: new Date('2026-03-12'), y: 116.3502 }, { x: new Date('2026-03-13'), y: 116.9053 }, { x: new Date('2026-03-14'), y: 116.8495 }, { x: new Date('2026-03-15'), y: 116.4053 }, { x: new Date('2026-03-16'), y: 116.4423 }, { x: new Date('2026-03-17'), y: 116.3215 }, { x: new Date('2026-03-18'), y: 116.3045 }, { x: new Date('2026-03-19'), y: 116.0806 }, { x: new Date('2026-03-20'), y: 115.618 }, { x: new Date('2026-03-21'), y: 115.7868 }, { x: new Date('2026-03-22'), y: 115.9709 }, { x: new Date('2026-03-23'), y: 115.9423 }, { x: new Date('2026-03-24'), y: 116.1036 }, { x: new Date('2026-03-25'), y: 115.559 }, { x: new Date('2026-03-26'), y: 115.4179 }, { x: new Date('2026-03-27'), y: 115.3568 }, { x: new Date('2026-03-28'), y: 115.31 }, { x: new Date('2026-03-29'), y: 115.3606 }, { x: new Date('2026-03-30'), y: 115.3607 }, { x: new Date('2026-03-31'), y: 115.3624 }, { x: new Date('2026-04-01'), y: 114.6861 }, { x: new Date('2026-04-02'), y: 114.25935627 }, { x: new Date('2026-04-03'), y: 114.2909 }, { x: new Date('2026-04-04'), y: 114.6106 }, { x: new Date('2026-04-05'), y: 114.5147 }, { x: new Date('2026-04-06'), y: 114.5349 }, { x: new Date('2026-04-07'), y: 114.5672 }, { x: new Date('2026-04-08'), y: 114.7177 }, { x: new Date('2026-04-09'), y: 114.7107 }, { x: new Date('2026-04-10'), y: 114.423 }, { x: new Date('2026-04-11'), y: 115.0117 }, { x: new Date('2026-04-12'), y: 115.1461 }, { x: new Date('2026-04-13'), y: 115.1446 }, { x: new Date('2026-04-14'), y: 115.173 }, { x: new Date('2026-04-15'), y: 115.4941 }, { x: new Date('2026-04-16'), y: 115.4148 }, { x: new Date('2026-04-17'), y: 115.6009 }, { x: new Date('2026-04-18'), y: 116.0915 }, { x: new Date('2026-04-19'), y: 115.877 }, { x: new Date('2026-04-20'), y: 115.9016 }, { x: new Date('2026-04-21'), y: 116.099 }, { x: new Date('2026-04-22'), y: 116.2958 }, { x: new Date('2026-04-23'), y: 116.6804 }, { x: new Date('2026-04-24'), y: 116.6805 }, { x: new Date('2026-04-25'), y: 116.6126 }, { x: new Date('2026-04-26'), y: 116.6038 }, { x: new Date('2026-04-27'), y: 116.5916 }, { x: new Date('2026-04-28'), y: 116.6459 }, { x: new Date('2026-04-29'), y: 116.9723 }, { x: new Date('2026-04-30'), y: 117.0767 }]; 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('ja-JP')}円`, offsetX: -17 } }, grid: { padding: { left: -10, right: 0 } }, tooltip: { x: { formatter: val => { const date = new Date(val); return new Intl.DateTimeFormat('ja-JP', { year: 'numeric', month: 'long', day: 'numeric', weekday: 'short' }).format(date); } }, y: { formatter: val => `${val.toLocaleString('ja-JP')}円` } }, 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);