<template> <BasicModal v-bind="$attrs" @register="registerModal" title="修改密码" @ok="handleSubmit" destroyOnClose :width="400"> <a-form class="antd-modal-form" ref="formRef" :model="formState" :rules="validatorRules"> <a-form-item name="phone"> <div class="black font-size-13">验证手机号</div> <div class="pass-padding"> <a-input placeholder="请输入手机号" v-model:value="formState.phone"/> </div> </a-form-item> <a-form-item name="smscode"> <CountdownInput v-model:value="formState.smscode" placeholder="请输入6位验证码" :sendCodeApi="sendCodeApi" /> </a-form-item> <a-form-item name="password"> <span class="black font-size-13">新密码</span> <div class="pass-padding"> <a-input-password v-model:value="formState.password" placeholder="新密码" autocomplete="new-password"/> </div> <span class="gray-9e font-size-13">8-20位,需包含字母和数字</span> </a-form-item> </a-form> </BasicModal> </template> <script lang="ts" name="user-pass-word-modal" setup> import { ref, computed, unref, reactive } from 'vue'; import { BasicModal, useModalInner } from '/@/components/Modal'; import { Rule } from '/@/components/Form/index'; import { updateUserPassword } from '../UserSetting.api'; import { useMessage } from "/@/hooks/web/useMessage"; import { useUserStore, useUserStoreWithOut } from "/@/store/modules/user"; import { getCaptcha } from "@/api/sys/user"; import { SmsEnum } from "@/views/sys/login/useLogin"; import { CountdownInput } from '/@/components/CountDown'; import { defHttp } from "@/utils/http/axios"; const { createMessage, createErrorModal } = useMessage(); //用户名 const username = ref<string>('') const formRef = ref(); const formState = reactive({ oldpassword:'', password:'', smscode:'', phone:'', }); // 声明Emits const emit = defineEmits(['success', 'register']); //表单赋值 const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => { setModalProps({ confirmLoading: false }); username.value = data.record.username Object.assign(formState, { password:'', smscode:'', phone:'',}) }); const userStore = useUserStore(); const validatorRules: Record<string, Rule[]> = { password: [{ required: true, validator:checkPassword},{ pattern:/^(?=.*[0-9])(?=.*[a-zA-Z])(.{8,20})$/,message:'8-20位,需包含字母和数字'}], phone: [{ required: true, message: '请输入手机号' }], smscode: [{ required: true, message: '请输入6位验证码' }], }; //表单提交事件 async function handleSubmit() { try { let values = await formRef.value.validateFields(); setModalProps({ confirmLoading: true }); //提交表单 values.username = unref(username); await updateUserPassword(values).then((res) =>{ if(res.success){ createMessage.info({ content:'密码修改成功,请重新登录!3s后自动退出登录', duration: 3 }) //3s后返回登录页面 setTimeout(()=>{ userStore.logout(true); },3000) //关闭弹窗 closeModal(); }else{ createMessage.warn(res.message); } }); } finally { setModalProps({ confirmLoading: false }); } } /** * 验证新密码是否为空 */ function checkPassword(_rule: Rule, value: string) { if(value === ''){ return Promise.reject('请输入新密码'); } return Promise.resolve(); } /** * 倒计时执行前的函数 */ function sendCodeApi() { return new Promise((resolve, reject) => { let params = { mobile: formState.phone }; defHttp.post({ url: "/sys/sendChangePwdSms", params }, { isTransformResponse: false }).then((res) => { if (res.success) { resolve(true); } else { createErrorModal({ title: '错误提示', content: res.message || '未知问题' }); reject(); } }).catch((res)=>{ createErrorModal({ title: '错误提示', content: res.message || '未知问题' }); reject(); }); }); } </script> <style lang="less" scoped> .black { color: @text-color; } .font-size-13 { font-size: 13px; line-height: 15px; } .gray-9e { color: #9e9e9e; } .float-left { float: left; } .pass-padding { padding-top: 10px; padding-bottom: 10px; } .antd-modal-form { padding: 10px 24px 10px 24px; } :deep(.ant-form-item){ margin-bottom: 10px; } </style>