index.js 20 KB

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