mirror of
				https://github.com/continew-org/continew-admin-ui.git
				synced 2025-11-04 20:59:23 +08:00 
			
		
		
		
	refactor: 优化邮件配置
This commit is contained in:
		@@ -293,13 +293,13 @@ export interface SiteConfig {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/** 邮箱配置类型 */
 | 
					/** 邮箱配置类型 */
 | 
				
			||||||
export interface MailConfig {
 | 
					export interface MailConfig {
 | 
				
			||||||
  MAIL_SMTP_HOST: OptionResp
 | 
					  MAIL_PROTOCOL: OptionResp
 | 
				
			||||||
  MAIL_SMTP_PORT: OptionResp
 | 
					  MAIL_HOST: OptionResp
 | 
				
			||||||
  MAIL_SMTP_USERNAME: OptionResp
 | 
					  MAIL_PORT: OptionResp
 | 
				
			||||||
  MAIL_SMTP_PASSWORD: OptionResp
 | 
					  MAIL_USERNAME: OptionResp
 | 
				
			||||||
 | 
					  MAIL_PASSWORD: OptionResp
 | 
				
			||||||
  MAIL_SSL_ENABLED: OptionResp
 | 
					  MAIL_SSL_ENABLED: OptionResp
 | 
				
			||||||
  MAIL_SSL_PORT: OptionResp
 | 
					  MAIL_SSL_PORT: OptionResp
 | 
				
			||||||
  MAIL_FROM: OptionResp
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/** 安全配置类型 */
 | 
					/** 安全配置类型 */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,17 +11,22 @@
 | 
				
			|||||||
      scroll-to-first-error
 | 
					      scroll-to-first-error
 | 
				
			||||||
      class="form"
 | 
					      class="form"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <a-form-item field="MAIL_SMTP_HOST" :label="mailConfig.MAIL_SMTP_HOST.name" hide-asterisk>
 | 
					      <a-form-item field="MAIL_PROTOCOL" :label="mailConfig.MAIL_PROTOCOL.name" hide-asterisk>
 | 
				
			||||||
        <a-input v-model.trim="form.MAIL_SMTP_HOST" />
 | 
					        <a-select v-model.trim="form.MAIL_PROTOCOL">
 | 
				
			||||||
 | 
					          <a-option label="SMTP" value="smtp" />
 | 
				
			||||||
 | 
					        </a-select>
 | 
				
			||||||
      </a-form-item>
 | 
					      </a-form-item>
 | 
				
			||||||
      <a-form-item field="MAIL_SMTP_PORT" :label="mailConfig.MAIL_SMTP_PORT.name" hide-asterisk>
 | 
					      <a-form-item field="MAIL_HOST" :label="mailConfig.MAIL_HOST.name" hide-asterisk>
 | 
				
			||||||
        <a-input-number v-model="form.MAIL_SMTP_PORT" :min="0" />
 | 
					        <a-input v-model.trim="form.MAIL_HOST" />
 | 
				
			||||||
      </a-form-item>
 | 
					      </a-form-item>
 | 
				
			||||||
      <a-form-item field="MAIL_SMTP_USERNAME" :label="mailConfig.MAIL_SMTP_USERNAME.name" hide-asterisk>
 | 
					      <a-form-item field="MAIL_PORT" :label="mailConfig.MAIL_PORT.name" hide-asterisk>
 | 
				
			||||||
        <a-input v-model.trim="form.MAIL_SMTP_USERNAME" />
 | 
					        <a-input-number v-model="form.MAIL_PORT" :min="0" />
 | 
				
			||||||
      </a-form-item>
 | 
					      </a-form-item>
 | 
				
			||||||
      <a-form-item field="MAIL_SMTP_PASSWORD" :label="mailConfig.MAIL_SMTP_PASSWORD?.name" hide-asterisk>
 | 
					      <a-form-item field="MAIL_USERNAME" :label="mailConfig.MAIL_USERNAME.name" hide-asterisk>
 | 
				
			||||||
        <a-input-password v-model.trim="form.MAIL_SMTP_PASSWORD" />
 | 
					        <a-input v-model.trim="form.MAIL_USERNAME" />
 | 
				
			||||||
 | 
					      </a-form-item>
 | 
				
			||||||
 | 
					      <a-form-item field="MAIL_PASSWORD" :label="mailConfig.MAIL_PASSWORD?.name" hide-asterisk>
 | 
				
			||||||
 | 
					        <a-input-password v-model.trim="form.MAIL_PASSWORD" />
 | 
				
			||||||
      </a-form-item>
 | 
					      </a-form-item>
 | 
				
			||||||
      <a-form-item field="MAIL_SSL_ENABLED" :label="mailConfig.MAIL_SSL_ENABLED?.name" hide-asterisk>
 | 
					      <a-form-item field="MAIL_SSL_ENABLED" :label="mailConfig.MAIL_SSL_ENABLED?.name" hide-asterisk>
 | 
				
			||||||
        <a-radio-group v-model:model-value="form.MAIL_SSL_ENABLED">
 | 
					        <a-radio-group v-model:model-value="form.MAIL_SSL_ENABLED">
 | 
				
			||||||
@@ -32,9 +37,6 @@
 | 
				
			|||||||
      <a-form-item v-if="form.MAIL_SSL_ENABLED === '1'" field="MAIL_SSL_PORT" :label="mailConfig.MAIL_SSL_PORT.name" hide-asterisk>
 | 
					      <a-form-item v-if="form.MAIL_SSL_ENABLED === '1'" field="MAIL_SSL_PORT" :label="mailConfig.MAIL_SSL_PORT.name" hide-asterisk>
 | 
				
			||||||
        <a-input-number v-model="form.MAIL_SSL_PORT" :min="0" />
 | 
					        <a-input-number v-model="form.MAIL_SSL_PORT" :min="0" />
 | 
				
			||||||
      </a-form-item>
 | 
					      </a-form-item>
 | 
				
			||||||
      <a-form-item field="MAIL_FROM" :label="mailConfig.MAIL_FROM.name" hide-asterisk>
 | 
					 | 
				
			||||||
        <a-input v-model.trim="form.MAIL_FROM" />
 | 
					 | 
				
			||||||
      </a-form-item>
 | 
					 | 
				
			||||||
      <a-space>
 | 
					      <a-space>
 | 
				
			||||||
        <a-button v-if="!isUpdate" v-permission="['system:config:update']" type="primary" @click="onUpdate">
 | 
					        <a-button v-if="!isUpdate" v-permission="['system:config:update']" type="primary" @click="onUpdate">
 | 
				
			||||||
          <template #icon><icon-edit /></template>修改
 | 
					          <template #icon><icon-edit /></template>修改
 | 
				
			||||||
@@ -73,43 +75,42 @@ const { width } = useWindowSize()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const formRef = ref<FormInstance>()
 | 
					const formRef = ref<FormInstance>()
 | 
				
			||||||
const { form } = useForm({
 | 
					const { form } = useForm({
 | 
				
			||||||
  MAIL_SMTP_HOST: '',
 | 
					  MAIL_PROTOCOL: '',
 | 
				
			||||||
  MAIL_SMTP_PORT: 0,
 | 
					  MAIL_HOST: '',
 | 
				
			||||||
  MAIL_SMTP_USERNAME: '',
 | 
					  MAIL_PORT: 0,
 | 
				
			||||||
  MAIL_SMTP_PASSWORD: '',
 | 
					  MAIL_USERNAME: '',
 | 
				
			||||||
 | 
					  MAIL_PASSWORD: '',
 | 
				
			||||||
  MAIL_SSL_ENABLED: '',
 | 
					  MAIL_SSL_ENABLED: '',
 | 
				
			||||||
  MAIL_SSL_PORT: 0,
 | 
					  MAIL_SSL_PORT: 0
 | 
				
			||||||
  MAIL_FROM: ''
 | 
					 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
const rules: FormInstance['rules'] = {
 | 
					const rules: FormInstance['rules'] = {
 | 
				
			||||||
  MAIL_SMTP_HOST: [{ required: true, message: '请输入值' }],
 | 
					  MAIL_HOST: [{ required: true, message: '请输入值' }],
 | 
				
			||||||
  MAIL_SMTP_PORT: [{ required: true, message: '请输入值' }],
 | 
					  MAIL_PORT: [{ required: true, message: '请输入值' }],
 | 
				
			||||||
  MAIL_SMTP_USERNAME: [{ required: true, message: '请输入值' }],
 | 
					  MAIL_USERNAME: [{ required: true, message: '请输入值' }],
 | 
				
			||||||
  MAIL_SMTP_PASSWORD: [{ required: true, message: '请输入值' }],
 | 
					  MAIL_PASSWORD: [{ required: true, message: '请输入值' }],
 | 
				
			||||||
  MAIL_SSL_PORT: [{ required: true, message: '请输入值' }],
 | 
					  MAIL_SSL_PORT: [{ required: true, message: '请输入值' }]
 | 
				
			||||||
  MAIL_FROM: [{ required: true, message: '请输入值' }]
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const mailConfig = ref<MailConfig>({
 | 
					const mailConfig = ref<MailConfig>({
 | 
				
			||||||
  MAIL_SMTP_HOST: {},
 | 
					  MAIL_PROTOCOL: {},
 | 
				
			||||||
  MAIL_SMTP_PORT: {},
 | 
					  MAIL_HOST: {},
 | 
				
			||||||
  MAIL_SMTP_USERNAME: {},
 | 
					  MAIL_PORT: {},
 | 
				
			||||||
  MAIL_SMTP_PASSWORD: {},
 | 
					  MAIL_USERNAME: {},
 | 
				
			||||||
 | 
					  MAIL_PASSWORD: {},
 | 
				
			||||||
  MAIL_SSL_ENABLED: {},
 | 
					  MAIL_SSL_ENABLED: {},
 | 
				
			||||||
  MAIL_SSL_PORT: {},
 | 
					  MAIL_SSL_PORT: {}
 | 
				
			||||||
  MAIL_FROM: {}
 | 
					 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// 重置
 | 
					// 重置
 | 
				
			||||||
const reset = () => {
 | 
					const reset = () => {
 | 
				
			||||||
  formRef.value?.resetFields()
 | 
					  formRef.value?.resetFields()
 | 
				
			||||||
  form.MAIL_SMTP_HOST = mailConfig.value.MAIL_SMTP_HOST.value || ''
 | 
					  form.MAIL_PROTOCOL = mailConfig.value.MAIL_PROTOCOL.value || ''
 | 
				
			||||||
  form.MAIL_SMTP_PORT = mailConfig.value.MAIL_SMTP_PORT.value || 0
 | 
					  form.MAIL_HOST = mailConfig.value.MAIL_HOST.value || ''
 | 
				
			||||||
  form.MAIL_SMTP_USERNAME = mailConfig.value.MAIL_SMTP_USERNAME.value || ''
 | 
					  form.MAIL_PORT = mailConfig.value.MAIL_PORT.value || 0
 | 
				
			||||||
  form.MAIL_SMTP_PASSWORD = mailConfig.value.MAIL_SMTP_PASSWORD?.value || ''
 | 
					  form.MAIL_USERNAME = mailConfig.value.MAIL_USERNAME.value || ''
 | 
				
			||||||
 | 
					  form.MAIL_PASSWORD = mailConfig.value.MAIL_PASSWORD?.value || ''
 | 
				
			||||||
  form.MAIL_SSL_ENABLED = mailConfig.value.MAIL_SSL_ENABLED.value || ''
 | 
					  form.MAIL_SSL_ENABLED = mailConfig.value.MAIL_SSL_ENABLED.value || ''
 | 
				
			||||||
  form.MAIL_SSL_PORT = mailConfig.value.MAIL_SSL_PORT.value || 0
 | 
					  form.MAIL_SSL_PORT = mailConfig.value.MAIL_SSL_PORT.value || 0
 | 
				
			||||||
  form.MAIL_FROM = mailConfig.value.MAIL_FROM.value || ''
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const isUpdate = ref(false)
 | 
					const isUpdate = ref(false)
 | 
				
			||||||
@@ -131,7 +132,7 @@ const queryForm = {
 | 
				
			|||||||
const getDataList = async () => {
 | 
					const getDataList = async () => {
 | 
				
			||||||
  const { data } = await listOption(queryForm)
 | 
					  const { data } = await listOption(queryForm)
 | 
				
			||||||
  mailConfig.value = data.reduce((obj: MailConfig, option: OptionResp) => {
 | 
					  mailConfig.value = data.reduce((obj: MailConfig, option: OptionResp) => {
 | 
				
			||||||
    obj[option.code] = { ...option, value: ['MAIL_SMTP_PORT', 'MAIL_SSL_PORT'].includes(option.code) ? Number.parseInt(option.value) : option.value }
 | 
					    obj[option.code] = { ...option, value: ['MAIL_PORT', 'MAIL_SSL_PORT'].includes(option.code) ? Number.parseInt(option.value) : option.value }
 | 
				
			||||||
    return obj
 | 
					    return obj
 | 
				
			||||||
  }, {})
 | 
					  }, {})
 | 
				
			||||||
  handleCancel()
 | 
					  handleCancel()
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user