layui.define(['message', 'table', 'jquery', 'element', 'yaml', 'form', 'tab', 'menu', 'frame', 'theme', 'convert'], function(exports) { "use strict"; var $ = layui.jquery, form = layui.form, element = layui.element, yaml = layui.yaml, pearTab = layui.tab, convert = layui.convert, pearMenu = layui.menu, pearFrame = layui.frame, pearTheme = layui.theme, message = layui.message; var bodyFrame; var sideMenu; var bodyTab; var config; var logout = function() {}; var msgInstance; var body = $('body'); var pearAdmin = new function() { // 默认配置 var configType = 'yml'; var configPath = 'pear.config.yml'; this.setConfigPath = function(path) { configPath = path; } this.setConfigType = function(type) { configType = type; } this.setAvatar = function(url, username) { var image = new Image(); image.src = url || "admin/images/avatar.jpg"; image.onload = function() { $(".layui-nav-img").attr("src", convert.imageToBase64(image)); } $(".layui-nav-img").parent().append(username); } this.render = function(initConfig) { if (initConfig !== undefined) { applyConfig(initConfig); } else { applyConfig(pearAdmin.readConfig()); } } this.readConfig = function() { if (configType === "yml") { return yaml.load(configPath); } else { var data; $.ajax({ url: configPath, type: 'get', dataType: 'json', async: false, success: function(result) { data = result; } }) return data; } } this.messageRender = function(option) { var option = { elem: '.message', url: option.header.message, height: '250px' }; msgInstance = message.render(option); } this.logoRender = function(param) { $(".layui-logo .logo").attr("src", param.logo.image); $(".layui-logo .title").html(param.logo.title); } this.menuRender = function(param) { sideMenu = pearMenu.render({ elem: 'sideMenu', async: param.menu.async !== undefined ? param.menu.async : true, theme: "dark-theme", height: '100%', method: param.menu.method, control: param.menu.control ? 'control' : false, // control defaultMenu: 0, accordion: param.menu.accordion, url: param.menu.data, data: param.menu.data, //async为false时,传入菜单数组 parseData: false, change: function() { compatible(); }, done: function() { sideMenu.selectItem(param.menu.select); } }); } this.bodyRender = function(param) { body.on("click", ".refresh", function() { var refreshA = $(".refresh a"); refreshA.removeClass("layui-icon-refresh-1"); refreshA.addClass("layui-anim"); refreshA.addClass("layui-anim-rotate"); refreshA.addClass("layui-anim-loop"); refreshA.addClass("layui-icon-loading"); if (param.tab.muiltTab) bodyTab.refresh(400); else bodyFrame.refresh(400); setTimeout(function() { refreshA.addClass("layui-icon-refresh-1"); refreshA.removeClass("layui-anim"); refreshA.removeClass("layui-anim-rotate"); refreshA.removeClass("layui-anim-loop"); refreshA.removeClass("layui-icon-loading"); }, 600) }) if (param.tab.muiltTab) { bodyTab = pearTab.render({ elem: 'content', roll: true, tool: true, width: '100%', height: '100%', session: param.tab.session, index: 0, tabMax: param.tab.tabMax, closeEvent: function(id) { sideMenu.selectItem(id); }, data: [{ id: param.tab.index.id, url: param.tab.index.href, title: param.tab.index.title, close: false }], success: function(id) { if (param.tab.session) { setTimeout(function() { sideMenu.selectItem(id); bodyTab.positionTab(); }, 500) } } }); bodyTab.click(function(id) { if (!param.tab.keepState) { bodyTab.refresh(false); } bodyTab.positionTab(); sideMenu.selectItem(id); }) sideMenu.click(function(dom, data) { bodyTab.addTabOnly({ id: data.menuId, title: data.menuTitle, url: data.menuUrl, icon: data.menuIcon, close: true }, 300); compatible(); }) } else { bodyFrame = pearFrame.render({ elem: 'content', title: '首页', url: param.tab.index.href, width: '100%', height: '100%' }); sideMenu.click(function(dom, data) { bodyFrame.changePage(data.menuUrl, data.menuPath, true); compatible() }) } } this.keepLoad = function(param) { compatible() setTimeout(function() { $(".loader-main").fadeOut(200); }, param.other.keepLoad) } this.themeRender = function(option) { if (option.theme.allowCustom === false) { $(".setting").remove(); } var colorId = localStorage.getItem("theme-color"); var currentColor = getColorById(colorId); localStorage.setItem("theme-color", currentColor.id); localStorage.setItem("theme-color-context", currentColor.color); pearTheme.changeTheme(window, option.other.autoHead); var menu = localStorage.getItem("theme-menu"); if (menu == null) { menu = option.theme.defaultMenu; } else { if (option.theme.allowCustom === false) { menu = option.theme.defaultMenu; } } localStorage.setItem("theme-menu", menu); this.menuSkin(menu); } this.menuSkin = function(theme) { var pearAdmin = $(".pear-admin"); pearAdmin.removeClass("light-theme"); pearAdmin.removeClass("dark-theme"); pearAdmin.addClass(theme); } this.logout = function(callback) { logout = callback; } this.message = function(callback) { if (callback != null) { msgInstance.click(callback); } else { msgInstance.click(messageTip); } } this.jump = function(id, title, url) { if (config.tab.muiltTab) { bodyTab.addTabOnly({ id: id, title: title, url: url, icon: null, close: true }, 300); } else { sideMenu.selectItem(id); bodyFrame.changePage(url, title, true); } } }; var messageTip = function(id, title, context, form) { layer.open({ type: 1, title: '消息', //标题 area: ['390px', '330px'], //宽高 shade: 0.4, //遮罩透明度 content: "
来源 :   " + form + "
标题 :   " + title + "
内容 :   " + context + "
", //支持获取DOM元素 btn: ['确认'], //按钮组 scrollbar: false, //屏蔽浏览器滚动条 yes: function(index) { //layer.msg('yes'); //点击确定回调 layer.close(index); showToast(); } }); } function collaspe() { sideMenu.collaspe(); var admin = $(".pear-admin"); var left = $(".layui-icon-spread-left") var right = $(".layui-icon-shrink-right") if (admin.is(".pear-mini")) { left.addClass("layui-icon-shrink-right") left.removeClass("layui-icon-spread-left") admin.removeClass("pear-mini"); } else { right.addClass("layui-icon-spread-left") right.removeClass("layui-icon-shrink-right") admin.addClass("pear-mini"); } } body.on("click", ".logout", function() { // 回调 var result = logout(); if (result) { // 清空缓存 bodyTab.clear(); } }) body.on("click", ".collaspe,.pear-cover", function() { collaspe(); }); body.on("click", ".fullScreen", function() { if ($(this).hasClass("layui-icon-screen-restore")) { screenFun(2).then(function() { $(".fullScreen").eq(0).removeClass("layui-icon-screen-restore"); }); } else { screenFun(1).then(function() { $(".fullScreen").eq(0).addClass("layui-icon-screen-restore"); }); } }); body.on("click", '[user-menu-id]', function() { if (config.tab.muiltTab) { bodyTab.addTabOnly({ id: $(this).attr("user-menu-id"), title: $(this).attr("user-menu-title"), url: $(this).attr("user-menu-url"), icon: "", close: true }, 300); } else { bodyFrame.changePage($(this).attr("user-menu-url"), "", true); } }); body.on("click", ".setting", function() { var bgColorHtml = '
  • ' + '' + '
    ' + '
    ' + '
    ' + '
  • '; bgColorHtml += '
  • ' + '' + '
    ' + '
    ' + '
    ' + '
  • '; var html = '
    \n' + '
    整体风格
    \n' + '
    \n' + '\n' + '
    \n' + '
    '; layer.open({ type: 1, offset: 'r', area: ['320px', '100%'], title: false, shade: 0.1, closeBtn: 0, shadeClose: false, anim: -1, skin: 'layer-anim-right', move: false, content: html + buildColorHtml() + buildLinkHtml() + bottomTool(), success: function(layero, index) { var color = localStorage.getItem("theme-color"); var menu = localStorage.getItem("theme-menu"); if (color !== "null") { $(".select-color-item").removeClass("layui-icon").removeClass("layui-icon-ok"); $("*[color-id='" + color + "']").addClass("layui-icon").addClass("layui-icon-ok"); } if (menu !== "null") { $("*[data-select-bgcolor]").removeClass("layui-this"); $("[data-select-bgcolor='" + menu + "']").addClass("layui-this"); } $('#layui-layer-shade' + index).click(function() { var $layero = $('#layui-layer' + index); $layero.animate({ left: $layero.offset().left + $layero.width() }, 200, function() { layer.close(index); }); }) $('#closeTheme').click(function() { var $layero = $('#layui-layer' + index); $layero.animate({ left: $layero.offset().left + $layero.width() }, 200, function() { layer.close(index); }); }) } }); }); function bottomTool() { return "" } body.on('click', '[data-select-bgcolor]', function() { var theme = $(this).attr('data-select-bgcolor'); $('[data-select-bgcolor]').removeClass("layui-this"); $(this).addClass("layui-this"); localStorage.setItem("theme-menu", theme); pearAdmin.menuSkin(theme); }); body.on('click', '.select-color-item', function() { $(".select-color-item").removeClass("layui-icon").removeClass("layui-icon-ok"); $(this).addClass("layui-icon").addClass("layui-icon-ok"); var colorId = $(".select-color-item.layui-icon-ok").attr("color-id"); var currentColor = getColorById(colorId); localStorage.setItem("theme-color", currentColor.id); localStorage.setItem("theme-color-context", currentColor.color); pearTheme.changeTheme(window, config.other.autoHead); }); function applyConfig(param) { config = param; pearAdmin.logoRender(param); pearAdmin.menuRender(param); pearAdmin.bodyRender(param); pearAdmin.themeRender(param); pearAdmin.keepLoad(param); if (param.header.message != false) { pearAdmin.messageRender(param); } } function getColorById(id) { var color; var flag = false; $.each(config.colors, function(i, value) { if (value.id === id) { color = value; flag = true; } }) if (flag === false || config.theme.allowCustom === false) { $.each(config.colors, function(i, value) { if (value.id === config.theme.defaultColor) { color = value; } }) } return color; } function buildLinkHtml() { var links = ""; $.each(config.links, function(i, value) { // value.target 存在,则为新窗口打开,增加 target="_blank" 属性 links += '' + ' ' + value.title + '' }) return '
    ' + links + '
    '; } function buildColorHtml() { var colors = ""; $.each(config.colors, function(i, value) { colors += ""; }) return "
    主题配色
    " + colors + "
    " } function compatible() { if ($(window).width() <= 768) { collaspe() } } function screenFun(num) { num = num || 1; num = num * 1; var docElm = document.documentElement; switch (num) { case 1: if (docElm.requestFullscreen) { docElm.requestFullscreen(); } else if (docElm.mozRequestFullScreen) { docElm.mozRequestFullScreen(); } else if (docElm.webkitRequestFullScreen) { docElm.webkitRequestFullScreen(); } else if (docElm.msRequestFullscreen) { docElm.msRequestFullscreen(); } break; case 2: if (document.exitFullscreen) { document.exitFullscreen(); } else if (document.mozCancelFullScreen) { document.mozCancelFullScreen(); } else if (document.webkitCancelFullScreen) { document.webkitCancelFullScreen(); } else if (document.msExitFullscreen) { document.msExitFullscreen(); } break; } return new Promise(function(res, rej) { res("返回值"); }); } function isFullscreen() { return document.fullscreenElement || document.msFullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || false; } window.onresize = function() { if (!isFullscreen()) { $(".fullScreen").eq(0).removeClass("layui-icon-screen-restore"); } } exports('admin', pearAdmin); })