Le V1
This commit is contained in:
parent
84e7df6c30
commit
4f086431f9
@ -2,6 +2,13 @@ import {
|
|||||||
Button,
|
Button,
|
||||||
Container,
|
Container,
|
||||||
Heading,
|
Heading,
|
||||||
|
ListItem,
|
||||||
|
Modal,
|
||||||
|
ModalBody,
|
||||||
|
ModalCloseButton,
|
||||||
|
ModalContent,
|
||||||
|
ModalHeader,
|
||||||
|
ModalOverlay,
|
||||||
Table,
|
Table,
|
||||||
TableCaption,
|
TableCaption,
|
||||||
TableContainer,
|
TableContainer,
|
||||||
@ -9,8 +16,12 @@ import {
|
|||||||
Td,
|
Td,
|
||||||
Thead,
|
Thead,
|
||||||
Tr,
|
Tr,
|
||||||
|
UnorderedList,
|
||||||
|
useDisclosure,
|
||||||
|
useToast,
|
||||||
} from "@chakra-ui/react";
|
} from "@chakra-ui/react";
|
||||||
import { useLoaderData } from "@remix-run/react";
|
import { useLoaderData } from "@remix-run/react";
|
||||||
|
import { useState } from "react";
|
||||||
|
|
||||||
export async function loader({ context }: { context: RequestContext }) {
|
export async function loader({ context }: { context: RequestContext }) {
|
||||||
const { current_user: currentUser } = context.data;
|
const { current_user: currentUser } = context.data;
|
||||||
@ -46,7 +57,7 @@ export async function loader({ context }: { context: RequestContext }) {
|
|||||||
|
|
||||||
const today = new Date().toISOString().split("T").at(0);
|
const today = new Date().toISOString().split("T").at(0);
|
||||||
const { results } = await context.env.D1.prepare(
|
const { results } = await context.env.D1.prepare(
|
||||||
"SELECT decisions, end, start, user FROM inactivity_notices WHERE start <= ?1 AND date(end, '+30 days') <= ?1; ",
|
"SELECT decisions, end, id, start, user FROM inactivity_notices WHERE start <= ?1 AND date(end, '+30 days') <= ?1; ",
|
||||||
)
|
)
|
||||||
.bind(today)
|
.bind(today)
|
||||||
.all();
|
.all();
|
||||||
@ -63,6 +74,7 @@ export async function loader({ context }: { context: RequestContext }) {
|
|||||||
}) as unknown as {
|
}) as unknown as {
|
||||||
decisions: { [k: string]: boolean };
|
decisions: { [k: string]: boolean };
|
||||||
end: string;
|
end: string;
|
||||||
|
id: string;
|
||||||
start: string;
|
start: string;
|
||||||
user: { email: string; id: string; username: string };
|
user: { email: string; id: string; username: string };
|
||||||
}[];
|
}[];
|
||||||
@ -70,9 +82,75 @@ export async function loader({ context }: { context: RequestContext }) {
|
|||||||
|
|
||||||
export default function () {
|
export default function () {
|
||||||
const data = useLoaderData<typeof loader>();
|
const data = useLoaderData<typeof loader>();
|
||||||
|
const [currentInactivity, setInactivity] = useState(
|
||||||
|
{} as { [k: string]: any },
|
||||||
|
);
|
||||||
|
const { isOpen, onClose, onOpen } = useDisclosure();
|
||||||
|
const toast = useToast();
|
||||||
|
|
||||||
|
async function getInactivity(id: string) {
|
||||||
|
const inactivityResponse = await fetch(`/api/inactivity/${id}`);
|
||||||
|
|
||||||
|
if (!inactivityResponse.ok) {
|
||||||
|
let msg = "Unknown error";
|
||||||
|
|
||||||
|
try {
|
||||||
|
msg = ((await inactivityResponse.json()) as { error: string }).error;
|
||||||
|
} catch {}
|
||||||
|
|
||||||
|
toast({
|
||||||
|
description: msg,
|
||||||
|
status: "error",
|
||||||
|
title: "Failed to fetch inactivity",
|
||||||
|
});
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
setInactivity(await inactivityResponse.json());
|
||||||
|
onOpen();
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Container maxW="container.lg">
|
<Container maxW="container.lg">
|
||||||
|
<Modal isOpen={isOpen} onClose={onClose}>
|
||||||
|
<ModalOverlay />
|
||||||
|
<ModalContent>
|
||||||
|
<ModalHeader>Inactivity Details</ModalHeader>
|
||||||
|
<ModalCloseButton />
|
||||||
|
<ModalBody>
|
||||||
|
<UnorderedList>
|
||||||
|
<ListItem>Username: ${currentInactivity.user.username}</ListItem>
|
||||||
|
<ListItem>User ID: ${currentInactivity.user.id}</ListItem>
|
||||||
|
<ListItem>Start Date: ${currentInactivity.start}</ListItem>
|
||||||
|
<ListItem>End Date: ${currentInactivity.end}</ListItem>
|
||||||
|
<ListItem>
|
||||||
|
Is Hiatus: ${currentInactivity.hiatus ? "Yes" : "No"}
|
||||||
|
</ListItem>
|
||||||
|
<ListItem>Reason: ${currentInactivity.reason}</ListItem>
|
||||||
|
<ListItem>
|
||||||
|
Decisions:
|
||||||
|
<br />
|
||||||
|
Approved: $
|
||||||
|
{Object.keys(currentInactivity.decisions).filter(
|
||||||
|
(d) => currentInactivity.decisions[d],
|
||||||
|
)}
|
||||||
|
<br />
|
||||||
|
Denied: $
|
||||||
|
{Object.keys(currentInactivity.decisions).filter(
|
||||||
|
(d) => !currentInactivity.decisions[d],
|
||||||
|
)}
|
||||||
|
<br />
|
||||||
|
Pending: $
|
||||||
|
{currentInactivity.departments.filter(
|
||||||
|
(d: "DM" | "ET" | "FM" | "WM") =>
|
||||||
|
typeof currentInactivity.decisions[d] === "undefined",
|
||||||
|
)}
|
||||||
|
</ListItem>
|
||||||
|
</UnorderedList>
|
||||||
|
</ModalBody>
|
||||||
|
</ModalContent>
|
||||||
|
</Modal>
|
||||||
<Heading pb="32px">Current Inactivity Notices</Heading>
|
<Heading pb="32px">Current Inactivity Notices</Heading>
|
||||||
<TableContainer>
|
<TableContainer>
|
||||||
<Table variant="simple">
|
<Table variant="simple">
|
||||||
|
Loading…
x
Reference in New Issue
Block a user