const fullData = [ { x: new Date('2025-04-21'), y: 38.94 }, { x: new Date('2025-04-22'), y: 38.69 }, { x: new Date('2025-04-23'), y: 38.87 }, { x: new Date('2025-04-24'), y: 39.20 }, { x: new Date('2025-04-25'), y: 39.19 }, { x: new Date('2025-04-26'), y: 39.43 }, { x: new Date('2025-04-27'), y: 39.45 }, { x: new Date('2025-04-28'), y: 39.46 }, { x: new Date('2025-05-02'), y: 39.73 }, { x: new Date('2025-05-03'), y: 39.78 }, { x: new Date('2025-05-05'), y: 39.76 }, { x: new Date('2025-05-06'), y: 39.76 }, { x: new Date('2025-05-07'), y: 39.29 }, { x: new Date('2025-05-08'), y: 39.43 }, { x: new Date('2025-05-09'), y: 39.92 }, { x: new Date('2025-05-10'), y: 39.89 }, { x: new Date('2025-05-11'), y: 39.88 }, { x: new Date('2025-05-12'), y: 40.02 }, { x: new Date('2025-05-13'), y: 40.62 }, { x: new Date('2025-05-14'), y: 40.56 }, { x: new Date('2025-05-15'), y: 40.24 }, { x: new Date('2025-05-16'), y: 40.03 }, { x: new Date('2025-05-17'), y: 40.04 }, { x: new Date('2025-05-19'), y: 39.92 }, { x: new Date('2025-05-20'), y: 39.82 }, { x: new Date('2025-05-21'), y: 39.70 }, { x: new Date('2025-05-22'), y: 39.49 }, { x: new Date('2025-05-24'), y: 39.19 }, { x: new Date('2025-05-26'), y: 39.20 }, { x: new Date('2025-05-27'), y: 39.20 }, { x: new Date('2025-05-29'), y: 39.80 }, { x: new Date('2025-06-02'), y: 39.52 }, { x: new Date('2025-06-06'), y: 39.40 }, { x: new Date('2025-06-10'), y: 39.70 }, { x: new Date('2025-06-11'), y: 39.77 }, { x: new Date('2025-06-12'), y: 39.70 }, { x: new Date('2025-06-14'), y: 39.55 }, { x: new Date('2025-06-15'), y: 39.54 }, { x: new Date('2025-06-16'), y: 39.67 }, { x: new Date('2025-06-17'), y: 39.69 }, { x: new Date('2025-06-18'), y: 39.87 }, { x: new Date('2025-06-20'), y: 39.94 }, { x: new Date('2025-06-21'), y: 40.06 }, { x: new Date('2025-06-22'), y: 40.05 }, { x: new Date('2025-06-23'), y: 40.13 }, { x: new Date('2025-06-24'), y: 40.21 }, { x: new Date('2025-06-25'), y: 39.80 }, { x: new Date('2025-06-26'), y: 39.90 }, { x: new Date('2025-06-27'), y: 39.68 }, { x: new Date('2025-06-28'), y: 39.73 }, { x: new Date('2025-06-29'), y: 39.73 }, { x: new Date('2025-06-30'), y: 39.69 }, { x: new Date('2025-07-01'), y: 39.58 }, { x: new Date('2025-07-02'), y: 39.40 }, { x: new Date('2025-07-04'), y: 39.72 }, { x: new Date('2025-07-05'), y: 39.70 }, { x: new Date('2025-07-06'), y: 39.69 }, { x: new Date('2025-07-07'), y: 39.69 }, { x: new Date('2025-07-08'), y: 40.06 }, { x: new Date('2025-07-09'), y: 40.28 }, { x: new Date('2025-07-10'), y: 40.21 }, { x: new Date('2025-07-11'), y: 40.1890 }, { x: new Date('2025-07-12'), y: 40.44 }, { x: new Date('2025-07-13'), y: 40.4307 }, { x: new Date('2025-07-14'), y: 40.4406 }, { x: new Date('2025-07-15'), y: 40.55 }, { x: new Date('2025-07-16'), y: 40.8028 }, { x: new Date('2025-07-17'), y: 40.7284 }, { x: new Date('2025-07-19'), y: 40.8501 }, { x: new Date('2025-07-20'), y: 40.8508 }, { x: new Date('2025-07-21'), y: 40.8259 }, { x: new Date('2025-07-22'), y: 40.5596 }, { x: new Date('2025-07-23'), y: 40.3316 }, { x: new Date('2025-07-24'), y: 40.2217 }, { x: new Date('2025-07-25'), y: 40.3253 }, { x: new Date('2025-07-26'), y: 40.5503 }, { x: new Date('2025-07-27'), y: 40.5466 }, { x: new Date('2025-07-29'), y: 40.7590 }, { x: new Date('2025-07-30'), y: 40.8052 }, { x: new Date('2025-07-31'), y: 40.9362 }, { x: new Date('2025-08-01'), y: 41.3136 }, { x: new Date('2025-08-02'), y: 40.7073 }, { x: new Date('2025-08-03'), y: 40.7562 }, { x: new Date('2025-08-04'), y: 40.5420 }, { x: new Date('2025-08-05'), y: 40.4175 }, { x: new Date('2025-08-07'), y: 40.4735 }, { x: new Date('2025-08-08'), y: 40.4306 }, { x: new Date('2025-08-09'), y: 40.5716 }, { x: new Date('2025-08-10'), y: 40.5649 }, { x: new Date('2025-08-11'), y: 40.5713 }, { x: new Date('2025-08-12'), y: 40.6680 }, { x: new Date('2025-08-13'), y: 40.6550 }, { x: new Date('2025-08-14'), y: 40.4750 }, { x: new Date('2025-08-15'), y: 40.4968 }, { x: new Date('2025-08-16'), y: 40.4105 }, { x: new Date('2025-08-18'), y: 40.4465 }, { x: new Date('2025-08-19'), y: 40.5918 }, { x: new Date('2025-08-20'), y: 40.5771 }, { x: new Date('2025-08-21'), y: 40.4835 }, { x: new Date('2025-08-22'), y: 40.6909 }, { x: new Date('2025-08-23'), y: 40.4366 }, { x: new Date('2025-08-24'), y: 40.4639 }, { x: new Date('2025-08-25'), y: 40.423 }, { x: new Date('2025-08-26'), y: 40.5581 }, { x: new Date('2025-08-27'), y: 40.4984 }, { x: new Date('2025-08-28'), y: 40.5332 }, { x: new Date('2025-08-29'), y: 40.3902 }, { x: new Date('2025-08-30'), y: 40.393 }, { x: new Date('2025-08-31'), y: 40.3838 }, { x: new Date('2025-09-01'), y: 40.4239 }, { x: new Date('2025-09-02'), y: 40.4212 }, { x: new Date('2025-09-03'), y: 40.7621 }, { x: new Date('2025-09-04'), y: 40.7166 }, { x: new Date('2025-09-05'), y: 40.7755 }, { x: new Date('2025-09-06'), y: 40.5353 }, { x: new Date('2025-09-07'), y: 40.5596 }, { x: new Date('2025-09-08'), y: 40.7306 }, { x: new Date('2025-09-09'), y: 40.5428 }, { x: new Date('2025-09-10'), y: 40.4439 }, { x: new Date('2025-09-11'), y: 40.4862 }, { x: new Date('2025-09-12'), y: 40.4817 }, { x: new Date('2025-09-13'), y: 40.5623 }, { x: new Date('2025-09-14'), y: 40.5616 }, { x: new Date('2025-09-15'), y: 40.5844 }, { x: new Date('2025-09-16'), y: 40.4922 }, { x: new Date('2025-09-17'), y: 40.2891 }, { x: new Date('2025-09-18'), y: 40.2825 }, { x: new Date('2025-09-19'), y: 40.551 }, { x: new Date('2025-09-20'), y: 40.6449 }, { x: new Date('2025-09-21'), y: 40.6441 }, { x: new Date('2025-09-22'), y: 40.6636 }, { x: new Date('2025-09-23'), y: 40.5997 }, { x: new Date('2025-09-24'), y: 40.5746 }, { x: new Date('2025-09-25'), y: 40.8308 }, { x: new Date('2025-09-26'), y: 41.0706 }, { x: new Date('2025-09-27'), y: 41.0923 }, { x: new Date('2025-09-28'), y: 41.0955 }, { x: new Date('2025-09-29'), y: 41.0596 }, { x: new Date('2025-09-30'), y: 40.8402 }, { x: new Date('2025-10-01'), y: 40.6561 }, { x: new Date('2025-10-02'), y: 40.4083 }, { x: new Date('2025-10-03'), y: 40.4117 }, { x: new Date('2025-10-04'), y: 40.4956 }, { x: new Date('2025-10-05'), y: 40.4915 }, { x: new Date('2025-10-06'), y: 40.9122 }, { x: new Date('2025-10-06'), y: 40.9122 }, { x: new Date('2025-10-07'), y: 41.218 }, { x: new Date('2025-10-08'), y: 41.5619 }, { x: new Date('2025-10-09'), y: 41.8914 }, { x: new Date('2025-10-10'), y: 42.0018 }, { x: new Date('2025-10-11'), y: 41.7043 }, { x: new Date('2025-10-12'), y: 41.7179 }, { x: new Date('2025-10-13'), y: 41.7539 }, { x: new Date('2025-10-14'), y: 41.7921 }, { x: new Date('2025-10-15'), y: 41.6985 }, { x: new Date('2025-10-16'), y: 41.5162 }, { x: new Date('2025-10-17'), y: 41.3378 }, { x: new Date('2025-10-18'), y: 41.3286 }, { x: new Date('2025-10-20'), y: 41.3151 }, { x: new Date('2025-10-21'), y: 41.4056 }, { x: new Date('2025-10-22'), y: 41.6231 }, { x: new Date('2025-10-23'), y: 41.7072 }, { x: new Date('2025-10-24'), y: 41.8881 }, { x: new Date('2025-10-25'), y: 41.9647 }, { x: new Date('2025-10-26'), y: 41.9647 }, { x: new Date('2025-10-27'), y: 41.9847 }, { x: new Date('2025-10-28'), y: 42.0363 }, { x: new Date('2025-10-29'), y: 41.9856 }, { x: new Date('2025-10-30'), y: 41.8064 }, { x: new Date('2025-10-31'), y: 41.8712 }, { x: new Date('2025-11-01'), y: 42.33670476 }, { x: new Date('2025-11-02'), y: 42.3372 }, { x: new Date('2025-11-03'), y: 42.3418 }, { x: new Date('2025-11-04'), y: 42.3542 }, { x: new Date('2025-11-05'), y: 42.205 }, { x: new Date('2025-11-06'), y: 42.2892 }, { x: new Date('2025-11-07'), y: 42.15905894 }, { x: new Date('2025-11-08'), y: 42.102 }, { x: new Date('2025-11-09'), y: 42.1198 }, { x: new Date('2025-11-10'), y: 42.1175 }, { x: new Date('2025-11-11'), y: 42.1992 }, { x: new Date('2025-11-12'), y: 42.3182 }, { x: new Date('2025-11-13'), y: 42.3369 }, { x: new Date('2025-11-14'), y: 42.5 }, { x: new Date('2025-11-15'), y: 42.4577 }, { x: new Date('2025-11-16'), y: 42.4356 }, { x: new Date('2025-11-17'), y: 42.4356 }, { x: new Date('2025-11-18'), y: 42.4425 }, { x: new Date('2025-11-19'), y: 42.5984 }, { x: new Date('2025-11-20'), y: 42.6944 }, { x: new Date('2025-11-21'), y: 43.0303 }, { x: new Date('2025-11-22'), y: 43.2432 }, { x: new Date('2025-11-23'), y: 43.068 }, { x: new Date('2025-11-24'), y: 43.068 }, { x: new Date('2025-11-25'), y: 43.1022 }, { x: new Date('2025-11-26'), y: 43.1022 }, { x: new Date('2025-11-27'), y: 42.9029 }, { x: new Date('2025-11-28'), y: 42.9679 }, { x: new Date('2025-11-29'), y: 42.9374 }, { x: new Date('2025-11-30'), y: 42.9051 }, { x: new Date('2025-12-01'), y: 42.8867 }, { x: new Date('2025-12-02'), y: 42.6724 }, { x: new Date('2025-12-03'), y: 42.8246 }, { x: new Date('2025-12-04'), y: 42.6574 }, { x: new Date('2025-12-05'), y: 42.5786 }, { x: new Date('2025-12-06'), y: 42.6402 }, { x: new Date('2025-12-07'), y: 42.637 }, { x: new Date('2025-12-08'), y: 42.6461 }, { x: new Date('2025-12-09'), y: 42.7847 }, { x: new Date('2025-12-10'), y: 43.029 }, { x: new Date('2025-12-11'), y: 42.9211 }, { x: new Date('2025-12-12'), y: 42.7261 }, { x: new Date('2025-12-13'), y: 42.8106 }, { x: new Date('2025-12-14'), y: 42.806 }, { x: new Date('2025-12-15'), y: 42.8056 }, { x: new Date('2025-12-16'), y: 42.6365 }, { x: new Date('2025-12-17'), y: 42.5147 }, { x: new Date('2025-12-18'), y: 42.7181 }, { x: new Date('2025-12-19'), y: 42.7502 }, { x: new Date('2025-12-20'), y: 43.2219 }, { x: new Date('2025-12-21'), y: 43.192 }, { x: new Date('2025-12-22'), y: 43.2879 }, { x: new Date('2025-12-23'), y: 43.1539 }, { x: new Date('2025-12-24'), y: 42.9158 }, { x: new Date('2025-12-25'), y: 42.8402 }, { x: new Date('2025-12-26'), y: 42.8394 }, { x: new Date('2025-12-27'), y: 42.9868 }, { x: new Date('2025-12-29'), y: 42.9945 }, { x: new Date('2025-12-30'), y: 42.9911 }, { x: new Date('2025-12-31'), y: 42.9022 }, { x: new Date('2026-01-01'), y: 42.9329 }, { x: new Date('2026-01-02'), y: 43.0476 }, { x: new Date('2026-01-03'), y: 43.0602 }, { x: new Date('2026-01-04'), y: 43.0897 }, { x: new Date('2026-01-05'), y: 43.0883 }, { x: new Date('2026-01-06'), y: 43.0787 }, { x: new Date('2026-01-07'), y: 43.0196 }, { x: new Date('2026-01-08'), y: 43.0279 }, { x: new Date('2026-01-09'), y: 43.0361 }, { x: new Date('2026-01-10'), y: 43.0851 }, { x: new Date('2026-01-11'), y: 43.346 }, { x: new Date('2026-01-12'), y: 43.3354 }, { x: new Date('2026-01-13'), y: 43.4098 }, { x: new Date('2026-01-14'), y: 43.4094 }, { x: new Date('2026-01-15'), y: 43.679 }, { x: new Date('2026-01-16'), y: 43.5424 }, { x: new Date('2026-01-17'), y: 43.5694 }, { x: new Date('2026-01-18'), y: 43.452 }, { x: new Date('2026-01-19'), y: 43.4526 }, { x: new Date('2026-01-20'), y: 43.3584 }, { x: new Date('2026-01-21'), y: 43.4169 }, { x: new Date('2026-01-22'), y: 43.4132 }, { x: new Date('2026-01-23'), y: 43.4476 }, { x: new Date('2026-01-24'), y: 43.5273 }, { x: new Date('2026-01-25'), y: 43.0799 }, { x: new Date('2026-01-26'), y: 43.1778 }, { x: new Date('2026-01-27'), y: 42.7603 }, { x: new Date('2026-01-28'), y: 42.3424 }, { x: new Date('2026-01-29'), y: 41.9928 }, { x: new Date('2026-01-30'), y: 42.0788 }, { x: new Date('2026-01-31'), y: 42.0631 }, { x: new Date('2026-02-01'), y: 42.4127 }, { x: new Date('2026-02-02'), y: 42.3938 }, { x: new Date('2026-02-03'), y: 42.5867 }, { x: new Date('2026-02-04'), y: 42.6791 }, { x: new Date('2026-02-05'), y: 42.7994 }, { x: new Date('2026-02-06'), y: 43.0418 }, { x: new Date('2026-02-07'), y: 43.1169 }, { x: new Date('2026-02-08'), y: 43.153 }, { x: new Date('2026-02-09'), y: 43.149 }, { x: new Date('2026-02-10'), y: 43.2296 }, { x: new Date('2026-02-11'), y: 42.8848 }, { x: new Date('2026-02-12'), y: 42.4799 }, { x: new Date('2026-02-13'), y: 42.1156 }, { x: new Date('2026-02-14'), y: 42.0195 }, { x: new Date('2026-02-15'), y: 42.0058 }, { x: new Date('2026-02-16'), y: 42.0151 }, { x: new Date('2026-02-17'), y: 41.9859 }, { x: new Date('2026-02-18'), y: 42.166 }, { x: new Date('2026-02-19'), y: 42.1158 }, { x: new Date('2026-02-20'), y: 42.4215 }, { x: new Date('2026-02-21'), y: 42.5752 }, { x: new Date('2026-02-22'), y: 42.6077 }, { x: new Date('2026-02-23'), y: 42.6214 }, { x: new Date('2026-02-24'), y: 42.5198 }, { x: new Date('2026-02-25'), y: 42.4725 }, { x: new Date('2026-02-26'), y: 42.7872 }, { x: new Date('2026-02-27'), y: 42.9527 }, { x: new Date('2026-02-28'), y: 42.8737 }, { x: new Date('2026-03-01'), y: 42.863 }, { x: new Date('2026-03-02'), y: 42.8674 }, { x: new Date('2026-03-03'), y: 42.9285 }, { x: new Date('2026-03-04'), y: 43.2039 }, { x: new Date('2026-03-05'), y: 43.3155 }, { x: new Date('2026-03-06'), y: 43.1685 }, { x: new Date('2026-03-07'), y: 43.2734 }, { x: new Date('2026-03-08'), y: 43.3404 }, { x: new Date('2026-03-09'), y: 43.3333 }, { x: new Date('2026-03-10'), y: 43.4856 }, { x: new Date('2026-03-11'), y: 43.4347 }, { x: new Date('2026-03-12'), y: 43.3824 }, { x: new Date('2026-03-13'), y: 43.6149 }, { x: new Date('2026-03-14'), y: 43.724 }, { x: new Date('2026-03-15'), y: 43.8289 }, { x: new Date('2026-03-16'), y: 43.8182 }, { x: new Date('2026-03-17'), y: 43.8355 }, { x: new Date('2026-03-18'), y: 43.7319 }, { x: new Date('2026-03-19'), y: 43.6806 }, { x: new Date('2026-03-20'), y: 43.603 }, { x: new Date('2026-03-21'), y: 43.6441 }, { x: new Date('2026-03-22'), y: 43.6894 }, { x: new Date('2026-03-23'), y: 43.6726 }, { x: new Date('2026-03-24'), y: 43.726 }, { x: new Date('2026-03-25'), y: 43.571 }, { x: new Date('2026-03-26'), y: 43.6143 }, { x: new Date('2026-03-27'), y: 43.7354 }, { x: new Date('2026-03-28'), y: 43.8492 }, { x: new Date('2026-03-29'), y: 43.9725 }, { x: new Date('2026-03-30'), y: 43.9612 }, { x: new Date('2026-03-31'), y: 44.0332 }, { x: new Date('2026-04-01'), y: 43.8687 }, { x: new Date('2026-04-02'), y: 43.57981871 }, { x: new Date('2026-04-03'), y: 43.5784 }, { x: new Date('2026-04-04'), y: 43.8002 }, { x: new Date('2026-04-05'), y: 43.8275 }, { x: new Date('2026-04-06'), y: 43.8374 }, { x: new Date('2026-04-07'), y: 43.869 }, { x: new Date('2026-04-08'), y: 43.8517 }, { x: new Date('2026-04-09'), y: 43.7575 }, { x: new Date('2026-04-10'), y: 43.5495 }, { x: new Date('2026-04-11'), y: 43.6739 }, { x: new Date('2026-04-12'), y: 43.7496 }, { x: new Date('2026-04-13'), y: 43.7426 }, { x: new Date('2026-04-14'), y: 43.8776 }, { x: new Date('2026-04-15'), y: 43.8079 }, { x: new Date('2026-04-16'), y: 43.6511 }, { x: new Date('2026-04-17'), y: 43.6549 }, { x: new Date('2026-04-18'), y: 43.7141 }, { x: new Date('2026-04-19'), y: 43.5766 }, { x: new Date('2026-04-20'), y: 43.5905 }, { x: new Date('2026-04-21'), y: 43.6891 }, { x: new Date('2026-04-22'), y: 43.6237 }, { x: new Date('2026-04-23'), y: 43.7591 }, { x: new Date('2026-04-24'), y: 43.7891 }, { x: new Date('2026-04-25'), y: 43.8486 }, { x: new Date('2026-04-26'), y: 43.806 }, { x: new Date('2026-04-27'), y: 43.8084 }, { x: new Date('2026-04-28'), y: 43.825 }, { x: new Date('2026-04-29'), y: 43.7776 }, { x: new Date('2026-04-30'), y: 43.9897 }]; 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);