import { Button, Textarea } from "@mui/joy"; import { useState } from "react"; import { toast } from "react-hot-toast"; import { Link } from "react-router-dom"; import { workspaceSettingServiceClient } from "@/grpcweb"; import { WorkspaceSettingPrefix, 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 Icon from "../Icon"; import showUpdateCustomizedProfileDialog from "../UpdateCustomizedProfileDialog"; const WorkspaceSection = () => { const t = useTranslate(); const workspaceSettingStore = useWorkspaceSettingStore(); const [workspaceGeneralSetting, setWorkspaceGeneralSetting] = useState( WorkspaceGeneralSetting.fromPartial(workspaceSettingStore.getWorkspaceSettingByKey(WorkspaceSettingKey.GENERAL)?.generalSetting || {}), ); const handleUpdateCustomizedProfileButtonClick = () => { showUpdateCustomizedProfileDialog(); }; const handleAdditionalStyleChanged = (value: string) => { setWorkspaceGeneralSetting({ ...workspaceGeneralSetting, additionalStyle: value }); }; const handleSaveAdditionalStyle = async () => { try { await workspaceSettingServiceClient.setWorkspaceSetting({ setting: { name: `${WorkspaceSettingPrefix}${WorkspaceSettingKey.GENERAL}`, generalSetting: workspaceGeneralSetting, }, }); } catch (error: any) { toast.error(error.response.data.message); console.error(error); return; } toast.success(t("message.update-succeed")); }; const handleAdditionalScriptChanged = (value: string) => { setWorkspaceGeneralSetting({ ...workspaceGeneralSetting, additionalScript: value }); }; const handleSaveAdditionalScript = async () => { try { await workspaceSettingServiceClient.setWorkspaceSetting({ setting: { name: `${WorkspaceSettingPrefix}${WorkspaceSettingKey.GENERAL}`, generalSetting: workspaceGeneralSetting, }, }); } catch (error: any) { toast.error(error.response.data.message); 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")}