const fullData = [ { x: new Date('2025-04-12'), y: 39.04 }, { x: new Date('2025-04-13'), y: 39.03 }, { x: new Date('2025-04-14'), y: 39.13 }, { x: new Date('2025-04-15'), y: 38.98 }, { x: new Date('2025-04-16'), y: 38.96 }, { x: new Date('2025-04-17'), y: 38.72 }, { x: new Date('2025-04-18'), y: 38.78 }, { x: new Date('2025-04-19'), y: 38.73 }, { x: new Date('2025-04-20'), y: 38.73 }, { x: new Date('2025-04-21'), y: 38.59 }, { x: new Date('2025-04-22'), y: 38.35 }, { x: new Date('2025-04-23'), y: 38.53 }, { x: new Date('2025-04-24'), y: 38.86 }, { x: new Date('2025-04-25'), y: 38.85 }, { x: new Date('2025-04-26'), y: 39.09 }, { x: new Date('2025-04-27'), y: 39.10 }, { x: new Date('2025-04-28'), y: 39.11 }, { x: new Date('2025-05-02'), y: 39.38 }, { x: new Date('2025-05-03'), y: 39.43 }, { x: new Date('2025-05-05'), y: 39.40 }, { x: new Date('2025-05-06'), y: 39.41 }, { x: new Date('2025-05-07'), y: 38.94 }, { x: new Date('2025-05-08'), y: 39.08 }, { x: new Date('2025-05-09'), y: 39.56 }, { x: new Date('2025-05-10'), y: 39.53 }, { x: new Date('2025-05-11'), y: 39.53 }, { x: new Date('2025-05-12'), y: 39.67 }, { x: new Date('2025-05-13'), y: 40.26 }, { x: new Date('2025-05-14'), y: 40.21 }, { x: new Date('2025-05-15'), y: 39.88 }, { x: new Date('2025-05-16'), y: 39.67 }, { x: new Date('2025-05-17'), y: 39.68 }, { x: new Date('2025-05-19'), y: 39.57 }, { x: new Date('2025-05-20'), y: 39.47 }, { x: new Date('2025-05-21'), y: 39.35 }, { x: new Date('2025-05-22'), y: 39.14 }, { x: new Date('2025-05-24'), y: 38.84 }, { x: new Date('2025-05-26'), y: 38.86 }, { x: new Date('2025-05-27'), y: 38.86 }, { x: new Date('2025-05-29'), y: 39.44 }, { x: new Date('2025-06-02'), y: 39.17 }, { x: new Date('2025-06-06'), y: 39.05 }, { x: new Date('2025-06-10'), y: 39.35 }, { x: new Date('2025-06-11'), y: 39.42 }, { x: new Date('2025-06-12'), y: 39.35 }, { x: new Date('2025-06-14'), y: 39.20 }, { x: new Date('2025-06-15'), y: 39.19 }, { x: new Date('2025-06-16'), y: 39.32 }, { x: new Date('2025-06-17'), y: 39.34 }, { x: new Date('2025-06-18'), y: 39.52 }, { x: new Date('2025-06-20'), y: 39.59 }, { x: new Date('2025-06-21'), y: 39.71 }, { x: new Date('2025-06-22'), y: 39.70 }, { x: new Date('2025-06-23'), y: 39.78 }, { x: new Date('2025-06-24'), y: 39.85 }, { x: new Date('2025-06-25'), y: 39.45 }, { x: new Date('2025-06-26'), y: 39.55 }, { x: new Date('2025-06-27'), y: 39.33 }, { x: new Date('2025-06-28'), y: 39.38 }, { x: new Date('2025-06-29'), y: 39.38 }, { x: new Date('2025-06-30'), y: 39.34 }, { x: new Date('2025-07-01'), y: 39.23 }, { x: new Date('2025-07-02'), y: 39.05 }, { x: new Date('2025-07-04'), y: 39.37 }, { x: new Date('2025-07-05'), y: 39.34 }, { x: new Date('2025-07-06'), y: 39.34 }, { x: new Date('2025-07-07'), y: 39.34 }, { x: new Date('2025-07-08'), y: 39.71 }, { x: new Date('2025-07-09'), y: 39.92 }, { x: new Date('2025-07-10'), y: 39.85 }, { x: new Date('2025-07-11'), y: 39.8334 }, { x: new Date('2025-07-12'), y: 40.08 }, { x: new Date('2025-07-13'), y: 40.0729 }, { x: new Date('2025-07-14'), y: 40.0827 }, { x: new Date('2025-07-15'), y: 40.1912 }, { x: new Date('2025-07-16'), y: 40.4417 }, { x: new Date('2025-07-17'), y: 40.3679 }, { x: new Date('2025-07-19'), y: 40.4886 }, { x: new Date('2025-07-20'), y: 40.4893 }, { x: new Date('2025-07-21'), y: 40.4646 }, { x: new Date('2025-07-22'), y: 40.2006 }, { x: new Date('2025-07-23'), y: 39.9747 }, { x: new Date('2025-07-24'), y: 39.8658 }, { x: new Date('2025-07-25'), y: 39.9684 }, { x: new Date('2025-07-26'), y: 40.1915 }, { x: new Date('2025-07-27'), y: 40.1877 }, { x: new Date('2025-07-29'), y: 40.3983 }, { x: new Date('2025-07-30'), y: 40.4441 }, { x: new Date('2025-07-31'), y: 40.5739 }, { x: new Date('2025-08-01'), y: 40.9480 }, { x: new Date('2025-08-02'), y: 40.3470 }, { x: new Date('2025-08-03'), y: 40.3955 }, { x: new Date('2025-08-04'), y: 40.1832 }, { x: new Date('2025-08-05'), y: 40.0599 }, { x: new Date('2025-08-07'), y: 40.1153 }, { x: new Date('2025-08-08'), y: 40.0728 }, { x: new Date('2025-08-09'), y: 40.2126 }, { x: new Date('2025-08-10'), y: 40.2060 }, { x: new Date('2025-08-11'), y: 40.2123 }, { x: new Date('2025-08-12'), y: 40.3081 }, { x: new Date('2025-08-13'), y: 40.2952 }, { x: new Date('2025-08-14'), y: 40.1168 }, { x: new Date('2025-08-15'), y: 40.1384 }, { x: new Date('2025-08-16'), y: 40.0528 }, { x: new Date('2025-08-18'), y: 40.0886 }, { x: new Date('2025-08-19'), y: 40.2326 }, { x: new Date('2025-08-20'), y: 40.218 }, { x: new Date('2025-08-21'), y: 40.1252 }, { x: new Date('2025-08-22'), y: 40.3308 }, { x: new Date('2025-08-23'), y: 40.0787 }, { x: new Date('2025-08-24'), y: 40.1058 }, { x: new Date('2025-08-25'), y: 40.0653 }, { x: new Date('2025-08-26'), y: 40.1992 }, { x: new Date('2025-08-27'), y: 40.14 }, { x: new Date('2025-08-28'), y: 40.1745 }, { x: new Date('2025-08-29'), y: 40.0327 }, { x: new Date('2025-08-30'), y: 40.0356 }, { x: new Date('2025-08-31'), y: 40.0264 }, { x: new Date('2025-09-01'), y: 40.0662 }, { x: new Date('2025-09-02'), y: 40.0635 }, { x: new Date('2025-09-03'), y: 40.4013 }, { x: new Date('2025-09-04'), y: 40.3563 }, { x: new Date('2025-09-05'), y: 40.4147 }, { x: new Date('2025-09-06'), y: 40.1766 }, { x: new Date('2025-09-07'), y: 40.2007 }, { x: new Date('2025-09-08'), y: 40.3701 }, { x: new Date('2025-09-09'), y: 40.184 }, { x: new Date('2025-09-10'), y: 40.086 }, { x: new Date('2025-09-11'), y: 40.1279 }, { x: new Date('2025-09-12'), y: 40.1235 }, { x: new Date('2025-09-13'), y: 40.2033 }, { x: new Date('2025-09-14'), y: 40.2027 }, { x: new Date('2025-09-15'), y: 40.2253 }, { x: new Date('2025-09-16'), y: 40.1339 }, { x: new Date('2025-09-17'), y: 39.9326 }, { x: new Date('2025-09-18'), y: 39.926 }, { x: new Date('2025-09-19'), y: 40.1921 }, { x: new Date('2025-09-20'), y: 40.2852 }, { x: new Date('2025-09-21'), y: 40.2844 }, { x: new Date('2025-09-22'), y: 40.3037 }, { x: new Date('2025-09-23'), y: 40.2404 }, { x: new Date('2025-09-24'), y: 40.2156 }, { x: new Date('2025-09-25'), y: 40.4694 }, { x: new Date('2025-09-26'), y: 40.7071 }, { x: new Date('2025-09-27'), y: 40.7287 }, { x: new Date('2025-09-28'), y: 40.7318 }, { x: new Date('2025-09-29'), y: 40.6962 }, { x: new Date('2025-09-30'), y: 40.4788 }, { x: new Date('2025-10-01'), y: 40.2963 }, { x: new Date('2025-10-02'), y: 40.0507 }, { x: new Date('2025-10-03'), y: 40.054 }, { x: new Date('2025-10-04'), y: 40.1372 }, { x: new Date('2025-10-05'), y: 40.1331 }, { x: new Date('2025-10-06'), y: 40.5501 }, { x: new Date('2025-10-06'), y: 40.5501 }, { x: new Date('2025-10-07'), y: 40.8532 }, { x: new Date('2025-10-08'), y: 41.1941 }, { x: new Date('2025-10-09'), y: 41.5207 }, { x: new Date('2025-10-10'), y: 41.6301 }, { x: new Date('2025-10-11'), y: 41.3352 }, { x: new Date('2025-10-12'), y: 41.3487 }, { x: new Date('2025-10-13'), y: 41.3844 }, { x: new Date('2025-10-14'), y: 41.4222 }, { x: new Date('2025-10-15'), y: 41.3295 }, { x: new Date('2025-10-16'), y: 41.1488 }, { x: new Date('2025-10-17'), y: 40.972 }, { x: new Date('2025-10-18'), y: 40.9629 }, { x: new Date('2025-10-20'), y: 40.9495 }, { x: new Date('2025-10-21'), y: 41.0391 }, { x: new Date('2025-10-22'), y: 41.2547 }, { x: new Date('2025-10-23'), y: 41.3381 }, { x: new Date('2025-10-24'), y: 41.5174 }, { x: new Date('2025-10-25'), y: 41.5933 }, { x: new Date('2025-10-26'), y: 41.5933 }, { x: new Date('2025-10-27'), y: 41.6131 }, { x: new Date('2025-10-28'), y: 41.6643 }, { x: new Date('2025-10-29'), y: 41.614 }, { x: new Date('2025-10-30'), y: 41.4364 }, { x: new Date('2025-10-31'), y: 41.5006 }, { x: new Date('2025-11-01'), y: 41.96204366 }, { x: new Date('2025-11-02'), y: 41.9625 }, { x: new Date('2025-11-03'), y: 41.9671 }, { x: new Date('2025-11-04'), y: 41.9794 }, { x: new Date('2025-11-05'), y: 41.8315 }, { x: new Date('2025-11-06'), y: 41.9149 }, { x: new Date('2025-11-07'), y: 41.78596993 }, { x: new Date('2025-11-08'), y: 41.7294 }, { x: new Date('2025-11-09'), y: 41.7471 }, { x: new Date('2025-11-10'), y: 41.7448 }, { x: new Date('2025-11-11'), y: 41.8258 }, { x: new Date('2025-11-12'), y: 41.9437 }, { x: new Date('2025-11-13'), y: 41.9622 }, { x: new Date('2025-11-14'), y: 42.1239 }, { x: new Date('2025-11-15'), y: 42.082 }, { x: new Date('2025-11-16'), y: 42.0601 }, { x: new Date('2025-11-17'), y: 42.0601 }, { x: new Date('2025-11-18'), y: 42.0669 }, { x: new Date('2025-11-19'), y: 42.2215 }, { x: new Date('2025-11-20'), y: 42.3166 }, { x: new Date('2025-11-21'), y: 42.6495 }, { x: new Date('2025-11-22'), y: 42.8606 }, { x: new Date('2025-11-23'), y: 42.6868 }, { x: new Date('2025-11-24'), y: 42.6868 }, { x: new Date('2025-11-25'), y: 42.7208 }, { x: new Date('2025-11-26'), y: 42.7208 }, { x: new Date('2025-11-27'), y: 42.5233 }, { x: new Date('2025-11-28'), y: 42.5877 }, { x: new Date('2025-11-29'), y: 42.5575 }, { x: new Date('2025-11-30'), y: 42.5255 }, { x: new Date('2025-12-01'), y: 42.5072 }, { x: new Date('2025-12-02'), y: 42.2947 }, { x: new Date('2025-12-03'), y: 42.4456 }, { x: new Date('2025-12-04'), y: 42.2799 }, { x: new Date('2025-12-05'), y: 42.2018 }, { x: new Date('2025-12-06'), y: 42.2629 }, { x: new Date('2025-12-07'), y: 42.2596 }, { x: new Date('2025-12-08'), y: 42.2687 }, { x: new Date('2025-12-09'), y: 42.4061 }, { x: new Date('2025-12-10'), y: 42.6482 }, { x: new Date('2025-12-11'), y: 42.5413 }, { x: new Date('2025-12-12'), y: 42.348 }, { x: new Date('2025-12-13'), y: 42.4317 }, { x: new Date('2025-12-14'), y: 42.4272 }, { x: new Date('2025-12-15'), y: 42.4268 }, { x: new Date('2025-12-16'), y: 42.2592 }, { x: new Date('2025-12-17'), y: 42.1385 }, { x: new Date('2025-12-18'), y: 42.3401 }, { x: new Date('2025-12-19'), y: 42.3719 }, { x: new Date('2025-12-20'), y: 42.8394 }, { x: new Date('2025-12-21'), y: 42.8098 }, { x: new Date('2025-12-22'), y: 42.9048 }, { x: new Date('2025-12-23'), y: 42.772 }, { x: new Date('2025-12-24'), y: 42.536 }, { x: new Date('2025-12-25'), y: 42.4611 }, { x: new Date('2025-12-26'), y: 42.4603 }, { x: new Date('2025-12-27'), y: 42.6064 }, { x: new Date('2025-12-29'), y: 42.614 }, { x: new Date('2025-12-30'), y: 42.6107 }, { x: new Date('2025-12-31'), y: 42.5226 }, { x: new Date('2026-01-01'), y: 42.5529 }, { x: new Date('2026-01-02'), y: 42.6667 }, { x: new Date('2026-01-03'), y: 42.6791 }, { x: new Date('2026-01-04'), y: 42.7083 }, { x: new Date('2026-01-05'), y: 42.707 }, { x: new Date('2026-01-06'), y: 42.6974 }, { x: new Date('2026-01-07'), y: 42.6389 }, { x: new Date('2026-01-08'), y: 42.6471 }, { x: new Date('2026-01-09'), y: 42.6552 }, { x: new Date('2026-01-10'), y: 42.7038 }, { x: new Date('2026-01-11'), y: 42.9624 }, { x: new Date('2026-01-12'), y: 42.9519 }, { x: new Date('2026-01-13'), y: 43.0256 }, { x: new Date('2026-01-14'), y: 43.0253 }, { x: new Date('2026-01-15'), y: 43.2924 }, { x: new Date('2026-01-16'), y: 43.157 }, { x: new Date('2026-01-17'), y: 43.1838 }, { x: new Date('2026-01-18'), y: 43.0675 }, { x: new Date('2026-01-19'), y: 43.0681 }, { x: new Date('2026-01-20'), y: 42.9747 }, { x: new Date('2026-01-21'), y: 43.0327 }, { x: new Date('2026-01-22'), y: 43.029 }, { x: new Date('2026-01-23'), y: 43.0631 }, { x: new Date('2026-01-24'), y: 43.1421 }, { x: new Date('2026-01-25'), y: 42.6987 }, { x: new Date('2026-01-26'), y: 42.7957 }, { x: new Date('2026-01-27'), y: 42.3819 }, { x: new Date('2026-01-28'), y: 41.9677 }, { x: new Date('2026-01-29'), y: 41.6212 }, { x: new Date('2026-01-30'), y: 41.7065 }, { x: new Date('2026-01-31'), y: 41.6908 }, { x: new Date('2026-02-01'), y: 42.0374 }, { x: new Date('2026-02-02'), y: 42.0187 }, { x: new Date('2026-02-03'), y: 42.2099 }, { x: new Date('2026-02-04'), y: 42.3015 }, { x: new Date('2026-02-05'), y: 42.4206 }, { x: new Date('2026-02-06'), y: 42.6608 }, { x: new Date('2026-02-07'), y: 42.7354 }, { x: new Date('2026-02-08'), y: 42.7711 }, { x: new Date('2026-02-09'), y: 42.7672 }, { x: new Date('2026-02-10'), y: 42.847 }, { x: new Date('2026-02-11'), y: 42.5053 }, { x: new Date('2026-02-12'), y: 42.104 }, { x: new Date('2026-02-13'), y: 41.7429 }, { x: new Date('2026-02-14'), y: 41.6477 }, { x: new Date('2026-02-15'), y: 41.6341 }, { x: new Date('2026-02-16'), y: 41.6433 }, { x: new Date('2026-02-17'), y: 41.6143 }, { x: new Date('2026-02-18'), y: 41.7928 }, { x: new Date('2026-02-19'), y: 41.7431 }, { x: new Date('2026-02-20'), y: 42.0461 }, { x: new Date('2026-02-21'), y: 42.1984 }, { x: new Date('2026-02-22'), y: 42.2307 }, { x: new Date('2026-02-23'), y: 42.2443 }, { x: new Date('2026-02-24'), y: 42.1436 }, { x: new Date('2026-02-25'), y: 42.0966 }, { x: new Date('2026-02-26'), y: 42.4086 }, { x: new Date('2026-02-27'), y: 42.5726 }, { x: new Date('2026-02-28'), y: 42.4943 }, { x: new Date('2026-03-01'), y: 42.4837 }, { x: new Date('2026-03-02'), y: 42.488 }, { x: new Date('2026-03-03'), y: 42.5486 }, { x: new Date('2026-03-04'), y: 42.8215 }, { x: new Date('2026-03-05'), y: 42.9321 }, { x: new Date('2026-03-06'), y: 42.7865 }, { x: new Date('2026-03-07'), y: 42.8904 }, { x: new Date('2026-03-08'), y: 42.9568 }, { x: new Date('2026-03-09'), y: 42.9498 }, { x: new Date('2026-03-10'), y: 43.1008 }, { x: new Date('2026-03-11'), y: 43.0503 }, { x: new Date('2026-03-12'), y: 42.9985 }, { x: new Date('2026-03-13'), y: 43.2289 }, { x: new Date('2026-03-14'), y: 43.337 }, { x: new Date('2026-03-15'), y: 43.441 }, { x: new Date('2026-03-16'), y: 43.4304 }, { x: new Date('2026-03-17'), y: 43.4476 }, { x: new Date('2026-03-18'), y: 43.3449 }, { x: new Date('2026-03-19'), y: 43.2941 }, { x: new Date('2026-03-20'), y: 43.2171 }, { x: new Date('2026-03-21'), y: 43.2579 }, { x: new Date('2026-03-22'), y: 43.3028 }, { x: new Date('2026-03-23'), y: 43.2861 }, { x: new Date('2026-03-24'), y: 43.339 }, { x: new Date('2026-03-25'), y: 43.1854 }, { x: new Date('2026-03-26'), y: 43.2284 }, { x: new Date('2026-03-27'), y: 43.3484 }, { x: new Date('2026-03-28'), y: 43.4612 }, { x: new Date('2026-03-29'), y: 43.5833 }, { x: new Date('2026-03-30'), y: 43.5721 }, { x: new Date('2026-03-31'), y: 43.6436 }, { x: new Date('2026-04-01'), y: 43.4805 }, { x: new Date('2026-04-02'), y: 43.1941566 }, { x: new Date('2026-04-03'), y: 43.1928 }, { x: new Date('2026-04-04'), y: 43.4126 }, { x: new Date('2026-04-05'), y: 43.4397 }, { x: new Date('2026-04-06'), y: 43.4495 }, { x: new Date('2026-04-07'), y: 43.4807 }, { x: new Date('2026-04-08'), y: 43.4637 }, { x: new Date('2026-04-09'), y: 43.3703 }, { x: new Date('2026-04-10'), y: 43.1641 }, { x: new Date('2026-04-11'), y: 43.2874 }, { x: new Date('2026-04-12'), y: 43.3625 }, { x: new Date('2026-04-13'), y: 43.3555 }, { x: new Date('2026-04-14'), y: 43.4893 }, { x: new Date('2026-04-15'), y: 43.4202 }, { x: new Date('2026-04-16'), y: 43.2648 }, { x: new Date('2026-04-17'), y: 43.2686 }, { x: new Date('2026-04-18'), y: 43.3272 }, { x: new Date('2026-04-19'), y: 43.191 }, { x: new Date('2026-04-20'), y: 43.2047 }, { x: new Date('2026-04-21'), y: 43.3025 }]; 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);