mirror of https://github.com/jumpserver/jumpserver
156 lines
5.5 KiB
Python
156 lines
5.5 KiB
Python
|
/*********************************
|
||
|
* Themes, rules, and i18n support
|
||
|
* Locale: Chinese; 中文
|
||
|
*********************************/
|
||
|
(function(factory) {
|
||
|
if (typeof define === 'function') {
|
||
|
define(function(require, exports, module){
|
||
|
var $ = require('jquery');
|
||
|
$._VALIDATOR_URI = module.uri;
|
||
|
require('../src/jquery.validator')($);
|
||
|
factory($);
|
||
|
});
|
||
|
} else {
|
||
|
factory(jQuery);
|
||
|
}
|
||
|
}(function($) {
|
||
|
/* Global configuration
|
||
|
*/
|
||
|
$.validator.config({
|
||
|
//stopOnError: false,
|
||
|
//theme: 'yellow_right',
|
||
|
defaultMsg: "{0}格式不正确",
|
||
|
loadingMsg: "正在验证...",
|
||
|
|
||
|
// Custom rules
|
||
|
rules: {
|
||
|
digits: [/^\d+$/, "请输入数字"]
|
||
|
,letters: [/^[a-z]+$/i, "{0}只能输入字母"]
|
||
|
,tel: [/^(?:(?:0\d{2,3}[\- ]?[1-9]\d{6,7})|(?:[48]00[\- ]?[1-9]\d{6}))$/, "电话格式不正确"]
|
||
|
,mobile: [/^1[3-9]\d{9}$/, "手机号格式不正确"]
|
||
|
,email: [/^[\w\+\-]+(\.[\w\+\-]+)*@[a-z\d\-]+(\.[a-z\d\-]+)*\.([a-z]{2,4})$/i, "邮箱格式不正确"]
|
||
|
,qq: [/^[1-9]\d{4,}$/, "QQ号格式不正确"]
|
||
|
,date: [/^\d{4}-\d{1,2}-\d{1,2}$/, "请输入正确的日期,例:yyyy-mm-dd"]
|
||
|
,time: [/^([01]\d|2[0-3])(:[0-5]\d){1,2}$/, "请输入正确的时间,例:14:30或14:30:00"]
|
||
|
,ID_card: [/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[A-Z])$/, "请输入正确的身份证号码"]
|
||
|
,url: [/^(https?|ftp):\/\/[^\s]+$/i, "网址格式不正确"]
|
||
|
,postcode: [/^[1-9]\d{5}$/, "邮政编码格式不正确"]
|
||
|
,chinese: [/^[\u0391-\uFFE5]+$/, "请输入中文"]
|
||
|
,username: [/^\w{3,12}$/, "请输入3-12位数字、字母、下划线"]
|
||
|
,password: [/^[0-9a-zA-Z]{6,16}$/, "密码由6-16位数字、字母组成"]
|
||
|
,accept: function (element, params){
|
||
|
if (!params) return true;
|
||
|
var ext = params[0];
|
||
|
return (ext === '*') ||
|
||
|
(new RegExp(".(?:" + (ext || "png|jpg|jpeg|gif") + ")$", "i")).test(element.value) ||
|
||
|
this.renderMsg("只接受{1}后缀", ext.replace('|', ','));
|
||
|
}
|
||
|
|
||
|
}
|
||
|
});
|
||
|
|
||
|
/* Default error messages
|
||
|
*/
|
||
|
$.validator.config({
|
||
|
messages: {
|
||
|
required: "{0}不能为空",
|
||
|
remote: "{0}已被使用",
|
||
|
integer: {
|
||
|
'*': "请输入整数",
|
||
|
'+': "请输入正整数",
|
||
|
'+0': "请输入正整数或0",
|
||
|
'-': "请输入负整数",
|
||
|
'-0': "请输入负整数或0"
|
||
|
},
|
||
|
match: {
|
||
|
eq: "{0}与{1}不一致",
|
||
|
neq: "{0}与{1}不能相同",
|
||
|
lt: "{0}必须小于{1}",
|
||
|
gt: "{0}必须大于{1}",
|
||
|
lte: "{0}必须小于或等于{1}",
|
||
|
gte: "{0}必须大于或等于{1}"
|
||
|
},
|
||
|
range: {
|
||
|
rg: "请输入{1}到{2}的数",
|
||
|
gte: "请输入大于或等于{1}的数",
|
||
|
lte: "请输入小于或等于{1}的数"
|
||
|
},
|
||
|
checked: {
|
||
|
eq: "请选择{1}项",
|
||
|
rg: "请选择{1}到{2}项",
|
||
|
gte: "请至少选择{1}项",
|
||
|
lte: "请最多选择{1}项"
|
||
|
},
|
||
|
length: {
|
||
|
eq: "请输入{1}个字符",
|
||
|
rg: "请输入{1}到{2}个字符",
|
||
|
gte: "请至少输入{1}个字符",
|
||
|
lte: "请最多输入{1}个字符",
|
||
|
eq_2: "",
|
||
|
rg_2: "",
|
||
|
gte_2: "",
|
||
|
lte_2: ""
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
|
||
|
/* Themes
|
||
|
*/
|
||
|
var TPL_ARROW = '<span class="n-arrow"><b>◆</b><i>◆</i></span>';
|
||
|
$.validator.setTheme({
|
||
|
'simple_right': {
|
||
|
formClass: 'n-simple',
|
||
|
msgClass: 'n-right'
|
||
|
},
|
||
|
'simple_bottom': {
|
||
|
formClass: 'n-simple',
|
||
|
msgClass: 'n-bottom'
|
||
|
},
|
||
|
'yellow_top': {
|
||
|
formClass: 'n-yellow',
|
||
|
msgClass: 'n-top',
|
||
|
msgArrow: TPL_ARROW
|
||
|
},
|
||
|
'yellow_right': {
|
||
|
formClass: 'n-yellow',
|
||
|
msgClass: 'n-right',
|
||
|
msgArrow: TPL_ARROW
|
||
|
},
|
||
|
'yellow_right_effect': {
|
||
|
formClass: 'n-yellow',
|
||
|
msgClass: 'n-right',
|
||
|
msgArrow: TPL_ARROW,
|
||
|
msgShow: function($msgbox, type){
|
||
|
var $el = $msgbox.children();
|
||
|
if ($el.is(':animated')) return;
|
||
|
if (type === 'error') {
|
||
|
$el.css({
|
||
|
left: '20px',
|
||
|
opacity: 0
|
||
|
}).delay(100).show().stop().animate({
|
||
|
left: '-4px',
|
||
|
opacity: 1
|
||
|
}, 150).animate({
|
||
|
left: '3px'
|
||
|
}, 80).animate({
|
||
|
left: 0
|
||
|
}, 80);
|
||
|
} else {
|
||
|
$el.css({
|
||
|
left: 0,
|
||
|
opacity: 1
|
||
|
}).fadeIn(200);
|
||
|
}
|
||
|
},
|
||
|
msgHide: function($msgbox, type){
|
||
|
var $el = $msgbox.children();
|
||
|
$el.stop().delay(100).show().animate({
|
||
|
left: '20px',
|
||
|
opacity: 0
|
||
|
}, 300, function(){
|
||
|
$msgbox.hide();
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}));
|