miniAdmin.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. /**
  2. * date:2020/02/27
  3. * author:Mr.Chung
  4. * version:2.0
  5. * description:layuimini 主体框架扩展
  6. */
  7. layui.define(["jquery", "miniMenu", "element","miniTab", "miniTheme"], function (exports) {
  8. var $ = layui.$,
  9. layer = layui.layer,
  10. miniMenu = layui.miniMenu,
  11. miniTheme = layui.miniTheme,
  12. element = layui.element ,
  13. miniTab = layui.miniTab;
  14. if (!/http(s*):\/\//.test(location.href)) {
  15. var tips = "请先将项目部署至web容器(Apache/Tomcat/Nginx/IIS/等),否则部分数据将无法显示";
  16. return layer.alert(tips);
  17. }
  18. var miniAdmin = {
  19. /**
  20. * 后台框架初始化
  21. * @param options.iniUrl 后台初始化接口地址
  22. * @param options.clearUrl 后台清理缓存接口
  23. * @param options.urlHashLocation URL地址hash定位
  24. * @param options.bgColorDefault 默认皮肤
  25. * @param options.multiModule 是否开启多模块
  26. * @param options.menuChildOpen 是否展开子菜单
  27. * @param options.loadingTime 初始化加载时间
  28. * @param options.pageAnim iframe窗口动画
  29. * @param options.maxTabNum 最大的tab打开数量
  30. */
  31. render: function (options) {
  32. options.iniUrl = options.iniUrl || null;
  33. options.clearUrl = options.clearUrl || null;
  34. options.urlHashLocation = options.urlHashLocation || false;
  35. options.bgColorDefault = options.bgColorDefault || 0;
  36. options.multiModule = options.multiModule || false;
  37. options.menuChildOpen = options.menuChildOpen || false;
  38. options.loadingTime = options.loadingTime || 1;
  39. options.pageAnim = options.pageAnim || false;
  40. options.maxTabNum = options.maxTabNum || 20;
  41. $.getJSON(options.iniUrl, function (data) {
  42. if (data == null) {
  43. miniAdmin.error('暂无菜单信息')
  44. } else {
  45. miniAdmin.renderLogo(data.logoInfo);
  46. miniAdmin.renderClear(options.clearUrl);
  47. miniAdmin.renderHome(data.homeInfo);
  48. miniAdmin.renderAnim(options.pageAnim);
  49. miniAdmin.listen();
  50. miniMenu.render({
  51. menuList: data.menuInfo,
  52. multiModule: options.multiModule,
  53. menuChildOpen: options.menuChildOpen
  54. });
  55. miniTab.render({
  56. filter: 'layuiminiTab',
  57. urlHashLocation: options.urlHashLocation,
  58. multiModule: options.multiModule,
  59. menuChildOpen: options.menuChildOpen,
  60. maxTabNum: options.maxTabNum,
  61. menuList: data.menuInfo,
  62. homeInfo: data.homeInfo,
  63. listenSwichCallback: function () {
  64. miniAdmin.renderDevice();
  65. }
  66. });
  67. miniTheme.render({
  68. bgColorDefault: options.bgColorDefault,
  69. listen: true,
  70. });
  71. miniAdmin.deleteLoader(options.loadingTime);
  72. }
  73. }).fail(function () {
  74. miniAdmin.error('菜单接口有误');
  75. });
  76. },
  77. /**
  78. * 初始化logo
  79. * @param data
  80. */
  81. renderLogo: function (data) {
  82. var html = '<a href="' + data.href + '"><img src="' + data.image + '" alt="logo"><h1>' + data.title + '</h1></a>';
  83. $('.layuimini-logo').html(html);
  84. },
  85. /**
  86. * 初始化首页
  87. * @param data
  88. */
  89. renderHome: function (data) {
  90. sessionStorage.setItem('layuiminiHomeHref', data.href);
  91. $('#layuiminiHomeTabId').html('<span class="layuimini-tab-active"></span><span class="disable-close">' + data.title + '</span><i class="layui-icon layui-unselect layui-tab-close">ဆ</i>');
  92. $('#layuiminiHomeTabId').attr('lay-id', data.href);
  93. $('#layuiminiHomeTabIframe').html('<iframe width="100%" height="100%" frameborder="no" border="0" marginwidth="0" marginheight="0" src="' + data.href + '"></iframe>');
  94. },
  95. /**
  96. * 初始化缓存地址
  97. * @param clearUrl
  98. */
  99. renderClear: function (clearUrl) {
  100. $('.layuimini-clear').attr('data-href',clearUrl);
  101. },
  102. /**
  103. * 初始化iframe窗口动画
  104. * @param anim
  105. */
  106. renderAnim: function (anim) {
  107. if (anim) {
  108. $('#layuimini-bg-color').after('<style id="layuimini-page-anim">' +
  109. '.layui-tab-item.layui-show {animation:moveTop 1s;-webkit-animation:moveTop 1s;animation-fill-mode:both;-webkit-animation-fill-mode:both;position:relative;height:100%;-webkit-overflow-scrolling:touch;}\n' +
  110. '@keyframes moveTop {0% {opacity:0;-webkit-transform:translateY(30px);-ms-transform:translateY(30px);transform:translateY(30px);}\n' +
  111. ' 100% {opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0);}\n' +
  112. '}\n' +
  113. '@-o-keyframes moveTop {0% {opacity:0;-webkit-transform:translateY(30px);-ms-transform:translateY(30px);transform:translateY(30px);}\n' +
  114. ' 100% {opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0);}\n' +
  115. '}\n' +
  116. '@-moz-keyframes moveTop {0% {opacity:0;-webkit-transform:translateY(30px);-ms-transform:translateY(30px);transform:translateY(30px);}\n' +
  117. ' 100% {opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0);}\n' +
  118. '}\n' +
  119. '@-webkit-keyframes moveTop {0% {opacity:0;-webkit-transform:translateY(30px);-ms-transform:translateY(30px);transform:translateY(30px);}\n' +
  120. ' 100% {opacity:1;-webkit-transform:translateY(0);-ms-transform:translateY(0);transform:translateY(0);}\n' +
  121. '}' +
  122. '</style>');
  123. }
  124. },
  125. fullScreen: function () {
  126. var el = document.documentElement;
  127. var rfs = el.requestFullScreen || el.webkitRequestFullScreen;
  128. if (typeof rfs != "undefined" && rfs) {
  129. rfs.call(el);
  130. } else if (typeof window.ActiveXObject != "undefined") {
  131. var wscript = new ActiveXObject("WScript.Shell");
  132. if (wscript != null) {
  133. wscript.SendKeys("{F11}");
  134. }
  135. } else if (el.msRequestFullscreen) {
  136. el.msRequestFullscreen();
  137. } else if (el.oRequestFullscreen) {
  138. el.oRequestFullscreen();
  139. } else if (el.webkitRequestFullscreen) {
  140. el.webkitRequestFullscreen();
  141. } else if (el.mozRequestFullScreen) {
  142. el.mozRequestFullScreen();
  143. } else {
  144. miniAdmin.error('浏览器不支持全屏调用!');
  145. }
  146. },
  147. /**
  148. * 退出全屏
  149. */
  150. exitFullScreen: function () {
  151. var el = document;
  152. var cfs = el.cancelFullScreen || el.webkitCancelFullScreen || el.exitFullScreen;
  153. if (typeof cfs != "undefined" && cfs) {
  154. cfs.call(el);
  155. } else if (typeof window.ActiveXObject != "undefined") {
  156. var wscript = new ActiveXObject("WScript.Shell");
  157. if (wscript != null) {
  158. wscript.SendKeys("{F11}");
  159. }
  160. } else if (el.msExitFullscreen) {
  161. el.msExitFullscreen();
  162. } else if (el.oRequestFullscreen) {
  163. el.oCancelFullScreen();
  164. }else if (el.mozCancelFullScreen) {
  165. el.mozCancelFullScreen();
  166. } else if (el.webkitCancelFullScreen) {
  167. el.webkitCancelFullScreen();
  168. } else {
  169. miniAdmin.error('浏览器不支持全屏调用!');
  170. }
  171. },
  172. /**
  173. * 初始化设备端
  174. */
  175. renderDevice: function () {
  176. if (miniAdmin.checkMobile()) {
  177. $('.layuimini-tool i').attr('data-side-fold', 1);
  178. $('.layuimini-tool i').attr('class', 'fa fa-outdent');
  179. $('.layui-layout-body').removeClass('layuimini-mini');
  180. $('.layui-layout-body').addClass('layuimini-all');
  181. }
  182. },
  183. /**
  184. * 初始化加载时间
  185. * @param loadingTime
  186. */
  187. deleteLoader: function (loadingTime) {
  188. setTimeout(function () {
  189. $('.layuimini-loader').fadeOut();
  190. }, loadingTime * 1000)
  191. },
  192. /**
  193. * 成功
  194. * @param title
  195. * @returns {*}
  196. */
  197. success: function (title) {
  198. return layer.msg(title, {icon: 1, shade: this.shade, scrollbar: false, time: 2000, shadeClose: true});
  199. },
  200. /**
  201. * 失败
  202. * @param title
  203. * @returns {*}
  204. */
  205. error: function (title) {
  206. return layer.msg(title, {icon: 2, shade: this.shade, scrollbar: false, time: 3000, shadeClose: true});
  207. },
  208. /**
  209. * 判断是否为手机
  210. * @returns {boolean}
  211. */
  212. checkMobile: function () {
  213. var ua = navigator.userAgent.toLocaleLowerCase();
  214. var pf = navigator.platform.toLocaleLowerCase();
  215. var isAndroid = (/android/i).test(ua) || ((/iPhone|iPod|iPad/i).test(ua) && (/linux/i).test(pf))
  216. || (/ucweb.*linux/i.test(ua));
  217. var isIOS = (/iPhone|iPod|iPad/i).test(ua) && !isAndroid;
  218. var isWinPhone = (/Windows Phone|ZuneWP7/i).test(ua);
  219. var clientWidth = document.documentElement.clientWidth;
  220. if (!isAndroid && !isIOS && !isWinPhone && clientWidth > 1024) {
  221. return false;
  222. } else {
  223. return true;
  224. }
  225. },
  226. /**
  227. * 监听
  228. */
  229. listen: function () {
  230. /**
  231. * 清理
  232. */
  233. $('body').on('click', '[data-clear]', function () {
  234. var loading = layer.load(0, {shade: false, time: 2 * 1000});
  235. sessionStorage.clear();
  236. // 判断是否清理服务端
  237. var clearUrl = $(this).attr('data-href');
  238. if (clearUrl != undefined && clearUrl != '' && clearUrl != null) {
  239. $.getJSON(clearUrl, function (data, status) {
  240. layer.close(loading);
  241. if (data.code != 1) {
  242. return miniAdmin.error(data.msg);
  243. } else {
  244. return miniAdmin.success(data.msg);
  245. }
  246. }).fail(function () {
  247. layer.close(loading);
  248. return miniAdmin.error('清理缓存接口有误');
  249. });
  250. } else {
  251. layer.close(loading);
  252. return miniAdmin.success('清除缓存成功');
  253. }
  254. });
  255. /**
  256. * 刷新
  257. */
  258. $('body').on('click', '[data-refresh]', function () {
  259. $(".layui-tab-item.layui-show").find("iframe")[0].contentWindow.location.reload();
  260. miniAdmin.success('刷新成功');
  261. });
  262. /**
  263. * 监听提示信息
  264. */
  265. $("body").on("mouseenter", ".layui-nav-tree .menu-li", function () {
  266. if (miniAdmin.checkMobile()) {
  267. return false;
  268. }
  269. var classInfo = $(this).attr('class'),
  270. tips = $(this).prop("innerHTML"),
  271. isShow = $('.layuimini-tool i').attr('data-side-fold');
  272. if (isShow == 0 && tips) {
  273. tips = "<ul class='layuimini-menu-left-zoom layui-nav layui-nav-tree layui-this'><li class='layui-nav-item layui-nav-itemed'>"+tips+"</li></ul>" ;
  274. window.openTips = layer.tips(tips, $(this), {
  275. tips: [2, '#2f4056'],
  276. time: 300000,
  277. skin:"popup-tips",
  278. success:function (el) {
  279. var left = $(el).position().left - 10 ;
  280. $(el).css({ left:left });
  281. element.render();
  282. }
  283. });
  284. }
  285. });
  286. $("body").on("mouseleave", ".popup-tips", function () {
  287. if (miniAdmin.checkMobile()) {
  288. return false;
  289. }
  290. var isShow = $('.layuimini-tool i').attr('data-side-fold');
  291. if (isShow == 0) {
  292. try {
  293. layer.close(window.openTips);
  294. } catch (e) {
  295. console.log(e.message);
  296. }
  297. }
  298. });
  299. /**
  300. * 全屏
  301. */
  302. $('body').on('click', '[data-check-screen]', function () {
  303. var check = $(this).attr('data-check-screen');
  304. if (check == 'full') {
  305. miniAdmin.fullScreen();
  306. $(this).attr('data-check-screen', 'exit');
  307. $(this).html('<i class="fa fa-compress"></i>');
  308. } else {
  309. miniAdmin.exitFullScreen();
  310. $(this).attr('data-check-screen', 'full');
  311. $(this).html('<i class="fa fa-arrows-alt"></i>');
  312. }
  313. });
  314. /**
  315. * 点击遮罩层
  316. */
  317. $('body').on('click', '.layuimini-make', function () {
  318. miniAdmin.renderDevice();
  319. });
  320. }
  321. };
  322. exports("miniAdmin", miniAdmin);
  323. });