jeecg-boot-vue3/src/utils/helper/validator.ts

156 lines
4.4 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

import { dateUtil } from '/@/utils/dateUtil';
import { duplicateCheck } from '/@/views/system/user/user.api';
export const rules = {
rule(type, required) {
if (type === 'email') {
return this.email(required);
}
if (type === 'phone') {
return this.phone(required);
}
},
email(required) {
return [
{
required: required ? required : false,
validator: async (_rule, value) => {
if (required == true && !value) {
return Promise.reject('请输入邮箱!');
}
if (
value &&
!new RegExp(
/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
).test(value)
) {
return Promise.reject('请输入正确邮箱格式!');
}
return Promise.resolve();
},
trigger: 'change',
},
] as ArrayRule;
},
phone(required) {
return [
{
required: required,
validator: async (_, value) => {
if (required && !value) {
return Promise.reject('请输入手机号码1!');
}
if (!new RegExp(/^1[3|4|5|7|8|9][0-9]\d{8}$/).test(value)) {
return Promise.reject('手机号码格式有误');
}
return Promise.resolve();
},
trigger: 'change',
},
];
},
startTime(endTime, required) {
return [
{
required: required ? required : false,
validator: (_, value) => {
if (required && !value) {
return Promise.reject('请选择开始时间');
}
if (endTime && value && dateUtil(endTime).isBefore(value)) {
return Promise.reject('开始时间需小于结束时间');
}
return Promise.resolve();
},
trigger: 'change',
},
];
},
endTime(startTime, required) {
return [
{
required: required ? required : false,
validator: (_, value) => {
if (required && !value) {
return Promise.reject('请选择结束时间');
}
if (startTime && value && dateUtil(value).isBefore(startTime)) {
return Promise.reject('结束时间需大于开始时间');
}
return Promise.resolve();
},
trigger: 'change',
},
];
},
confirmPassword(values, required) {
return [
{
required: required ? required : false,
validator: (_, value) => {
if (!value) {
return Promise.reject('密码不能为空');
}
if (value !== values.password) {
return Promise.reject('两次输入的密码不一致!');
}
return Promise.resolve();
},
},
];
},
duplicateCheckRule(tableName, fieldName, model, schema, required?) {
return [
{
validator: (_, value) => {
if (!value && required) {
return Promise.reject(`请输入${schema.label}`);
}
return new Promise<void>((resolve, reject) => {
duplicateCheck({
tableName,
fieldName,
fieldVal: value,
dataId: model.id,
})
.then((res) => {
res.success ? resolve() : reject(res.message || '校验失败');
})
.catch((err) => {
reject(err.message || '验证失败');
});
});
},
},
] as ArrayRule;
},
};
//update-begin-author:taoyan date:2022-6-16 for: 代码生成-原生表单用
/**
* 唯一校验函数,给原生<a-form>使用vben的表单校验建议使用上述rules
* @param tableName 表名
* @param fieldName 字段名
* @param fieldVal 字段值
* @param dataId 数据ID
*/
export async function duplicateValidate(tableName, fieldName, fieldVal, dataId) {
try {
let params = {
tableName,
fieldName,
fieldVal,
dataId: dataId,
};
const res = await duplicateCheck(params);
if (res.success) {
return Promise.resolve();
} else {
return Promise.reject(res.message || '校验失败');
}
} catch (e) {
return Promise.reject('校验失败,可能是断网等问题导致的校验失败');
}
}
//update-end-author:taoyan date:2022-6-16 for: 代码生成-原生表单用