174 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			174 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| package home
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"management/internal/pkg/mid"
 | |
| )
 | |
| 
 | |
| templ Home(ctx context.Context) {
 | |
|     <!DOCTYPE html>
 | |
|     <html lang="zh-CN">
 | |
| 
 | |
|     <head>
 | |
|         <meta charset="utf-8">
 | |
|         <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
 | |
|         <title>管理后台</title>
 | |
|         <link rel="icon" type="image/x-icon" href="/statics/favicon.ico">
 | |
|         <link rel="stylesheet" href="/statics/component/pear/css/pear.css" />
 | |
|         <link rel="stylesheet" href="/statics/admin/css/admin.css" />
 | |
|         <link rel="stylesheet" href="/statics/admin/css/admin.dark.css" />
 | |
|         <link rel="stylesheet" href="/statics/admin/css/variables.css" />
 | |
|         <link rel="stylesheet" href="/statics/admin/css/reset.css" />
 | |
|         <link rel="stylesheet" href="/statics/admin/css/style.css" />
 | |
|     </head>
 | |
| 
 | |
|     <body class="layui-layout-body pear-admin">
 | |
|         <!-- 布 局 框 架 -->
 | |
|         <div class="layui-layout layui-layout-admin">
 | |
|             <!-- 顶 部 样 式 -->
 | |
|             <div class="layui-header">
 | |
|                 <!-- 菜 单 顶 部 -->
 | |
|                 <div class="layui-logo">
 | |
|                     <!-- 图 标 -->
 | |
|                     <img class="logo" alt="" src="">
 | |
|                     <!-- 标 题 -->
 | |
|                     <span class="title"></span>
 | |
|                 </div>
 | |
|                 <!-- 顶 部 左 侧 功 能 -->
 | |
|                 <ul class="layui-nav layui-layout-left">
 | |
|                     <li class="collapse layui-nav-item">
 | |
|                         <a href="#" class="layui-icon layui-icon-shrink-right"> </a>
 | |
|                     </li>
 | |
|                     <li class="refresh layui-nav-item">
 | |
|                         <a href="#" class="layui-icon layui-icon-refresh-1"> </a>
 | |
|                     </li>
 | |
|                 </ul>
 | |
|                 <!-- 多 系 统 菜 单 -->
 | |
|                 <div id="control" class="layui-layout-control"></div>
 | |
|                 <!-- 顶 部 右 侧 菜 单 -->
 | |
|                 <ul class="layui-nav layui-layout-right">
 | |
|                     <!-- <li class="layui-nav-item layui-hide-xs"><a href="#"
 | |
|                             class="menuSearch layui-icon layui-icon-search"></a></li>
 | |
|                     <li class="layui-nav-item layui-hide-xs message"></li> -->
 | |
|                     <li class="layui-nav-item layui-hide-xs"><a href="#"
 | |
|                             class="fullScreen layui-icon layui-icon-screen-full"></a></li>
 | |
|                     <li class="layui-nav-item user">
 | |
|                         <!-- 头 像 -->
 | |
|                         <a class="layui-icon layui-icon-username" href="javascript:;"></a>
 | |
|                         <!-- 功 能 菜 单 -->
 | |
|                         <dl class="layui-nav-child">
 | |
|                             {{ user := mid.GetUser(ctx) }}
 | |
|                                 if user.ID > 0 {
 | |
|                                     <dd>
 | |
|                                         <a user-menu-url="/system/user/profile" user-menu-id="profile"
 | |
|                                             user-menu-title="基本资料">基本资料</a>
 | |
|                                     </dd>
 | |
|                                     <dd>
 | |
|                                         <a href="javascript:void(0);" title={ user.Username } class="logout">注销登录</a>
 | |
|                                     </dd>
 | |
|                                 }
 | |
|                         </dl>
 | |
|                     </li>
 | |
|                     <!-- 主 题 配 置 -->
 | |
|                     <li class="layui-nav-item setting"><a href="#" class="layui-icon layui-icon-more-vertical"></a></li>
 | |
|                 </ul>
 | |
|             </div>
 | |
|             <!-- 侧 边 区 域 -->
 | |
|             <div class="layui-side layui-bg-black">
 | |
|                 <!-- 菜 单 顶 部 -->
 | |
|                 <div class="layui-logo">
 | |
|                     <!-- 图 标 -->
 | |
|                     <img class="logo">
 | |
|                     <!-- 标 题 -->
 | |
|                     <span class="title"></span>
 | |
|                 </div>
 | |
|                 <!-- 菜 单 内 容 -->
 | |
|                 <div class="layui-side-scroll">
 | |
|                     <div id="side"></div>
 | |
|                 </div>
 | |
|             </div>
 | |
|             <!-- 视 图 页 面 -->
 | |
|             <div class="layui-body" style="padding: 0">
 | |
|                 <!-- 内 容 页 面 -->
 | |
|                 <div id="content"></div>
 | |
|             </div>
 | |
|             <!-- 页脚 -->
 | |
|             <div class="layui-footer layui-text"></div>
 | |
|             <!-- 遮 盖 层 -->
 | |
|             <div class="pear-cover"></div>
 | |
|             <!-- 加 载 动 画 -->
 | |
|             <div class="loader-wrapper">
 | |
|                 <!-- 动 画 对 象 -->
 | |
|                 <div class="loader"></div>
 | |
|             </div>
 | |
|         </div>
 | |
|         <!-- 移 动 端 便 捷 操 作 -->
 | |
|         <div class="pear-collapsed-pe collapse">
 | |
|             <a href="#" class="layui-icon layui-icon-shrink-right"></a>
 | |
|         </div>
 | |
| 
 | |
|         <script src="/statics/component/layui/layui.js"></script>
 | |
|         <script src="/statics/component/pear/pear.js"></script>
 | |
|         <script>
 | |
|             layui.use(['admin', 'jquery', 'popup', 'drawer'], function () {
 | |
|                 const $ = layui.jquery;
 | |
|                 const admin = layui.admin;
 | |
|                 const popup = layui.popup;
 | |
| 
 | |
|                 // yml | json | api
 | |
|                 admin.setConfigurationPath("/pear.json");
 | |
| 
 | |
|                 admin.render();
 | |
| 
 | |
|                 // 登出逻辑
 | |
|                 admin.logout(function () {
 | |
|                     window.location.href = '/logout';
 | |
|                     // 清空 tabs 缓存
 | |
|                     return new Promise((resolve) => {
 | |
|                         resolve(true)
 | |
|                     });
 | |
|                 })
 | |
| 
 | |
|                 // 读取 localStorage 主题颜色值,初始化 iframe 主题
 | |
|                 //darkTheme();
 | |
|                 //themeColor();
 | |
| 
 | |
|                 // iframe 页监听 localStorage [pear 框架主题颜色] 变化。发生变化,同步更新 iframe 显示效果
 | |
|                 // window.addEventListener('storage', function (event) {
 | |
|                 //     if (event.key === 'dark') {
 | |
|                 //         darkTheme();
 | |
|                 //     }
 | |
|                 //     if (event.key === 'theme-color') {
 | |
|                 //         themeColor();
 | |
|                 //     }
 | |
|                 // });
 | |
| 
 | |
|                 // 夜间模式切换
 | |
|                 // function darkTheme() {
 | |
|                 //     var $pearAdmin = $(".pear-admin");  // 主体
 | |
|                 //     var $layuiCard = $('.layui-card');  // 编辑页
 | |
| 
 | |
|                 //     if (localStorage.getItem('dark') === 'true') {
 | |
|                 //         $pearAdmin.addClass("pear-admin-dark");
 | |
|                 //         $layuiCard.addClass('layui-card-dark');
 | |
|                 //     } else {
 | |
|                 //         $pearAdmin.removeClass("pear-admin-dark");
 | |
|                 //         $layuiCard.removeClass('layui-card-dark');
 | |
|                 //     }
 | |
|                 // }
 | |
| 
 | |
|                 // 主题颜色切换
 | |
|                 // function themeColor() {
 | |
|                 //     const variableKey = "--global-primary-color";
 | |
|                 //     const variableVal = localStorage.getItem("theme-color-color");
 | |
|                 //     document.documentElement.style.setProperty(variableKey, variableVal);
 | |
|                 // }
 | |
| 
 | |
|                 // 消息点击回调
 | |
|                 // admin.message(function (id, title, context, form) { });
 | |
|             })
 | |
|         </script>
 | |
|     </body>
 | |
|     </html>
 | |
| } |