//swiper
var swiper = {
init:function () {
if ($('.swiper-container').length > 0) {
Do('swiper', function () {
$('.swiper-container').each(function () {
var $option = $(this).data('option');
var id = $(this).attr('id');
$option = helper.parseOptions($option);
var option = $option || {};
var defaultOptions = {
};
var options = $.extend({}, defaultOptions, option);
new Swiper('#'+id,options);
})
});
}
}
};
//js验证
var valid = {
//是否为空
isEmpty: function (str) {
return str === "" || str === null || str === undefined;
},
//是否为邮件
isEmail: function (str) {
var reg = /^\w+((-w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/;
if (reg.test(str)) return true;
},
//是否为手机号
isMobile: function (str) {
var a = /^1\d{10}$/, s = $.trim(str);
if (a.test(s)) return true;
},
//是否汉字
isCN: function (str) {
var s = $.trim(str), reg = /^[\u4e00-\u9fa5]+$/;
return reg.test(s);
},
//是否密码
isPwd: function (str) {
var reg = /^[A-Za-z0-9_-]+$/;
if (reg.test(str)) return true;
},
//是否为微信号
isWx: function (str) {
var rex = /^[a-zA-Z\d_]{5,}$/;
return rex.test($.trim(str));
},
//是否全为数字
isNum: function (num) {
var rex = /^[0-9]+$/;
return rex.test($.trim(num));
},
//是否为热线电话
isPhone: function (num) {
var rex = /^[0-9]([0-9]|-)*[0-9]$/;
return rex.test($.trim(num));
},
//是否为钱数
isFloat: function (n) {
return !isNaN(n);
},
//判断是否为url地址
isUrl: function (str) {
var rex = /^(http|https){1}:\/\/[^\s]+$/;
return rex.test($.trim(str));
}
};
//通用辅助方法
var helper = {
/**
* 格式化参数
* @param string
*/
parseOptions: function (string) {
if ($.isPlainObject(string)) {
return string;
}
var start = (string ? string.indexOf('{') : -1),
options = {};
if (start != -1) {
try {
options = (new Function('', 'var json = ' + string.substr(start) + '; return JSON.parse(JSON.stringify(json));'))();
} catch (e) {
}
}
return options;
},
layerMedia: function (width, height) {
var windowWidth = $(window).width(); //可视区域宽度
var windowHeight = $(window).height() //可视区域高度
var areaWidth = windowWidth < 1024 ? '100vw' : width;
var areaHeight = height > windowHeight ? '100vh' : height; //兼容小屏幕设备
return [areaWidth, areaHeight];
},
calc: function (arg1, arg2, operator) {
var oper = ['+', '-', '*', '/'];
// 不合法的运算
if (isNaN(arg1) || isNaN(arg2) || oper.indexOf(operator) < 0) return NaN;
// 除以0
if (operator === '/' && Number(arg2) === 0) return Infinity;
// 和0相乘
if (operator === '*' && Number(arg2) === 0) return 0;
// 相等两个数字相减
if ((arg1 === arg2 || Number(arg1) === Number(arg2)) && operator === '-') return 0;
var r1, r2, max, _r1, _r2;
try {
r1 = arg1.toString().split(".")[1].length
} catch (e) {
r1 = 0
}
try {
r2 = arg2.toString().split(".")[1].length
} catch (e) {
r2 = 0
}
max = Math.max(r1, r2)
_r1 = max - r1;
_r2 = max - r2;
if (_r1 !== 0) {
arg1 = arg1 + '0'.repeat(_r1)
}
if (_r2 !== 0) {
arg2 = arg2 + '0'.repeat(_r2)
}
arg1 = Number(arg1.toString().replace('.', ''));
arg2 = Number(arg2.toString().replace('.', ''));
var r3 = operator === '*' ? (max * 2) : (operator === '/' ? 0 : max);
var newNum = eval(arg1 + operator + arg2);
if (r3 !== 0) {
var nStr = newNum.toString();
nStr = nStr.replace(/^-/, '');
if (nStr.length < r3 + 1) {
nStr = '0'.repeat(r3 + 1 - nStr.length) + nStr;
}
nStr = nStr.replace(new RegExp('(\\\d{' + r3 + '})$'), '.$1');
if (newNum < 0) {
nStr = '-' + nStr;
}
newNum = nStr * 1;
}
return newNum;
},
createTab(opt) {
var defaultOpt = {refresh: false};
var option = $.extend({}, defaultOpt, opt);
if (self != top) {
top.$(parent.document).data('multitabs').create(option, true);
} else {
location.href = option.url;
}
},
closeTabOthers() {
parent.$(parent.document).data('multitabs').closeOthers();
},
closeTabAll() {
parent.$(parent.document).data('multitabs').closeAll();
},
closeTabById(id) {
parent.$(parent.document).data('multitabs').closeById(id);
},
closeTabByUrl(url) {
parent.$(parent.document).data('multitabs').closeByUrl(url);
},
closeCurrent() {
if (self != top) {
parent.$(parent.document).data('multitabs').closeCurrent();
} else {
window.close();
}
},
json2str: function (json) {
return JSON.stringify(json);
},
/**
* 刷新页面
* @returns {boolean}
*/
refresh: function () {
window.location.reload();
},
/**
* 返回
*/
back: function () {
window.history.go(-1);
},
/**
* 跳转
* @param url
*/
location: function (url) {
window.location.href = url;
},
/**
* 全选
* @param dom
*/
checkAll: function (dom) {
$(dom + " :checkbox").prop("checked", true);
},
/**
* 反选
* @param dom
*/
checkOther: function (dom) {
$(dom + " :checkbox").each(function () {
$(this).prop("checked", !$(this).prop("checked"));
});
},
/**
* 获取复选款值
* @param dom
* @returns {[]}
*/
getCheckboxValue: function (dom) {
var reVal = [];
$(dom).find("input[type='checkbox']").each(function () {
if ($(this).prop("checked")) {
reVal.push($(this).val());
}
});
return reVal;
},
/**
* json数据取指定列数据
* @param json
* @param col
* @returns array
*/
json2col: function (json, col) {
var len = json.length;
var renal = [];
if (len == 0) return renal;
for (var i = 0; i < len; i++) {
renal.push(json[i][col]);
}
return renal;
},
/**
* 操作后提示
* @param msg
* @param icon
* @param callFn
* @returns {boolean}
*/
tips: function (msg, icon, callFn) {
var opt = valid.isNum(icon) ? {icon: icon, time: 1200} : {time: 1200};
layer.msg(msg, opt, function () {
if (typeof (callFn) != "undefined") {
callFn();
}
});
},
/**
* 封装ajax请求
* @param opt
*/
getAjax: function (opt) {
var defaultConfig = {
type: 'post',
cache: true,
async: true,
dataType: 'json',
beforeSend: function () {
helper.loading('show');
},
error: function () {
layer.alert('与服务器断开连接!');
return false;
},
complete: function () {
helper.loading('hide');
}
};
var config = $.extend({}, defaultConfig, opt);
$.ajax(config);
},
/**
* loading
* @param $mode
* @returns {boolean}
*/
loading: function ($mode) {
var $loadingEl = jQuery('#loading');
$mode = $mode || 'show';
if ($mode === 'show') {
if ($loadingEl.length) {
$loadingEl.fadeIn(250);
} else {
$('body').prepend(
'
'
);
}
}
if ($mode === 'hide') {
if ($loadingEl.length) {
$loadingEl.fadeOut(250);
}
}
return false;
},
/**
* 图片懒加载
* @param throttle
*/
lazy: function (throttle) {
var t = throttle || 0;
Do('echo', function () {
echo.init({
offset: 0, //离可视区域多少像素的图片可以被加载
throttle: t //图片延迟多少毫秒加载
});
});
},
/*
字符串拼接,记得将反斜杠替换为正斜杠
var str = helper.heredoc(function () {\*
{@each list as row}
${row.title}
{@/each}
*\})
*/
heredoc: function (fn) {
return fn.toString().split('\n').slice(1, -1).join('\n') + '\n'
},
/**
* 获取url地址栏参数
* @return {string}
*/
GetQueryString: function (name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if (r != null) return unescape(r[2]);
return null;
},
/**
* 判断是否手机
* @returns {boolean}
*/
checkMobile: function () {
var ua = navigator.userAgent;
var ipad = ua.match(/(iPad).*OS\s([\d_]+)/),
isIphone = !ipad && ua.match(/(iPhone\sOS)\s([\d_]+)/),
isAndroid = ua.match(/(Android)\s+([\d.]+)/),
isMobile = isIphone || isAndroid;
return !!isMobile;
},
/**
* 获取检索参数name用@隔开,需单独传递参数使用字段@own
* @param dom
*/
getSearchParams: function (dom) {
var obj = dom || '#search-form';
var params = {};
var filter = [];
if ($(obj).length > 0) {
var formData = $(obj).serializeArray();
for (var i = 0; i < formData.length; i++) {
var formInfo = formData[i];
var arr = formInfo.name.split('@');
var field = arr[0];
if (arr.length == 1) { //单独传输
params[field] = formInfo.value;
} else {
filter.push({field: field, op: arr[1], value: formInfo.value});
}
}
}
params.filter = filter;
return params;
},
/**
* bootstrap-table封装
* @param opt
* @param dom
*/
bootstrapTable: function (opt, dom) {
var obj = dom || '#grid';
var defaultOption = {
iconsPrefix: "mdi",
icons: {
paginationSwitchDown: "mdi-arrow-down",
paginationSwitchUp: "mdi-arrow-up",
refresh: "mdi-refresh",
toggleOff: "mdi-set-left",
toggleOn: "mdi-set-right",
columns: "mdi-view-list",
fullscreen: "mdi-fullscreen",
detailOpen: "mdi-plus",
detailClose: "mdi-minus",
export: "mdi-download"
},
uniqueId: 'id',
toolbar: '.toolbar',
pagination: true,
pageSize: 20,
sidePagination: "server",
showJumpTo: true,
paginationSuccessivelySize: 3,
method: "post",
queryParamsType: "page",
pageList: [20, 40, 80, 100, 500, 'all'],
showFullscreen: false,
showColumns: true,
showRefresh: true,
showToggle: false,
showExport: true,
smartDisplay: true,
exportTypes: ['excel', 'csv', 'json', 'xml', 'txt'],
exportOptions: {
ignoreColumn: ['checkbox', 'operate'] //导出忽略单选/复选列/操作列
},
clickToSelect: true
};
var option = $.extend({}, defaultOption, opt);
var bodyWidth = $(document.body).outerWidth();
var bodyHeight = $(document.body).outerHeight();
if (!option.hasOwnProperty('height')) {
if (bodyWidth > 1023) {
option.height = bodyHeight - 90;
}
}
if (option.hasOwnProperty('height')) {
var height = option.height;
if (height == "t1" && bodyWidth > 1023) {
option.height = bodyHeight - 35;
}
}
if (!option.hasOwnProperty('queryParams')) {
option.queryParams = function (params) {
var searchParams = helper.getSearchParams();
return $.extend({}, params, searchParams);
}
}
Do('bootstrap-table', 'export', function () {
$(obj).bootstrapTable(option);
});
},
treeTable: function (opt, dom) {
var grid = dom || '#grid';
var defaultOption = {
expanderCollapsedClass: "mdi mdi-folder",
expanderExpandedClass: "mdi mdi-folder-open",
saveState: true
};
var options = $.extend({}, defaultOption, opt);
Do('tree-grid', function () {
$(grid).treegrid(options);
});
},
/**
* bootstrap-table刷新表格封装
* @param dom
*/
refreshTable: function (dom) {
var obj = dom || '#grid';
$(obj).bootstrapTable('refresh', {pageNumber: 1});
},
/**
* ajax分页封装
* @param options
* @param dom
*/
pagination: function (options, dom) {
var obj = dom || '#page';
var params = options.params || {};
Do('pagination', function () {
var defaultConfig = {
locator: 'rows',
totalNumberLocator: function (response) {
return response.total;
},
className: 'paginationjs-theme-primary',
pageSize: 20,
showGoInput: false,
showGoButton: false,
autoHidePrevious: true,
autoHideNext: true,
ajax: {
type: 'post',
data: params,
beforeSend: function () {
helper.loading('show');
},
complete: function () {
helper.loading('hide');
}
}
};
var config = $.extend({}, defaultConfig, options);
$(obj).pagination(config);
});
},
renderSize:function (fileSize){
if(null==fileSize||fileSize=='') return "0 Bytes";
var unitArr = ["Bytes","KB","MB","GB","TB","PB","EB","ZB","YB"];
var index=0;
var srcsize = parseFloat(fileSize);
index=Math.floor(Math.log(srcsize)/Math.log(1024));
var size =srcsize/Math.pow(1024,index);
size=size.toFixed(2);//保留的小数位数
return size+unitArr[index];
},
/**
* 友好时间显示
* @param timestamp
* @returns {string|*}
*/
dateDiff: function (timestamp) {
// 补全为13位
var arrTimestamp = (timestamp + '').split('');
for (var start = 0; start < 13; start++) {
if (!arrTimestamp[start]) {
arrTimestamp[start] = '0';
}
}
timestamp = arrTimestamp.join('') * 1;
var minute = 1000 * 60;
var hour = minute * 60;
var day = hour * 24;
var halfamonth = day * 15;
var month = day * 30;
var now = new Date().getTime();
var diffValue = now - timestamp;
// 如果本地时间反而小于变量时间
if (diffValue < 0) return '不久前';
// 计算差异时间的量级
var monthC = diffValue / month;
var weekC = diffValue / (7 * day);
var dayC = diffValue / day;
var hourC = diffValue / hour;
var minC = diffValue / minute;
// 数值补0方法
var zero = function (value) {
if (value < 10) return '0' + value;
return value;
};
// 使用
if (monthC > 12) {
// 超过1年,直接显示年月日
return (function () {
var date = new Date(timestamp);
return date.getFullYear() + '年' + zero(date.getMonth() + 1) + '月' + zero(date.getDate()) + '日';
})();
} else if (monthC >= 1) {
return parseInt(monthC) + "月前";
} else if (weekC >= 1) {
return parseInt(weekC) + "周前";
} else if (dayC >= 1) {
return parseInt(dayC) + "天前";
} else if (hourC >= 1) {
return parseInt(hourC) + "小时前";
} else if (minC >= 1) {
return parseInt(minC) + "分钟前";
}
return '刚刚';
},
/**
* 格式化时间戳
* @param timestamp
* @param formats
* @returns {string}
*/
dateFormat: function (timestamp, formats) {
// formats格式包括
// 1. Y-m-d
// 2. Y-m-d H:i:s
// 3. Y年m月d日
// 4. Y年m月d日 H时i分
formats = formats || 'Y-m-d';
var zero = function (value) {
if (value < 10) return '0' + value;
return value;
};
if (parseInt(timestamp) === 0) return '';
timestamp = timestamp * 1000;
var myDate = timestamp ? new Date(timestamp) : new Date();
var year = myDate.getFullYear();
var month = zero(myDate.getMonth() + 1);
var day = zero(myDate.getDate());
var hour = zero(myDate.getHours());
var minite = zero(myDate.getMinutes());
var second = zero(myDate.getSeconds());
return formats.replace(/Y|m|d|H|i|s/ig, function (matches) {
return ({
Y: year,
m: month,
d: day,
H: hour,
i: minite,
s: second
})[matches];
});
},
/**
* 秒数转小时
* @param second
* @returns {string}
*/
getDuration:function (second) {
if(valid.isEmpty(second)) return '0:00:00';
var hours = Math.floor(second/3600);
var minutes = Math.floor(second/60) % 60;
var seconds = Math.floor(second % 60);
var time = [helper.PrefixZero(hours,2),helper.PrefixZero(minutes,2),helper.PrefixZero(seconds,2)];
return time.join(':');
},
/**
* 自定义函数名:PrefixZero
* @param num: 被操作数
* @param n: 固定的总位数
* @return {string}
*/
PrefixZero:function (num, n) {
return (Array(n).join(0) + num).slice(-n);
},
/**
* 确认后操作
* @param obj
* @param callFn
*/
doConfirm: function (obj, callFn) {
var data = $(obj).data();
var msg = valid.isEmpty(data.msg) ? '确认操作吗?' : data.msg;
layer.confirm(msg, {icon: 3}, function (index) {
helper.getAjax({
url: data.url,
data: data.params,
success: function (res) {
if (res.code == 1) {
if (typeof (callFn) == "undefined") {
helper.refreshTable();
} else if (callFn == 'refresh') {
helper.refresh();
} else if (callFn.substring(0, 4) == 'url:') {
var arr = callFn.split(':');
helper.location(arr[1]);
} else {
callFn(res);
}
} else {
helper.tips(res.msg);
}
}
});
layer.close(index);
});
},
/**
* 弹框操作
* @param obj
*/
doDialog: function (obj) {
var url = $(obj).data('url'),
width = $(obj).data('width') || '80%',
height = $(obj).data('height') || '90%',
offset = $(obj).data('offset') || '30px',
title = $(obj).data('title') || '操作窗口';
var index = layer.open({
type: 2,
title: title,
offset: offset,
area: [width, height],
closeBtn: 1,
shade: 0.2,
isOutAnim: false,
shadeClose: true,
resize: false,
fixed: false, //不固定
content: url
});
var bodyWidth = $(document.body).width();
if (bodyWidth < 768) layer.full(index);
},
/**
* 删除行
* @param obj
* @param callFn
*/
delRow: function (obj, callFn) {
$(obj).closest('.item-row').remove();
if (typeof callFn != 'undefined') {
callFn(obj);
}
},
/**
* 上移
* @param obj
*/
upMove: function (obj) {
var leftMove = $(obj).closest('.item-row'); //当前行
var prevMove = leftMove.prev('.item-row'); //上一个同级元素
if (prevMove.length > 0) { //存在上一个同级元素
prevMove.insertAfter(leftMove); //就把它移动到前面
}
},
/**
* 下移
* @param obj
*/
downMove: function (obj) {
var rightMove = $(obj).closest('.item-row');
var nextMove = rightMove.next('.item-row');
if (nextMove.length > 0) {
nextMove.insertBefore(rightMove);
}
},
};
//表单辅助方法
var formHelper = {
init: function () {
this.laydate();
this.number();
this.tags();
this.ckEditor();
this.ace();
this.area();
this.selectpage();
this.h5uploader();
this.inputGroup();
},
/**
* 表单提交
* @param opt
* @param dom
*/
subForm: function (opt, dom) {
var referrer = document.referrer;
var obj = dom || '#form';
var defaultConfig = {
btnSubmit: ".btn-sub",
btnReset: ".btn-reset",
ajaxPost: true,
tipSweep: true,
label: '.control-label',
tiptype: function (msg, o, cssctl) {
if (o.type == 3) {
o.obj.closest('.form-group').addClass('has-error');
o.obj.closest('.form-group').find('.error-msg').html(' ' + msg);;
$(obj).find('.error-msg').show().html(' ' + msg);
} else {
o.obj.closest('.form-group').removeClass('has-error');
o.obj.closest('.form-group').find('.error-msg').empty();
$(obj).find('.error-msg').html('').hide();
}
},
beforeCheck: function (curform) {
if (typeof CKEDITOR != 'undefined') { //同步编辑器
for (ck in CKEDITOR.instances) {
CKEDITOR.instances[ck].updateElement();
}
}
},
beforeSubmit: function (curform) {
helper.loading('show');
$(obj).find('.btn-sub').attr("disabled", "disabled"); //禁用按钮
$(obj).find('.btn-reset').attr("disabled", "disabled"); //禁用按钮
},
callback: function (res) {
helper.loading('hide');
$(obj).find('.btn-sub').removeAttr("disabled"); //启用按钮
$(obj).find('.btn-reset').removeAttr("disabled"); //启用按钮
if (res.code == 1) {
if (typeof opt == 'function') {
opt(res);
var index = parent.layer.getFrameIndex(window.name);
parent.layer.close(index);
} else {
var call = $(obj).data('call') || '';
if (call == '') {
layer.confirm('操作成功', {
closeBtn: 0,
icon: 1,
btn: ['继续操作', '关闭页面'] //按钮
}, function () {
helper.refresh();
}, function () {
var url = $(obj).data('url');
if (!valid.isEmpty(url)) { //刷新指定页面
var iframe = parent.$(parent.document).find("iframe[src='" + url + "']");
if (iframe.length > 0) {
var refreshType=$(obj).data('refresh') || 0; //0刷新刷新grid 1刷新整个页面
if(refreshType==0){ //默认刷新grid
var id = '#' + iframe.attr('id');
top.$(id).contents().find('#search-btn').click();
} else {
iframe.attr('src',url);
}
}
}
helper.closeCurrent();
});
} else {
if (call == "refreshSelfPage") helper.refresh();
if (call == "refreshPage") parent.helper.refresh();
if (call == 'refreshTable') parent.helper.refreshTable();
if (call == 'url') helper.location(res.url);
if (call == 'none') layer.msg(res.msg);
var index = parent.layer.getFrameIndex(window.name);
parent.layer.close(index);
}
}
} else {
$(obj).find('.error-msg').show().html(' ' + res.msg);
}
}
};
var config = defaultConfig;
if (typeof opt == 'object') {
config = $.extend({}, defaultConfig, opt);
}
Do('valid', function () {
$(obj).Validform(config);
});
},
copy: function () {
Do('copy', function () {
var clipboard = new ClipboardJS('.f-copy');
clipboard.on('success', function (e) {
layer.msg('拷贝成功');
});
});
},
number: function () {
$('.f-number').each(function () {
var type = $(this).data('type');
$(this).keyup(function () {
if (type == 'number') {
$(this).val($(this).val().replace(/[^-\d]/g, ''));
}
if (type == 'float') {
$(this).val($(this).val().replace(/[^-\d.]/g, ''));
}
}).bind("paste", function () { //CTR+V事件处理
if (type == 'number') {
$(this).val($(this).val().replace(/[^-\d]/g, ''));
}
if (type == 'float') {
$(this).val($(this).val().replace(/[^-\d.]/g, ''));
}
}).css("ime-mode", "disabled"); //CSS设置输入法不可用
});
},
laydate: function () {
if ($('.f-laydate').length > 0) {
Do('laydate', function () {
$('.f-laydate').each(function () {
var opt = $(this).data();
var defaultOption = {
elem: this
};
var option = $.extend({}, defaultOption, opt);
laydate.render(option);
});
});
}
},
selectpage: function () {
if ($('.f-selectPage').length > 0) {
Do('selectpage', function () {
$('.f-selectPage').each(function () {
var arrFun = ['formatItem', 'eAjaxSuccess', 'eSelect', 'eOpen', 'eTagRemove', 'eClear'];
var opt = $(this).data();
for (var j = 0; j < arrFun.length; j++) {
if (opt.hasOwnProperty(arrFun[j])) {
var strFun = opt[arrFun[j]];
opt[arrFun[j]] = function (data) {
return eval(strFun + '(data)');
};
}
}
var params = {searchField: opt.showField};
if (opt.hasOwnProperty('params')) params = $.extend({}, params, opt.params);
opt.params = function () {
return params;
};
var defaultOption = {
keyField: 'id',
showField: 'name',
eAjaxSuccess: function (d) {
return d ? d : undefined;
}
};
var option = $.extend({}, defaultOption, opt);
$(this).selectPage(option);
});
});
}
},
ace: function () {
if ($('.f-ace').length > 0) {
Do('ace', function () {
$('.f-ace').each(function (i) {
var id = $(this).attr('id');
var data = $(this).data();
var theme = data.theme || 'chrome';
var mode = data.mode || 'html';
var readonly = data.readonly || false;
var html = $(this).html();
var editor = ace.edit(id);
editor.setOptions({
autoScrollEditorIntoView: true,
});
editor.setTheme("ace/theme/" + theme); //设置风格
editor.getSession().setMode("ace/mode/" + mode); //设置语言模式
document.getElementById(id).style.fontSize = '16px'; //设置字体大小
editor.setReadOnly(readonly); //设置编辑器只读
editor.setValue(html);
editor.getSession().on("change", function (e) {
$("textarea[name='" + id + "']").val(editor.getValue());
});
Do.setData('ace-' + id, editor);
});
})
}
},
tags: function () {
Do('tags', function () {
$('.f-tags').tagsinput({
trimValue: true, //去除标签空白
focusClass: 'my-focus-class'
});
});
},
area: function () {
if ($('.f-area').length > 0) {
Do('city', function () {
$('.f-area').each(function () {
var name = $(this).data('name') || 'area_code';
var inputObj = $(this).find("[name='" + name + "']");
var code = inputObj.val();
var option = $(this).data();
var defaultOption = {
code: code,
provinceField: 'prov',
cityField: 'city',
areaField: 'area',
required: true,
onChange: function (info) {
var val = info.code == 0 ? '' : info.code;
var area = [];
if (!valid.isEmpty(info.province)) area.push(info.province);
if (!valid.isEmpty(info.city)) area.push(info.city);
if (!valid.isEmpty(info.area)) area.push(info.area);
inputObj.val(val);
inputObj.attr('area', area.join('/'));
if (typeof option['change'] != 'undefined') {
eval(option['change'] + '(info,this)');
}
}
};
var opt = $.extend({}, defaultOption, option);
if (code == '' && opt.required == true) { //初始code为空,且必填时补充
inputObj.val('110101');
inputObj.attr('area', '北京市/东城区');
opt.code = '110101';
}
$(this).citys(opt);
});
})
}
},
ckEditor: function () {
if ($('.f-ck-editor').length > 0) {
Do('ckeditor', 'lrz', function () {
$('.f-ck-editor').each(function () {
var name = $(this).attr('name');
var $option = $(this).data('option');
var toolbar = $(this).data('toolbar');
if (valid.isEmpty(toolbar)) {
var bodyWidth = $(document.body).width();
toolbar = bodyWidth <= 1024 ? 'Basic' : 'Full';
}
var option = valid.isEmpty($option) ? {} : $option;
var defaultOptions = {
toolbar: toolbar
};
var options = $.extend({}, defaultOptions, option);
var editor = CKEDITOR.replace(name, options);
//增加视频按钮
editor.ui.addButton && editor.ui.addButton('html5video', {
label: 'Vod',
command: 'html5video'
});
});
});
}
},
h5uploader: function () {
if ($('.f-upload').length > 0) {
Do('lrz', 'upload', function () {
$('.f-upload').each(function () {
var _this = $(this);
var inputFile = $(_this).find("[type='file']");
var uploadBtn = $(_this).find('.upload-btn');
inputFile.change(function (e) {
uploadHelper.funGetFiles(e, _this);
});
uploadBtn.click(function () {
inputFile.trigger('click');
});
//初始化直在这里设置
var value = _this.data('value') || '';
var theme = _this.data('theme');
var Fun = _this.data('theme-fun') || theme;
if (value != '') eval('themeCallfn.' + Fun + '(value,_this)');
});
})
}
},
/*
* 新封装多行数据
* 增加设置name后的回调 data-setname-after
* 增加Add后的回调 data-add-after
* 增加Del后的回调 data-del-after
*/
inputGroup: function () {
var groupObj = $('.f-input-group');
if (groupObj.length > 0) {
groupObj.each(function () {
var that = $(this);
var name = that.data('name');
var set_after_fun = that.data('setname-after');
that.find('.item').each(function (index, element) {
var _that = $(this);
if (index == 0) {
_that.find('.btn-del').hide();
_that.find('.btn-add').show();
} else {
_that.find('.btn-del').show();
_that.find('.btn-add').hide();
}
_that.find('.item-input').each(function (i, v) {
var children_name = $(this).data('name');
$(this).attr('name', name + '[' + index + '][' + children_name + ']');
if (typeof set_after_fun != 'undefined') {
eval(set_after_fun + '(_that,index,$(this),i)');
}
})
})
})
}
},
/*增加一行*/
inputGroupAdd: function (obj) {
var that = $(obj).closest('.f-input-group');
var html = that.find('.item').eq(0).prop("outerHTML");
var add_after_fun = that.data('add-after');
that.append(html);
formHelper.inputGroup();
that.find('.item:last').find('.item-input').each(function () {
$(this).val('');
});
if (typeof add_after_fun != 'undefined') {
eval(add_after_fun + '(that,$(obj))');
}
},
/*删除一行*/
inputGroupDel: function (obj) {
var that = $(obj).closest('.f-input-group');
var del_after_fun = that.data('del-after');
$(obj).closest('.item').remove();
formHelper.inputGroup();
if (typeof del_after_fun != 'undefined') {
eval(add_after_fun + '(that,$(obj))');
}
},
/*上移*/
inputGroupup: function (obj) {
var leftMove = $(obj).closest('.item'); //当前行
var prevMove = leftMove.prev('.item'); //上一个同级元素
if (prevMove.length > 0) { //存在上一个同级元素
prevMove.insertAfter(leftMove); //就把它移动到前面
}
formHelper.inputGroup();
},
/*下移*/
inputGroupdown: function (obj) {
var rightMove = $(obj).closest('.item');
var nextMove = rightMove.next('.item');
if (nextMove.length > 0) {
nextMove.insertBefore(rightMove);
}
formHelper.inputGroup();
},
};
//js数值计算
Number.prototype.calc = function (op, arg) {
return helper.calc(this, arg, op);
};
juicer.register('json2str', helper.json2str);
juicer.register('dateFormat', helper.dateFormat);
juicer.register('renderSize', helper.renderSize);
juicer.register('getDuration', helper.getDuration);