const fullData = [ { x: new Date('2025-03-03'), y: 40.18 }, { x: new Date('2025-03-04'), y: 39.78 }, { x: new Date('2025-03-05'), y: 39.92 }, { x: new Date('2025-03-06'), y: 39.77 }, { x: new Date('2025-03-07'), y: 39.45 }, { x: new Date('2025-03-08'), y: 39.45 }, { x: new Date('2025-03-10'), y: 39.38 }, { x: new Date('2025-03-11'), y: 39.21 }, { x: new Date('2025-03-12'), y: 39.39 }, { x: new Date('2025-03-13'), y: 39.54 }, { x: new Date('2025-03-14'), y: 39.43 }, { x: new Date('2025-03-15'), y: 39.61 }, { x: new Date('2025-03-16'), y: 39.60 }, { x: new Date('2025-03-17'), y: 39.60 }, { x: new Date('2025-03-18'), y: 39.62 }, { x: new Date('2025-03-19'), y: 39.84 }, { x: new Date('2025-03-20'), y: 39.80 }, { x: new Date('2025-03-21'), y: 39.64 }, { x: new Date('2025-03-22'), y: 39.77 }, { x: new Date('2025-03-23'), y: 39.76 }, { x: new Date('2025-03-24'), y: 39.82 }, { x: new Date('2025-03-25'), y: 40.09 }, { x: new Date('2025-03-26'), y: 39.98 }, { x: new Date('2025-03-27'), y: 40.08 }, { x: new Date('2025-03-28'), y: 40.23 }, { x: new Date('2025-03-29'), y: 40.03 }, { x: new Date('2025-03-30'), y: 40.03 }, { x: new Date('2025-03-31'), y: 39.90 }, { x: new Date('2025-04-01'), y: 39.95 }, { x: new Date('2025-04-02'), y: 39.89 }, { x: new Date('2025-04-03'), y: 39.72 }, { x: new Date('2025-04-04'), y: 38.95 }, { x: new Date('2025-04-05'), y: 39.01 }, { x: new Date('2025-04-06'), y: 39.00 }, { x: new Date('2025-04-07'), y: 38.75 }, { x: new Date('2025-04-08'), y: 39.30 }, { x: new Date('2025-04-09'), y: 39.07 }, { x: new Date('2025-04-10'), y: 38.97 }, { x: new Date('2025-04-11'), y: 38.57 }, { x: new Date('2025-04-12'), y: 38.24 }, { x: new Date('2025-04-13'), y: 38.22 }, { x: new Date('2025-04-14'), y: 38.32 }, { x: new Date('2025-04-15'), y: 38.17 }, { x: new Date('2025-04-16'), y: 38.15 }, { x: new Date('2025-04-17'), y: 37.92 }, { x: new Date('2025-04-18'), y: 37.97 }, { x: new Date('2025-04-19'), y: 37.93 }, { x: new Date('2025-04-20'), y: 37.93 }, { x: new Date('2025-04-21'), y: 37.80 }, { x: new Date('2025-04-22'), y: 37.55 }, { x: new Date('2025-04-23'), y: 37.73 }, { x: new Date('2025-04-24'), y: 38.05 }, { x: new Date('2025-04-25'), y: 38.04 }, { x: new Date('2025-04-26'), y: 38.28 }, { x: new Date('2025-04-27'), y: 38.29 }, { x: new Date('2025-04-28'), y: 38.31 }, { x: new Date('2025-05-02'), y: 38.56 }, { x: new Date('2025-05-03'), y: 38.62 }, { x: new Date('2025-05-05'), y: 38.59 }, { x: new Date('2025-05-06'), y: 38.59 }, { x: new Date('2025-05-07'), y: 38.13 }, { x: new Date('2025-05-08'), y: 38.27 }, { x: new Date('2025-05-09'), y: 38.74 }, { x: new Date('2025-05-10'), y: 38.72 }, { x: new Date('2025-05-11'), y: 38.71 }, { x: new Date('2025-05-12'), y: 38.85 }, { x: new Date('2025-05-13'), y: 39.43 }, { x: new Date('2025-05-14'), y: 39.37 }, { x: new Date('2025-05-15'), y: 39.06 }, { x: new Date('2025-05-16'), y: 38.85 }, { x: new Date('2025-05-17'), y: 38.86 }, { x: new Date('2025-05-19'), y: 38.75 }, { x: new Date('2025-05-20'), y: 38.65 }, { x: new Date('2025-05-21'), y: 38.53 }, { x: new Date('2025-05-22'), y: 38.34 }, { x: new Date('2025-05-24'), y: 38.04 }, { x: new Date('2025-05-26'), y: 38.05 }, { x: new Date('2025-05-27'), y: 38.05 }, { x: new Date('2025-05-29'), y: 38.63 }, { x: new Date('2025-06-02'), y: 38.36 }, { x: new Date('2025-06-06'), y: 38.25 }, { x: new Date('2025-06-10'), y: 38.54 }, { x: new Date('2025-06-11'), y: 38.61 }, { x: new Date('2025-06-12'), y: 38.53 }, { x: new Date('2025-06-14'), y: 38.39 }, { x: new Date('2025-06-15'), y: 38.38 }, { x: new Date('2025-06-16'), y: 38.50 }, { x: new Date('2025-06-17'), y: 38.53 }, { x: new Date('2025-06-18'), y: 38.70 }, { x: new Date('2025-06-20'), y: 38.77 }, { x: new Date('2025-06-21'), y: 38.89 }, { x: new Date('2025-06-22'), y: 38.88 }, { x: new Date('2025-06-23'), y: 38.95 }, { x: new Date('2025-06-24'), y: 39.03 }, { x: new Date('2025-06-25'), y: 38.63 }, { x: new Date('2025-06-26'), y: 38.73 }, { x: new Date('2025-06-27'), y: 38.52 }, { x: new Date('2025-06-28'), y: 38.57 }, { x: new Date('2025-06-29'), y: 38.56 }, { x: new Date('2025-06-30'), y: 38.53 }, { x: new Date('2025-07-01'), y: 38.42 }, { x: new Date('2025-07-02'), y: 38.24 }, { x: new Date('2025-07-04'), y: 38.56 }, { x: new Date('2025-07-05'), y: 38.53 }, { x: new Date('2025-07-06'), y: 38.53 }, { x: new Date('2025-07-07'), y: 38.53 }, { x: new Date('2025-07-08'), y: 38.89 }, { x: new Date('2025-07-09'), y: 39.09 }, { x: new Date('2025-07-10'), y: 39.03 }, { x: new Date('2025-07-11'), y: 39.0101 }, { x: new Date('2025-07-12'), y: 39.26 }, { x: new Date('2025-07-13'), y: 39.2447 }, { x: new Date('2025-07-14'), y: 39.2544 }, { x: new Date('2025-07-15'), y: 39.3606 }, { x: new Date('2025-07-16'), y: 39.6059 }, { x: new Date('2025-07-17'), y: 39.5337 }, { x: new Date('2025-07-19'), y: 39.6519 }, { x: new Date('2025-07-20'), y: 39.6525 }, { x: new Date('2025-07-21'), y: 39.6284 }, { x: new Date('2025-07-22'), y: 39.3698 }, { x: new Date('2025-07-23'), y: 39.1486 }, { x: new Date('2025-07-24'), y: 39.0419 }, { x: new Date('2025-07-25'), y: 39.1424 }, { x: new Date('2025-07-26'), y: 39.3609 }, { x: new Date('2025-07-27'), y: 39.3572 }, { x: new Date('2025-07-29'), y: 39.5634 }, { x: new Date('2025-07-30'), y: 39.6083 }, { x: new Date('2025-07-31'), y: 39.7354 }, { x: new Date('2025-08-01'), y: 40.1017 }, { x: new Date('2025-08-02'), y: 39.5132 }, { x: new Date('2025-08-03'), y: 39.5607 }, { x: new Date('2025-08-04'), y: 39.3528 }, { x: new Date('2025-08-05'), y: 39.2320 }, { x: new Date('2025-08-07'), y: 39.2863 }, { x: new Date('2025-08-08'), y: 39.2446 }, { x: new Date('2025-08-09'), y: 39.3815 }, { x: new Date('2025-08-10'), y: 39.3750 }, { x: new Date('2025-08-11'), y: 39.3812 }, { x: new Date('2025-08-12'), y: 39.4751 }, { x: new Date('2025-08-13'), y: 39.4624 }, { x: new Date('2025-08-14'), y: 39.2877 }, { x: new Date('2025-08-15'), y: 39.3089 }, { x: new Date('2025-08-16'), y: 39.2251 }, { x: new Date('2025-08-18'), y: 39.2601 }, { x: new Date('2025-08-19'), y: 39.4011 }, { x: new Date('2025-08-20'), y: 39.3868 }, { x: new Date('2025-08-21'), y: 39.296 }, { x: new Date('2025-08-22'), y: 39.4973 }, { x: new Date('2025-08-23'), y: 39.2504 }, { x: new Date('2025-08-24'), y: 39.277 }, { x: new Date('2025-08-25'), y: 39.2373 }, { x: new Date('2025-08-26'), y: 39.3684 }, { x: new Date('2025-08-27'), y: 39.3105 }, { x: new Date('2025-08-28'), y: 39.3442 }, { x: new Date('2025-08-29'), y: 39.2054 }, { x: new Date('2025-08-30'), y: 39.2082 }, { x: new Date('2025-08-31'), y: 39.1992 }, { x: new Date('2025-09-01'), y: 39.2381 }, { x: new Date('2025-09-02'), y: 39.2355 }, { x: new Date('2025-09-03'), y: 39.5664 }, { x: new Date('2025-09-04'), y: 39.5222 }, { x: new Date('2025-09-05'), y: 39.5794 }, { x: new Date('2025-09-06'), y: 39.3463 }, { x: new Date('2025-09-07'), y: 39.3699 }, { x: new Date('2025-09-08'), y: 39.5358 }, { x: new Date('2025-09-09'), y: 39.3535 }, { x: new Date('2025-09-10'), y: 39.2576 }, { x: new Date('2025-09-11'), y: 39.2986 }, { x: new Date('2025-09-12'), y: 39.2942 }, { x: new Date('2025-09-13'), y: 39.3725 }, { x: new Date('2025-09-14'), y: 39.3718 }, { x: new Date('2025-09-15'), y: 39.394 }, { x: new Date('2025-09-16'), y: 39.3045 }, { x: new Date('2025-09-17'), y: 39.1073 }, { x: new Date('2025-09-18'), y: 39.1009 }, { x: new Date('2025-09-19'), y: 39.3615 }, { x: new Date('2025-09-20'), y: 39.4527 }, { x: new Date('2025-09-21'), y: 39.4519 }, { x: new Date('2025-09-22'), y: 39.4708 }, { x: new Date('2025-09-23'), y: 39.4088 }, { x: new Date('2025-09-24'), y: 39.3844 }, { x: new Date('2025-09-25'), y: 39.6331 }, { x: new Date('2025-09-26'), y: 39.8659 }, { x: new Date('2025-09-27'), y: 39.887 }, { x: new Date('2025-09-28'), y: 39.89 }, { x: new Date('2025-09-29'), y: 39.8552 }, { x: new Date('2025-09-30'), y: 39.6423 }, { x: new Date('2025-10-01'), y: 39.4635 }, { x: new Date('2025-10-02'), y: 39.223 }, { x: new Date('2025-10-03'), y: 39.2263 }, { x: new Date('2025-10-04'), y: 39.3077 }, { x: new Date('2025-10-05'), y: 39.3037 }, { x: new Date('2025-10-06'), y: 39.7121 }, { x: new Date('2025-10-06'), y: 39.7121 }, { x: new Date('2025-10-07'), y: 40.0089 }, { x: new Date('2025-10-08'), y: 40.3428 }, { x: new Date('2025-10-09'), y: 40.6626 }, { x: new Date('2025-10-10'), y: 40.7698 }, { x: new Date('2025-10-11'), y: 40.4809 }, { x: new Date('2025-10-12'), y: 40.4942 }, { x: new Date('2025-10-13'), y: 40.5291 }, { x: new Date('2025-10-14'), y: 40.5662 }, { x: new Date('2025-10-15'), y: 40.4753 }, { x: new Date('2025-10-16'), y: 40.2984 }, { x: new Date('2025-10-17'), y: 40.1252 }, { x: new Date('2025-10-18'), y: 40.1163 }, { x: new Date('2025-10-20'), y: 40.1032 }, { x: new Date('2025-10-21'), y: 40.191 }, { x: new Date('2025-10-22'), y: 40.4021 }, { x: new Date('2025-10-23'), y: 40.4838 }, { x: new Date('2025-10-24'), y: 40.6593 }, { x: new Date('2025-10-25'), y: 40.7337 }, { x: new Date('2025-10-26'), y: 40.7337 }, { x: new Date('2025-10-27'), y: 40.7531 }, { x: new Date('2025-10-28'), y: 40.8033 }, { x: new Date('2025-10-29'), y: 40.754 }, { x: new Date('2025-10-30'), y: 40.58 }, { x: new Date('2025-10-31'), y: 40.643 }, { x: new Date('2025-11-01'), y: 41.09482809 }, { x: new Date('2025-11-02'), y: 41.0953 }, { x: new Date('2025-11-03'), y: 41.0997 }, { x: new Date('2025-11-04'), y: 41.1118 }, { x: new Date('2025-11-05'), y: 40.9669 }, { x: new Date('2025-11-06'), y: 41.0487 }, { x: new Date('2025-11-07'), y: 40.92239321 }, { x: new Date('2025-11-08'), y: 40.867 }, { x: new Date('2025-11-09'), y: 40.8843 }, { x: new Date('2025-11-10'), y: 40.8821 }, { x: new Date('2025-11-11'), y: 40.9614 }, { x: new Date('2025-11-12'), y: 41.0769 }, { x: new Date('2025-11-13'), y: 41.095 }, { x: new Date('2025-11-14'), y: 41.2533 }, { x: new Date('2025-11-15'), y: 41.2123 }, { x: new Date('2025-11-16'), y: 41.1908 }, { x: new Date('2025-11-17'), y: 41.1908 }, { x: new Date('2025-11-18'), y: 41.1975 }, { x: new Date('2025-11-19'), y: 41.3489 }, { x: new Date('2025-11-20'), y: 41.442 }, { x: new Date('2025-11-21'), y: 41.7681 }, { x: new Date('2025-11-22'), y: 41.9748 }, { x: new Date('2025-11-23'), y: 41.8047 }, { x: new Date('2025-11-24'), y: 41.8047 }, { x: new Date('2025-11-25'), y: 41.8379 }, { x: new Date('2025-11-26'), y: 41.8379 }, { x: new Date('2025-11-27'), y: 41.6444 }, { x: new Date('2025-11-28'), y: 41.7075 }, { x: new Date('2025-11-29'), y: 41.6779 }, { x: new Date('2025-11-30'), y: 41.6466 }, { x: new Date('2025-12-01'), y: 41.6287 }, { x: new Date('2025-12-02'), y: 41.4207 }, { x: new Date('2025-12-03'), y: 41.5684 }, { x: new Date('2025-12-04'), y: 41.4061 }, { x: new Date('2025-12-05'), y: 41.3297 }, { x: new Date('2025-12-06'), y: 41.3895 }, { x: new Date('2025-12-07'), y: 41.3863 }, { x: new Date('2025-12-08'), y: 41.3951 }, { x: new Date('2025-12-09'), y: 41.5297 }, { x: new Date('2025-12-10'), y: 41.7668 }, { x: new Date('2025-12-11'), y: 41.6621 }, { x: new Date('2025-12-12'), y: 41.4728 }, { x: new Date('2025-12-13'), y: 41.5548 }, { x: new Date('2025-12-14'), y: 41.5504 }, { x: new Date('2025-12-15'), y: 41.5499 }, { x: new Date('2025-12-16'), y: 41.3858 }, { x: new Date('2025-12-17'), y: 41.2676 }, { x: new Date('2025-12-18'), y: 41.4651 }, { x: new Date('2025-12-19'), y: 41.4962 }, { x: new Date('2025-12-20'), y: 41.954 }, { x: new Date('2025-12-21'), y: 41.925 }, { x: new Date('2025-12-22'), y: 42.0181 }, { x: new Date('2025-12-23'), y: 41.888 }, { x: new Date('2025-12-24'), y: 41.6569 }, { x: new Date('2025-12-25'), y: 41.5836 }, { x: new Date('2025-12-26'), y: 41.5828 }, { x: new Date('2025-12-27'), y: 41.7258 }, { x: new Date('2025-12-29'), y: 41.7333 }, { x: new Date('2025-12-30'), y: 41.73 }, { x: new Date('2025-12-31'), y: 41.6438 }, { x: new Date('2026-01-01'), y: 41.6735 }, { x: new Date('2026-01-02'), y: 41.7849 }, { x: new Date('2026-01-03'), y: 41.7971 }, { x: new Date('2026-01-04'), y: 41.8257 }, { x: new Date('2026-01-05'), y: 41.8244 }, { x: new Date('2026-01-06'), y: 41.815 }, { x: new Date('2026-01-07'), y: 41.7577 }, { x: new Date('2026-01-08'), y: 41.7657 }, { x: new Date('2026-01-09'), y: 41.7737 }, { x: new Date('2026-01-10'), y: 41.8212 }, { x: new Date('2026-01-11'), y: 42.0746 }, { x: new Date('2026-01-12'), y: 42.0642 }, { x: new Date('2026-01-13'), y: 42.1364 }, { x: new Date('2026-01-14'), y: 42.1361 }, { x: new Date('2026-01-15'), y: 42.3977 }, { x: new Date('2026-01-16'), y: 42.2651 }, { x: new Date('2026-01-17'), y: 42.2914 }, { x: new Date('2026-01-18'), y: 42.1774 }, { x: new Date('2026-01-19'), y: 42.178 }, { x: new Date('2026-01-20'), y: 42.0865 }, { x: new Date('2026-01-21'), y: 42.1434 }, { x: new Date('2026-01-22'), y: 42.1398 }, { x: new Date('2026-01-23'), y: 42.1731 }, { x: new Date('2026-01-24'), y: 42.2505 }, { x: new Date('2026-01-25'), y: 41.8162 }, { x: new Date('2026-01-26'), y: 41.9113 }, { x: new Date('2026-01-27'), y: 41.506 }, { x: new Date('2026-01-28'), y: 41.1003 }, { x: new Date('2026-01-29'), y: 40.761 }, { x: new Date('2026-01-30'), y: 40.8445 }, { x: new Date('2026-01-31'), y: 40.8292 }, { x: new Date('2026-02-01'), y: 41.1686 }, { x: new Date('2026-02-02'), y: 41.1503 }, { x: new Date('2026-02-03'), y: 41.3375 }, { x: new Date('2026-02-04'), y: 41.4272 }, { x: new Date('2026-02-05'), y: 41.5439 }, { x: new Date('2026-02-06'), y: 41.7792 }, { x: new Date('2026-02-07'), y: 41.8522 }, { x: new Date('2026-02-08'), y: 41.8872 }, { x: new Date('2026-02-09'), y: 41.8833 }, { x: new Date('2026-02-10'), y: 41.9615 }, { x: new Date('2026-02-11'), y: 41.6268 }, { x: new Date('2026-02-12'), y: 41.2338 }, { x: new Date('2026-02-13'), y: 40.8802 }, { x: new Date('2026-02-14'), y: 40.7869 }, { x: new Date('2026-02-15'), y: 40.7737 }, { x: new Date('2026-02-16'), y: 40.7827 }, { x: new Date('2026-02-17'), y: 40.7543 }, { x: new Date('2026-02-18'), y: 40.9291 }, { x: new Date('2026-02-19'), y: 40.8804 }, { x: new Date('2026-02-20'), y: 41.1772 }, { x: new Date('2026-02-21'), y: 41.3263 }, { x: new Date('2026-02-22'), y: 41.3579 }, { x: new Date('2026-02-23'), y: 41.3712 }, { x: new Date('2026-02-24'), y: 41.2726 }, { x: new Date('2026-02-25'), y: 41.2266 }, { x: new Date('2026-02-26'), y: 41.5321 }, { x: new Date('2026-02-27'), y: 41.6928 }, { x: new Date('2026-02-28'), y: 41.6161 }, { x: new Date('2026-03-01'), y: 41.6057 }, { x: new Date('2026-03-02'), y: 41.6099 }, { x: new Date('2026-03-03'), y: 41.6693 }, { x: new Date('2026-03-04'), y: 41.9366 }, { x: new Date('2026-03-05'), y: 42.0449 }, { x: new Date('2026-03-06'), y: 41.9022 }, { x: new Date('2026-03-07'), y: 42.004 }, { x: new Date('2026-03-08'), y: 42.0691 }, { x: new Date('2026-03-09'), y: 42.0622 }, { x: new Date('2026-03-10'), y: 42.21 }, { x: new Date('2026-03-11'), y: 42.1606 }, { x: new Date('2026-03-12'), y: 42.1099 }, { x: new Date('2026-03-13'), y: 42.3355 }]; 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 filtered = fullData.filter(item => item.x >= start && item.x <= latestDate); chart.updateSeries([{ name: '', data: filtered }]); } 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);