424 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			424 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <!DOCTYPE html>
 | ||
| <html>
 | ||
| 
 | ||
| <head>
 | ||
| 	<meta charset="utf-8">
 | ||
| 	<title>{$config['admin_name']}</title>
 | ||
| 	<meta name="renderer" content="webkit">
 | ||
| 	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
 | ||
| 	<meta name="viewport"
 | ||
| 		content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
 | ||
| 	<link rel="stylesheet" type="text/css" href="/static/third/layui/css/layui.css" media="all">
 | ||
| 	<link rel="stylesheet" type="text/css" href="/static/css/index.css" media="all">
 | ||
| 	<script type="text/javascript" src="/static/third/layui/layui.js"></script>
 | ||
| 	<script type="text/javascript" src="/static/js/admin.js"></script>
 | ||
| 	<style>
 | ||
| 		.layadmin-side-shrink .layui-layout-admin .layui-logo {
 | ||
| 			width: 60px;
 | ||
| 			background-image: url("/static/images/logob32.jpg");
 | ||
| 		}
 | ||
| 		.main-content {
 | ||
| 			height: 100%;
 | ||
| 			background: #fff;
 | ||
| 		}
 | ||
| 		#mainWorkspace {
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 		#mainTabs.layui-tab {
 | ||
| 			margin: 0;
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 		.layui-tab-content {
 | ||
| 			padding: 0;
 | ||
| 			height: calc(100% - 41px);
 | ||
| 		}
 | ||
| 		.layui-tab-item {
 | ||
| 			height: 100%;
 | ||
| 		}
 | ||
| 		.main-iframe {
 | ||
| 			width: 100%;
 | ||
| 			height: 100%;
 | ||
| 			border: none;
 | ||
| 			/* background-color: #f2f2f2; */
 | ||
| 		}
 | ||
| 		.layui-tab-title {
 | ||
| 			background: #fff;
 | ||
| 			box-shadow: 0 1px 2px 0 rgba(0,0,0,.1);
 | ||
| 		}
 | ||
| 		.layui-tab-title .layui-this:after {
 | ||
| 			border-bottom-color: #009688;
 | ||
| 		}
 | ||
| 		#LAY_app_body {
 | ||
| 			overflow: hidden;
 | ||
| 		}
 | ||
| 		.layui-tab-content .layui-tab-item {
 | ||
| 			position: relative;
 | ||
| 		}
 | ||
| 	</style>
 | ||
| </head>
 | ||
| 
 | ||
| <body layadmin-themealias="default" class="layui-layout-body">
 | ||
| 	<div id="LAY_app" class="layadmin-tabspage-none">
 | ||
| 		<div class="layui-layout layui-layout-admin">
 | ||
| 			<div class="layui-header">
 | ||
| 				<!-- 头部区域 -->
 | ||
| 				<div style="display: flex;align-items: center;height:70px;">
 | ||
| 					<ul class="layui-nav layui-layout-left">
 | ||
| 						<li class="layui-nav-item layadmin-flexible" lay-unselect onclick="shrink()">
 | ||
| 							<a href="javascript:;" layadmin-event="flexible" title="侧边伸缩">
 | ||
| 								<i class="layui-icon layui-icon-shrink-right" id="LAY_app_flexible"></i>
 | ||
| 							</a>
 | ||
| 						</li>
 | ||
| 					</ul>
 | ||
| 					<ul class="layui-nav layui-layout-right" lay-filter="layadmin-layout-right">
 | ||
| 						<li class="layui-nav-item layui-hide-xs" lay-unselect title="前端站点" onclick="gotoFront()">
 | ||
| 							<a href="javascript:;" layadmin-event="gotoFront">
 | ||
| 								<i class="layui-icon layui-icon-website"></i>
 | ||
| 							</a>
 | ||
| 						</li>
 | ||
| 						<li class="layui-nav-item layui-hide-xs" lay-unselect title="全屏" onclick="fullScreen()">
 | ||
| 							<a href="javascript:;" layadmin-event="fullscreen">
 | ||
| 								<i class="layui-icon layui-icon-screen-full"></i>
 | ||
| 							</a>
 | ||
| 						</li>
 | ||
| 						<li class="layui-nav-item" lay-unselect>
 | ||
| 							<a href="javascript:;">
 | ||
| 								<cite>{$aUser['name']}</cite>
 | ||
| 							</a>
 | ||
