"use client"; import { useRouter, useSearchParams } from "next/navigation"; import { useCallback, useEffect, useLayoutEffect, useMemo, useState } from "react"; import SearchResults, { Column } from "../SearchResults"; // import { TeamResult } from "@/app/api/team"; import { useTranslation } from "react-i18next"; import { Button, Card, CardContent, Grid, Stack, Tab, Tabs, TabsProps, TextField, Typography, } from "@mui/material"; import { FieldErrors, FormProvider, SubmitErrorHandler, SubmitHandler, useForm, useFormContext, } from "react-hook-form"; import { Check, Close, Error, RestartAlt } from "@mui/icons-material"; import { StaffResult } from "@/app/api/staff"; import { UserInputs, adminChangePassword, editUser, fetchUserDetails } from "@/app/api/user/actions"; import UserDetail from "./UserDetail"; import { UserResult, passwordRule } from "@/app/api/user"; import { auth, fetchAuth } from "@/app/api/group/actions"; import AuthAllocation from "./AuthAllocation"; interface Props { user: UserResult, rules: passwordRule, auths: auth[] } const EditUser: React.FC = async ({ user, rules, auths }) => { const { t } = useTranslation(); const formProps = useForm(); const searchParams = useSearchParams(); const id = parseInt(searchParams.get("id") || "0"); const [tabIndex, setTabIndex] = useState(0); const router = useRouter(); const [serverError, setServerError] = useState(""); const handleTabChange = useCallback>( (_e, newValue) => { setTabIndex(newValue); }, [] ); const errors = formProps.formState.errors; useEffect(() => { try { const addAuthIds = auths && auths.length > 0 ? auths.filter((item) => item.v === 1).map((item) => item.id).sort((a, b) => a - b) : [] formProps.reset({ name: user.username, email: user.email, addAuthIds: addAuthIds }); } catch (error) { console.log(error); setServerError(t("An error has occurred. Please try again later.")); } }, [user, auths]); const hasErrorsInTab = ( tabIndex: number, errors: FieldErrors ) => { switch (tabIndex) { case 0: return Object.keys(errors).length > 0; default: false; } }; const handleCancel = () => { router.back(); }; const onSubmit = useCallback>( async (data) => { try { let haveError = false let regex_pw = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*])[A-Za-z\d!@#$%^&*]{8,20}$/ let pw = '' if (data.password && data.password.length > 0) { pw = data.password if (pw.length < rules.min) { haveError = true formProps.setError("password", { message: t("The password requires 8-20 characters."), type: "required" }) } if (pw.length > rules.max) { haveError = true formProps.setError("password", { message: t("The password requires 8-20 characters."), type: "required" }) } if (!regex_pw.test(pw)) { haveError = true formProps.setError("password", { message: "A combination of uppercase letters, lowercase letters, numbers, and symbols is required.", type: "required" }) } } const userData = { name: data.name, locked: false, addAuthIds: data.addAuthIds || [], removeAuthIds: data.removeAuthIds || [], } const pwData = { id: id, password: "", newPassword: pw } if (haveError) { return } console.log("passed") await editUser(id, userData); if (data.password && data.password.length > 0) { await adminChangePassword(pwData); } router.replace("/settings/staff"); } catch (e) { console.log(e); setServerError(t("An error has occurred. Please try again later.")); } }, [router] ); const onSubmitError = useCallback>( (errors) => { console.log(errors); }, [] ); return ( <> {serverError && ( {serverError} )} ) : undefined } iconPosition="end" /> {tabIndex == 0 && } {tabIndex === 1 && } ); }; export default EditUser;