var active; var userId; layui.config({ base: basePath, version: skyeyeVersion }).extend({ window: 'js/winui.window' }).define(['window', 'radialin', 'form', 'element', 'tautocomplete', 'spop'], function (exports) { var $ = layui.jquery, form = layui.form, element = layui.element; $(document).attr("title", sysMainMation.mationTitle); $(".tradition-left-top").find("span").html(sysMainMation.mationTitle); // 修改版权 $(".tradition-right-bottom-copyright").html(sysMainMation.copyright); //顶部桌面模板 var desktopTemplate = $("#desktopTemplate").html(); //菜单盒子模板 var menuBoxTemplate = $("#menuBoxTemplate").html(); //二级菜单模板 var menuMoreTemplate = $("#menuMoreTemplate").html(); //一级菜单模板 var menuTemplate = $("#menuTemplate").html(); $(function () { // 获取当前登录员工信息 systemCommonUtil.getSysCurrentLoginUserMation(function (data) { userId = data.bean.id; $("#userPhoto").attr("src", fileBasePath + data.bean.userPhoto); $("#userName").html(data.bean.userCode + '(' + data.bean.userName + ')'); }); // 加载首页 initDefaultPage(); // 加载菜单数据 loadMenuListToShow(); etiger.socket.init(); }); //搜索自动补充数据来源 var data = new Array(); //加载菜单数据 function loadMenuListToShow(){ //获取桌面消息 AjaxPostUtil.request({url: reqBasePath + "login009", params: {}, type: 'json', method: "GET", callback: function(l){ var str = "";//顶部桌面字符串 var menuBoxStr = "";//多个菜单的字符串 $.each(l.rows, function(i, row){ row.show = 'none'; if (i == 0) { row.show = 'block'; row.chooseDeskTop = ' select'; } var jsonStr = { bean: row }; str += getDataUseHandlebars(desktopTemplate, jsonStr); menuBoxStr += getDataUseHandlebars(menuBoxTemplate, jsonStr); }); $(".desktop-menu-box").find("ul").html(str); $("#sysMenuListBox").html(menuBoxStr); //重新计算头部宽度 initDeskTopMenuBox(); // 加载菜单 AjaxPostUtil.request({url: reqBasePath + "login005", params: {}, type: 'json', method: "GET", callback: function (json) { var menuStr; $.each(json.rows, function(i, row){ menuStr = ""; row.icon = desktopMenuUtil.getTraditionPageMenuIcon(row); if(row.pageURL != '--'){ //一级菜单 menuStr = getDataUseHandlebars(menuTemplate, {bean: row}); if(isNull(row.deskTopId)){ $("ul[menurowid='winfixedpage00000000']").append(menuStr); } else { $("ul[menurowid='" + row.deskTopId + "']").append(menuStr); } data.push({id: row.id, name: row.name, pageURL: row.pageURL, winName: isNull(row.deskTopId) ? defaultName : $(".desktop-menu-box").find("li[rowid='" + row.deskTopId + "']").find('span').html()}); } else { //二级菜单 if (!isNull(row.childs)){ $.each(row.childs, function(j, child){ child.icon = desktopMenuUtil.getTraditionPageMenuIcon(child); data.push({id: child.id, name: child.name, pageURL: child.pageURL, winName: isNull(row.deskTopId) ? defaultName : $(".desktop-menu-box").find("li[rowid='" + row.deskTopId + "']").find('span').html()}); }); } menuStr = getDataUseHandlebars(menuMoreTemplate, {bean: row}); if(isNull(row.deskTopId)){ $("ul[menurowid='winfixedpage00000000']").append(menuStr); } else { $("ul[menurowid='" + row.deskTopId + "']").append(menuStr); } } }); var text2 = $("#Text2").tautocomplete({ width: "500px", placeholder: $("#Text2").attr("placeholder"), columns: [{field: 'name', title: '菜单名称'}, {field: 'winName', title: '所属桌面'}], data: function() { var filterData = []; var searchData = eval("/" + text2.searchdata() + "/gi"); $.each(data, function(i, v) { if(v.name.search(new RegExp(searchData)) != -1) { filterData.push(v); } }); return filterData; }, onchange: function() { if (!isNull(text2.id())){ var dataMenu = $("#sysMenuListBox").find("a[data-id='" + text2.id() + "']"); indexMenu.loadTraditionPage(dataMenu); } } }); matchingLanguage(); }}); }}); } //计算头部宽度 function initDeskTopMenuBox(){ var items = $(".desktop-menu-box").find('li'); var maxWidth = 50; $.each(items, function(i, item) { maxWidth += $(item).width(); }); $(".desktop-menu-box").find('ul').css({'width': maxWidth + 'px'}); } //触发事件 active = { //在这里给active绑定几项事件,后面可通过active调用这些事件 tabAdd: function(url, id, name) { url = systemCommonUtil.getUrl(url, null); //新增一个Tab项 传入三个参数,分别对应其标题,tab页面的地址,还有一个规定的id,是标签中data-id的属性值 //关于tabAdd的方法所传入的参数可看layui的开发文档中基础方法部分 element.tabAdd('menubox', { title: name, content: '', id: id //规定好的id }) CustomRightClick(id); //给tab绑定右击事件 }, tabChange: function(id) { //切换到指定Tab项 element.tabChange('menubox', id); //根据传入的id传入到指定的tab项 }, tabDelete: function(id) { element.tabDelete("menubox", id); //删除 }, tabDeleteAll: function(ids) { //删除所有 $.each(ids, function(i, item) { element.tabDelete("menubox", item); //ids是一个数组,里面存放了多个id,调用tabDelete方法分别删除 }) } }; // 当点击有page-item-click属性的标签时,即左侧菜单栏中内容 ,触发点击事件 $("body").on("click", ".page-item-click", function (e) { var dataMenu = $(this); if("win" === dataMenu.attr("data-type")){ window.open(dataMenu.attr("data-url")); } else { indexMenu.loadTraditionPage(dataMenu); } }); //右键事件 function CustomRightClick(id) { // 取消右键 rightmenu属性开始是隐藏的 ,当右击的时候显示,左击的时候隐藏 $('#LAY_app_tabsheader li').on('contextmenu', function() { return false; }) $('#LAY_app_tabsheader, #LAY_app_tabsheader li').click(function() { $('.rightmenu').hide(); }); //桌面点击右击 $('#LAY_app_tabsheader li').on('contextmenu', function(e) { var popupmenu = $(".rightmenu"); popupmenu.find("li").attr("data-id", id); //在右键菜单中的标签绑定id属性 //判断右侧菜单的位置 l = ($(document).width() - e.clientX) < popupmenu.width() ? (e.clientX - popupmenu.width()) : e.clientX; t = ($(document).height() - e.clientY) < popupmenu.height() ? (e.clientY - popupmenu.height()) : e.clientY; popupmenu.css({ left: l, top: t }).show(); //进行绝对定位 return false; }); } //加载初始化界面-首页 function initDefaultPage(){ active.tabAdd("../../tpl/mainPage/mainPage.html", "initDefaultPageId", ''); active.tabChange("initDefaultPageId"); } //菜单点击 $("body").on("click", ".menu-box-none", function (e) { if($(this).parent().hasClass("layui-nav-itemed")){ $(this).parent().removeClass("layui-nav-itemed"); } else { $(this).parent().addClass("layui-nav-itemed"); } }); //关闭操作 $("body").on("click", ".rightmenu li, .right-close-operator dd a", function (e) { //右键菜单中的选项被点击之后,判断type的类型,决定关闭所有还是关闭当前。 if($(this).attr("data-type") == "closethis") { var choosePage = $("#LAY_app_tabsheader li[class='layui-this']").attr('lay-id'); if(isNull(choosePage)){ winui.window.msg('请选中当前标签页~', {shift: 6}); return; } //如果关闭当前,即根据显示右键菜单时所绑定的id,执行tabDelete if(choosePage != 'initDefaultPageId'){ active.tabDelete(choosePage); } else { winui.window.msg('首页不能关闭~', {shift: 6}); } } else if($(this).attr("data-type") == "closeall") { var tabtitle = $("#LAY_app_tabsheader li"); var ids = new Array(); $.each(tabtitle, function(i) { if($(this).attr("lay-id") != 'initDefaultPageId'){ ids.push($(this).attr("lay-id")); } }) //如果关闭所有 ,即将所有的lay-id放进数组,执行tabDeleteAll active.tabDeleteAll(ids); } else if($(this).attr("data-type") == "closeother") {//关闭其他标签页 var choosePage = $("#LAY_app_tabsheader li[class='layui-this']").attr('lay-id'); if(isNull(choosePage)){ winui.window.msg('请选中当前标签页~', {shift: 6}); return; } var tabtitle = $("#LAY_app_tabsheader li"); var ids = new Array(); $.each(tabtitle, function(i) { if($(this).attr("lay-id") != 'initDefaultPageId' && $(this).attr("lay-id") != choosePage){ ids.push($(this).attr("lay-id")); } }) //如果关闭所有 ,即将所有的lay-id放进数组,执行tabDeleteAll active.tabDeleteAll(ids); } $('.rightmenu').hide(); //最后再隐藏右键菜单 }); // 全屏操作 var isFullScreen = false;// 全屏参数 $("body").on("click", "#isFullScreen", function (e) { if(!isFullScreen){// 非全屏状态 isFullScreen = true; fullScreen(); } else {// 全屏状态 isFullScreen = false; exitFullScreen(); } }); // 个人中心 $("body").on("click", ".winui-start-syspersonal", function (e) { // 否则判断该tab项是否以及存在 var isData = false; // 初始化一个标志,为false说明未打开该tab项 为true则说明已有 $.each($("#LAY_app_tabsheader li[lay-id]"), function() { // 如果点击左侧菜单栏所传入的id 在右侧tab项中的lay-id属性可以找到,则说明该tab项已经打开 if($(this).attr("lay-id") === "syspersonal") { isData = true; } }) if(isData == false) { // 标志为false 新增一个tab项 active.tabAdd("../../tpl/syspersonal/syspersonal.html", "syspersonal", '个人中心'); } active.tabChange("syspersonal"); }); // 任务空间 $("body").on("click", ".winui-start-job-space", function (e) { window.open("../../tpl/jobSpace/jobSpace.html"); }); // 配色方案 $("body").on("click", ".winui-start-color-scheme", function (e) { layer.open({ type: 2, title: '配色方案', shadeClose: true, closeBtn: 0, shade: 0.3, area: ['400px', '95%'], offset: 'rb', content: '../../tpl/colorScheme/colorScheme.html' }); }); // 切换风格 $("body").on("click", ".winui-switching-style", function (e) { location.href = "../../tpl/index/index.html"; }); var nowType = isNull(getCookie("languageType")) ? "zh" : getCookie("languageType"); if(nowType == "zh"){ // 中文 $("#switchLanguage").find("a").attr("title", "切换英文"); $("#switchLanguage").find("a").html(''); } else { // 英文 $("#switchLanguage").find("a").attr("title", "切换中文"); $("#switchLanguage").find("a").html(''); } // 切换语言 $("body").on("click", "#switchLanguage", function (e) { var nowType = isNull(getCookie("languageType")) ? "zh" : getCookie("languageType"); if(nowType == "zh"){ // 中文,设置为英文 setCookie('languageType', "cn"); } else { // 英文,设置为中文 setCookie('languageType', "zh"); } window.location.reload(); }); // 菜单收缩按钮 var notOrContraction = false;// 菜单收缩参数 $("body").on("click", "#notOrContraction", function (e) { if(!notOrContraction){// 展开状态 notOrContraction = true; $(".tradition-left").animate({width: "0px"}); $(".tradition-right").animate({width: "100%"}); } else {// 收缩状态 notOrContraction = false; $(".tradition-left").animate({width: "218px"}); var _width = $("body").width(); $(".tradition-right").animate({width: (_width - 220) + "px"}, function () { $(this).css({width:"calc(100% - 218px)"}) }); } }); // 退出 $("body").on("click", ".logout", function (e) { winui.window.confirm('确认注销吗?', {id: 'exit-confim', icon: 3, title: '提示', skin: 'msg-skin-message', success: function(layero, index){ var times = $("#exit-confim").parent().attr("times"); var zIndex = $("#exit-confim").parent().css("z-index"); $("#layui-layer-shade" + times).css({'z-index': zIndex}); }}, function (index) { AjaxPostUtil.request({url: reqBasePath + "login003", params: {}, type: 'json', method: "POST", callback: function (json) { if (etiger != null) { etiger.socket.close(); } location.href = "../../tpl/index/login.html"; }, errorCallback: function (json) { location.href = "../../tpl/index/login.html"; }}); }); }); // 头部桌面列表滚动事件 $("body").on("wheel", ".desktop-menu-box", function (e) { var _this = $(this); var right = _this.find("ul").width() - _this[0].offsetWidth; if (_this.scrollLeft() < right && e.originalEvent.deltaY > 0) { //禁止事件默认行为(此处禁止鼠标滚轮行为关联到"屏幕滚动条上下移动"行为) var left = (_this.scrollLeft() + 50); _this.scrollLeft(left) } if (_this.scrollLeft() > 0 && e.originalEvent.deltaY < 0) { //禁止事件默认行为(此处禁止鼠标滚轮行为关联到"屏幕滚动条上下移动"行为) var left = (_this.scrollLeft() - 50); _this.scrollLeft(left) } }); // 头部桌面列表点击事件 $("body").on("click", ".desktop-menu-box ul .layui-nav-item", function (e) { $("#sysMenuListBox").find(".layui-nav-tree").hide(); $(".desktop-menu-box ul .layui-nav-item").removeClass('select'); $(this).addClass('select'); var rowId = $(this).attr("rowid"); $("#sysMenuListBox").find("ul[menurowid='" + rowId + "']").show(); }); // 消息中心 $("body").on("click", "#messageCenter", function (e) { var url = systemCommonUtil.getUrl('FP2024013100007', null); $(this).attr('data-url', url); indexMenu.loadTraditionPage($(this)); }); // 左侧底部功能 $("body").on("click", ".tradition-left-bottom .other-item", function (e) { var dataMenu = $(this); var icon = dataMenu.find(".other-item-img").html(); indexMenu.loadTraditionPage(dataMenu, icon); }); $(window).resize(function () { }); matchingLanguage(); exports('traditionpageindex', {}); });