| 							<dl class="layui-nav-child">
 | ||
| 								<dd><a lay-href="" onclick="menuFire('yunzeradmin/admininfo',1)">个人中心</a></dd>
 | ||
| 								<hr>
 | ||
| 								<dd layadmin-event="logout" style="text-align:center;" onclick="logout()">
 | ||
| 									<a>退出</a>
 | ||
| 								</dd>
 | ||
| 							</dl>
 | ||
| 						</li>
 | ||
| 					</ul>
 | ||
| 				</div>
 | ||
| 			</div>
 | ||
| 			<!-- 侧边菜单 -->
 | ||
| 			<div class="layui-side layui-side-menu">
 | ||
| 				<div class="layui-side-scroll">
 | ||
| 					<div class="layui-logo" lay-href="" style="display: flex;align-items: center;">
 | ||
| 						<img src="/static/images/logo-l-w.png" alt="{$config['admin_name']}"
 | ||
| 							style="max-width: 100%; max-height: 100%;">
 | ||
| 					</div>
 | ||
| 					<ul class="layui-nav layui-nav-tree" lay-shrink="all" id="LAY-system-side-menu"
 | ||
| 						lay-filter="layadmin-system-side-menu">
 | ||
| 						<!-- 固定的工作台菜单项 -->
 | ||
| 						<li class="layui-nav-item" data-name="index/welcome">
 | ||
| 							<a href="javascript:;" lay-tips="工作台" lay-direction="2"
 | ||
| 								onclick="menuFire('index/welcome',1)">
 | ||
| 								<i class="layui-icon layui-icon-home" style="margin-top: -30px;"></i>
 | ||
| 								<cite>工作台</cite>
 | ||
| 							</a>
 | ||
| 						</li>
 | ||
| 						<!-- 下面是原有的菜单循环 -->
 | ||
| 						{volist name="menu" id="vo"}
 | ||
| 						<li data-name="{$vo.src}" data-jump="" class="layui-nav-item">
 | ||
| 							<!-- 修改一级菜单的点击事件,只有当有src时才跳转 -->
 | ||
| 							<a href="javascript:;" lay-tips="{$vo['label']}" lay-direction="2" {if isset($vo['src']) &&
 | ||
| 								$vo['src']}onclick="menuFire('{$vo.src}',1)" {/if}>
 | ||
| 								<i class="layui-icon layui-icons {$vo['icon_class']}"></i>
 | ||
| 								<cite>{$vo['label']}</cite>
 | ||
| 							</a>
 | ||
| 							{if (isset($vo['children']) && $vo['children'])}
 | ||
| 							<dl class="layui-nav-child">
 | ||
| 								{volist name="vo.children" id="cvo"}
 | ||
| 								<dd data-name="" data-jump="/">
 | ||
| 									{if $cvo['type'] == 1}
 | ||
| 									<a href="javascript:;" onclick="menuFire('{$cvo.src}',1)">
 | ||
| 										<i class="layui-icon layui-icons {$cvo.icon_class}"></i>{$cvo.label}
 | ||
| 									</a>
 | ||
| 									{elseif $cvo['type'] == 2 /}
 | ||
| 									<a href="{$cvo.src}" target="_blank">
 | ||
| 										<i class="layui-icon layui-icons {$cvo.icon_class}"></i>{$cvo.label}
 | ||
| 									</a>
 | ||
| 									{/if}
 | ||
| 								</dd>
 | ||
| 								{/volist}
 | ||
| 							</dl>
 | ||
| 							{/if}
 | ||
| 						</li>
 | ||
| 						{/volist}
 | ||
| 					</ul>
 | ||
| 					<div style="position: absolute;bottom:20px;width:200px;display:flex;justify-content: center;">
 | ||
| 						<a style="color:#848484" href="https://www.yunzer.cn/">POWER BY 云泽网</a>
 | ||
| 					</div>
 | ||
| 				</div>
 | ||
| 			</div>
 | ||
| 			<!-- 主体内容 -->
 | ||
| 			<div class="layui-body" id="LAY_app_body">
 | ||
| 				<div class="main-content">
 | ||
| 					<!-- 默认工作台界面 -->
 | ||
| 					<div id="mainWorkspace">
 | ||
| 						<iframe src="{$config['admin_route']}index/welcome" class="main-iframe" frameborder="0" scrolling="0"></iframe>
 | ||
| 					</div>
 | ||
