2023-05-20 12:00:15 +00:00
|
|
|
// types
|
|
|
|
import { ChartDataType } from "../types";
|
|
|
|
// data
|
|
|
|
import { weeks, months } from "../data";
|
|
|
|
// helpers
|
|
|
|
import { getDatesBetweenTwoDates, getWeeksByMonthAndYear } from "./helpers";
|
|
|
|
|
2023-08-28 16:37:10 +00:00
|
|
|
interface IYearChild {
|
|
|
|
active: boolean;
|
|
|
|
date: Date;
|
|
|
|
day: number;
|
|
|
|
dayData: {
|
|
|
|
key: number;
|
|
|
|
shortTitle: string;
|
|
|
|
title: string;
|
|
|
|
};
|
|
|
|
title: string;
|
|
|
|
today: boolean;
|
|
|
|
weekNumber: number;
|
|
|
|
}
|
|
|
|
export interface IYearBlock {
|
|
|
|
children: IYearChild[];
|
|
|
|
month: number;
|
|
|
|
monthData: {
|
|
|
|
key: number;
|
|
|
|
shortTitle: string;
|
|
|
|
title: string;
|
|
|
|
};
|
|
|
|
title: string;
|
|
|
|
year: number;
|
|
|
|
}
|
|
|
|
[];
|
|
|
|
|
|
|
|
const generateMonthDataByMonthAndYearInMonthView = (month: number, year: number): IYearBlock => {
|
2023-05-20 12:00:15 +00:00
|
|
|
const currentMonth: number = month;
|
|
|
|
const currentYear: number = year;
|
|
|
|
const today = new Date();
|
|
|
|
|
|
|
|
const weeksBetweenTwoDates = getWeeksByMonthAndYear(month, year);
|
|
|
|
|
|
|
|
const weekPayload = {
|
|
|
|
year: currentYear,
|
|
|
|
month: currentMonth,
|
|
|
|
monthData: months[currentMonth],
|
|
|
|
children: weeksBetweenTwoDates.map((weekData: any) => {
|
|
|
|
const date: Date = weekData.startDate;
|
|
|
|
return {
|
|
|
|
date: date,
|
|
|
|
startDate: weekData.startDate,
|
|
|
|
endDate: weekData.endDate,
|
|
|
|
day: date.getDay(),
|
|
|
|
dayData: weeks[date.getDay()],
|
|
|
|
weekNumber: weekData.weekNumber,
|
|
|
|
title: `W${weekData.weekNumber} (${date.getDate()})`,
|
|
|
|
active: false,
|
|
|
|
today: today >= weekData.startDate && today <= weekData.endDate ? true : false,
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
title: `${months[currentMonth].title} ${currentYear}`,
|
|
|
|
};
|
|
|
|
|
|
|
|
return weekPayload;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const generateYearChart = (yearPayload: ChartDataType, side: null | "left" | "right") => {
|
|
|
|
let renderState = yearPayload;
|
|
|
|
const renderPayload: any = [];
|
|
|
|
|
|
|
|
const range: number = renderState.data.approxFilterRange || 6;
|
|
|
|
let filteredDates: Date[] = [];
|
|
|
|
let minusDate: Date = new Date();
|
|
|
|
let plusDate: Date = new Date();
|
|
|
|
|
|
|
|
if (side === null) {
|
|
|
|
const currentDate = renderState.data.currentDate;
|
|
|
|
|
|
|
|
minusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() - range, 1);
|
|
|
|
plusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() + range, 0);
|
|
|
|
|
|
|
|
if (minusDate && plusDate) filteredDates = getDatesBetweenTwoDates(minusDate, plusDate);
|
|
|
|
|
|
|
|
renderState = {
|
|
|
|
...renderState,
|
|
|
|
data: {
|
|
|
|
...renderState.data,
|
|
|
|
startDate: filteredDates[0],
|
|
|
|
endDate: filteredDates[filteredDates.length - 1],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
} else if (side === "left") {
|
|
|
|
const currentDate = renderState.data.startDate;
|
|
|
|
|
|
|
|
minusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() - range, 1);
|
|
|
|
plusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 0);
|
|
|
|
|
|
|
|
if (minusDate && plusDate) filteredDates = getDatesBetweenTwoDates(minusDate, plusDate);
|
|
|
|
|
|
|
|
renderState = {
|
|
|
|
...renderState,
|
|
|
|
data: { ...renderState.data, startDate: filteredDates[0] },
|
|
|
|
};
|
|
|
|
} else if (side === "right") {
|
|
|
|
const currentDate = renderState.data.endDate;
|
|
|
|
|
|
|
|
minusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 1);
|
|
|
|
plusDate = new Date(currentDate.getFullYear(), currentDate.getMonth() + range, 0);
|
|
|
|
|
|
|
|
if (minusDate && plusDate) filteredDates = getDatesBetweenTwoDates(minusDate, plusDate);
|
|
|
|
|
|
|
|
renderState = {
|
|
|
|
...renderState,
|
|
|
|
data: { ...renderState.data, endDate: filteredDates[filteredDates.length - 1] },
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
if (filteredDates && filteredDates.length > 0)
|
|
|
|
for (const currentDate in filteredDates) {
|
|
|
|
const date = filteredDates[parseInt(currentDate)];
|
|
|
|
const currentYear = date.getFullYear();
|
|
|
|
const currentMonth = date.getMonth();
|
|
|
|
renderPayload.push(generateMonthDataByMonthAndYearInMonthView(currentMonth, currentYear));
|
|
|
|
}
|
|
|
|
|
|
|
|
const scrollWidth =
|
|
|
|
renderPayload
|
|
|
|
.map((monthData: any) => monthData.children.length)
|
|
|
|
.reduce((partialSum: number, a: number) => partialSum + a, 0) * yearPayload.data.width;
|
|
|
|
|
|
|
|
return { state: renderState, payload: renderPayload, scrollWidth: scrollWidth };
|
|
|
|
};
|
|
|
|
|
|
|
|
export const getNumberOfDaysBetweenTwoDatesInYear = (startDate: Date, endDate: Date) => {
|
|
|
|
let weeksDifference: number = 0;
|
|
|
|
|
|
|
|
const timeDiff = Math.abs(endDate.getTime() - startDate.getTime());
|
|
|
|
const diffDays = Math.ceil(timeDiff / (1000 * 3600 * 24));
|
|
|
|
weeksDifference = Math.floor(diffDays / 7);
|
|
|
|
|
|
|
|
return weeksDifference;
|
|
|
|
};
|