el.xwx.moe/pages/admin.tsx

111 lines
3.4 KiB
TypeScript
Raw Normal View History

2024-05-03 09:22:45 -05:00
import NewUserModal from "@/components/ModalContent/NewUserModal";
2024-04-22 17:00:59 -05:00
import { User as U } from "@prisma/client";
import Link from "next/link";
2024-08-01 15:54:19 -05:00
import { useState } from "react";
2024-05-27 16:42:29 -05:00
import { useTranslation } from "next-i18next";
import getServerSideProps from "@/lib/client/getServerSideProps";
import UserListing from "@/components/UserListing";
2024-08-01 15:54:19 -05:00
import { useUsers } from "@/hooks/store/admin/users";
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();
const { data: users = [] } = useUsers();
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
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(
2024-08-01 15:54:19 -05:00
users.filter((user: any) =>
2024-04-24 08:16:34 -05:00
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
{newUserModal ? (
<NewUserModal onClose={() => setNewUserModal(false)} />
) : null}
2024-04-22 17:00:59 -05:00
</div>
);
}
2024-04-24 08:16:34 -05:00
export { getServerSideProps };