import { useTranslation } from "react-i18next"; import { Form, type FormInstance, Input, InputNumber } from "antd"; import { createSchemaFieldRule } from "antd-zod"; import { z } from "zod"; import { validPortNumber } from "@/utils/validators"; type DeployNodeConfigFormBaotaWAFSiteConfigFieldValues = Nullish<{ siteName: string; sitePort: number; }>; export type DeployNodeConfigFormBaotaWAFSiteConfigProps = { form: FormInstance; formName: string; disabled?: boolean; initialValues?: DeployNodeConfigFormBaotaWAFSiteConfigFieldValues; onValuesChange?: (values: DeployNodeConfigFormBaotaWAFSiteConfigFieldValues) => void; }; const initFormModel = (): DeployNodeConfigFormBaotaWAFSiteConfigFieldValues => { return { siteName: "", sitePort: 443, }; }; const DeployNodeConfigFormBaotaWAFSiteConfig = ({ form: formInst, formName, disabled, initialValues, onValuesChange, }: DeployNodeConfigFormBaotaWAFSiteConfigProps) => { const { t } = useTranslation(); const formSchema = z.object({ siteName: z.string().nonempty(t("workflow_node.deploy.form.baotawaf_site_name.placeholder")).trim(), sitePort: z.preprocess( (v) => Number(v), z .number() .int(t("workflow_node.deploy.form.baotawaf_site_port.placeholder")) .refine((v) => validPortNumber(v), t("common.errmsg.port_invalid")) ), }); const formRule = createSchemaFieldRule(formSchema); const handleFormChange = (_: unknown, values: z.infer) => { onValuesChange?.(values); }; return (
} >
); }; export default DeployNodeConfigFormBaotaWAFSiteConfig;