el.xwx.moe/pages/admin.tsx

113 lines
3.4 KiB
TypeScript
Raw Normal View History

2024-05-03 09:22:45 -05:00
import NewUserModal from "@/components/ModalContent/NewUserModal";
2024-05-02 08:17:56 -05:00
import useUserStore from "@/store/admin/users";
2024-04-22 17:00:59 -05:00
import { User as U } from "@prisma/client";
import Link from "next/link";
2024-05-27 16:42:29 -05:00
import { useEffect, useState } from "react";
import { useTranslation } from "next-i18next";
import getServerSideProps from "@/lib/client/getServerSideProps";
import UserListing from "@/components/UserListing";
2024-04-22 17:00:59 -05:00
interface User extends U {
subscriptions: {
active: boolean;
};
}
2024-05-02 08:17:56 -05:00
type UserModal = {
isOpen: boolean;
userId: number | null;
};
2024-04-22 17:00:59 -05:00
export default function Admin() {
2024-05-27 16:42:29 -05:00
const { t } = useTranslation();
2024-05-02 08:17:56 -05:00
const { users, setUsers } = useUserStore();
2024-04-22 17:00:59 -05:00
2024-04-24 08:16:34 -05:00
const [searchQuery, setSearchQuery] = useState("");
const [filteredUsers, setFilteredUsers] = useState<User[]>();
2024-05-02 08:17:56 -05:00
const [deleteUserModal, setDeleteUserModal] = useState<UserModal>({
isOpen: false,
userId: null,
});
2024-05-03 09:22:45 -05:00
const [newUserModal, setNewUserModal] = useState(false);
2024-04-22 17:00:59 -05:00
useEffect(() => {
2024-05-03 09:22:45 -05:00
setUsers();
2024-04-22 17:00:59 -05:00
}, []);
return (
2024-04-24 08:16:34 -05:00
<div className="max-w-6xl mx-auto p-5">
<div className="flex sm:flex-row flex-col justify-between gap-2">
<div className="gap-2 inline-flex items-center">
<Link
href="/dashboard"
className="text-neutral btn btn-square btn-sm btn-ghost"
>
<i className="bi-chevron-left text-xl"></i>
</Link>
2024-05-02 08:17:56 -05:00
<p className="capitalize text-3xl font-thin inline">
2024-05-27 16:42:29 -05:00
{t("user_administration")}
2024-04-24 08:16:34 -05:00
</p>
</div>
<div className="flex items-center relative justify-between gap-2">
<div>
<label
htmlFor="search-box"
className="inline-flex items-center w-fit absolute left-1 pointer-events-none rounded-md p-1 text-primary"
>
<i className="bi-search"></i>
</label>
<input
id="search-box"
type="text"
placeholder={t("search_users")}
2024-04-24 08:16:34 -05:00
value={searchQuery}
onChange={(e) => {
setSearchQuery(e.target.value);
if (users) {
setFilteredUsers(
users.filter((user) =>
JSON.stringify(user)
.toLowerCase()
.includes(e.target.value.toLowerCase())
)
);
}
}}
className="border border-neutral-content bg-base-200 focus:border-primary py-1 rounded-md pl-9 pr-2 w-full max-w-[15rem] md:w-[15rem] md:max-w-full duration-200 outline-none"
/>
</div>
2024-05-03 09:22:45 -05:00
<div
onClick={() => setNewUserModal(true)}
className="flex items-center btn btn-accent dark:border-violet-400 text-white btn-sm px-2 aspect-square relative"
>
2024-04-24 08:16:34 -05:00
<i className="bi-plus text-3xl absolute"></i>
</div>
</div>
2024-04-22 17:00:59 -05:00
</div>
<div className="divider my-3"></div>
2024-04-24 08:16:34 -05:00
{filteredUsers && filteredUsers.length > 0 && searchQuery !== "" ? (
UserListing(filteredUsers, deleteUserModal, setDeleteUserModal, t)
2024-04-24 08:16:34 -05:00
) : searchQuery !== "" ? (
<p>{t("no_user_found_in_search")}</p>
2024-04-24 08:16:34 -05:00
) : users && users.length > 0 ? (
UserListing(users, deleteUserModal, setDeleteUserModal, t)
2024-04-22 17:00:59 -05:00
) : (
<p>{t("no_users_found")}</p>
2024-04-22 17:00:59 -05:00
)}
2024-05-03 09:22:45 -05:00
2024-07-27 17:41:13 -05:00
{newUserModal && <NewUserModal onClose={() => setNewUserModal(false)} />}
2024-04-22 17:00:59 -05:00
</div>
);
}
2024-04-24 08:16:34 -05:00
export { getServerSideProps };