create.config.ts 5.74 KB
import {
  EmailProtocolEnum,
  EmailProtocolNameEnum,
  TSLVersionEnum,
  TSLVersionNameEnum,
} from '../../../enum/form';
import { useRuleChainI18n } from '../../../hook/useRuleChainI18n';
import { FormSchema } from '/@/components/Form';

export enum SendEmailFieldsEnum {
  USE_SYSTEM_SMTP_SETTINGS = 'useSystemSmtpSettings',
  SMTP_PROTOCOL = 'smtpProtocol',
  SMTP_HOST = 'smtpHost',
  SMTP_PORT = 'smtpPort',
  TIMEOUT = 'timeout',
  ENABLE_TLS = 'enableTls',
  TLS_VERSION = 'tlsVersion',
  ENABLE_PROXY = 'enableProxy',
  PROXY_HOST = 'proxyHost',
  PROXY_PORT = 'proxyPort',
  PROXY_USER = 'proxyUser',
  PROXY_PASSWORD = 'proxyPassword',
  USERNAME = 'username',
  PASSWORD = 'password',
}

const { tLabel, tPlaceholder } = useRuleChainI18n('external', 'sendEmail');

export const formSchemas: FormSchema[] = [
  {
    field: SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS,
    label: '',
    component: 'Checkbox',
    renderComponentContent: () => ({
      default: () => tLabel(SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS),
    }),
  },
  {
    field: SendEmailFieldsEnum.SMTP_PROTOCOL,
    label: tLabel(SendEmailFieldsEnum.SMTP_PROTOCOL),
    component: 'Select',
    required: true,
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      options: Object.keys(EmailProtocolEnum).map((value) => ({
        label: EmailProtocolNameEnum[value],
        value,
      })),
      placeholder: tPlaceholder(SendEmailFieldsEnum.SMTP_PROTOCOL, 'choose'),
      getPopupContainer: () => document.body,
    },
  },
  {
    field: SendEmailFieldsEnum.SMTP_HOST,
    label: tLabel(SendEmailFieldsEnum.SMTP_HOST),
    component: 'Input',
    required: true,
    colProps: { span: 12 },
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.SMTP_HOST),
    },
  },
  {
    field: SendEmailFieldsEnum.SMTP_PORT,
    label: tLabel(SendEmailFieldsEnum.SMTP_PORT),
    component: 'InputNumber',
    required: true,
    colProps: { span: 12 },
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      min: 0,
      placeholder: tPlaceholder(SendEmailFieldsEnum.SMTP_PORT),
    },
  },
  {
    field: SendEmailFieldsEnum.TIMEOUT,
    label: tLabel(SendEmailFieldsEnum.TIMEOUT),
    component: 'InputNumber',
    required: true,
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      min: 0,
      placeholder: tPlaceholder(SendEmailFieldsEnum.TIMEOUT),
    },
  },
  {
    field: SendEmailFieldsEnum.ENABLE_TLS,
    label: '',
    component: 'Checkbox',
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    renderComponentContent: () => ({
      default: () => tLabel(SendEmailFieldsEnum.ENABLE_TLS),
    }),
  },
  {
    field: SendEmailFieldsEnum.TLS_VERSION,
    label: tLabel(SendEmailFieldsEnum.TLS_VERSION),
    component: 'Select',
    required: true,
    ifShow: ({ model }) =>
      model[SendEmailFieldsEnum.ENABLE_TLS] && !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      options: Object.keys(TSLVersionEnum).map((value) => ({
        label: TSLVersionNameEnum[value],
        value,
      })),
      placeholder: tPlaceholder(SendEmailFieldsEnum.TLS_VERSION, 'choose'),
      getPopupContainer: () => document.body,
    },
  },
  {
    field: SendEmailFieldsEnum.ENABLE_PROXY,
    label: '',
    component: 'Checkbox',
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    renderComponentContent: () => ({
      default: () => tLabel(SendEmailFieldsEnum.ENABLE_PROXY),
    }),
  },
  {
    field: SendEmailFieldsEnum.PROXY_HOST,
    label: tLabel(SendEmailFieldsEnum.PROXY_HOST),
    component: 'Input',
    required: true,
    colProps: { span: 12 },
    ifShow: ({ model }) =>
      !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS] &&
      model[SendEmailFieldsEnum.ENABLE_PROXY],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.PROXY_HOST),
    },
  },
  {
    field: SendEmailFieldsEnum.PROXY_PORT,
    label: tLabel(SendEmailFieldsEnum.PROXY_PORT),
    component: 'Input',
    required: true,
    colProps: { span: 12 },
    ifShow: ({ model }) =>
      !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS] &&
      model[SendEmailFieldsEnum.ENABLE_PROXY],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.PROXY_PORT),
    },
  },
  {
    field: SendEmailFieldsEnum.PROXY_USER,
    label: tLabel(SendEmailFieldsEnum.PROXY_USER),
    component: 'Input',
    ifShow: ({ model }) =>
      !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS] &&
      model[SendEmailFieldsEnum.ENABLE_PROXY],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.PROXY_USER),
    },
  },
  {
    field: SendEmailFieldsEnum.PROXY_PASSWORD,
    label: tLabel(SendEmailFieldsEnum.PROXY_PASSWORD),
    component: 'Input',
    ifShow: ({ model }) =>
      !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS] &&
      model[SendEmailFieldsEnum.ENABLE_PROXY],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.PROXY_PASSWORD),
    },
  },
  {
    field: SendEmailFieldsEnum.USERNAME,
    label: tLabel(SendEmailFieldsEnum.USERNAME),
    component: 'Input',
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.USERNAME),
    },
  },
  {
    field: SendEmailFieldsEnum.PASSWORD,
    label: tLabel(SendEmailFieldsEnum.PASSWORD),
    component: 'InputPassword',
    ifShow: ({ model }) => !model[SendEmailFieldsEnum.USE_SYSTEM_SMTP_SETTINGS],
    componentProps: {
      placeholder: tPlaceholder(SendEmailFieldsEnum.PASSWORD),
    },
  },
];