Calender nav #42

Merged
LucidKobold merged 20 commits from calender-nav into main 2022-03-27 02:48:04 -04:00
4 changed files with 479 additions and 420 deletions
Showing only changes of commit 1eef28377d - Show all commits

View File

@@ -1,10 +1,12 @@
import React, { useEffect, useState } from "react"; import React, { useEffect, useState } from "react";
import { Box } from "@chakra-ui/react"; import { Box } from "@chakra-ui/react";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import { endOfMonth, getDay } from "date-fns";
import ErrorPage from "next/error"; import ErrorPage from "next/error";
import Calender from "../../components/calender"; import Calender from "../../components/calender";
import { CalenderContextProvider } from "../../contexts/CalenderContext"; import { CalenderContextProvider } from "../../contexts/CalenderContext";
import { StickersContextProvider } from "../../contexts/StickerContext"; import { StickersContextProvider } from "../../contexts/StickerContext";
import { es } from "date-fns/locale";
const DateRoute: React.FC<unknown> = () => { const DateRoute: React.FC<unknown> = () => {
const router = useRouter(); const router = useRouter();
@@ -12,6 +14,8 @@ const DateRoute: React.FC<unknown> = () => {
const [date, setDate] = useState<UpdateCalendarProps | null>(null); const [date, setDate] = useState<UpdateCalendarProps | null>(null);
const [error, setError] = useState<boolean>(false);
const validateDateInput = (dateArr: number[]): UpdateCalendarProps => { const validateDateInput = (dateArr: number[]): UpdateCalendarProps => {
if (!(dateArr.length >= 2) && !(dateArr.length <= 3)) { if (!(dateArr.length >= 2) && !(dateArr.length <= 3)) {
return { return {
@@ -31,21 +35,28 @@ const DateRoute: React.FC<unknown> = () => {
date.year = dateArr[0]; date.year = dateArr[0];
} }
if (dateArr[1] > 0 || dateArr[1] <= 12) { if (dateArr[1] > 0 && dateArr[1] <= 12) {
date.month = dateArr[1]; date.month = dateArr[1];
} }
if (dateArr[2] && (dateArr[2] > 0 || dateArr[2] <= 31)) { if (date.month && date.year) {
date.day = dateArr[2]; const lastDay = getDay(endOfMonth(new Date(date.year, date.month - 1, 1)))
} else if (!dateArr[2]) { if (dateArr[2] && (dateArr[2] > 0 && dateArr[2] <= lastDay)) {
date.day = 1; date.day = dateArr[2];
} else if (!dateArr[2]) {
date.day = 1;
}
} else {
return date;
} }
return date; return date;
}; };
useEffect(() => { useEffect(() => {
if (slug && slug.length === 1 && slug[0] !== "now") { if (slug && slug.length === 1 && slug[0] !== "now") {
setError(true);
return console.warn("improper date input"); return console.warn("improper date input");
} }
@@ -53,9 +64,16 @@ const DateRoute: React.FC<unknown> = () => {
const parsedSlug = slug.map((e) => { const parsedSlug = slug.map((e) => {
return parseInt(e); return parseInt(e);
}); });
setDate({
...validateDateInput(parsedSlug) const newDate = validateDateInput(parsedSlug);
});
if (newDate.year === 0 || newDate.month === 0 || newDate.day === 0) {
setError(true);
} else {
setDate({
...validateDateInput(parsedSlug)
});
}
} }
}, [slug]); }, [slug]);
@@ -70,15 +88,16 @@ const DateRoute: React.FC<unknown> = () => {
* last month that has stickers within it (When filter is enabled) or to the creation date of the chart.. * last month that has stickers within it (When filter is enabled) or to the creation date of the chart..
*/ */
return ( return error ?
<Box textAlign="center" w="100%" h="auto" pt="50px" pb="10vh"> (<ErrorPage statusCode={404} />)
:
(<Box textAlign="center" w="100%" h="auto" pt="50px" pb="10vh">
<CalenderContextProvider> <CalenderContextProvider>
<StickersContextProvider> <StickersContextProvider>
<Calender {...date} /> <Calender {...date} />
</StickersContextProvider> </StickersContextProvider>
</CalenderContextProvider> </CalenderContextProvider>
</Box> </Box>)
);
}; };
export default DateRoute; export default DateRoute;