const fullData = [ { x: new Date('2025-02-20'), y: 489.17 }, { x: new Date('2025-02-21'), y: 485.59 }, { x: new Date('2025-02-22'), y: 483.48 }, { x: new Date('2025-02-23'), y: 483.48 }, { x: new Date('2025-02-24'), y: 483.48 }, { x: new Date('2025-02-25'), y: 486.99 }, { x: new Date('2025-02-26'), y: 482.64 }, { x: new Date('2025-02-27'), y: 482.72 }, { x: new Date('2025-02-28'), y: 484.51 }, { x: new Date('2025-03-03'), y: 487.70 }, { x: new Date('2025-03-04'), y: 483.17 }, { x: new Date('2025-03-05'), y: 485.19 }, { x: new Date('2025-03-06'), y: 483.71 }, { x: new Date('2025-03-07'), y: 479.96 }, { x: new Date('2025-03-08'), y: 480.56 }, { x: new Date('2025-03-10'), y: 479.66 }, { x: new Date('2025-03-11'), y: 478.07 }, { x: new Date('2025-03-12'), y: 478.92 }, { x: new Date('2025-03-13'), y: 481.85 }, { x: new Date('2025-03-14'), y: 479.77 }, { x: new Date('2025-03-15'), y: 481.99 }, { x: new Date('2025-03-16'), y: 482.07 }, { x: new Date('2025-03-17'), y: 482.07 }, { x: new Date('2025-03-18'), y: 483.08 }, { x: new Date('2025-03-19'), y: 485.87 }, { x: new Date('2025-03-20'), y: 486.79 }, { x: new Date('2025-03-21'), y: 482.53 }, { x: new Date('2025-03-22'), y: 484.35 }, { x: new Date('2025-03-23'), y: 484.43 }, { x: new Date('2025-03-24'), y: 483.90 }, { x: new Date('2025-03-25'), y: 487.07 }, { x: new Date('2025-03-26'), y: 487.05 }, { x: new Date('2025-03-27'), y: 488.06 }, { x: new Date('2025-03-28'), y: 489.40 }, { x: new Date('2025-03-29'), y: 487.99 }, { x: new Date('2025-03-30'), y: 488.29 }, { x: new Date('2025-03-31'), y: 488.97 }, { x: new Date('2025-04-01'), y: 485.65 }, { x: new Date('2025-04-02'), y: 484.80 }, { x: new Date('2025-04-03'), y: 486.14 }, { x: new Date('2025-04-04'), y: 476.43 }, { x: new Date('2025-04-05'), y: 474.85 }, { x: new Date('2025-04-06'), y: 475.10 }, { x: new Date('2025-04-07'), y: 475.77 }, { x: new Date('2025-04-08'), y: 478.11 }, { x: new Date('2025-04-09'), y: 477.98 }, { x: new Date('2025-04-10'), y: 472.09 }, { x: new Date('2025-04-11'), y: 473.64 }, { x: new Date('2025-04-12'), y: 472.27 }, { x: new Date('2025-04-13'), y: 471.99 }, { x: new Date('2025-04-14'), y: 466.84 }, { x: new Date('2025-04-15'), y: 466.69 }, { x: new Date('2025-04-16'), y: 466.47 }, { x: new Date('2025-04-17'), y: 465.25 }, { x: new Date('2025-04-18'), y: 464.85 }, { x: new Date('2025-04-19'), y: 465.58 }, { x: new Date('2025-04-20'), y: 465.60 }, { x: new Date('2025-04-21'), y: 464.27 }, { x: new Date('2025-04-22'), y: 461.12 }, { x: new Date('2025-04-23'), y: 460.04 }, { x: new Date('2025-04-24'), y: 464.47 }, { x: new Date('2025-04-25'), y: 465.61 }, { x: new Date('2025-04-26'), y: 468.39 }, { x: new Date('2025-04-27'), y: 469.20 }, { x: new Date('2025-04-28'), y: 468.68 }, { x: new Date('2025-05-02'), y: 469.07 }, { x: new Date('2025-05-03'), y: 471.37 }, { x: new Date('2025-05-05'), y: 471.78 }, { x: new Date('2025-05-06'), y: 471.78 }, { x: new Date('2025-05-07'), y: 466.32 }, { x: new Date('2025-05-08'), y: 467.81 }, { x: new Date('2025-05-09'), y: 472.73 }, { x: new Date('2025-05-10'), y: 473.27 }, { x: new Date('2025-05-11'), y: 473.29 }, { x: new Date('2025-05-12'), y: 473.64 }, { x: new Date('2025-05-13'), y: 480.68 }, { x: new Date('2025-05-14'), y: 481.35 }, { x: new Date('2025-05-15'), y: 476.39 }, { x: new Date('2025-05-16'), y: 474.62 }, { x: new Date('2025-05-17'), y: 474.96 }, { x: new Date('2025-05-19'), y: 474.22 }, { x: new Date('2025-05-20'), y: 472.12 }, { x: new Date('2025-05-21'), y: 471.55 }, { x: new Date('2025-05-22'), y: 468.79 }, { x: new Date('2025-05-24'), y: 466.52 }, { x: new Date('2025-05-26'), y: 464.85 }, { x: new Date('2025-05-27'), y: 466.55 }, { x: new Date('2025-05-29'), y: 471.52 }, { x: new Date('2025-06-02'), y: 469.64 }, { x: new Date('2025-06-06'), y: 468.71 }, { x: new Date('2025-06-10'), y: 470.82 }, { x: new Date('2025-06-11'), y: 473.17 }, { x: new Date('2025-06-12'), y: 473.31 }, { x: new Date('2025-06-14'), y: 471.38 }, { x: new Date('2025-06-15'), y: 471.53 }, { x: new Date('2025-06-16'), y: 470.97 }, { x: new Date('2025-06-17'), y: 471.63 }, { x: new Date('2025-06-18'), y: 473.39 }, { x: new Date('2025-06-20'), y: 475.43 }, { x: new Date('2025-06-21'), y: 476.18 }, { x: new Date('2025-06-22'), y: 476.16 }, { x: new Date('2025-06-23'), y: 476.83 }, { x: new Date('2025-06-24'), y: 480.81 }, { x: new Date('2025-06-25'), y: 474.82 }, { x: new Date('2025-06-26'), y: 476.28 }, { x: new Date('2025-06-27'), y: 472.71 }, { x: new Date('2025-06-28'), y: 473.78 }, { x: new Date('2025-06-29'), y: 473.98 }, { x: new Date('2025-06-30'), y: 473.11 }, { x: new Date('2025-07-01'), y: 472.22 }, { x: new Date('2025-07-02'), y: 470.49 }, { x: new Date('2025-07-04'), y: 473.39 }, { x: new Date('2025-07-05'), y: 473.83 }, { x: new Date('2025-07-06'), y: 473.96 }, { x: new Date('2025-07-07'), y: 473.55 }, { x: new Date('2025-07-08'), y: 477.36 }, { x: new Date('2025-07-09'), y: 480.17 }, { x: new Date('2025-07-10'), y: 480.61 }, { x: new Date('2025-07-11'), y: 479.5973 }, { x: new Date('2025-07-12'), y: 481.85 }, { x: new Date('2025-07-13'), y: 481.9393 }, { x: new Date('2025-07-14'), y: 482.6615 }, { x: new Date('2025-07-15'), y: 483.4585 }, { x: new Date('2025-07-16'), y: 485.6506 }, { x: new Date('2025-07-17'), y: 486.2808 }, { x: new Date('2025-07-19'), y: 486.9846 }, { x: new Date('2025-07-20'), y: 487.2646 }, { x: new Date('2025-07-21'), y: 486.8766 }, { x: new Date('2025-07-22'), y: 484.1142 }, { x: new Date('2025-07-23'), y: 481.8816 }, { x: new Date('2025-07-24'), y: 480.5810 }, { x: new Date('2025-07-25'), y: 481.2465 }, { x: new Date('2025-07-26'), y: 484.4047 }, { x: new Date('2025-07-27'), y: 484.5215 }, { x: new Date('2025-07-29'), y: 486.2837 }, { x: new Date('2025-07-30'), y: 486.5208 }, { x: new Date('2025-07-31'), y: 486.7352 }, { x: new Date('2025-08-01'), y: 491.0186 }, { x: new Date('2025-08-02'), y: 488.7483 }, { x: new Date('2025-08-03'), y: 488.1439 }, { x: new Date('2025-08-04'), y: 492.8093 }, { x: new Date('2025-08-05'), y: 482.8576 }, { x: new Date('2025-08-07'), y: 482.9806 }, { x: new Date('2025-08-08'), y: 482.8526 }, { x: new Date('2025-08-09'), y: 484.0014 }, { x: new Date('2025-08-10'), y: 484.1577 }, { x: new Date('2025-08-11'), y: 483.9961 }, { x: new Date('2025-08-12'), y: 484.3079 }, { x: new Date('2025-08-13'), y: 485.3541 }, { x: new Date('2025-08-14'), y: 483.0159 }, { x: new Date('2025-08-15'), y: 482.1033 }, { x: new Date('2025-08-16'), y: 481.8393 }, { x: new Date('2025-08-18'), y: 481.673 }, { x: new Date('2025-08-19'), y: 483.6776 }, { x: new Date('2025-08-20'), y: 484.0769 }, { x: new Date('2025-08-21'), y: 482.8095 }, { x: new Date('2025-08-22'), y: 484.6972 }, { x: new Date('2025-08-23'), y: 483.0918 }, { x: new Date('2025-08-24'), y: 483.7595 }, { x: new Date('2025-08-25'), y: 484.5605 }, { x: new Date('2025-08-26'), y: 483.5134 }, { x: new Date('2025-08-27'), y: 483.1845 }, { x: new Date('2025-08-28'), y: 484.1712 }, { x: new Date('2025-08-29'), y: 482.2926 }, { x: new Date('2025-08-30'), y: 481.9403 }, { x: new Date('2025-08-31'), y: 482.2887 }, { x: new Date('2025-09-01'), y: 481.6951 }, { x: new Date('2025-09-02'), y: 481.753 }, { x: new Date('2025-09-03'), y: 485.0082 }, { x: new Date('2025-09-04'), y: 485.6202 }, { x: new Date('2025-09-05'), y: 486.334 }, { x: new Date('2025-09-06'), y: 483.2651 }, { x: new Date('2025-09-07'), y: 483.962 }, { x: new Date('2025-09-08'), y: 483.9602 }, { x: new Date('2025-09-09'), y: 484.9745 }, { x: new Date('2025-09-10'), y: 482.2004 }, { x: new Date('2025-09-11'), y: 483.2015 }, { x: new Date('2025-09-12'), y: 483.774 }, { x: new Date('2025-09-13'), y: 484.8161 }, { x: new Date('2025-09-14'), y: 485.0306 }, { x: new Date('2025-09-15'), y: 484.3601 }, { x: new Date('2025-09-16'), y: 483.6404 }, { x: new Date('2025-09-17'), y: 482.0332 }, { x: new Date('2025-09-18'), y: 480.6722 }, { x: new Date('2025-09-19'), y: 484.4794 }, { x: new Date('2025-09-20'), y: 485.0329 }, { x: new Date('2025-09-21'), y: 485.3063 }, { x: new Date('2025-09-22'), y: 484.5492 }, { x: new Date('2025-09-23'), y: 485.3663 }, { x: new Date('2025-09-24'), y: 485.0582 }, { x: new Date('2025-09-25'), y: 486.8615 }, { x: new Date('2025-09-26'), y: 489.1122 }, { x: new Date('2025-09-27'), y: 490.0348 }, { x: new Date('2025-09-28'), y: 490.3053 }, { x: new Date('2025-09-29'), y: 489.896 }, { x: new Date('2025-09-30'), y: 487.7259 }, { x: new Date('2025-10-01'), y: 485.4821 }, { x: new Date('2025-10-02'), y: 482.4562 }, { x: new Date('2025-10-03'), y: 482.1118 }, { x: new Date('2025-10-04'), y: 482.7469 }, { x: new Date('2025-10-05'), y: 483.0632 }, { x: new Date('2025-10-06'), y: 482.4848 }, { x: new Date('2025-10-06'), y: 482.4848 }, { x: new Date('2025-10-07'), y: 491.4277 }, { x: new Date('2025-10-08'), y: 493.6563 }, { x: new Date('2025-10-09'), y: 498.9638 }, { x: new Date('2025-10-10'), y: 499.2736 }, { x: new Date('2025-10-11'), y: 497.1746 }, { x: new Date('2025-10-12'), y: 497.7545 }, { x: new Date('2025-10-13'), y: 496.2205 }, { x: new Date('2025-10-14'), y: 496.6503 }, { x: new Date('2025-10-15'), y: 495.938 }, { x: new Date('2025-10-16'), y: 493.8647 }, { x: new Date('2025-10-17'), y: 494.345 }, { x: new Date('2025-10-18'), y: 492.6144 }, { x: new Date('2025-10-20'), y: 492.9609 }, { x: new Date('2025-10-21'), y: 492.2597 }, { x: new Date('2025-10-22'), y: 496.0742 }, { x: new Date('2025-10-23'), y: 495.9212 }, { x: new Date('2025-10-24'), y: 498.7883 }, { x: new Date('2025-10-25'), y: 499.5059 }, { x: new Date('2025-10-26'), y: 499.5059 }, { x: new Date('2025-10-27'), y: 499.8493 }, { x: new Date('2025-10-28'), y: 499.388 }, { x: new Date('2025-10-29'), y: 499.7443 }, { x: new Date('2025-10-30'), y: 496.766 }, { x: new Date('2025-10-31'), y: 496.8384 }, { x: new Date('2025-11-01'), y: 502.83849438 }, { x: new Date('2025-11-02'), y: 502.9301 }, { x: new Date('2025-11-03'), y: 502.4584 }, { x: new Date('2025-11-04'), y: 502.8893 }, { x: new Date('2025-11-05'), y: 500.8132 }, { x: new Date('2025-11-06'), y: 501.4344 }, { x: new Date('2025-11-07'), y: 500.62819881 }, { x: new Date('2025-11-08'), y: 500.6762 }, { x: new Date('2025-11-09'), y: 500.209 }, { x: new Date('2025-11-10'), y: 500.6595 }, { x: new Date('2025-11-11'), y: 500.3135 }, { x: new Date('2025-11-12'), y: 502.5411 }, { x: new Date('2025-11-13'), y: 502.9499 }, { x: new Date('2025-11-14'), y: 504.6367 }, { x: new Date('2025-11-15'), y: 504.6848 }, { x: new Date('2025-11-16'), y: 505.5236 }, { x: new Date('2025-11-17'), y: 505.5236 }, { x: new Date('2025-11-18'), y: 504.0504 }, { x: new Date('2025-11-19'), y: 505.9508 }, { x: new Date('2025-11-20'), y: 506.9194 }, { x: new Date('2025-11-21'), y: 509.6576 }, { x: new Date('2025-11-22'), y: 512.9575 }, { x: new Date('2025-11-23'), y: 511.7451 }, { x: new Date('2025-11-24'), y: 511.7451 }, { x: new Date('2025-11-25'), y: 511.4632 }, { x: new Date('2025-11-26'), y: 511.4632 }, { x: new Date('2025-11-27'), y: 510.1331 }, { x: new Date('2025-11-28'), y: 510.1154 }, { x: new Date('2025-11-29'), y: 509.8913 }, { x: new Date('2025-11-30'), y: 510.2503 }, { x: new Date('2025-12-01'), y: 509.2737 }, { x: new Date('2025-12-02'), y: 506.9266 }, { x: new Date('2025-12-03'), y: 508.7824 }, { x: new Date('2025-12-04'), y: 507.4309 }, { x: new Date('2025-12-05'), y: 505.779 }, { x: new Date('2025-12-06'), y: 506.8467 }, { x: new Date('2025-12-07'), y: 507.1189 }, { x: new Date('2025-12-08'), y: 506.5049 }, { x: new Date('2025-12-09'), y: 507.8015 }, { x: new Date('2025-12-10'), y: 510.3987 }, { x: new Date('2025-12-11'), y: 510.8185 }, { x: new Date('2025-12-12'), y: 508.061 }, { x: new Date('2025-12-13'), y: 509.142 }, { x: new Date('2025-12-14'), y: 509.4723 }, { x: new Date('2025-12-15'), y: 509.1619 }, { x: new Date('2025-12-16'), y: 507.4021 }, { x: new Date('2025-12-17'), y: 505.9239 }, { x: new Date('2025-12-18'), y: 507.5978 }, { x: new Date('2025-12-19'), y: 508.1595 }, { x: new Date('2025-12-20'), y: 512.2493 }, { x: new Date('2025-12-21'), y: 512.2355 }, { x: new Date('2025-12-22'), y: 513.2314 }, { x: new Date('2025-12-23'), y: 512.4549 }, { x: new Date('2025-12-24'), y: 509.5883 }, { x: new Date('2025-12-25'), y: 508.5298 }, { x: new Date('2025-12-26'), y: 509.0595 }, { x: new Date('2025-12-27'), y: 510.794 }, { x: new Date('2025-12-29'), y: 510.9866 }, { x: new Date('2025-12-30'), y: 510.5954 }, { x: new Date('2025-12-31'), y: 509.0713 }, { x: new Date('2026-01-01'), y: 508.4027 }, { x: new Date('2026-01-02'), y: 510.7422 }, { x: new Date('2026-01-03'), y: 510.3574 }, { x: new Date('2026-01-04'), y: 510.0823 }, { x: new Date('2026-01-05'), y: 510.1586 }, { x: new Date('2026-01-06'), y: 511.339 }, { x: new Date('2026-01-07'), y: 510.8575 }, { x: new Date('2026-01-08'), y: 510.5813 }, { x: new Date('2026-01-09'), y: 510.9377 }, { x: new Date('2026-01-10'), y: 511.5551 }, { x: new Date('2026-01-11'), y: 514.4342 }, { x: new Date('2026-01-12'), y: 516.7753 }, { x: new Date('2026-01-13'), y: 514.6923 }, { x: new Date('2026-01-14'), y: 515.113 }, { x: new Date('2026-01-15'), y: 517.6536 }, { x: new Date('2026-01-16'), y: 516.5264 }, { x: new Date('2026-01-17'), y: 516.1199 }, { x: new Date('2026-01-18'), y: 515.1528 }, { x: new Date('2026-01-19'), y: 515.7793 }, { x: new Date('2026-01-20'), y: 514.6587 }, { x: new Date('2026-01-21'), y: 514.7321 }, { x: new Date('2026-01-22'), y: 514.8679 }, { x: new Date('2026-01-23'), y: 516.0006 }, { x: new Date('2026-01-24'), y: 517.2643 }, { x: new Date('2026-01-25'), y: 516.1979 }, { x: new Date('2026-01-26'), y: 515.7332 }, { x: new Date('2026-01-27'), y: 515.3652 }, { x: new Date('2026-01-28'), y: 502.8754 }, { x: new Date('2026-01-29'), y: 503.1938 }, { x: new Date('2026-01-30'), y: 500.6357 }, { x: new Date('2026-01-31'), y: 500.918 }, { x: new Date('2026-02-01'), y: 504.1319 }, { x: new Date('2026-02-02'), y: 504.507 }, { x: new Date('2026-02-03'), y: 504.4811 }, { x: new Date('2026-02-04'), y: 506.4384 }, { x: new Date('2026-02-05'), y: 508.1253 }, { x: new Date('2026-02-06'), y: 510.7478 }, { x: new Date('2026-02-07'), y: 512.0758 }, { x: new Date('2026-02-08'), y: 512.3244 }, { x: new Date('2026-02-09'), y: 512.7445 }, { x: new Date('2026-02-10'), y: 512.5853 }, { x: new Date('2026-02-11'), y: 510.4583 }, { x: new Date('2026-02-12'), y: 507.0618 }, { x: new Date('2026-02-13'), y: 500.5643 }, { x: new Date('2026-02-14'), y: 499.5525 }, { x: new Date('2026-02-15'), y: 500.4496 }, { x: new Date('2026-02-16'), y: 501.0623 }, { x: new Date('2026-02-17'), y: 500.2886 }, { x: new Date('2026-02-18'), y: 500.5734 }, { x: new Date('2026-02-19'), y: 500.5022 }, { x: new Date('2026-02-20'), y: 502.7384 }, { x: new Date('2026-02-21'), y: 504.9445 }, { x: new Date('2026-02-22'), y: 505.4609 }, { x: new Date('2026-02-23'), y: 505.5037 }, { x: new Date('2026-02-24'), y: 506.3289 }, { x: new Date('2026-02-25'), y: 504.9555 }, { x: new Date('2026-02-26'), y: 508.4448 }, { x: new Date('2026-02-27'), y: 510.8173 }, { x: new Date('2026-02-28'), y: 510.1814 }, { x: new Date('2026-03-01'), y: 510.145 }, { x: new Date('2026-03-02'), y: 510.5218 }, { x: new Date('2026-03-03'), y: 509.8931 }, { x: new Date('2026-03-04'), y: 512.9816 }]; 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);