const fullData = [ { x: new Date('2025-04-21'), y: 0.0054 }, { x: new Date('2025-04-22'), y: 0.0054 }, { x: new Date('2025-04-23'), y: 0.0055 }, { x: new Date('2025-04-24'), y: 0.0055 }, { x: new Date('2025-04-25'), y: 0.0054 }, { x: new Date('2025-04-26'), y: 0.0055 }, { x: new Date('2025-04-27'), y: 0.0055 }, { x: new Date('2025-04-28'), y: 0.0055 }, { x: new Date('2025-05-02'), y: 0.0055 }, { x: new Date('2025-05-03'), y: 0.0055 }, { x: new Date('2025-05-05'), y: 0.0055 }, { x: new Date('2025-05-06'), y: 0.0055 }, { x: new Date('2025-05-07'), y: 0.0055 }, { x: new Date('2025-05-08'), y: 0.0055 }, { x: new Date('2025-05-09'), y: 0.0056 }, { x: new Date('2025-05-10'), y: 0.0056 }, { x: new Date('2025-05-11'), y: 0.0056 }, { x: new Date('2025-05-12'), y: 0.0056 }, { x: new Date('2025-05-13'), y: 0.0057 }, { x: new Date('2025-05-14'), y: 0.0056 }, { x: new Date('2025-05-15'), y: 0.0056 }, { x: new Date('2025-05-16'), y: 0.0056 }, { x: new Date('2025-05-17'), y: 0.0056 }, { x: new Date('2025-05-19'), y: 0.0062 }, { x: new Date('2025-05-20'), y: 0.0055 }, { x: new Date('2025-05-21'), y: 0.0055 }, { x: new Date('2025-05-22'), y: 0.0055 }, { x: new Date('2025-05-24'), y: 0.0054 }, { x: new Date('2025-05-26'), y: 0.0055 }, { x: new Date('2025-05-27'), y: 0.0055 }, { x: new Date('2025-05-29'), y: 0.0056 }, { x: new Date('2025-06-02'), y: 0.0055 }, { x: new Date('2025-06-06'), y: 0.0055 }, { x: new Date('2025-06-10'), y: 0.0055 }, { x: new Date('2025-06-11'), y: 0.0055 }, { x: new Date('2025-06-12'), y: 0.0055 }, { x: new Date('2025-06-14'), y: 0.0055 }, { x: new Date('2025-06-15'), y: 0.0055 }, { x: new Date('2025-06-16'), y: 0.0055 }, { x: new Date('2025-06-17'), y: 0.0055 }, { x: new Date('2025-06-18'), y: 0.0055 }, { x: new Date('2025-06-20'), y: 0.0055 }, { x: new Date('2025-06-21'), y: 0.0055 }, { x: new Date('2025-06-22'), y: 0.0056 }, { x: new Date('2025-06-23'), y: 0.0056 }, { x: new Date('2025-06-24'), y: 0.0056 }, { x: new Date('2025-06-25'), y: 0.0055 }, { x: new Date('2025-06-26'), y: 0.0055 }, { x: new Date('2025-06-27'), y: 0.0055 }, { x: new Date('2025-06-28'), y: 0.0055 }, { x: new Date('2025-06-29'), y: 0.0055 }, { x: new Date('2025-06-30'), y: 0.0055 }, { x: new Date('2025-07-01'), y: 0.0055 }, { x: new Date('2025-07-02'), y: 0.0055 }, { x: new Date('2025-07-04'), y: 0.0055 }, { x: new Date('2025-07-05'), y: 0.0055 }, { x: new Date('2025-07-06'), y: 0.0055 }, { x: new Date('2025-07-07'), y: 0.0055 }, { x: new Date('2025-07-08'), y: 0.0056 }, { x: new Date('2025-07-09'), y: 0.0056 }, { x: new Date('2025-07-10'), y: 0.0056 }, { x: new Date('2025-07-11'), y: 0.005615 }, { x: new Date('2025-07-12'), y: 0.0056 }, { x: new Date('2025-07-13'), y: 0.005648 }, { x: new Date('2025-07-14'), y: 0.005739 }, { x: new Date('2025-07-15'), y: 0.005666 }, { x: new Date('2025-07-16'), y: 0.005689 }, { x: new Date('2025-07-17'), y: 0.005684 }, { x: new Date('2025-07-19'), y: 0.005698 }, { x: new Date('2025-07-20'), y: 0.0057 }, { x: new Date('2025-07-21'), y: 0.005696 }, { x: new Date('2025-07-22'), y: 0.005664 }, { x: new Date('2025-07-23'), y: 0.005639 }, { x: new Date('2025-07-24'), y: 0.005617 }, { x: new Date('2025-07-25'), y: 0.005634 }, { x: new Date('2025-07-26'), y: 0.005651 }, { x: new Date('2025-07-27'), y: 0.005654 }, { x: new Date('2025-07-29'), y: 0.005688 }, { x: new Date('2025-07-30'), y: 0.005681 }, { x: new Date('2025-07-31'), y: 0.005702 }, { x: new Date('2025-08-01'), y: 0.005752 }, { x: new Date('2025-08-02'), y: 0.005801 }, { x: new Date('2025-08-03'), y: 0.005788 }, { x: new Date('2025-08-04'), y: 0.005783 }, { x: new Date('2025-08-05'), y: 0.00563 }, { x: new Date('2025-08-07'), y: 0.005635 }, { x: new Date('2025-08-08'), y: 0.005624 }, { x: new Date('2025-08-09'), y: 0.005644 }, { x: new Date('2025-08-10'), y: 0.005648 }, { x: new Date('2025-08-11'), y: 0.005652 }, { x: new Date('2025-08-12'), y: 0.005663 }, { x: new Date('2025-08-13'), y: 0.005655 }, { x: new Date('2025-08-14'), y: 0.005628 }, { x: new Date('2025-08-15'), y: 0.005642 }, { x: new Date('2025-08-16'), y: 0.005612 }, { x: new Date('2025-08-18'), y: 0.005632 }, { x: new Date('2025-08-19'), y: 0.005647 }, { x: new Date('2025-08-20'), y: 0.005633 }, { x: new Date('2025-08-21'), y: 0.005621 }, { x: new Date('2025-08-22'), y: 0.005634 }, { x: new Date('2025-08-23'), y: 0.005623 }, { x: new Date('2025-08-24'), y: 0.005618 }, { x: new Date('2025-08-25'), y: 0.005633 }, { x: new Date('2025-08-26'), y: 0.005634 }, { x: new Date('2025-08-27'), y: 0.005619 }, { x: new Date('2025-08-28'), y: 0.005615 }, { x: new Date('2025-08-29'), y: 0.005599 }, { x: new Date('2025-08-30'), y: 0.005614 }, { x: new Date('2025-08-31'), y: 0.005605 }, { x: new Date('2025-09-01'), y: 0.005613 }, { x: new Date('2025-09-02'), y: 0.005611 }, { x: new Date('2025-09-03'), y: 0.005661 }, { x: new Date('2025-09-04'), y: 0.005638 }, { x: new Date('2025-09-05'), y: 0.005633 }, { x: new Date('2025-09-06'), y: 0.005631 }, { x: new Date('2025-09-07'), y: 0.005624 }, { x: new Date('2025-09-08'), y: 0.005649 }, { x: new Date('2025-09-09'), y: 0.005613 }, { x: new Date('2025-09-10'), y: 0.005611 }, { x: new Date('2025-09-11'), y: 0.005611 }, { x: new Date('2025-09-12'), y: 0.005616 }, { x: new Date('2025-09-13'), y: 0.005633 }, { x: new Date('2025-09-14'), y: 0.005621 }, { x: new Date('2025-09-15'), y: 0.005626 }, { x: new Date('2025-09-16'), y: 0.005619 }, { x: new Date('2025-09-17'), y: 0.005591 }, { x: new Date('2025-09-18'), y: 0.0056 }, { x: new Date('2025-09-19'), y: 0.00563 }, { x: new Date('2025-09-20'), y: 0.005642 }, { x: new Date('2025-09-21'), y: 0.005631 }, { x: new Date('2025-09-22'), y: 0.005636 }, { x: new Date('2025-09-23'), y: 0.005625 }, { x: new Date('2025-09-24'), y: 0.005618 }, { x: new Date('2025-09-25'), y: 0.005654 }, { x: new Date('2025-09-26'), y: 0.005629 }, { x: new Date('2025-09-27'), y: 0.005722 }, { x: new Date('2025-09-28'), y: 0.005706 }, { x: new Date('2025-09-29'), y: 0.005682 }, { x: new Date('2025-09-30'), y: 0.00565 }, { x: new Date('2025-10-01'), y: 0.005627 }, { x: new Date('2025-10-02'), y: 0.005592 }, { x: new Date('2025-10-03'), y: 0.005602 }, { x: new Date('2025-10-04'), y: 0.005618 }, { x: new Date('2025-10-05'), y: 0.005608 }, { x: new Date('2025-10-06'), y: 0.00565 }, { x: new Date('2025-10-06'), y: 0.00565 }, { x: new Date('2025-10-07'), y: 0.005721 }, { x: new Date('2025-10-08'), y: 0.005767 }, { x: new Date('2025-10-09'), y: 0.005814 }, { x: new Date('2025-10-10'), y: 0.005823 }, { x: new Date('2025-10-11'), y: 0.005807 }, { x: new Date('2025-10-12'), y: 0.005799 }, { x: new Date('2025-10-13'), y: 0.005794 }, { x: new Date('2025-10-14'), y: 0.005801 }, { x: new Date('2025-10-15'), y: 0.005798 }, { x: new Date('2025-10-16'), y: 0.005758 }, { x: new Date('2025-10-17'), y: 0.005748 }, { x: new Date('2025-10-18'), y: 0.005768 }, { x: new Date('2025-10-20'), y: 0.005754 }, { x: new Date('2025-10-21'), y: 0.005743 }, { x: new Date('2025-10-22'), y: 0.00578 }, { x: new Date('2025-10-23'), y: 0.005789 }, { x: new Date('2025-10-24'), y: 0.005818 }, { x: new Date('2025-10-25'), y: 0.00582 }, { x: new Date('2025-10-26'), y: 0.00582 }, { x: new Date('2025-10-27'), y: 0.005827 }, { x: new Date('2025-10-28'), y: 0.005836 }, { x: new Date('2025-10-29'), y: 0.005847 }, { x: new Date('2025-10-30'), y: 0.005796 }, { x: new Date('2025-10-31'), y: 0.005807 }, { x: new Date('2025-11-01'), y: 0.0058589 }, { x: new Date('2025-11-02'), y: 0.00586 }, { x: new Date('2025-11-03'), y: 0.005881 }, { x: new Date('2025-11-04'), y: 0.005893 }, { x: new Date('2025-11-05'), y: 0.005866 }, { x: new Date('2025-11-06'), y: 0.005876 }, { x: new Date('2025-11-07'), y: 0.00585429 }, { x: new Date('2025-11-08'), y: 0.005854 }, { x: new Date('2025-11-09'), y: 0.005883 }, { x: new Date('2025-11-10'), y: 0.005871 }, { x: new Date('2025-11-11'), y: 0.005865 }, { x: new Date('2025-11-12'), y: 0.005893 }, { x: new Date('2025-11-13'), y: 0.005896 }, { x: new Date('2025-11-14'), y: 0.00591 }, { x: new Date('2025-11-15'), y: 0.005904 }, { x: new Date('2025-11-16'), y: 0.005902 }, { x: new Date('2025-11-17'), y: 0.005902 }, { x: new Date('2025-11-18'), y: 0.005884 }, { x: new Date('2025-11-19'), y: 0.005903 }, { x: new Date('2025-11-20'), y: 0.005914 }, { x: new Date('2025-11-21'), y: 0.005959 }, { x: new Date('2025-11-22'), y: 0.005997 }, { x: new Date('2025-11-23'), y: 0.005968 }, { x: new Date('2025-11-24'), y: 0.005968 }, { x: new Date('2025-11-25'), y: 0.00597 }, { x: new Date('2025-11-26'), y: 0.00597 }, { x: new Date('2025-11-27'), y: 0.005962 }, { x: new Date('2025-11-28'), y: 0.005951 }, { x: new Date('2025-11-29'), y: 0.005951 }, { x: new Date('2025-11-30'), y: 0.005944 }, { x: new Date('2025-12-01'), y: 0.005949 }, { x: new Date('2025-12-02'), y: 0.005916 }, { x: new Date('2025-12-03'), y: 0.005931 }, { x: new Date('2025-12-04'), y: 0.00591 }, { x: new Date('2025-12-05'), y: 0.005898 }, { x: new Date('2025-12-06'), y: 0.0059 }, { x: new Date('2025-12-07'), y: 0.005906 }, { x: new Date('2025-12-08'), y: 0.005909 }, { x: new Date('2025-12-09'), y: 0.005929 }, { x: new Date('2025-12-10'), y: 0.005964 }, { x: new Date('2025-12-11'), y: 0.00596 }, { x: new Date('2025-12-12'), y: 0.00593 }, { x: new Date('2025-12-13'), y: 0.005941 }, { x: new Date('2025-12-14'), y: 0.005946 }, { x: new Date('2025-12-15'), y: 0.005949 }, { x: new Date('2025-12-16'), y: 0.00592 }, { x: new Date('2025-12-17'), y: 0.005899 }, { x: new Date('2025-12-18'), y: 0.005925 }, { x: new Date('2025-12-19'), y: 0.005934 }, { x: new Date('2025-12-20'), y: 0.005985 }, { x: new Date('2025-12-21'), y: 0.005983 }, { x: new Date('2025-12-22'), y: 0.006011 }, { x: new Date('2025-12-23'), y: 0.005986 }, { x: new Date('2025-12-24'), y: 0.00596 }, { x: new Date('2025-12-25'), y: 0.005954 }, { x: new Date('2025-12-26'), y: 0.005956 }, { x: new Date('2025-12-27'), y: 0.005961 }, { x: new Date('2025-12-29'), y: 0.005967 }, { x: new Date('2025-12-30'), y: 0.005978 }, { x: new Date('2025-12-31'), y: 0.005965 }, { x: new Date('2026-01-01'), y: 0.005978 }, { x: new Date('2026-01-02'), y: 0.005988 }, { x: new Date('2026-01-03'), y: 0.005982 }, { x: new Date('2026-01-04'), y: 0.005971 }, { x: new Date('2026-01-05'), y: 0.005973 }, { x: new Date('2026-01-06'), y: 0.005991 }, { x: new Date('2026-01-07'), y: 0.005985 }, { x: new Date('2026-01-08'), y: 0.005987 }, { x: new Date('2026-01-09'), y: 0.005991 }, { x: new Date('2026-01-10'), y: 0.005994 }, { x: new Date('2026-01-11'), y: 0.006016 }, { x: new Date('2026-01-12'), y: 0.00602 }, { x: new Date('2026-01-13'), y: 0.006039 }, { x: new Date('2026-01-14'), y: 0.006035 }, { x: new Date('2026-01-15'), y: 0.006063 }, { x: new Date('2026-01-16'), y: 0.006055 }, { x: new Date('2026-01-17'), y: 0.006056 }, { x: new Date('2026-01-18'), y: 0.006034 }, { x: new Date('2026-01-19'), y: 0.006043 }, { x: new Date('2026-01-20'), y: 0.006009 }, { x: new Date('2026-01-21'), y: 0.006042 }, { x: new Date('2026-01-22'), y: 0.006042 }, { x: new Date('2026-01-23'), y: 0.006054 }, { x: new Date('2026-01-24'), y: 0.006064 }, { x: new Date('2026-01-25'), y: 0.006003 }, { x: new Date('2026-01-26'), y: 0.006002 }, { x: new Date('2026-01-27'), y: 0.006074 }, { x: new Date('2026-01-28'), y: 0.005907 }, { x: new Date('2026-01-29'), y: 0.005889 }, { x: new Date('2026-01-30'), y: 0.005882 }, { x: new Date('2026-01-31'), y: 0.005903 }, { x: new Date('2026-02-01'), y: 0.005953 }, { x: new Date('2026-02-02'), y: 0.005953 }, { x: new Date('2026-02-03'), y: 0.00599 }, { x: new Date('2026-02-04'), y: 0.005983 }, { x: new Date('2026-02-05'), y: 0.006004 }, { x: new Date('2026-02-06'), y: 0.006042 }, { x: new Date('2026-02-07'), y: 0.006058 }, { x: new Date('2026-02-08'), y: 0.006059 }, { x: new Date('2026-02-09'), y: 0.006062 }, { x: new Date('2026-02-10'), y: 0.006076 }, { x: new Date('2026-02-11'), y: 0.006043 }, { x: new Date('2026-02-12'), y: 0.006005 }, { x: new Date('2026-02-13'), y: 0.005908 }, { x: new Date('2026-02-14'), y: 0.005903 }, { x: new Date('2026-02-15'), y: 0.005894 }, { x: new Date('2026-02-16'), y: 0.005902 }, { x: new Date('2026-02-17'), y: 0.005933 }, { x: new Date('2026-02-18'), y: 0.005923 }, { x: new Date('2026-02-19'), y: 0.005916 }, { x: new Date('2026-02-20'), y: 0.005958 }, { x: new Date('2026-02-21'), y: 0.005987 }, { x: new Date('2026-02-22'), y: 0.005982 }, { x: new Date('2026-02-23'), y: 0.005988 }, { x: new Date('2026-02-24'), y: 0.005975 }, { x: new Date('2026-02-25'), y: 0.005941 }, { x: new Date('2026-02-26'), y: 0.005963 }, { x: new Date('2026-02-27'), y: 0.005994 }, { x: new Date('2026-02-28'), y: 0.005988 }, { x: new Date('2026-03-01'), y: 0.005986 }, { x: new Date('2026-03-02'), y: 0.005986 }, { x: new Date('2026-03-03'), y: 0.006021 }, { x: new Date('2026-03-04'), y: 0.006022 }, { x: new Date('2026-03-05'), y: 0.006041 }, { x: new Date('2026-03-06'), y: 0.006029 }, { x: new Date('2026-03-07'), y: 0.006037 }, { x: new Date('2026-03-08'), y: 0.006028 }, { x: new Date('2026-03-09'), y: 0.006032 }, { x: new Date('2026-03-10'), y: 0.006042 }, { x: new Date('2026-03-11'), y: 0.006051 }, { x: new Date('2026-03-12'), y: 0.006038 }, { x: new Date('2026-03-13'), y: 0.006065 }, { x: new Date('2026-03-14'), y: 0.006076 }, { x: new Date('2026-03-15'), y: 0.00608 }, { x: new Date('2026-03-16'), y: 0.006085 }, { x: new Date('2026-03-17'), y: 0.006098 }, { x: new Date('2026-03-18'), y: 0.006088 }, { x: new Date('2026-03-19'), y: 0.006082 }, { x: new Date('2026-03-20'), y: 0.006059 }, { x: new Date('2026-03-21'), y: 0.006074 }, { x: new Date('2026-03-22'), y: 0.006055 }, { x: new Date('2026-03-23'), y: 0.006053 }, { x: new Date('2026-03-24'), y: 0.00605 }, { x: new Date('2026-03-25'), y: 0.006027 }, { x: new Date('2026-03-26'), y: 0.006057 }, { x: new Date('2026-03-27'), y: 0.006063 }, { x: new Date('2026-03-28'), y: 0.006082 }, { x: new Date('2026-03-29'), y: 0.006089 }, { x: new Date('2026-03-30'), y: 0.006093 }, { x: new Date('2026-03-31'), y: 0.006105 }, { x: new Date('2026-04-01'), y: 0.00608 }, { x: new Date('2026-04-02'), y: 0.00606413 }, { x: new Date('2026-04-03'), y: 0.006055 }, { x: new Date('2026-04-04'), y: 0.006083 }, { x: new Date('2026-04-05'), y: 0.006068 }, { x: new Date('2026-04-06'), y: 0.006073 }, { x: new Date('2026-04-07'), y: 0.006087 }, { x: new Date('2026-04-08'), y: 0.006089 }, { x: new Date('2026-04-09'), y: 0.006074 }, { x: new Date('2026-04-10'), y: 0.006043 }, { x: new Date('2026-04-11'), y: 0.006063 }, { x: new Date('2026-04-12'), y: 0.006056 }, { x: new Date('2026-04-13'), y: 0.006062 }, { x: new Date('2026-04-14'), y: 0.006081 }, { x: new Date('2026-04-15'), y: 0.006074 }, { x: new Date('2026-04-16'), y: 0.006053 }, { x: new Date('2026-04-17'), y: 0.006059 }, { x: new Date('2026-04-18'), y: 0.006059 }, { x: new Date('2026-04-19'), y: 0.006039 }, { x: new Date('2026-04-20'), y: 0.006047 }, { x: new Date('2026-04-21'), y: 0.00606 }, { x: new Date('2026-04-22'), y: 0.006055 }, { x: new Date('2026-04-23'), y: 0.006067 }, { x: new Date('2026-04-24'), y: 0.006073 }, { x: new Date('2026-04-25'), y: 0.006084 }, { x: new Date('2026-04-26'), y: 0.006062 }, { x: new Date('2026-04-27'), y: 0.00607 }, { x: new Date('2026-04-28'), y: 0.006081 }, { x: new Date('2026-04-29'), y: 0.006075 }, { x: new Date('2026-04-30'), y: 0.006092 }]; 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);