const fullData = [ { x: new Date('2025-03-03'), y: 93.63 }, { x: new Date('2025-03-04'), y: 92.67 }, { x: new Date('2025-03-05'), y: 93.88 }, { x: new Date('2025-03-06'), y: 94.44 }, { x: new Date('2025-03-07'), y: 93.47 }, { x: new Date('2025-03-08'), y: 93.33 }, { x: new Date('2025-03-10'), y: 93.02 }, { x: new Date('2025-03-11'), y: 92.70 }, { x: new Date('2025-03-12'), y: 92.91 }, { x: new Date('2025-03-13'), y: 93.61 }, { x: new Date('2025-03-14'), y: 92.97 }, { x: new Date('2025-03-15'), y: 93.92 }, { x: new Date('2025-03-16'), y: 93.90 }, { x: new Date('2025-03-17'), y: 93.90 }, { x: new Date('2025-03-18'), y: 94.00 }, { x: new Date('2025-03-19'), y: 95.15 }, { x: new Date('2025-03-20'), y: 94.78 }, { x: new Date('2025-03-21'), y: 93.59 }, { x: new Date('2025-03-22'), y: 93.69 }, { x: new Date('2025-03-23'), y: 93.69 }, { x: new Date('2025-03-24'), y: 93.95 }, { x: new Date('2025-03-25'), y: 94.48 }, { x: new Date('2025-03-26'), y: 94.64 }, { x: new Date('2025-03-27'), y: 94.78 }, { x: new Date('2025-03-28'), y: 95.09 }, { x: new Date('2025-03-29'), y: 94.63 }, { x: new Date('2025-03-30'), y: 94.71 }, { x: new Date('2025-03-31'), y: 94.15 }, { x: new Date('2025-04-01'), y: 93.49 }, { x: new Date('2025-04-02'), y: 93.69 }, { x: new Date('2025-04-03'), y: 93.85 }, { x: new Date('2025-04-04'), y: 92.68 }, { x: new Date('2025-04-05'), y: 89.00 }, { x: new Date('2025-04-06'), y: 89.20 }, { x: new Date('2025-04-07'), y: 87.54 }, { x: new Date('2025-04-08'), y: 88.53 }, { x: new Date('2025-04-09'), y: 88.14 }, { x: new Date('2025-04-10'), y: 88.37 }, { x: new Date('2025-04-11'), y: 89.72 }, { x: new Date('2025-04-12'), y: 89.85 }, { x: new Date('2025-04-13'), y: 89.75 }, { x: new Date('2025-04-14'), y: 90.29 }, { x: new Date('2025-04-15'), y: 90.41 }, { x: new Date('2025-04-16'), y: 90.80 }, { x: new Date('2025-04-17'), y: 90.66 }, { x: new Date('2025-04-18'), y: 90.83 }, { x: new Date('2025-04-19'), y: 90.67 }, { x: new Date('2025-04-20'), y: 90.70 }, { x: new Date('2025-04-21'), y: 90.51 }, { x: new Date('2025-04-22'), y: 90.40 }, { x: new Date('2025-04-23'), y: 90.26 }, { x: new Date('2025-04-24'), y: 91.04 }, { x: new Date('2025-04-25'), y: 91.22 }, { x: new Date('2025-04-26'), y: 91.75 }, { x: new Date('2025-04-27'), y: 91.74 }, { x: new Date('2025-04-28'), y: 91.77 }, { x: new Date('2025-05-02'), y: 92.46 }, { x: new Date('2025-05-03'), y: 93.24 }, { x: new Date('2025-05-05'), y: 93.21 }, { x: new Date('2025-05-06'), y: 93.21 }, { x: new Date('2025-05-07'), y: 92.72 }, { x: new Date('2025-05-08'), y: 92.65 }, { x: new Date('2025-05-09'), y: 93.14 }, { x: new Date('2025-05-10'), y: 93.16 }, { x: new Date('2025-05-11'), y: 93.14 }, { x: new Date('2025-05-12'), y: 93.49 }, { x: new Date('2025-05-13'), y: 94.48 }, { x: new Date('2025-05-14'), y: 95.28 }, { x: new Date('2025-05-15'), y: 94.38 }, { x: new Date('2025-05-16'), y: 93.35 }, { x: new Date('2025-05-17'), y: 93.37 }, { x: new Date('2025-05-19'), y: 93.22 }, { x: new Date('2025-05-20'), y: 93.51 }, { x: new Date('2025-05-21'), y: 92.73 }, { x: new Date('2025-05-22'), y: 92.63 }, { x: new Date('2025-05-24'), y: 92.46 }, { x: new Date('2025-05-26'), y: 92.77 }, { x: new Date('2025-05-27'), y: 92.68 }, { x: new Date('2025-05-29'), y: 93.15 }, { x: new Date('2025-06-02'), y: 92.63 }, { x: new Date('2025-06-06'), y: 93.43 }, { x: new Date('2025-06-10'), y: 94.17 }, { x: new Date('2025-06-11'), y: 94.43 }, { x: new Date('2025-06-12'), y: 94.21 }, { x: new Date('2025-06-14'), y: 93.48 }, { x: new Date('2025-06-15'), y: 93.47 }, { x: new Date('2025-06-16'), y: 93.67 }, { x: new Date('2025-06-17'), y: 94.15 }, { x: new Date('2025-06-18'), y: 94.39 }, { x: new Date('2025-06-20'), y: 94.12 }, { x: new Date('2025-06-21'), y: 94.29 }, { x: new Date('2025-06-22'), y: 94.31 }, { x: new Date('2025-06-23'), y: 94.29 }, { x: new Date('2025-06-24'), y: 94.33 }, { x: new Date('2025-06-25'), y: 94.21 }, { x: new Date('2025-06-26'), y: 94.51 }, { x: new Date('2025-06-27'), y: 94.55 }, { x: new Date('2025-06-28'), y: 94.50 }, { x: new Date('2025-06-29'), y: 94.50 }, { x: new Date('2025-06-30'), y: 94.43 }, { x: new Date('2025-07-01'), y: 94.50 }, { x: new Date('2025-07-02'), y: 94.29 }, { x: new Date('2025-07-04'), y: 94.92 }, { x: new Date('2025-07-05'), y: 94.69 }, { x: new Date('2025-07-06'), y: 94.70 }, { x: new Date('2025-07-07'), y: 94.66 }, { x: new Date('2025-07-08'), y: 94.76 }, { x: new Date('2025-07-09'), y: 95.76 }, { x: new Date('2025-07-10'), y: 95.62 }, { x: new Date('2025-07-11'), y: 96.0689 }, { x: new Date('2025-07-12'), y: 96.80 }, { x: new Date('2025-07-13'), y: 96.7438 }, { x: new Date('2025-07-14'), y: 96.7998 }, { x: new Date('2025-07-15'), y: 96.7268 }, { x: new Date('2025-07-16'), y: 97.0004 }, { x: new Date('2025-07-17'), y: 96.6930 }, { x: new Date('2025-07-19'), y: 96.8519 }, { x: new Date('2025-07-20'), y: 96.8461 }, { x: new Date('2025-07-21'), y: 96.7197 }, { x: new Date('2025-07-22'), y: 96.2192 }, { x: new Date('2025-07-23'), y: 96.0827 }, { x: new Date('2025-07-24'), y: 96.54 }, { x: new Date('2025-07-25'), y: 96.9127 }, { x: new Date('2025-07-26'), y: 96.9321 }, { x: new Date('2025-07-27'), y: 96.9399 }, { x: new Date('2025-07-29'), y: 96.8005 }, { x: new Date('2025-07-30'), y: 96.6990 }, { x: new Date('2025-07-31'), y: 96.2099 }, { x: new Date('2025-08-01'), y: 96.7994 }, { x: new Date('2025-08-02'), y: 95.8097 }, { x: new Date('2025-08-03'), y: 95.9506 }, { x: new Date('2025-08-04'), y: 95.4551 }, { x: new Date('2025-08-05'), y: 95.3578 }, { x: new Date('2025-08-07'), y: 95.7465 }, { x: new Date('2025-08-08'), y: 95.8930 }, { x: new Date('2025-08-09'), y: 96.3463 }, { x: new Date('2025-08-10'), y: 96.3233 }, { x: new Date('2025-08-11'), y: 96.2475 }, { x: new Date('2025-08-12'), y: 96.3718 }, { x: new Date('2025-08-13'), y: 96.4549 }, { x: new Date('2025-08-14'), y: 96.4336 }, { x: new Date('2025-08-15'), y: 95.8575 }, { x: new Date('2025-08-16'), y: 95.7829 }, { x: new Date('2025-08-18'), y: 95.8732 }, { x: new Date('2025-08-19'), y: 96.0432 }, { x: new Date('2025-08-20'), y: 95.5356 }, { x: new Date('2025-08-21'), y: 94.7852 }, { x: new Date('2025-08-22'), y: 95.1493 }, { x: new Date('2025-08-23'), y: 95.3914 }, { x: new Date('2025-08-24'), y: 95.4032 }, { x: new Date('2025-08-25'), y: 95.5094 }, { x: new Date('2025-08-26'), y: 95.7632 }, { x: new Date('2025-08-27'), y: 95.6969 }, { x: new Date('2025-08-28'), y: 95.8574 }, { x: new Date('2025-08-29'), y: 95.9203 }, { x: new Date('2025-08-30'), y: 96.107 }, { x: new Date('2025-08-31'), y: 96.1065 }, { x: new Date('2025-09-01'), y: 96.2363 }, { x: new Date('2025-09-02'), y: 96.4194 }, { x: new Date('2025-09-03'), y: 96.7122 }, { x: new Date('2025-09-04'), y: 96.9204 }, { x: new Date('2025-09-05'), y: 96.7288 }, { x: new Date('2025-09-06'), y: 96.6758 }, { x: new Date('2025-09-07'), y: 96.6984 }, { x: new Date('2025-09-08'), y: 97.0019 }, { x: new Date('2025-09-09'), y: 97.2411 }, { x: new Date('2025-09-10'), y: 97.0182 }, { x: new Date('2025-09-11'), y: 97.4787 }, { x: new Date('2025-09-12'), y: 97.8595 }, { x: new Date('2025-09-13'), y: 98.1295 }, { x: new Date('2025-09-14'), y: 98.1292 }, { x: new Date('2025-09-15'), y: 98.1808 }, { x: new Date('2025-09-16'), y: 98.2233 }, { x: new Date('2025-09-17'), y: 97.9182 }, { x: new Date('2025-09-18'), y: 97.7063 }, { x: new Date('2025-09-19'), y: 97.868 }, { x: new Date('2025-09-20'), y: 97.611 }, { x: new Date('2025-09-21'), y: 97.6375 }, { x: new Date('2025-09-22'), y: 97.5729 }, { x: new Date('2025-09-23'), y: 97.474 }, { x: new Date('2025-09-24'), y: 97.4799 }, { x: new Date('2025-09-25'), y: 97.9385 }, { x: new Date('2025-09-26'), y: 97.9705 }, { x: new Date('2025-09-27'), y: 97.869 }, { x: new Date('2025-09-28'), y: 97.8728 }, { x: new Date('2025-09-29'), y: 97.8597 }, { x: new Date('2025-09-30'), y: 97.6949 }, { x: new Date('2025-10-01'), y: 97.796 }, { x: new Date('2025-10-02'), y: 97.247 }, { x: new Date('2025-10-03'), y: 97.0698 }, { x: new Date('2025-10-04'), y: 97.3411 }, { x: new Date('2025-10-05'), y: 97.3249 }, { x: new Date('2025-10-06'), y: 98.0764 }, { x: new Date('2025-10-06'), y: 98.0764 }, { x: new Date('2025-10-07'), y: 99.2745 }, { x: new Date('2025-10-08'), y: 99.6741 }, { x: new Date('2025-10-09'), y: 100.4238 }, { x: new Date('2025-10-10'), y: 100.5081 }, { x: new Date('2025-10-11'), y: 99.0766 }, { x: new Date('2025-10-12'), y: 99.3731 }, { x: new Date('2025-10-13'), y: 98.9159 }, { x: new Date('2025-10-14'), y: 99.1689 }, { x: new Date('2025-10-15'), y: 98.4616 }, { x: new Date('2025-10-16'), y: 98.3872 }, { x: new Date('2025-10-17'), y: 97.6745 }, { x: new Date('2025-10-18'), y: 97.6218 }, { x: new Date('2025-10-20'), y: 97.5474 }, { x: new Date('2025-10-21'), y: 97.9088 }, { x: new Date('2025-10-22'), y: 98.5232 }, { x: new Date('2025-10-23'), y: 98.5631 }, { x: new Date('2025-10-24'), y: 99.3268 }, { x: new Date('2025-10-25'), y: 99.4709 }, { x: new Date('2025-10-26'), y: 99.4709 }, { x: new Date('2025-10-27'), y: 99.4584 }, { x: new Date('2025-10-28'), y: 99.7663 }, { x: new Date('2025-10-29'), y: 100.1452 }, { x: new Date('2025-10-30'), y: 99.9496 }, { x: new Date('2025-10-31'), y: 100.4165 }, { x: new Date('2025-11-01'), y: 100.87429455 }, { x: new Date('2025-11-02'), y: 100.8782 }, { x: new Date('2025-11-03'), y: 100.9062 }, { x: new Date('2025-11-04'), y: 100.8348 }, { x: new Date('2025-11-05'), y: 99.6842 }, { x: new Date('2025-11-06'), y: 99.9755 }, { x: new Date('2025-11-07'), y: 99.68598806 }, { x: new Date('2025-11-08'), y: 99.5783 }, { x: new Date('2025-11-09'), y: 99.3964 }, { x: new Date('2025-11-10'), y: 99.332 }, { x: new Date('2025-11-11'), y: 99.6025 }, { x: new Date('2025-11-12'), y: 100.613 }, { x: new Date('2025-11-13'), y: 100.606 }, { x: new Date('2025-11-14'), y: 101.1085 }, { x: new Date('2025-11-15'), y: 101.1349 }, { x: new Date('2025-11-16'), y: 100.9644 }, { x: new Date('2025-11-17'), y: 100.9644 }, { x: new Date('2025-11-18'), y: 100.95 }, { x: new Date('2025-11-19'), y: 100.8542 }, { x: new Date('2025-11-20'), y: 101.0561 }, { x: new Date('2025-11-21'), y: 101.3603 }, { x: new Date('2025-11-22'), y: 101.6868 }, { x: new Date('2025-11-23'), y: 101.0655 }, { x: new Date('2025-11-24'), y: 101.0655 }, { x: new Date('2025-11-25'), y: 101.315 }, { x: new Date('2025-11-26'), y: 101.315 }, { x: new Date('2025-11-27'), y: 100.9606 }, { x: new Date('2025-11-28'), y: 101.7941 }, { x: new Date('2025-11-29'), y: 102.054 }, { x: new Date('2025-11-30'), y: 102.0468 }, { x: new Date('2025-12-01'), y: 102.1333 }, { x: new Date('2025-12-02'), y: 101.7214 }, { x: new Date('2025-12-03'), y: 102.2631 }, { x: new Date('2025-12-04'), y: 102.3757 }, { x: new Date('2025-12-05'), y: 102.4303 }, { x: new Date('2025-12-06'), y: 102.9519 }, { x: new Date('2025-12-07'), y: 102.8697 }, { x: new Date('2025-12-08'), y: 103.0515 }, { x: new Date('2025-12-09'), y: 103.2282 }, { x: new Date('2025-12-10'), y: 103.9166 }, { x: new Date('2025-12-11'), y: 103.9556 }, { x: new Date('2025-12-12'), y: 103.5906 }, { x: new Date('2025-12-13'), y: 103.6878 }, { x: new Date('2025-12-14'), y: 103.6777 }, { x: new Date('2025-12-15'), y: 103.5889 }, { x: new Date('2025-12-16'), y: 103.0659 }, { x: new Date('2025-12-17'), y: 102.6635 }, { x: new Date('2025-12-18'), y: 102.7766 }, { x: new Date('2025-12-19'), y: 102.9144 }, { x: new Date('2025-12-20'), y: 103.9805 }, { x: new Date('2025-12-21'), y: 103.8672 }, { x: new Date('2025-12-22'), y: 104.1193 }, { x: new Date('2025-12-23'), y: 104.4476 }, { x: new Date('2025-12-24'), y: 104.5283 }, { x: new Date('2025-12-25'), y: 104.56 }, { x: new Date('2025-12-26'), y: 104.5059 }, { x: new Date('2025-12-27'), y: 104.9056 }, { x: new Date('2025-12-29'), y: 104.6875 }, { x: new Date('2025-12-30'), y: 104.9376 }, { x: new Date('2025-12-31'), y: 104.4957 }, { x: new Date('2026-01-01'), y: 104.6643 }, { x: new Date('2026-01-02'), y: 104.6632 }, { x: new Date('2026-01-03'), y: 104.6784 }, { x: new Date('2026-01-04'), y: 104.8739 }, { x: new Date('2026-01-05'), y: 104.8284 }, { x: new Date('2026-01-06'), y: 104.8841 }, { x: new Date('2026-01-07'), y: 104.8475 }, { x: new Date('2026-01-08'), y: 105.3039 }, { x: new Date('2026-01-09'), y: 105.3607 }, { x: new Date('2026-01-10'), y: 105.0411 }, { x: new Date('2026-01-11'), y: 105.4273 }, { x: new Date('2026-01-12'), y: 105.362 }, { x: new Date('2026-01-13'), y: 105.5481 }, { x: new Date('2026-01-14'), y: 105.9852 }, { x: new Date('2026-01-15'), y: 106.3794 }, { x: new Date('2026-01-16'), y: 105.8794 }, { x: new Date('2026-01-17'), y: 106.1829 }, { x: new Date('2026-01-18'), y: 105.7721 }, { x: new Date('2026-01-19'), y: 105.8215 }, { x: new Date('2026-01-20'), y: 105.4776 }, { x: new Date('2026-01-21'), y: 106.0001 }, { x: new Date('2026-01-22'), y: 106.3762 }, { x: new Date('2026-01-23'), y: 106.817 }, { x: new Date('2026-01-24'), y: 108.176 }, { x: new Date('2026-01-25'), y: 107.966 }, { x: new Date('2026-01-26'), y: 108.132 }, { x: new Date('2026-01-27'), y: 107.5848 }, { x: new Date('2026-01-28'), y: 106.6023 }, { x: new Date('2026-01-29'), y: 106.6225 }, { x: new Date('2026-01-30'), y: 107.2232 }, { x: new Date('2026-01-31'), y: 107.9503 }, { x: new Date('2026-02-01'), y: 107.8517 }, { x: new Date('2026-02-02'), y: 107.8484 }, { x: new Date('2026-02-03'), y: 107.8294 }, { x: new Date('2026-02-04'), y: 108.0059 }, { x: new Date('2026-02-05'), y: 109.188 }, { x: new Date('2026-02-06'), y: 109.787 }, { x: new Date('2026-02-07'), y: 109.1566 }, { x: new Date('2026-02-08'), y: 109.9639 }, { x: new Date('2026-02-09'), y: 109.8339 }, { x: new Date('2026-02-10'), y: 110.3799 }, { x: new Date('2026-02-11'), y: 110.3839 }, { x: new Date('2026-02-12'), y: 109.3378 }, { x: new Date('2026-02-13'), y: 109.1565 }, { x: new Date('2026-02-14'), y: 108.5431 }, { x: new Date('2026-02-15'), y: 108.1151 }, { x: new Date('2026-02-16'), y: 108.1016 }, { x: new Date('2026-02-17'), y: 108.0424 }, { x: new Date('2026-02-18'), y: 108.6403 }, { x: new Date('2026-02-19'), y: 108.3352 }, { x: new Date('2026-02-20'), y: 108.8487 }, { x: new Date('2026-02-21'), y: 109.2718 }, { x: new Date('2026-02-22'), y: 109.597 }, { x: new Date('2026-02-23'), y: 109.5338 }, { x: new Date('2026-02-24'), y: 109.5766 }, { x: new Date('2026-02-25'), y: 109.1926 }, { x: new Date('2026-02-26'), y: 109.9103 }, { x: new Date('2026-02-27'), y: 111.082 }, { x: new Date('2026-02-28'), y: 110.8662 }, { x: new Date('2026-03-01'), y: 110.9464 }, { x: new Date('2026-03-02'), y: 110.8907 }, { x: new Date('2026-03-03'), y: 110.6407 }, { x: new Date('2026-03-04'), y: 111.4013 }, { x: new Date('2026-03-05'), y: 110.913 }, { x: new Date('2026-03-06'), y: 110.9413 }, { x: new Date('2026-03-07'), y: 110.5235 }, { x: new Date('2026-03-08'), y: 110.712 }, { x: new Date('2026-03-09'), y: 110.6628 }, { x: new Date('2026-03-10'), y: 110.3546 }, { x: new Date('2026-03-11'), y: 111.3151 }, { x: new Date('2026-03-12'), y: 112.4404 }, { x: new Date('2026-03-13'), y: 113.4017 }]; 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);