123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506 |
- /**
- * 通用方法封装处理
- * Copyright (c) 2019 ruoyi
- */
- var startLayDate;
- var endLayDate;
- $(function() {
-
- // layer扩展皮肤
- if (window.layer !== undefined) {
- layer.config({
- extend: 'moon/style.css',
- skin: 'layer-ext-moon'
- });
- }
-
- // 回到顶部绑定
- if ($.fn.toTop !== undefined) {
- $('#scroll-up').toTop();
- }
-
- // select2复选框事件绑定
- if ($.fn.select2 !== undefined) {
- $.fn.select2.defaults.set( "theme", "bootstrap" );
- $("select.form-control:not(.noselect2)").each(function () {
- $(this).select2().on("change", function () {
- $(this).valid();
- })
- })
- }
-
- // iCheck单选框及复选框事件绑定
- if ($.fn.iCheck !== undefined) {
- $(".check-box:not(.noicheck),.radio-box:not(.noicheck)").each(function() {
- $(this).iCheck({
- checkboxClass: 'icheckbox-blue',
- radioClass: 'iradio-blue',
- })
- })
- }
-
- // 取消回车自动提交表单
- $(document).on("keypress", ":input:not(textarea):not([type=submit])", function(event) {
- if (event.keyCode == 13) {
- event.preventDefault();
- }
- });
-
- // laydate 时间控件绑定
- if ($(".select-time").length > 0) {
- layui.use('laydate', function() {
- var laydate = layui.laydate;
- startLayDate = laydate.render({
- elem: '#startTime',
- max: $('#endTime').val(),
- theme: 'molv',
- type: $('#startTime').attr("data-type") || 'date',
- trigger: 'click',
- done: function(value, date) {
- // 结束时间大于开始时间
- if (value !== '') {
- endLayDate.config.min.year = date.year;
- endLayDate.config.min.month = date.month - 1;
- endLayDate.config.min.date = date.date;
- } else {
- endLayDate.config.min.year = '';
- endLayDate.config.min.month = '';
- endLayDate.config.min.date = '';
- }
- }
- });
- endLayDate = laydate.render({
- elem: '#endTime',
- min: $('#startTime').val(),
- theme: 'molv',
- type: $('#endTime').attr("data-type") || 'date',
- trigger: 'click',
- done: function(value, date) {
- // 开始时间小于结束时间
- if (value !== '') {
- startLayDate.config.max.year = date.year;
- startLayDate.config.max.month = date.month - 1;
- startLayDate.config.max.date = date.date;
- } else {
- startLayDate.config.max.year = '2099';
- startLayDate.config.max.month = '12';
- startLayDate.config.max.date = '31';
- }
- }
- });
- });
- }
-
- // laydate time-input 时间控件绑定
- if ($(".time-input").length > 0) {
- layui.use('laydate', function () {
- var com = layui.laydate;
- $(".time-input").each(function (index, item) {
- var time = $(item);
- // 控制控件外观
- var type = time.attr("data-type") || 'date';
- // 控制回显格式
- var format = time.attr("data-format") || 'yyyy-MM-dd';
- // 控制日期控件按钮
- var buttons = time.attr("data-btn") || 'clear|now|confirm', newBtnArr = [];
- // 日期控件选择完成后回调处理
- var callback = time.attr("data-callback") || {};
- if (buttons) {
- if (buttons.indexOf("|") > 0) {
- var btnArr = buttons.split("|"), btnLen = btnArr.length;
- for (var j = 0; j < btnLen; j++) {
- if ("clear" === btnArr[j] || "now" === btnArr[j] || "confirm" === btnArr[j]) {
- newBtnArr.push(btnArr[j]);
- }
- }
- } else {
- if ("clear" === buttons || "now" === buttons || "confirm" === buttons) {
- newBtnArr.push(buttons);
- }
- }
- } else {
- newBtnArr = ['clear', 'now', 'confirm'];
- }
- com.render({
- elem: item,
- theme: 'molv',
- trigger: 'click',
- type: type,
- format: format,
- btns: newBtnArr,
- done: function (value, data) {
- if (typeof window[callback] != 'undefined'
- && window[callback] instanceof Function) {
- window[callback](value, data);
- }
- }
- });
- });
- });
- }
-
- // tree 关键字搜索绑定
- if ($("#keyword").length > 0) {
- $("#keyword").bind("focus", function focusKey(e) {
- if ($("#keyword").hasClass("empty")) {
- $("#keyword").removeClass("empty");
- }
- }).bind("blur", function blurKey(e) {
- if ($("#keyword").val() === "") {
- $("#keyword").addClass("empty");
- }
- $.tree.searchNode(e);
- }).bind("input propertychange", $.tree.searchNode);
- }
-
- // tree表格树 展开/折叠
- var expandFlag;
- $("#expandAllBtn").click(function() {
- var dataExpand = $.common.isEmpty(table.options.expandAll) ? true : table.options.expandAll;
- expandFlag = $.common.isEmpty(expandFlag) ? dataExpand : expandFlag;
- if (!expandFlag) {
- $.bttTable.bootstrapTreeTable('expandAll');
- } else {
- $.bttTable.bootstrapTreeTable('collapseAll');
- }
- expandFlag = expandFlag ? false: true;
- })
-
- // 按下ESC按钮关闭弹层
- $('body', document).on('keyup', function(e) {
- if (e.which === 27) {
- $.modal.closeAll();
- }
- });
- });
- (function ($) {
- 'use strict';
- $.fn.toTop = function(opt) {
- var elem = this;
- var win = (opt && opt.hasOwnProperty('win')) ? opt.win : $(window);
- var doc = (opt && opt.hasOwnProperty('doc')) ? opt.doc : $('html, body');
- var options = $.extend({
- autohide: true,
- offset: 50,
- speed: 500,
- position: true,
- right: 15,
- bottom: 5
- }, opt);
- elem.css({
- 'cursor': 'pointer'
- });
- if (options.autohide) {
- elem.css('display', 'none');
- }
- if (options.position) {
- elem.css({
- 'position': 'fixed',
- 'right': options.right,
- 'bottom': options.bottom,
- });
- }
- elem.click(function() {
- doc.animate({
- scrollTop: 0
- }, options.speed);
- });
- win.scroll(function() {
- var scrolling = win.scrollTop();
- if (options.autohide) {
- if (scrolling > options.offset) {
- elem.fadeIn(options.speed);
- } else elem.fadeOut(options.speed);
- }
- });
- };
- })(jQuery);
- /** 刷新选项卡 */
- var refreshItem = function(){
- var topWindow = $(window.parent.document);
- var currentId = $('.page-tabs-content', topWindow).find('.active').attr('data-id');
- var target = $('.RuoYi_iframe[data-id="' + currentId + '"]', topWindow);
- var url = target.attr('src');
- target.attr('src', url).ready();
- }
- /** 关闭选项卡 */
- var closeItem = function(dataId){
- var topWindow = $(window.parent.document);
- if($.common.isNotEmpty(dataId)){
- window.parent.$.modal.closeLoading();
- // 根据dataId关闭指定选项卡
- $('.menuTab[data-id="' + dataId + '"]', topWindow).remove();
- // 移除相应tab对应的内容区
- $('.mainContent .RuoYi_iframe[data-id="' + dataId + '"]', topWindow).remove();
- return;
- }
- var panelUrl = window.frameElement.getAttribute('data-panel');
- $('.page-tabs-content .active i', topWindow).click();
- if($.common.isNotEmpty(panelUrl)){
- $('.menuTab[data-id="' + panelUrl + '"]', topWindow).addClass('active').siblings('.menuTab').removeClass('active');
- $('.mainContent .RuoYi_iframe', topWindow).each(function() {
- if ($(this).data('id') == panelUrl) {
- $(this).show().siblings('.RuoYi_iframe').hide();
- return false;
- }
- });
- }
- }
- /** 创建选项卡 */
- function createMenuItem(dataUrl, menuName, isRefresh) {
- var panelUrl = window.frameElement.getAttribute('data-id'),
- dataIndex = $.common.random(1, 100),
- flag = true;
- if (dataUrl == undefined || $.trim(dataUrl).length == 0) return false;
- var topWindow = $(window.parent.document);
- // 选项卡菜单已存在
- $('.menuTab', topWindow).each(function() {
- if ($(this).data('id') == dataUrl) {
- if (!$(this).hasClass('active')) {
- $(this).addClass('active').siblings('.menuTab').removeClass('active');
- scrollToTab(this);
- $('.page-tabs-content').animate({ marginLeft: ""}, "fast");
- // 显示tab对应的内容区
- $('.mainContent .RuoYi_iframe', topWindow).each(function() {
- if ($(this).data('id') == dataUrl) {
- $(this).show().siblings('.RuoYi_iframe').hide();
- return false;
- }
- });
- }
- if (isRefresh) {
- refreshTab();
- }
- flag = false;
- return false;
- }
- });
- // 选项卡菜单不存在
- if (flag) {
- var str = '<a href="javascript:;" class="active menuTab noactive" data-id="' + dataUrl + '" data-panel="' + panelUrl + '">' + menuName + ' <i class="fa fa-times-circle"></i></a>';
- $('.menuTab', topWindow).removeClass('active');
- // 添加选项卡对应的iframe
- var str1 = '<iframe class="RuoYi_iframe" name="iframe' + dataIndex + '" width="100%" height="100%" src="' + dataUrl + '" frameborder="0" data-id="' + dataUrl + '" data-panel="' + panelUrl + '" seamless></iframe>';
- $('.mainContent', topWindow).find('iframe.RuoYi_iframe').hide().parents('.mainContent').append(str1);
-
- window.parent.$.modal.loading("数据加载中,请稍后...");
- $('.mainContent iframe:visible', topWindow).load(function () {
- window.parent.$.modal.closeLoading();
- });
- // 添加选项卡
- $('.menuTabs .page-tabs-content', topWindow).append(str);
- scrollToTab($('.menuTab.active', topWindow));
- }
- return false;
- }
- // 刷新iframe
- function refreshTab() {
- var topWindow = $(window.parent.document);
- var currentId = $('.page-tabs-content', topWindow).find('.active').attr('data-id');
- var target = $('.RuoYi_iframe[data-id="' + currentId + '"]', topWindow);
- var url = target.attr('src');
- target.attr('src', url).ready();
- }
- // 滚动到指定选项卡
- function scrollToTab(element) {
- var topWindow = $(window.parent.document);
- var marginLeftVal = calSumWidth($(element).prevAll()),
- marginRightVal = calSumWidth($(element).nextAll());
- // 可视区域非tab宽度
- var tabOuterWidth = calSumWidth($(".content-tabs", topWindow).children().not(".menuTabs"));
- //可视区域tab宽度
- var visibleWidth = $(".content-tabs", topWindow).outerWidth(true) - tabOuterWidth;
- //实际滚动宽度
- var scrollVal = 0;
- if ($(".page-tabs-content", topWindow).outerWidth() < visibleWidth) {
- scrollVal = 0;
- } else if (marginRightVal <= (visibleWidth - $(element).outerWidth(true) - $(element).next().outerWidth(true))) {
- if ((visibleWidth - $(element).next().outerWidth(true)) > marginRightVal) {
- scrollVal = marginLeftVal;
- var tabElement = element;
- while ((scrollVal - $(tabElement).outerWidth()) > ($(".page-tabs-content", topWindow).outerWidth() - visibleWidth)) {
- scrollVal -= $(tabElement).prev().outerWidth();
- tabElement = $(tabElement).prev();
- }
- }
- } else if (marginLeftVal > (visibleWidth - $(element).outerWidth(true) - $(element).prev().outerWidth(true))) {
- scrollVal = marginLeftVal - $(element).prev().outerWidth(true);
- }
- $('.page-tabs-content', topWindow).animate({ marginLeft: 0 - scrollVal + 'px' }, "fast");
- }
- // 计算元素集合的总宽度
- function calSumWidth(elements) {
- var width = 0;
- $(elements).each(function() {
- width += $(this).outerWidth(true);
- });
- return width;
- }
- // 返回当前激活的Tab页面关联的iframe的Windows对象
- function activeWindow() {
- var topWindow = $(window.parent.document);
- var currentId = $('.page-tabs-content', topWindow).find('.active').attr('data-id');
- var activeWindow = $('.RuoYi_iframe[data-id="' + currentId + '"]', topWindow)[0].contentWindow;
- return activeWindow;
- }
- /** 密码规则范围验证 */
- function checkpwd(chrtype, password) {
- if (chrtype == 1) {
- if(!$.common.numValid(password)){
- $.modal.alertWarning("密码只能为0-9数字");
- return false;
- }
- } else if (chrtype == 2) {
- if(!$.common.enValid(password)){
- $.modal.alertWarning("密码只能为a-z和A-Z字母");
- return false;
- }
- } else if (chrtype == 3) {
- if(!$.common.enNumValid(password)){
- $.modal.alertWarning("密码必须包含字母以及数字");
- return false;
- }
- } else if (chrtype == 4) {
- if(!$.common.charValid(password)){
- $.modal.alertWarning("密码必须包含字母、数字、以及特殊符号<font color='red'>~!@#$%^&*()-=_+</font>");
- return false;
- }
- }
- return true;
- }
- // 日志打印封装处理
- var log = {
- log: function(msg) {
- console.log(msg);
- },
- info: function(msg) {
- console.info(msg);
- },
- warn: function(msg) {
- console.warn(msg);
- },
- error: function(msg) {
- console.error(msg);
- }
- };
- // 本地缓存处理
- var storage = {
- set: function(key, value) {
- window.localStorage.setItem(key, value);
- },
- get: function(key) {
- return window.localStorage.getItem(key);
- },
- remove: function(key) {
- window.localStorage.removeItem(key);
- },
- clear: function() {
- window.localStorage.clear();
- }
- };
- // 主子表操作封装处理
- var sub = {
- editColumn: function() {
- var dataColumns = [];
- for (var columnIndex = 0; columnIndex < table.options.columns.length; columnIndex++) {
- if (table.options.columns[columnIndex].visible != false) {
- dataColumns.push(table.options.columns[columnIndex]);
- }
- }
- var params = new Array();
- var data = $("#" + table.options.id).bootstrapTable('getData');
- var count = data.length;
- for (var dataIndex = 0; dataIndex < count; dataIndex++) {
- var columns = $('#' + table.options.id + ' tr[data-index="' + dataIndex + '"] td');
- var obj = new Object();
- for (var i = 0; i < columns.length; i++) {
- var inputValue = $(columns[i]).find('input');
- var selectValue = $(columns[i]).find('select');
- var textareaValue = $(columns[i]).find('textarea');
- var key = dataColumns[i].field;
- if ($.common.isNotEmpty(inputValue.val())) {
- obj[key] = inputValue.val();
- } else if ($.common.isNotEmpty(selectValue.val())) {
- obj[key] = selectValue.val();
- } else if ($.common.isNotEmpty(textareaValue.val())) {
- obj[key] = textareaValue.val();
- } else {
- obj[key] = "";
- }
- }
- var item = data[dataIndex];
- var extendObj = $.extend({}, item, obj);
- params.push({ index: dataIndex, row: extendObj });
- }
- $("#" + table.options.id).bootstrapTable("updateRow", params);
- },
- delColumn: function(column) {
- sub.editColumn();
- var subColumn = $.common.isEmpty(column) ? "index" : column;
- var ids = $.table.selectColumns(subColumn);
- if (ids.length == 0) {
- $.modal.alertWarning("请至少选择一条记录");
- return;
- }
- $("#" + table.options.id).bootstrapTable('remove', { field: subColumn, values: ids });
- },
- addColumn: function(row, tableId) {
- var currentId = $.common.isEmpty(tableId) ? table.options.id : tableId;
- table.set(currentId);
- var count = $("#" + currentId).bootstrapTable('getData').length;
- sub.editColumn();
- $("#" + currentId).bootstrapTable('insertRow', {
- index: count + 1,
- row: row
- });
- }
- };
- // 动态加载css文件
- function loadCss(file, headElem) {
- var link = document.createElement('link');
- link.href = file;
- link.rel = 'stylesheet';
- link.type = 'text/css';
- if (headElem) headElem.appendChild(link);
- else document.getElementsByTagName('head')[0].appendChild(link);
- }
- // 动态加载js文件
- function loadJs(file, headElem) {
- var script = document.createElement('script');
- script.src = file;
- script.type = 'text/javascript';
- if (headElem) headElem.appendChild(script);
- else document.getElementsByTagName('head')[0].appendChild(script);
- }
- /** 设置全局ajax处理 */
- $.ajaxSetup({
- complete: function(XMLHttpRequest, textStatus) {
- if (textStatus == 'timeout') {
- $.modal.alertWarning("服务器超时,请稍后再试!");
- $.modal.enable();
- $.modal.closeLoading();
- } else if (textStatus == "parsererror" || textStatus == "error") {
- $.modal.alertWarning("服务器错误,请联系管理员!");
- $.modal.enable();
- $.modal.closeLoading();
- }
- }
- });
|