import { Button, Select, Textarea, Option, Divider, Switch } from "@mui/joy"; import { isEqual } from "lodash-es"; import { ExternalLinkIcon } from "lucide-react"; import { useState } from "react"; import { toast } from "react-hot-toast"; import { Link } from "react-router-dom"; import { workspaceSettingNamePrefix, 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"; import showUpdateCustomizedProfileDialog from "../UpdateCustomizedProfileDialog"; const WorkspaceSection = () => { const t = useTranslate(); const workspaceSettingStore = useWorkspaceSettingStore(); const originalSetting = WorkspaceGeneralSetting.fromPartial( workspaceSettingStore.getWorkspaceSettingByKey(WorkspaceSettingKey.GENERAL)?.generalSetting || {}, ); const [workspaceGeneralSetting, setWorkspaceGeneralSetting] = useState(originalSetting); const handleUpdateCustomizedProfileButtonClick = () => { showUpdateCustomizedProfileDialog(); }; const updatePartialSetting = (partial: Partial) => { const newWorkspaceGeneralSetting = WorkspaceGeneralSetting.fromPartial({ ...workspaceGeneralSetting, ...partial, }); setWorkspaceGeneralSetting(newWorkspaceGeneralSetting); }; const handleSaveGeneralSetting = async () => { try { await workspaceSettingStore.setWorkspaceSetting({ name: `${workspaceSettingNamePrefix}${WorkspaceSettingKey.GENERAL}`, generalSetting: workspaceGeneralSetting, }); } catch (error: any) { toast.error(error.details); console.error(error); return; } toast.success(t("message.update-succeed")); }; return (

{t("common.basic")}

{t("setting.system-section.server-name")}:{" "} {workspaceGeneralSetting.customProfile?.title || "Memos"}

General

{t("setting.system-section.additional-style")}