import { Button, Input } from "@usememos/mui"; import { LoaderIcon } from "lucide-react"; import { ClientError } from "nice-grpc-web"; import { useState } from "react"; import { toast } from "react-hot-toast"; import { Link } from "react-router-dom"; import AppearanceSelect from "@/components/AppearanceSelect"; import LocaleSelect from "@/components/LocaleSelect"; import { authServiceClient } from "@/grpcweb"; import useLoading from "@/hooks/useLoading"; import useNavigateTo from "@/hooks/useNavigateTo"; import { useCommonContext } from "@/layouts/CommonContextProvider"; import { useUserStore, useWorkspaceSettingStore } from "@/store/v1"; import { WorkspaceGeneralSetting } from "@/types/proto/api/v1/workspace_setting_service"; import { WorkspaceSettingKey } from "@/types/proto/store/workspace_setting"; import { useTranslate } from "@/utils/i18n"; const SignUp = () => { const t = useTranslate(); const navigateTo = useNavigateTo(); const commonContext = useCommonContext(); const workspaceSettingStore = useWorkspaceSettingStore(); const userStore = useUserStore(); const actionBtnLoadingState = useLoading(false); const [username, setUsername] = useState(""); const [password, setPassword] = useState(""); const workspaceGeneralSetting = workspaceSettingStore.getWorkspaceSettingByKey(WorkspaceSettingKey.GENERAL).generalSetting || WorkspaceGeneralSetting.fromPartial({}); const handleUsernameInputChanged = (e: React.ChangeEvent) => { const text = e.target.value as string; setUsername(text); }; const handlePasswordInputChanged = (e: React.ChangeEvent) => { const text = e.target.value as string; setPassword(text); }; const handleLocaleSelectChange = (locale: Locale) => { commonContext.setLocale(locale); }; const handleAppearanceSelectChange = (appearance: Appearance) => { commonContext.setAppearance(appearance); }; const handleFormSubmit = (e: React.FormEvent) => { e.preventDefault(); handleSignUpButtonClick(); }; const handleSignUpButtonClick = async () => { if (username === "" || password === "") { return; } if (actionBtnLoadingState.isLoading) { return; } try { actionBtnLoadingState.setLoading(); await authServiceClient.signUp({ username, password }); await userStore.fetchCurrentUser(); navigateTo("/"); } catch (error: any) { console.error(error); toast.error((error as ClientError).details || "Sign up failed"); } actionBtnLoadingState.setFinish(); }; return (

{workspaceGeneralSetting.customProfile?.title || "Memos"}

{!workspaceGeneralSetting.disallowUserRegistration ? ( <>

{t("auth.create-your-account")}

{t("common.username")}
{t("common.password")}
) : (

Sign up is not allowed.

)} {!commonContext.profile.owner ? (

{t("auth.host-tip")}

) : (

{t("auth.sign-in-tip")} {t("common.sign-in")}

)}
); }; export default SignUp;