123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401 |
- var tabFilter,menu=[],liIndex,curNav,delMenu,
- changeRefreshStr = window.sessionStorage.getItem("changeRefresh");
- layui.define(["element","jquery"],function(exports){
- var element = layui.element,
- $ = layui.$,
- layId,
- Tab = function(){
- this.tabConfig = {
- openTabNum : undefined,
- tabFilter : "bodyTab",
- url : undefined
- }
- };
-
- Tab.prototype.navBar = function(strData){
- var data;
- if(typeof(strData) == "string"){
- var data = JSON.parse(strData);
- console.log(data)
- }else{
- data = strData;
- }
- var ulHtml = '';
- for(var i=0;i<data.length;i++){
- if(data[i].spread || data[i].spread == undefined){
- ulHtml += '<li class="layui-nav-item ">';
- }else{
- ulHtml += '<li class="layui-nav-item">';
- }
- if(data[i].children != undefined && data[i].children.length > 0){
- ulHtml += '<a>';
- if(data[i].icon != undefined && data[i].icon != ''){
- if(data[i].icon.indexOf("icon-") != -1){
- ulHtml += '<i class="seraph '+data[i].icon+'" data-icon="'+data[i].icon+'"></i>';
- }else{
- ulHtml += '<i class="layui-icon" data-icon="'+data[i].icon+'">'+data[i].icon+'</i>';
- }
- }
- ulHtml += '<cite>'+data[i].title+'</cite>';
- ulHtml += '<span class="layui-nav-more"></span>';
- ulHtml += '</a>';
- ulHtml += '<dl class="layui-nav-child">';
- for(var j=0;j<data[i].children.length;j++){
- if(data[i].children[j].target == "_blank"){
- ulHtml += '<dd><a data-url="'+data[i].children[j].href+'" target="'+data[i].children[j].target+'">';
- }else{
- ulHtml += '<dd><a data-url="'+data[i].children[j].href+'">';
- }
- if(data[i].children[j].icon != undefined && data[i].children[j].icon != ''){
- if(data[i].children[j].icon.indexOf("icon-") != -1){
- ulHtml += '<i class="seraph '+data[i].children[j].icon+'" data-icon="'+data[i].children[j].icon+'"></i>';
- }else{
- ulHtml += '<i class="layui-icon" data-icon="'+data[i].children[j].icon+'">'+data[i].children[j].icon+'</i>';
- }
- }
- ulHtml += '<cite>'+data[i].children[j].title+'</cite></a></dd>';
- }
- ulHtml += "</dl>";
- }else{
- if(data[i].target == "_blank"){
- ulHtml += '<a data-url="'+data[i].href+'" target="'+data[i].target+'">';
- }else{
- ulHtml += '<a data-url="'+data[i].href+'">';
- }
- if(data[i].icon != undefined && data[i].icon != ''){
- if(data[i].icon.indexOf("icon-") != -1){
- ulHtml += '<i class="seraph '+data[i].icon+'" data-icon="'+data[i].icon+'"></i>';
- }else{
- ulHtml += '<i class="layui-icon" data-icon="'+data[i].icon+'">'+data[i].icon+'</i>';
- }
- }
- ulHtml += '<cite>'+data[i].title+'</cite></a>';
- }
- ulHtml += '</li>';
- }
- return ulHtml;
- }
-
- Tab.prototype.render = function() {
-
- var _this = this;
- $(".navBar ul").html('<li class="layui-nav-item layui-this"><a data-url="page/main.html"><i class="layui-icon" data-icon=""></i><cite>后台首页</cite></a></li>').append(_this.navBar(dataStr)).height($(window).height()-210);
- element.init();
- $(window).resize(function(){
- $(".navBar").height($(window).height()-210);
- })
- }
-
- Tab.prototype.changeRegresh = function(index){
- if(changeRefreshStr == "true"){
- $(".clildFrame .layui-tab-item").eq(index).find("iframe")[0].contentWindow.location.reload();
- }
- }
-
- Tab.prototype.set = function(option) {
- var _this = this;
- $.extend(true, _this.tabConfig, option);
- return _this;
- };
-
- Tab.prototype.getLayId = function(title){
- $(".layui-tab-title.top_tab li").each(function(){
- if($(this).find("cite").text() == title){
- layId = $(this).attr("lay-id");
- }
- })
- return layId;
- }
-
- Tab.prototype.hasTab = function(title){
- var tabIndex = -1;
- $(".layui-tab-title.top_tab li").each(function(){
- if($(this).find("cite").text() == title){
- tabIndex = 1;
- }
- })
- return tabIndex;
- }
-
- var tabIdIndex = 0;
- Tab.prototype.tabAdd = function(_this){
- if(window.sessionStorage.getItem("menu")){
- menu = JSON.parse(window.sessionStorage.getItem("menu"));
- }
- var that = this;
- var openTabNum = that.tabConfig.openTabNum;
- tabFilter = that.tabConfig.tabFilter;
- if(_this.attr("target") == "_blank"){
- window.open(_this.attr("data-url"));
- }else if(_this.attr("data-url") != undefined){
- var title = '';
- if(_this.find("i.seraph,i.layui-icon").attr("data-icon") != undefined){
- if(_this.find("i.seraph").attr("data-icon") != undefined){
- title += '<i class="seraph '+_this.find("i.seraph").attr("data-icon")+'"></i>';
- }else{
- title += '<i class="layui-icon">'+_this.find("i.layui-icon").attr("data-icon")+'</i>';
- }
- }
-
- if(that.hasTab(_this.find("cite").text()) == -1 && _this.siblings("dl.layui-nav-child").length == 0){
- if($(".layui-tab-title.top_tab li").length == openTabNum){
- layer.msg('只能同时打开'+openTabNum+'个选项卡哦。不然系统会卡的!');
- return;
- }
- tabIdIndex++;
- title += '<cite>'+_this.find("cite").text()+'</cite>';
- title += '<i class="layui-icon layui-unselect layui-tab-close" data-id="'+tabIdIndex+'">ဆ</i>';
- element.tabAdd(tabFilter, {
- title : title,
- content :"<iframe src='"+_this.attr("data-url")+"' data-id='"+tabIdIndex+"'></frame>",
- id : new Date().getTime()
- })
-
- var curmenu = {
- "icon" : _this.find("i.seraph").attr("data-icon")!=undefined ? _this.find("i.seraph").attr("data-icon") : _this.find("i.layui-icon").attr("data-icon"),
- "title" : _this.find("cite").text(),
- "href" : _this.attr("data-url"),
- "layId" : new Date().getTime()
- }
- menu.push(curmenu);
- window.sessionStorage.setItem("menu",JSON.stringify(menu));
- window.sessionStorage.setItem("curmenu",JSON.stringify(curmenu));
- element.tabChange(tabFilter, that.getLayId(_this.find("cite").text()));
- that.tabMove();
- }else{
-
- var curmenu = {
- "icon" : _this.find("i.seraph").attr("data-icon")!=undefined ? _this.find("i.seraph").attr("data-icon") : _this.find("i.layui-icon").attr("data-icon"),
- "title" : _this.find("cite").text(),
- "href" : _this.attr("data-url")
- }
- that.changeRegresh(_this.parent('.layui-nav-item').index());
- window.sessionStorage.setItem("curmenu", JSON.stringify(curmenu));
- element.tabChange(tabFilter, that.getLayId(_this.find("cite").text()));
- that.tabMove();
- }
- }
- }
-
- Tab.prototype.tabMove = function(){
- $(window).on("resize",function(event){
- var topTabsBox = $("#top_tabs_box"),
- topTabsBoxWidth = $("#top_tabs_box").width(),
- topTabs = $("#top_tabs"),
- topTabsWidth = $("#top_tabs").width(),
- tabLi = topTabs.find("li.layui-this"),
- top_tabs = document.getElementById("top_tabs"),
- event = event || window.event;
- if(topTabsWidth > topTabsBoxWidth){
- if(tabLi.position().left > topTabsBoxWidth || tabLi.position().left+topTabsBoxWidth > topTabsWidth){
- topTabs.css("left",topTabsBoxWidth-topTabsWidth);
- }else{
- topTabs.css("left",-tabLi.position().left);
- }
-
- var flag = false;
- var cur = {
- x:0,
- y:0
- }
- var nx,dx,x ;
- function down(){
- flag = true;
- var touch ;
- if(event.touches){
- touch = event.touches[0];
- }else {
- touch = event;
- }
- cur.x = touch.clientX;
- dx = top_tabs.offsetLeft;
- }
- function move(){
- var self = this;
- if(flag){
- window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();
- var touch ;
- if(event.touches){
- touch = event.touches[0];
- }else {
- touch = event;
- }
- nx = touch.clientX - cur.x;
- x = dx+nx;
- if(x > 0){
- x = 0;
- }else{
- if(x < topTabsBoxWidth-topTabsWidth){
- x = topTabsBoxWidth-topTabsWidth;
- }else{
- x = dx+nx;
- }
- }
- top_tabs.style.left = x +"px";
-
- document.addEventListener("touchmove",function(){
- event.preventDefault();
- },false);
- }
- }
-
- function end(){
- flag = false;
- }
-
- topTabs.on("mousedown",down);
- topTabs.on("mousemove",move);
- $(document).on("mouseup",end);
-
- topTabs.on("touchstart",down);
- topTabs.on("touchmove",move);
- topTabs.on("touchend",end);
- }else{
-
- topTabs.off("mousedown",down);
- topTabs.off("mousemove",move);
- topTabs.off("mouseup",end);
-
- topTabs.off("touchstart",down);
- topTabs.off("touchmove",move);
- topTabs.off("touchend",end);
- topTabs.removeAttr("style");
- return false;
- }
- }).resize();
- }
-
- $("body").on("click",".top_tab li",function(){
- var curmenu = '';
- var menu = JSON.parse(window.sessionStorage.getItem("menu"));
- if(window.sessionStorage.getItem("menu")) {
- curmenu = menu[$(this).index() - 1];
- }
- if($(this).index() == 0){
- window.sessionStorage.setItem("curmenu",'');
- }else{
- window.sessionStorage.setItem("curmenu",JSON.stringify(curmenu));
- if(window.sessionStorage.getItem("curmenu") == "undefined"){
-
- if(curNav != JSON.stringify(delMenu)){
- window.sessionStorage.setItem("curmenu",curNav);
- }else{
- window.sessionStorage.setItem("curmenu",JSON.stringify(menu[liIndex-1]));
- }
- }
- }
- element.tabChange(tabFilter,$(this).attr("lay-id")).init();
- bodyTab.changeRegresh($(this).index());
- setTimeout(function(){
- bodyTab.tabMove();
- },100);
- })
-
- $("body").on("click",".top_tab li i.layui-tab-close",function(){
-
- liIndex = $(this).parent("li").index();
- var menu = JSON.parse(window.sessionStorage.getItem("menu"));
- if(menu != null) {
-
- delMenu = menu[liIndex - 1];
- var curmenu = window.sessionStorage.getItem("curmenu") == "undefined" ? undefined : window.sessionStorage.getItem("curmenu") == "" ? '' : JSON.parse(window.sessionStorage.getItem("curmenu"));
- if (JSON.stringify(curmenu) != JSON.stringify(menu[liIndex - 1])) {
-
- curNav = JSON.stringify(curmenu);
- } else {
- if ($(this).parent("li").length > liIndex) {
- window.sessionStorage.setItem("curmenu", curmenu);
- curNav = curmenu;
- } else {
- window.sessionStorage.setItem("curmenu", JSON.stringify(menu[liIndex - 1]));
- curNav = JSON.stringify(menu[liIndex - 1]);
- }
- }
- menu.splice((liIndex - 1), 1);
- window.sessionStorage.setItem("menu", JSON.stringify(menu));
- }
- element.tabDelete("bodyTab",$(this).parent("li").attr("lay-id")).init();
- bodyTab.tabMove();
- })
-
- $(".refresh").on("click",function(){
- if($(this).hasClass("refreshThis")){
- $(this).removeClass("refreshThis");
- $(".clildFrame .layui-tab-item.layui-show").find("iframe")[0].contentWindow.location.reload();
- setTimeout(function(){
- $(".refresh").addClass("refreshThis");
- },2000)
- }else{
- layer.msg("您点击的速度超过了服务器的响应速度,还是等两秒再刷新吧!");
- }
- })
-
- $(".closePageOther").on("click",function(){
- if($("#top_tabs li").length>2 && $("#top_tabs li.layui-this cite").text()!="后台首页"){
- var menu = JSON.parse(window.sessionStorage.getItem("menu"));
- $("#top_tabs li").each(function(){
- if($(this).attr("lay-id") != '' && !$(this).hasClass("layui-this")){
- element.tabDelete("bodyTab",$(this).attr("lay-id")).init();
-
- for(var i=0;i<menu.length;i++){
- if($("#top_tabs li.layui-this cite").text() == menu[i].title){
- menu.splice(0,menu.length,menu[i]);
- window.sessionStorage.setItem("menu",JSON.stringify(menu));
- }
- }
- }
- })
- }else if($("#top_tabs li.layui-this cite").text()=="后台首页" && $("#top_tabs li").length>1){
- $("#top_tabs li").each(function(){
- if($(this).attr("lay-id") != '' && !$(this).hasClass("layui-this")){
- element.tabDelete("bodyTab",$(this).attr("lay-id")).init();
- window.sessionStorage.removeItem("menu");
- menu = [];
- window.sessionStorage.removeItem("curmenu");
- }
- })
- }else{
- layer.msg("没有可以关闭的窗口了@_@");
- }
-
- tab.tabMove();
- })
-
- $(".closePageAll").on("click",function(){
- if($("#top_tabs li").length > 1){
- $("#top_tabs li").each(function(){
- if($(this).attr("lay-id") != ''){
- element.tabDelete("bodyTab",$(this).attr("lay-id")).init();
- window.sessionStorage.removeItem("menu");
- menu = [];
- window.sessionStorage.removeItem("curmenu");
- }
- })
- }else{
- layer.msg("没有可以关闭的窗口了@_@");
- }
-
- tab.tabMove();
- })
- var bodyTab = new Tab();
- exports("bodyTab",function(option){
- return bodyTab.set(option);
- });
- })
|