index.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448
  1. define(['jquery', 'bootstrap', 'backend', 'addtabs', 'adminlte', 'form'], function ($, undefined, Backend, undefined, AdminLTE, Form) {
  2. var Controller = {
  3. index: function () {
  4. //双击重新加载页面
  5. $(document).on("dblclick", ".sidebar-menu li > a", function (e) {
  6. $("#con_" + $(this).attr("addtabs") + " iframe").attr('src', function (i, val) {
  7. return val;
  8. });
  9. e.stopPropagation();
  10. });
  11. //修复在移除窗口时下拉框不隐藏的BUG
  12. $(window).on("blur", function () {
  13. $("[data-toggle='dropdown']").parent().removeClass("open");
  14. if ($("body").hasClass("sidebar-open")) {
  15. $(".sidebar-toggle").trigger("click");
  16. }
  17. });
  18. //快捷搜索
  19. $(".menuresult").width($("form.sidebar-form > .input-group").width());
  20. var searchResult = $(".menuresult");
  21. $("form.sidebar-form").on("blur", "input[name=q]", function () {
  22. searchResult.addClass("hide");
  23. }).on("focus", "input[name=q]", function () {
  24. if ($("a", searchResult).length > 0) {
  25. searchResult.removeClass("hide");
  26. }
  27. }).on("keyup", "input[name=q]", function () {
  28. searchResult.html('');
  29. var val = $(this).val();
  30. var html = [];
  31. if (val != '') {
  32. $("ul.sidebar-menu li a[addtabs]:not([href^='javascript:;'])").each(function () {
  33. if ($("span:first", this).text().indexOf(val) > -1 || $(this).attr("py").indexOf(val) > -1 || $(this).attr("pinyin").indexOf(val) > -1) {
  34. html.push('<a data-url="' + $(this).attr("href") + '" href="javascript:;">' + $("span:first", this).text() + '</a>');
  35. if (html.length >= 100) {
  36. return false;
  37. }
  38. }
  39. });
  40. }
  41. $(searchResult).append(html.join(""));
  42. if (html.length > 0) {
  43. searchResult.removeClass("hide");
  44. } else {
  45. searchResult.addClass("hide");
  46. }
  47. });
  48. //快捷搜索点击事件
  49. $("form.sidebar-form").on('mousedown click', '.menuresult a[data-url]', function () {
  50. Backend.api.addtabs($(this).data("url"));
  51. });
  52. //切换左侧sidebar显示隐藏
  53. $(document).on("click fa.event.toggleitem", ".sidebar-menu li > a", function (e) {
  54. var nextul = $(this).next("ul");
  55. if (nextul.length == 0 && (!$(this).parent("li").hasClass("treeview") || ($("body").hasClass("multiplenav") && $(this).parent().parent().hasClass("sidebar-menu")))) {
  56. $(".sidebar-menu li").not($(this).parents("li")).removeClass("active");
  57. }
  58. //当外部触发隐藏的a时,触发父辈a的事件
  59. if (!$(this).closest("ul").is(":visible")) {
  60. //如果不需要左侧的菜单栏联动可以注释下面一行即可
  61. $(this).closest("ul").prev().trigger("click");
  62. }
  63. var visible = nextul.is(":visible");
  64. if (nextul.length == 0) {
  65. $(this).parents("li").addClass("active");
  66. } else {
  67. }
  68. e.stopPropagation();
  69. });
  70. //清除缓存
  71. $(document).on('click', "ul.wipecache li a,a.wipecache", function () {
  72. $.ajax({
  73. url: 'ajax/wipecache',
  74. dataType: 'json',
  75. data: {type: $(this).data("type")},
  76. cache: false,
  77. success: function (ret) {
  78. if (ret.hasOwnProperty("code")) {
  79. var msg = ret.hasOwnProperty("msg") && ret.msg != "" ? ret.msg : "";
  80. if (ret.code === 1) {
  81. Toastr.success(msg ? msg : __('Wipe cache completed'));
  82. } else {
  83. Toastr.error(msg ? msg : __('Wipe cache failed'));
  84. }
  85. } else {
  86. Toastr.error(__('Unknown data format'));
  87. }
  88. }, error: function () {
  89. Toastr.error(__('Network error'));
  90. }
  91. });
  92. });
  93. //全屏事件
  94. $(document).on('click', "[data-toggle='fullscreen']", function () {
  95. var doc = document.documentElement;
  96. if ($(document.body).hasClass("full-screen")) {
  97. $(document.body).removeClass("full-screen");
  98. document.exitFullscreen ? document.exitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitExitFullscreen && document.webkitExitFullscreen();
  99. } else {
  100. $(document.body).addClass("full-screen");
  101. doc.requestFullscreen ? doc.requestFullscreen() : doc.mozRequestFullScreen ? doc.mozRequestFullScreen() : doc.webkitRequestFullscreen ? doc.webkitRequestFullscreen() : doc.msRequestFullscreen && doc.msRequestFullscreen();
  102. }
  103. });
  104. var multiplenav = $("body").hasClass("multiplenav") > 0 ? true : false;
  105. var firstnav = $("#firstnav .nav-addtabs");
  106. var nav = multiplenav ? $("#secondnav .nav-addtabs") : firstnav;
  107. //刷新菜单事件
  108. $(document).on('refresh', '.sidebar-menu', function () {
  109. Fast.api.ajax({
  110. url: 'index/index',
  111. data: {action: 'refreshmenu'},
  112. loading: false
  113. }, function (data) {
  114. $(".sidebar-menu li:not([data-rel='external'])").remove();
  115. $(".sidebar-menu").prepend(data.menulist);
  116. if (multiplenav) {
  117. firstnav.html(data.navlist);
  118. }
  119. $("li[role='presentation'].active a", nav).trigger('click');
  120. $(window).trigger("resize");
  121. return false;
  122. }, function () {
  123. return false;
  124. });
  125. });
  126. // 定时刷新
  127. setInterval(function (){
  128. menuli = $("ul.sidebar-menu li.treeview-open ul.menu-open li.active a").attr('addtabs');
  129. Fast.api.ajax({
  130. url: 'index/index',
  131. data: {action: 'refreshmenu'},
  132. loading: false
  133. }, function (data) {
  134. $(".sidebar-menu li:not([data-rel='external'])").remove();
  135. $(".sidebar-menu").prepend(data.menulist);
  136. if (multiplenav) {
  137. firstnav.html(data.navlist);
  138. }
  139. $(`ul.sidebar-menu li a[addtabs=1]`).parent().removeClass("active");
  140. $(`ul.sidebar-menu li ul li a[addtabs=${menuli}]`).parent().addClass("active");
  141. $(`ul.sidebar-menu li ul li a[addtabs=${menuli}]`).parent().parent().addClass("menu-open");
  142. $(`ul.sidebar-menu li ul li a[addtabs=${menuli}]`).parent().parent().parent().addClass("treeview-open");
  143. $(`ul.sidebar-menu li ul li a[addtabs=${menuli}]`).parent().parent().parent().addClass("active");
  144. // $("li[role='presentation'].active a", nav).trigger('click');
  145. $(window).trigger("resize");
  146. return false;
  147. }, function () {
  148. return false;
  149. });
  150. }, 120000);//2分钟请求1次
  151. if (multiplenav) {
  152. firstnav.css("overflow", "inherit");
  153. //一级菜单自适应
  154. $(window).resize(function () {
  155. var siblingsWidth = 0;
  156. firstnav.siblings().each(function () {
  157. siblingsWidth += $(this).outerWidth();
  158. });
  159. firstnav.width(firstnav.parent().width() - siblingsWidth);
  160. firstnav.refreshAddtabs();
  161. });
  162. //点击顶部第一级菜单栏
  163. firstnav.on("click", "li a", function () {
  164. $("li", firstnav).removeClass("active");
  165. $(this).closest("li").addClass("active");
  166. $(".sidebar-menu > li[pid]").addClass("hidden");
  167. if ($(this).attr("url") == "javascript:;") {
  168. var sonlist = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']");
  169. sonlist.removeClass("hidden");
  170. var sidenav;
  171. var last_id = $(this).attr("last-id");
  172. if (last_id) {
  173. sidenav = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "'] a[addtabs='" + last_id + "']");
  174. } else {
  175. sidenav = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']:first > a");
  176. }
  177. if (sidenav) {
  178. sidenav.attr("href") != "javascript:;" && sidenav.trigger('click');
  179. }
  180. } else {
  181. }
  182. });
  183. var mobilenav = $(".mobilenav");
  184. $("#firstnav .nav-addtabs li a").each(function () {
  185. mobilenav.append($(this).clone().addClass("btn btn-app"));
  186. });
  187. //点击移动端一级菜单
  188. mobilenav.on("click", "a", function () {
  189. $("a", mobilenav).removeClass("active");
  190. $(this).addClass("active");
  191. $(".sidebar-menu > li[pid]").addClass("hidden");
  192. if ($(this).attr("url") == "javascript:;") {
  193. var sonlist = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']");
  194. sonlist.removeClass("hidden");
  195. }
  196. });
  197. //点击左侧菜单栏
  198. $(document).on('click', '.sidebar-menu li a[addtabs]', function (e) {
  199. var parents = $(this).parentsUntil("ul.sidebar-menu", "li");
  200. var top = parents[parents.length - 1];
  201. var pid = $(top).attr("pid");
  202. if (pid) {
  203. var obj = $("li a[addtabs=" + pid + "]", firstnav);
  204. var last_id = obj.attr("last-id");
  205. if (!last_id || last_id != pid) {
  206. obj.attr("last-id", $(this).attr("addtabs"));
  207. if (!obj.closest("li").hasClass("active")) {
  208. obj.trigger("click");
  209. }
  210. }
  211. mobilenav.find("a").removeClass("active");
  212. mobilenav.find("a[addtabs='" + pid + "']").addClass("active");
  213. }
  214. });
  215. }
  216. //这一行需要放在点击左侧链接事件之前
  217. var addtabs = Config.referer ? localStorage.getItem("addtabs") : null;
  218. //绑定tabs事件,如果需要点击强制刷新iframe,则请将iframeForceRefresh置为true,iframeForceRefreshTable只强制刷新表格
  219. nav.addtabs({iframeHeight: "100%", iframeForceRefresh: false, iframeForceRefreshTable: true, nav: nav});
  220. if ($("ul.sidebar-menu li.active a").length > 0) {
  221. $("ul.sidebar-menu li.active a").trigger("click");
  222. } else {
  223. if (multiplenav) {
  224. $("li:first > a", firstnav).trigger("click");
  225. } else {
  226. $("ul.sidebar-menu li a[url!='javascript:;']:first").trigger("click");
  227. }
  228. }
  229. //如果是刷新操作则直接返回刷新前的页面
  230. if (Config.referer) {
  231. if (Config.referer === $(addtabs).attr("url")) {
  232. var active = $("ul.sidebar-menu li a[addtabs=" + $(addtabs).attr("addtabs") + "]");
  233. if (multiplenav && active.length == 0) {
  234. active = $("ul li a[addtabs='" + $(addtabs).attr("addtabs") + "']");
  235. }
  236. if (active.length > 0) {
  237. active.trigger("click");
  238. } else {
  239. $(addtabs).appendTo(document.body).addClass("hide").trigger("click");
  240. }
  241. } else {
  242. //刷新页面后跳到到刷新前的页面
  243. Backend.api.addtabs(Config.referer);
  244. }
  245. }
  246. var createCookie = function (name, value) {
  247. var date = new Date();
  248. date.setTime(date.getTime() + (365 * 24 * 60 * 60 * 1000));
  249. var path = Config.moduleurl;
  250. document.cookie = encodeURIComponent(Config.cookie.prefix + name) + "=" + encodeURIComponent(value) + "; path=" + path + "; expires=" + date.toGMTString();
  251. };
  252. var my_skins = [
  253. "skin-blue",
  254. "skin-black",
  255. "skin-red",
  256. "skin-yellow",
  257. "skin-purple",
  258. "skin-green",
  259. "skin-blue-light",
  260. "skin-black-light",
  261. "skin-red-light",
  262. "skin-yellow-light",
  263. "skin-purple-light",
  264. "skin-green-light",
  265. "skin-black-blue",
  266. "skin-black-purple",
  267. "skin-black-red",
  268. "skin-black-green",
  269. "skin-black-yellow",
  270. "skin-black-pink",
  271. ];
  272. // 皮肤切换
  273. $("[data-skin]").on('click', function (e) {
  274. var skin = $(this).data('skin');
  275. if (!$("body").hasClass(skin)) {
  276. $("body").removeClass(my_skins.join(' ')).addClass(skin);
  277. var cssfile = Config.site.cdnurl + "/assets/css/skins/" + skin + ".css";
  278. $('head').append('<link rel="stylesheet" href="' + cssfile + '" type="text/css" />');
  279. $(".skin-list li.active").removeClass("active");
  280. $(".skin-list li a[data-skin='" + skin + "']").parent().addClass("active");
  281. createCookie('adminskin', skin);
  282. }
  283. return false;
  284. });
  285. // 收起菜单栏切换
  286. $("[data-layout='sidebar-collapse']").on('click', function () {
  287. $(".sidebar-toggle").trigger("click");
  288. });
  289. // 切换子菜单显示和菜单小图标的显示
  290. $("[data-menu='show-submenu']").on('click', function () {
  291. createCookie('show_submenu', $(this).prop("checked") ? 1 : 0);
  292. location.reload();
  293. });
  294. // 右侧控制栏切换
  295. $("[data-controlsidebar]").on('click', function () {
  296. var cls = $(this).data('controlsidebar');
  297. $("body").toggleClass(cls);
  298. AdminLTE.layout.fixSidebar();
  299. //Fix the problem with right sidebar and layout boxed
  300. if (cls == "layout-boxed")
  301. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  302. if ($('body').hasClass('fixed') && cls == 'fixed') {
  303. AdminLTE.pushMenu.expandOnHover();
  304. AdminLTE.layout.activate();
  305. }
  306. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  307. AdminLTE.controlSidebar._fix($(".control-sidebar"));
  308. var slide = !AdminLTE.options.controlSidebarOptions.slide;
  309. AdminLTE.options.controlSidebarOptions.slide = slide;
  310. if (!slide)
  311. $('.control-sidebar').removeClass('control-sidebar-open');
  312. });
  313. // 右侧控制栏背景切换
  314. $("[data-sidebarskin='toggle']").on('click', function () {
  315. var sidebar = $(".control-sidebar");
  316. if (sidebar.hasClass("control-sidebar-dark")) {
  317. sidebar.removeClass("control-sidebar-dark")
  318. sidebar.addClass("control-sidebar-light")
  319. } else {
  320. sidebar.removeClass("control-sidebar-light")
  321. sidebar.addClass("control-sidebar-dark")
  322. }
  323. });
  324. // 菜单栏展开或收起
  325. $("[data-enable='expandOnHover']").on('click', function () {
  326. $.AdminLTE.options.sidebarExpandOnHover = $(this).prop("checked") ? 1 : 0;
  327. localStorage.setItem('sidebarExpandOnHover', $.AdminLTE.options.sidebarExpandOnHover);
  328. AdminLTE.pushMenu.expandOnHover();
  329. $.AdminLTE.layout.fixSidebar();
  330. });
  331. // 切换菜单栏
  332. $(document).on("click", ".sidebar-toggle", function () {
  333. var value = $("body").hasClass("sidebar-collapse") ? 1 : 0;
  334. setTimeout(function () {
  335. $(window).trigger("resize");
  336. }, 300);
  337. createCookie('sidebar_collapse', value);
  338. });
  339. // 切换多级菜单
  340. $(document).on("click", "[data-config='multiplenav']", function () {
  341. var value = $(this).prop("checked") ? 1 : 0;
  342. createCookie('multiplenav', value);
  343. location.reload();
  344. });
  345. // 切换多选项卡
  346. $(document).on("click", "[data-config='multipletab']", function () {
  347. var value = $(this).prop("checked") ? 1 : 0;
  348. $("body").toggleClass("multipletab", value);
  349. createCookie('multipletab', value);
  350. });
  351. // 重设选项
  352. if ($('body').hasClass('fixed')) {
  353. $("[data-layout='fixed']").attr('checked', 'checked');
  354. }
  355. if ($('body').hasClass('layout-boxed')) {
  356. $("[data-layout='layout-boxed']").attr('checked', 'checked');
  357. }
  358. if ($('body').hasClass('sidebar-collapse')) {
  359. $("[data-layout='sidebar-collapse']").attr('checked', 'checked');
  360. }
  361. if ($('ul.sidebar-menu').hasClass('show-submenu')) {
  362. $("[data-menu='show-submenu']").attr('checked', 'checked');
  363. }
  364. var sidebarExpandOnHover = localStorage.getItem('sidebarExpandOnHover');
  365. if (sidebarExpandOnHover == '1') {
  366. $("[data-enable='expandOnHover']").trigger("click");
  367. }
  368. $.each(my_skins, function (i, j) {
  369. if ($("body").hasClass(j)) {
  370. $(".skin-list li a[data-skin='" + j + "']").parent().addClass("active");
  371. }
  372. });
  373. $(window).resize();
  374. },
  375. login: function () {
  376. var lastlogin = localStorage.getItem("lastlogin");
  377. if (lastlogin) {
  378. lastlogin = JSON.parse(lastlogin);
  379. $("#profile-img").attr("src", Backend.api.cdnurl(lastlogin.avatar));
  380. $("#profile-name").val(lastlogin.username);
  381. }
  382. //让错误提示框居中
  383. Fast.config.toastr.positionClass = "toast-top-center";
  384. //本地验证未通过时提示
  385. $("#login-form").data("validator-options", {
  386. invalid: function (form, errors) {
  387. $.each(errors, function (i, j) {
  388. Toastr.error(j);
  389. });
  390. },
  391. target: '#errtips'
  392. });
  393. //为表单绑定事件
  394. Form.api.bindevent($("#login-form"), function (data) {
  395. localStorage.setItem("lastlogin", JSON.stringify({
  396. id: data.id,
  397. username: data.username,
  398. avatar: data.avatar
  399. }));
  400. location.href = Backend.api.fixurl(data.url);
  401. }, function (data) {
  402. $("input[name=captcha]").next(".input-group-addon").find("img").trigger("click");
  403. });
  404. }
  405. };
  406. return Controller;
  407. });