| 					<!-- 动态标签页 -->
 | ||
| 					<div id="mainTabs" class="layui-tab" lay-allowClose="true" lay-filter="mainTabs" style="margin-top: 10px;">
 | ||
| 						<ul class="layui-tab-title"></ul>
 | ||
| 						<div class="layui-tab-content"></div>
 | ||
| 					</div>
 | ||
| 				</div>
 | ||
| 			</div>
 | ||
| 			<!-- 辅助元素,一般用于移动设备下遮罩 -->
 | ||
| 			<div class="layadmin-body-shade" layadmin-event="shade" onclick="shrink()"></div>
 | ||
| 		</div>
 | ||
| 	</div>
 | ||
| 	<!-- 辅助元素,一般用于移动设备下遮罩 -->
 | ||
| 	<div class="layadmin-body-shade" layadmin-event="shade"></div>
 | ||
| 	</div>
 | ||
| 	</div>
 | ||
| 	<script type="text/javascript">
 | ||
| 		layui.use(['element', 'layer', 'jquery'], function () {
 | ||
| 			var element = layui.element;
 | ||
| 			$ = layui.jquery;
 | ||
| 			layer = layui.layer;
 | ||
| 			setter = layui.setter;
 | ||
| 
 | ||
| 			// 保存标签状态
 | ||
| 			function saveTabState(layid, title, url) {
 | ||
| 				var tabState = {
 | ||
| 					layid: layid,
 | ||
| 					title: title,
 | ||
| 					url: url
 | ||
| 				};
 | ||
| 				sessionStorage.setItem('currentTab', JSON.stringify(tabState));
 | ||
| 			}
 | ||
| 
 | ||
| 			// 恢复标签状态
 | ||
| 			function restoreTabState() {
 | ||
| 				var tabState = sessionStorage.getItem('currentTab');
 | ||
| 				if (tabState) {
 | ||
| 					try {
 | ||
| 						var tab = JSON.parse(tabState);
 | ||
| 						if (tab.url && tab.title) {
 | ||
| 							addTab(tab.title, tab.url, tab.layid);
 | ||
| 						}
 | ||
| 					} catch (e) {
 | ||
| 						console.error('Failed to restore tab state:', e);
 | ||
| 					}
 | ||
| 				}
 | ||
| 			}
 | ||
| 
 | ||
| 			// 在页面加载完成后执行
 | ||
| 			$(document).ready(function () {
 | ||
| 				// 获取URL参数
 | ||
| 				var urlParams = new URLSearchParams(window.location.search);
 | ||
| 				var page = urlParams.get('page');
 | ||
| 
 | ||
| 				if (page) {
 | ||
| 					// 如果有page参数,加载对应页面到iframe
 | ||
| 					$('iframe').attr('src', "{$config['admin_route']}" + page);
 | ||
| 				} else {
 | ||
| 					// 否则加载默认页面
 | ||
| 					$('iframe').attr('src', "{$config['admin_route']}index/welcome");
 | ||
| 				}
 | ||
| 				
 | ||
| 				// 恢复标签状态
 | ||
| 				restoreTabState();
 | ||
| 			});
 | ||
| 
 | ||
| 			// 添加或切换到标签页
 | ||
| 			window.addTab = function(title, url, id) {
 | ||
| 				var element = layui.element;
 | ||
| 				var $ = layui.jquery;
 | ||
| 				var layid = id || url.replace(/\//g, '_');
 | ||
| 
 | ||
| 				// 如果是首页/工作台,直接显示主工作区
 | ||
| 				if(url.indexOf('index/welcome') > -1 || url.indexOf('welcome') > -1) {
 | ||
| 					$('#mainTabs').hide();
 | ||
| 					$('#mainWorkspace').show();
 | ||
| 					$('#mainWorkspace iframe').attr('src', url);
 | ||
| 					sessionStorage.removeItem('currentTab');
 | ||
| 					return;
 | ||
| 				}
 | ||
| 				
 | ||
| 				// 显示标签区域
 | ||
| 				$('#mainWorkspace').hide();
 | ||
| 				$('#mainTabs').show();
 | ||
| 
 | ||
| 				// 如果标签已存在,直接切换
 | ||
| 				if($('.layui-tab-title li[lay-id="'+ layid +'"]').length > 0) {
 | ||
| 					element.tabChange('mainTabs', layid);
 | ||
| 					saveTabState(layid, title, url);
 | ||
| 					return;
 | ||
| 				}
 | ||
| 
 | ||
| 				// 添加新标签
 | ||
| 				element.tabAdd('mainTabs', {
 | ||
| 					title: title,
 | ||
| 					content: '<iframe src="' + url + '" class="main-iframe" frameborder="0"></iframe>',
 | ||
| 					id: layid
 | ||
| 				});
 | ||
| 
 | ||
| 				// 切换到新标签页
 | ||
| 				element.tabChange('mainTabs', layid);
 | ||
| 				
 | ||
| 				// 保存当前标签状态
 | ||
| 				saveTabState(layid, title, url);
 | ||
| 			};
 | ||
| 
 | ||
| 			// 监听标签切换事件
 | ||
| 			element.on('tab(mainTabs)', function(data){
 | ||
| 				var layid = $(this).attr('lay-id');
 | ||
| 				// 确保当前标签页内容可见
 | ||
| 				$('.layui-tab-content .layui-tab-item').eq(data.index).addClass('layui-show')
 | ||
| 					.siblings().removeClass('layui-show');
 | ||
| 				
 | ||
| 				// 更新保存的标签状态
 | ||
| 				var title = $(this).text();
 | ||
| 				var url = $('.layui-tab-content .layui-tab-item').eq(data.index).find('iframe').attr('src');
 | ||
| 				saveTabState(layid, title, url);
 | ||
| 			});
 | ||
| 
 | ||
| 			// 监听标签删除事件
 | ||
| 			element.on('tabDelete(mainTabs)', function(data){
 | ||
| 				// 如果没有标签了,显示工作台
 | ||
| 				if($('.layui-tab-title li').length === 0) {
 | ||
| 					$('#mainTabs').hide();
 | ||
| 					$('#mainWorkspace').show();
 | ||
| 					sessionStorage.removeItem('currentTab');
 | ||
| 				}
 | ||
| 			});
 | ||
| 
 | ||
| 			// 左侧菜单点击事件
 | ||
| 			$('.left-nav #nav li').click(function (event) {
 | ||
| 				if ($(this).children('.sub-menu').length) {
 | ||
| 					if ($(this).hasClass('open')) {
 | ||
| 						$(this).removeClass('open');
 | ||
| 						$(this).find('.nav_right').html('');
 | ||
| 						$(this).children('.sub-menu').stop().slideUp();
 | ||
| 						$(this).siblings().children('.sub-menu').slideUp();
 | ||
| 					} else {
 | ||
| 						$(this).addClass('open');
 | ||
| 						$(this).children('a').find('.nav_right').html('');
 | ||
| 						$(this).children('.sub-menu').stop().slideDown();
 | ||
| 						$(this).siblings().children('.sub-menu').stop().slideUp();
 | ||
| 						$(this).siblings().find('.nav_right').html('');
 | ||
| 						$(this).siblings().removeClass('open');
 | ||
| 					}
 | ||
| 				} else {
 | ||
| 					var url = $(this).children('a').attr('_href');
 | ||
| 					var title = $(this).children('a').html();
 | ||
| 					title = title.replace(/<[^>]+>/g, "").trim();  // 移除HTML标签
 | ||
| 					
 | ||
| 					if (url) {
 | ||
| 						window.addTab(title, url);
 | ||
| 					}
 | ||
| 				}
 | ||
| 				event.stopPropagation();
 | ||
| 			})
 | ||
| 
 | ||
| 			// 修改resetMainHeight函数
 | ||
| 			function resetMainHeight(iframe) {
 | ||
| 				if (!iframe) return;
 | ||
| 				try {
 | ||
| 					// 获取视口高度
 | ||
| 					var clientHeight = document.documentElement.clientHeight;
 | ||
| 					// 计算iframe应该的高度(减去头部和tab标签的高度)
 | ||
| 					var iframeHeight = clientHeight - 60 - 40; // 60px是头部高度,40px是tab标签高度
 | ||
| 					$(iframe).css({
 | ||
| 						'height': iframeHeight + 'px',
 | ||
| 						'width': '100%',
 | ||
| 						'display': 'block'
 | ||
| 					});
 | ||
| 				} catch(e) {
 | ||
| 					console.error('Reset iframe height failed:', e);
 | ||
| 				}
 | ||
| 			}
 | ||
| 
 | ||
| 			// 在窗口大小改变时重置所有iframe高度
 | ||
| 			$(window).on('resize', function() {
 | ||
| 				$('.main-iframe').each(function() {
 | ||
| 					resetMainHeight(this);
 | ||
| 				});
 | ||
| 			});
 | ||
| 		});
 | ||
| 
 | ||
| 		// 菜单点击
 | ||
| 		function menuFire(obj, num) {
 | ||
| 			if (num == 1) {
 | ||
| 				var title = '';
 | ||
| 				// 获取菜单标题
 | ||
| 				$('.layui-nav-item a').each(function() {
 | ||
| 					if($(this).attr('onclick') && $(this).attr('onclick').indexOf(obj) > -1) {
 | ||
| 						title = $(this).text().trim();
 | ||
| 						return false;
 | ||
| 					}
 | ||
| 				});
 | ||
| 				
 | ||
| 				// 如果没找到标题,使用子菜单查找
 | ||
| 				if(!title) {
 | ||
| 					$('.layui-nav-child a').each(function() {
 | ||
| 						if($(this).attr('onclick') && $(this).attr('onclick').indexOf(obj) > -1) {
 | ||
| 							title = $(this).text().trim();
 | ||
| 							return false;
 | ||
| 						}
 | ||
| 					});
 | ||
| 				}
 | ||
| 
 | ||
| 				// 添加或切换到标签页
 | ||
| 				window.addTab(title || '新页面', "{$config['admin_route']}" + obj, obj.replace(/\//g, '_'));
 | ||
| 
 | ||
| 				// 更新浏览器URL,但保持在index页面
 | ||
| 				window.history.pushState({}, '', "{$config['admin_route']}index/index?page=" + obj);
 | ||
| 
 | ||
| 				// 如果是子菜单,确保父菜单展开
 | ||
| 				if (obj.indexOf('/') > -1) {
 | ||
| 					var parentMenu = obj.split('/')[0];
 | ||
| 					$('.layui-nav-item').each(function () {
 | ||
| 						var menuSrc = $(this).find('a').attr('onclick');
 | ||
| 						if (menuSrc && menuSrc.indexOf(parentMenu) > -1) {
 | ||
| 							$(this).addClass('layui-nav-itemed');
 | ||
| 						}
 | ||
| 					});
 | ||
| 				}
 | ||
| 			}
 | ||
| 			var width = screen();
 | ||
| 			if (width < 2) {
 | ||
| 				shrink();
 | ||
| 			}
 | ||
| 		}
 | ||
| 
 | ||
| 		// 监听浏览器前进后退按钮
 | ||
| 		window.addEventListener('popstate', function (event) {
 | ||
| 			// 获取URL参数
 | ||
| 			var urlParams = new URLSearchParams(window.location.search);
 | ||
| 			var page = urlParams.get('page');
 | ||
| 
 | ||
| 			if (page) {
 | ||
| 				// 如果有page参数,通过标签系统加载页面
 | ||
| 				var title = '新页面';
 | ||
| 				window.addTab(title, "{$config['admin_route']}" + page, page.replace(/\//g, '_'));
 | ||
| 			} else {
 | ||
| 				// 否则加载默认页面
 | ||
| 				element.tabChange('mainTabs', 'welcome');
 | ||
| 			}
 | ||
| 		});
 | ||
| 
 | ||
| 		// 退出
 | ||
| 		function logout() {
 | ||
| 			layer.confirm('确定要退出吗?', {
 | ||
| 				icon: 3,
 | ||
| 				btn: ['确定', '取消']
 | ||
| 			}, function () {
 | ||
| 				$.get("{$config['admin_route']}login/logout", function (res) {
 | ||
| 					if (res.code > 0) {
 | ||
| 						layer.msg(res.msg, { 'icon': 2 });
 | ||
| 					} else {
 | ||
| 						layer.msg(res.msg, { 'icon': 1 });
 | ||
| 						setTimeout(function () { window.location.href = "{$config['admin_route']}login/index"; }, 1000);
 | ||
| 					}
 | ||
| 				}, 'json');
 | ||
| 			});
 | ||
| 		}
 | ||
| 
 | ||
| 		//跳转前端站点
 | ||
| 		function gotoFront() {
 | ||
| 			window.open("//{$config['admin_domain']}", "_blank");
 | ||
| 		}
 | ||
| 	</script>
 | ||
| </body>
 | ||
| 
 | ||
| </html> |