mediahub-fe/app/[locale]/(protected)/charts/appex-charts/charts-appex-line/zoomable-timeseries.tsx

602 lines
12 KiB
TypeScript

"use client";
import dynamic from "next/dynamic";
const Chart = dynamic(() => import("react-apexcharts"), { ssr: false });
import { colors } from "@/lib/colors";
import { useTheme } from "next-themes";
import { hexToRGB } from "@/lib/utils";
import { useConfig } from "@/hooks/use-config";
import {
getGridConfig,
getYAxisConfig,
getLabel,
} from "@/lib/appex-chart-options";
const ZoomableTimeSeries = ({ height = 300 }) => {
const [config] = useConfig();
const { theme: mode } = useTheme();
const series = [
{
name: "XYZ MOTORS",
data: [
{
x: new Date("2018-01-12").getTime(),
y: 140,
},
{
x: new Date("2018-01-13").getTime(),
y: 147,
},
{
x: new Date("2018-01-14").getTime(),
y: 150,
},
{
x: new Date("2018-01-15").getTime(),
y: 154,
},
{
x: new Date("2018-01-16").getTime(),
y: 160,
},
{
x: new Date("2018-01-17").getTime(),
y: 165,
},
{
x: new Date("2018-01-18").getTime(),
y: 162,
},
{
x: new Date("2018-01-20").getTime(),
y: 159,
},
{
x: new Date("2018-01-21").getTime(),
y: 164,
},
{
x: new Date("2018-01-22").getTime(),
y: 160,
},
{
x: new Date("2018-01-23").getTime(),
y: 165,
},
{
x: new Date("2018-01-24").getTime(),
y: 169,
},
{
x: new Date("2018-01-25").getTime(),
y: 172,
},
{
x: new Date("2018-01-26").getTime(),
y: 177,
},
{
x: new Date("2018-01-27").getTime(),
y: 173,
},
{
x: new Date("2018-01-28").getTime(),
y: 169,
},
{
x: new Date("2018-01-29").getTime(),
y: 163,
},
{
x: new Date("2018-01-30").getTime(),
y: 158,
},
{
x: new Date("2018-02-01").getTime(),
y: 153,
},
{
x: new Date("2018-02-02").getTime(),
y: 149,
},
{
x: new Date("2018-02-03").getTime(),
y: 144,
},
{
x: new Date("2018-02-05").getTime(),
y: 150,
},
{
x: new Date("2018-02-06").getTime(),
y: 155,
},
{
x: new Date("2018-02-07").getTime(),
y: 159,
},
{
x: new Date("2018-02-08").getTime(),
y: 163,
},
{
x: new Date("2018-02-09").getTime(),
y: 156,
},
{
x: new Date("2018-02-11").getTime(),
y: 151,
},
{
x: new Date("2018-02-12").getTime(),
y: 157,
},
{
x: new Date("2018-02-13").getTime(),
y: 161,
},
{
x: new Date("2018-02-14").getTime(),
y: 150,
},
{
x: new Date("2018-02-15").getTime(),
y: 154,
},
{
x: new Date("2018-02-16").getTime(),
y: 160,
},
{
x: new Date("2018-02-17").getTime(),
y: 165,
},
{
x: new Date("2018-02-18").getTime(),
y: 162,
},
{
x: new Date("2018-02-20").getTime(),
y: 159,
},
{
x: new Date("2018-02-21").getTime(),
y: 164,
},
{
x: new Date("2018-02-22").getTime(),
y: 160,
},
{
x: new Date("2018-02-23").getTime(),
y: 165,
},
{
x: new Date("2018-02-24").getTime(),
y: 169,
},
{
x: new Date("2018-02-25").getTime(),
y: 172,
},
{
x: new Date("2018-02-26").getTime(),
y: 177,
},
{
x: new Date("2018-02-27").getTime(),
y: 173,
},
{
x: new Date("2018-02-28").getTime(),
y: 169,
},
{
x: new Date("2018-02-29").getTime(),
y: 163,
},
{
x: new Date("2018-02-30").getTime(),
y: 162,
},
{
x: new Date("2018-03-01").getTime(),
y: 158,
},
{
x: new Date("2018-03-02").getTime(),
y: 152,
},
{
x: new Date("2018-03-03").getTime(),
y: 147,
},
{
x: new Date("2018-03-05").getTime(),
y: 142,
},
{
x: new Date("2018-03-06").getTime(),
y: 147,
},
{
x: new Date("2018-03-07").getTime(),
y: 151,
},
{
x: new Date("2018-03-08").getTime(),
y: 155,
},
{
x: new Date("2018-03-09").getTime(),
y: 159,
},
{
x: new Date("2018-03-11").getTime(),
y: 162,
},
{
x: new Date("2018-03-12").getTime(),
y: 157,
},
{
x: new Date("2018-03-13").getTime(),
y: 161,
},
{
x: new Date("2018-03-14").getTime(),
y: 166,
},
{
x: new Date("2018-03-15").getTime(),
y: 169,
},
{
x: new Date("2018-03-16").getTime(),
y: 172,
},
{
x: new Date("2018-03-17").getTime(),
y: 177,
},
{
x: new Date("2018-03-18").getTime(),
y: 181,
},
{
x: new Date("2018-03-20").getTime(),
y: 178,
},
{
x: new Date("2018-03-21").getTime(),
y: 173,
},
{
x: new Date("2018-03-22").getTime(),
y: 169,
},
{
x: new Date("2018-03-23").getTime(),
y: 163,
},
{
x: new Date("2018-03-24").getTime(),
y: 159,
},
{
x: new Date("2018-03-25").getTime(),
y: 164,
},
{
x: new Date("2018-03-26").getTime(),
y: 168,
},
{
x: new Date("2018-03-27").getTime(),
y: 172,
},
{
x: new Date("2018-03-28").getTime(),
y: 169,
},
{
x: new Date("2018-03-29").getTime(),
y: 163,
},
{
x: new Date("2018-03-30").getTime(),
y: 162,
},
{
x: new Date("2018-04-01").getTime(),
y: 158,
},
{
x: new Date("2018-04-02").getTime(),
y: 152,
},
{
x: new Date("2018-04-03").getTime(),
y: 147,
},
{
x: new Date("2018-04-05").getTime(),
y: 142,
},
{
x: new Date("2018-04-06").getTime(),
y: 147,
},
{
x: new Date("2018-04-07").getTime(),
y: 151,
},
{
x: new Date("2018-04-08").getTime(),
y: 155,
},
{
x: new Date("2018-04-09").getTime(),
y: 159,
},
{
x: new Date("2018-04-11").getTime(),
y: 162,
},
{
x: new Date("2018-04-12").getTime(),
y: 157,
},
{
x: new Date("2018-04-13").getTime(),
y: 161,
},
{
x: new Date("2018-04-14").getTime(),
y: 166,
},
{
x: new Date("2018-04-15").getTime(),
y: 169,
},
{
x: new Date("2018-04-16").getTime(),
y: 172,
},
{
x: new Date("2018-04-17").getTime(),
y: 177,
},
{
x: new Date("2018-04-18").getTime(),
y: 181,
},
{
x: new Date("2018-04-20").getTime(),
y: 178,
},
{
x: new Date("2018-04-21").getTime(),
y: 173,
},
{
x: new Date("2018-04-22").getTime(),
y: 169,
},
{
x: new Date("2018-04-23").getTime(),
y: 163,
},
{
x: new Date("2018-04-24").getTime(),
y: 159,
},
{
x: new Date("2018-04-25").getTime(),
y: 164,
},
{
x: new Date("2018-04-26").getTime(),
y: 168,
},
{
x: new Date("2018-04-27").getTime(),
y: 172,
},
{
x: new Date("2018-04-28").getTime(),
y: 169,
},
{
x: new Date("2018-04-29").getTime(),
y: 163,
},
{
x: new Date("2018-04-30").getTime(),
y: 162,
},
{
x: new Date("2018-05-01").getTime(),
y: 158,
},
{
x: new Date("2018-05-02").getTime(),
y: 152,
},
{
x: new Date("2018-05-03").getTime(),
y: 147,
},
{
x: new Date("2018-05-04").getTime(),
y: 142,
},
{
x: new Date("2018-05-05").getTime(),
y: 147,
},
{
x: new Date("2018-05-07").getTime(),
y: 151,
},
{
x: new Date("2018-05-08").getTime(),
y: 155,
},
{
x: new Date("2018-05-09").getTime(),
y: 159,
},
{
x: new Date("2018-05-11").getTime(),
y: 162,
},
{
x: new Date("2018-05-12").getTime(),
y: 157,
},
{
x: new Date("2018-05-13").getTime(),
y: 161,
},
{
x: new Date("2018-05-14").getTime(),
y: 166,
},
{
x: new Date("2018-05-15").getTime(),
y: 169,
},
{
x: new Date("2018-05-16").getTime(),
y: 172,
},
{
x: new Date("2018-05-17").getTime(),
y: 177,
},
{
x: new Date("2018-05-18").getTime(),
y: 181,
},
{
x: new Date("2018-05-20").getTime(),
y: 178,
},
{
x: new Date("2018-05-21").getTime(),
y: 173,
},
{
x: new Date("2018-05-22").getTime(),
y: 169,
},
{
x: new Date("2018-05-23").getTime(),
y: 163,
},
{
x: new Date("2018-05-24").getTime(),
y: 159,
},
{
x: new Date("2018-05-25").getTime(),
y: 164,
},
{
x: new Date("2018-05-26").getTime(),
y: 168,
},
{
x: new Date("2018-05-27").getTime(),
y: 172,
},
{
x: new Date("2018-05-28").getTime(),
y: 169,
},
{
x: new Date("2018-05-29").getTime(),
y: 163,
},
{
x: new Date("2018-05-30").getTime(),
y: 162,
},
],
},
];
const options: any = {
chart: {
zoom: {
type: "x",
enabled: true,
autoScaleYaxis: true,
},
toolbar: {
show: false,
},
},
dataLabels: {
enabled: false,
},
stroke: {
curve: "smooth",
width: 4,
},
zoom: {
type: "x",
enabled: true,
autoScaleYaxis: true,
},
colors: [
colors.success,
],
tooltip: {
theme: mode === "dark" ? "dark" : "light",
},
grid: getGridConfig(),
fill: {
type: "gradient",
gradient: {
shadeIntensity: 1,
inverseColors: false,
opacityFrom: 0.5,
opacityTo: 0,
stops: [0, 90, 100],
},
},
yaxis: getYAxisConfig(
mode === 'light' ? colors["default-600"] : colors["default-300"]
),
xaxis: {
type: "datetime",
labels: getLabel(mode === 'light' ? colors["default-600"] : colors["default-300"]),
axisBorder: {
show: false,
},
axisTicks: {
show: false,
},
},
padding: {
top: 0,
right: 0,
bottom: 0,
left: 0,
},
};
return (
<Chart
options={options}
series={series}
type="area"
height={height}
width={"100%"}
/>
);
};
export default ZoomableTimeSeries;