import { useTranslation } from "react-i18next"; import { Form, type FormInstance, Input, Radio, Switch } from "antd"; import { createSchemaFieldRule } from "antd-zod"; import { z } from "zod/v4"; import { type AccessConfigForFlexCDN } from "@/domain/access"; type AccessFormFlexCDNConfigFieldValues = Nullish; export type AccessFormFlexCDNConfigProps = { form: FormInstance; formName: string; disabled?: boolean; initialValues?: AccessFormFlexCDNConfigFieldValues; onValuesChange?: (values: AccessFormFlexCDNConfigFieldValues) => void; }; const initFormModel = (): AccessFormFlexCDNConfigFieldValues => { return { serverUrl: "http://:8000/", apiRole: "user", accessKeyId: "", accessKey: "", }; }; const AccessFormFlexCDNConfig = ({ form: formInst, formName, disabled, initialValues, onValuesChange }: AccessFormFlexCDNConfigProps) => { const { t } = useTranslation(); const formSchema = z.object({ serverUrl: z.url(t("common.errmsg.url_invalid")), role: z.literal(["user", "admin"], t("access.form.flexcdn_api_role.placeholder")), accessKeyId: z.string().nonempty(t("access.form.flexcdn_access_key_id.placeholder")), accessKey: z.string().nonempty(t("access.form.flexcdn_access_key.placeholder")), allowInsecureConnections: z.boolean().nullish(), }); const formRule = createSchemaFieldRule(formSchema); const handleFormChange = (_: unknown, values: z.infer) => { onValuesChange?.(values); }; return (
({ label: t(`access.form.flexcdn_api_role.option.${s}.label`), value: s }))} /> } > } >
); }; export default AccessFormFlexCDNConfig;