index.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490
  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 isAndroid = /(android)/i.test(navigator.userAgent);
  21. var searchResult = $(".menuresult");
  22. $("form.sidebar-form").on("blur", "input[name=q]", function () {
  23. searchResult.addClass("hide");
  24. if (isAndroid) {
  25. $.AdminLTE.options.sidebarSlimScroll = true;
  26. }
  27. }).on("focus", "input[name=q]", function () {
  28. if (isAndroid) {
  29. $.AdminLTE.options.sidebarSlimScroll = false;
  30. }
  31. if ($("a", searchResult).size() > 0) {
  32. searchResult.removeClass("hide");
  33. }
  34. }).on("keyup", "input[name=q]", function () {
  35. searchResult.html('');
  36. var val = $(this).val();
  37. var html = new Array();
  38. if (val != '') {
  39. $("ul.sidebar-menu li a[addtabs]:not([href^='javascript:;'])").each(function () {
  40. if ($("span:first", this).text().indexOf(val) > -1 || $(this).attr("py").indexOf(val) > -1 || $(this).attr("pinyin").indexOf(val) > -1) {
  41. html.push('<a data-url="' + $(this).attr("href") + '" href="javascript:;">' + $("span:first", this).text() + '</a>');
  42. if (html.length >= 100) {
  43. return false;
  44. }
  45. }
  46. });
  47. }
  48. $(searchResult).append(html.join(""));
  49. if (html.length > 0) {
  50. searchResult.removeClass("hide");
  51. } else {
  52. searchResult.addClass("hide");
  53. }
  54. });
  55. //快捷搜索点击事件
  56. $("form.sidebar-form").on('mousedown click', '.menuresult a[data-url]', function () {
  57. Backend.api.addtabs($(this).data("url"));
  58. });
  59. //读取FastAdmin的更新信息
  60. $.ajax({
  61. url: Config.fastadmin.api_url + '/news/index',
  62. type: 'post',
  63. dataType: 'jsonp',
  64. success: function (ret) {
  65. $(".notifications-menu > a span").text(ret.new > 0 ? ret.new : '');
  66. $(".notifications-menu .footer a").attr("href", ret.url);
  67. $.each(ret.newslist, function (i, j) {
  68. var item = '<li><a href="' + j.url + '" target="_blank"><i class="' + j.icon + '"></i> ' + j.title + '</a></li>';
  69. $(item).appendTo($(".notifications-menu ul.menu"));
  70. });
  71. }
  72. });
  73. //读取首次登录推荐插件列表
  74. if (localStorage.getItem("fastep") == "installed") {
  75. $.ajax({
  76. url: Config.fastadmin.api_url + '/addon/recommend',
  77. type: 'post',
  78. dataType: 'jsonp',
  79. success: function (ret) {
  80. require(['template'], function (Template) {
  81. var install = function (name, title) {
  82. Fast.api.ajax({
  83. url: 'addon/install',
  84. data: {name: name, faversion: Config.fastadmin.version}
  85. }, function (data, ret) {
  86. Fast.api.refreshmenu();
  87. });
  88. };
  89. $(document).on('click', '.btn-install', function () {
  90. $(this).prop("disabled", true).addClass("disabled");
  91. $("input[name=addon]:checked").each(function () {
  92. install($(this).data("name"));
  93. });
  94. return false;
  95. });
  96. $(document).on('click', '.btn-notnow', function () {
  97. Layer.closeAll();
  98. });
  99. Layer.open({
  100. type: 1, skin: 'layui-layer-page', area: ["860px", "620px"], title: '',
  101. content: Template.render(ret.tpl, {addonlist: ret.rows})
  102. });
  103. localStorage.setItem("fastep", "dashboard");
  104. });
  105. }
  106. });
  107. }
  108. //版本检测
  109. var checkupdate = function (ignoreversion, tips) {
  110. $.ajax({
  111. url: Config.fastadmin.api_url + '/version/check',
  112. type: 'post',
  113. data: {version: Config.fastadmin.version},
  114. dataType: 'jsonp',
  115. success: function (ret) {
  116. if (ret.data && ignoreversion !== ret.data.newversion) {
  117. Layer.open({
  118. title: __('Discover new version'),
  119. maxHeight: 400,
  120. content: '<h5 style="background-color:#f7f7f7; font-size:14px; padding: 10px;">' + __('Your current version') + ':' + ret.data.version + ',' + __('New version') + ':' + ret.data.newversion + '</h5><span class="label label-danger">'+__('Release notes')+'</span><br/>' + ret.data.upgradetext,
  121. btn: [__('Go to download'), __('Ignore this version'), __('Do not remind again')],
  122. btn2: function (index, layero) {
  123. localStorage.setItem("ignoreversion", ret.data.newversion);
  124. },
  125. btn3: function (index, layero) {
  126. localStorage.setItem("ignoreversion", "*");
  127. },
  128. success: function (layero, index) {
  129. $(".layui-layer-btn0", layero).attr("href", ret.data.downloadurl).attr("target", "_blank");
  130. }
  131. });
  132. } else {
  133. if (tips) {
  134. Toastr.success(__('Currently is the latest version'));
  135. }
  136. }
  137. }, error: function (e) {
  138. if (tips) {
  139. Toastr.error(__('Unknown data format') + ":" + e.message);
  140. }
  141. }
  142. });
  143. };
  144. //读取版本检测信息
  145. var ignoreversion = localStorage.getItem("ignoreversion");
  146. if (Config.fastadmin.checkupdate && ignoreversion !== "*") {
  147. checkupdate(ignoreversion, false);
  148. }
  149. //手动检测版本信息
  150. $("a[data-toggle='checkupdate']").on('click', function () {
  151. checkupdate('', true);
  152. });
  153. //切换左侧sidebar显示隐藏
  154. $(document).on("click fa.event.toggleitem", ".sidebar-menu li > a", function (e) {
  155. $(".sidebar-menu li").removeClass("active");
  156. //当外部触发隐藏的a时,触发父辈a的事件
  157. if (!$(this).closest("ul").is(":visible")) {
  158. //如果不需要左侧的菜单栏联动可以注释下面一行即可
  159. $(this).closest("ul").prev().trigger("click");
  160. }
  161. var visible = $(this).next("ul").is(":visible");
  162. if (!visible) {
  163. $(this).parents("li").addClass("active");
  164. } else {
  165. }
  166. e.stopPropagation();
  167. });
  168. //清除缓存
  169. $(document).on('click', "ul.wipecache li a", function () {
  170. $.ajax({
  171. url: 'ajax/wipecache',
  172. dataType: 'json',
  173. data: {type: $(this).data("type")},
  174. cache: false,
  175. success: function (ret) {
  176. if (ret.hasOwnProperty("code")) {
  177. var msg = ret.hasOwnProperty("msg") && ret.msg != "" ? ret.msg : "";
  178. if (ret.code === 1) {
  179. Toastr.success(msg ? msg : __('Wipe cache completed'));
  180. } else {
  181. Toastr.error(msg ? msg : __('Wipe cache failed'));
  182. }
  183. } else {
  184. Toastr.error(__('Unknown data format'));
  185. }
  186. }, error: function () {
  187. Toastr.error(__('Network error'));
  188. }
  189. });
  190. });
  191. //全屏事件
  192. $(document).on('click', "[data-toggle='fullscreen']", function () {
  193. var doc = document.documentElement;
  194. if ($(document.body).hasClass("full-screen")) {
  195. $(document.body).removeClass("full-screen");
  196. document.exitFullscreen ? document.exitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitExitFullscreen && document.webkitExitFullscreen();
  197. } else {
  198. $(document.body).addClass("full-screen");
  199. doc.requestFullscreen ? doc.requestFullscreen() : doc.mozRequestFullScreen ? doc.mozRequestFullScreen() : doc.webkitRequestFullscreen ? doc.webkitRequestFullscreen() : doc.msRequestFullscreen && doc.msRequestFullscreen();
  200. }
  201. });
  202. var multiplenav = Config.fastadmin.multiplenav;
  203. var firstnav = $("#firstnav .nav-addtabs");
  204. var nav = multiplenav ? $("#secondnav .nav-addtabs") : firstnav;
  205. //刷新菜单事件
  206. $(document).on('refresh', '.sidebar-menu', function () {
  207. Fast.api.ajax({
  208. url: 'index/index',
  209. data: {action: 'refreshmenu'}
  210. }, function (data) {
  211. $(".sidebar-menu li:not([data-rel='external'])").remove();
  212. $(".sidebar-menu").prepend(data.menulist);
  213. if (multiplenav) {
  214. firstnav.html(data.navlist);
  215. }
  216. $("li[role='presentation'].active a", nav).trigger('click');
  217. return false;
  218. }, function () {
  219. return false;
  220. });
  221. });
  222. if (multiplenav) {
  223. //一级菜单自适应
  224. $(window).resize(function () {
  225. var siblingsWidth = 0;
  226. firstnav.siblings().each(function () {
  227. siblingsWidth += $(this).outerWidth();
  228. });
  229. firstnav.width(firstnav.parent().width() - siblingsWidth);
  230. firstnav.refreshAddtabs();
  231. });
  232. //点击顶部第一级菜单栏
  233. firstnav.on("click", "li a", function () {
  234. $("li", firstnav).removeClass("active");
  235. $(this).closest("li").addClass("active");
  236. $(".sidebar-menu > li.treeview").addClass("hidden");
  237. if ($(this).attr("url") == "javascript:;") {
  238. var sonlist = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']");
  239. sonlist.removeClass("hidden");
  240. var sidenav;
  241. var last_id = $(this).attr("last-id");
  242. if (last_id) {
  243. sidenav = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "'] a[addtabs='" + last_id + "']");
  244. } else {
  245. sidenav = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']:first > a");
  246. }
  247. if (sidenav) {
  248. sidenav.attr("href") != "javascript:;" && sidenav.trigger('click');
  249. }
  250. } else {
  251. }
  252. });
  253. //点击左侧菜单栏
  254. $(document).on('click', '.sidebar-menu li a[addtabs]', function (e) {
  255. var parents = $(this).parentsUntil("ul.sidebar-menu", "li");
  256. var top = parents[parents.length - 1];
  257. var pid = $(top).attr("pid");
  258. if (pid) {
  259. var obj = $("li a[addtabs=" + pid + "]", firstnav);
  260. var last_id = obj.attr("last-id");
  261. if (!last_id || last_id != pid) {
  262. obj.attr("last-id", $(this).attr("addtabs"));
  263. if (!obj.closest("li").hasClass("active")) {
  264. obj.trigger("click");
  265. }
  266. }
  267. }
  268. });
  269. var mobilenav = $(".mobilenav");
  270. $("#firstnav .nav-addtabs li a").each(function () {
  271. mobilenav.append($(this).clone().addClass("btn btn-app"));
  272. });
  273. //点击移动端一级菜单
  274. mobilenav.on("click", "a", function () {
  275. $("a", mobilenav).removeClass("active");
  276. $(this).addClass("active");
  277. $(".sidebar-menu > li.treeview").addClass("hidden");
  278. if ($(this).attr("url") == "javascript:;") {
  279. var sonlist = $(".sidebar-menu > li[pid='" + $(this).attr("addtabs") + "']");
  280. sonlist.removeClass("hidden");
  281. }
  282. });
  283. }
  284. //这一行需要放在点击左侧链接事件之前
  285. var addtabs = Config.referer ? localStorage.getItem("addtabs") : null;
  286. //绑定tabs事件,如果需要点击强制刷新iframe,则请将iframeForceRefresh置为true
  287. nav.addtabs({iframeHeight: "100%", iframeForceRefresh: false, nav: nav});
  288. if ($("ul.sidebar-menu li.active a").size() > 0) {
  289. $("ul.sidebar-menu li.active a").trigger("click");
  290. } else {
  291. if (Config.fastadmin.multiplenav) {
  292. $("li:first > a", firstnav).trigger("click");
  293. } else {
  294. $("ul.sidebar-menu li a[url!='javascript:;']:first").trigger("click");
  295. }
  296. }
  297. //如果是刷新操作则直接返回刷新前的页面
  298. if (Config.referer) {
  299. if (Config.referer === $(addtabs).attr("url")) {
  300. var active = $("ul.sidebar-menu li a[addtabs=" + $(addtabs).attr("addtabs") + "]");
  301. if (multiplenav && active.size() == 0) {
  302. active = $("ul li a[addtabs='" + $(addtabs).attr("addtabs") + "']");
  303. }
  304. if (active.size() > 0) {
  305. active.trigger("click");
  306. } else {
  307. $(addtabs).appendTo(document.body).addClass("hide").trigger("click");
  308. }
  309. } else {
  310. //刷新页面后跳到到刷新前的页面
  311. Backend.api.addtabs(Config.referer);
  312. }
  313. }
  314. var my_skins = [
  315. "skin-blue",
  316. "skin-white",
  317. "skin-red",
  318. "skin-yellow",
  319. "skin-purple",
  320. "skin-green",
  321. "skin-blue-light",
  322. "skin-white-light",
  323. "skin-red-light",
  324. "skin-yellow-light",
  325. "skin-purple-light",
  326. "skin-green-light"
  327. ];
  328. setup();
  329. function change_layout(cls) {
  330. $("body").toggleClass(cls);
  331. AdminLTE.layout.fixSidebar();
  332. //Fix the problem with right sidebar and layout boxed
  333. if (cls == "layout-boxed")
  334. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  335. if ($('body').hasClass('fixed') && cls == 'fixed') {
  336. AdminLTE.pushMenu.expandOnHover();
  337. AdminLTE.layout.activate();
  338. }
  339. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  340. AdminLTE.controlSidebar._fix($(".control-sidebar"));
  341. }
  342. function change_skin(cls) {
  343. if (!$("body").hasClass(cls)) {
  344. $("body").removeClass(my_skins.join(' ')).addClass(cls);
  345. localStorage.setItem('skin', cls);
  346. var cssfile = Config.site.cdnurl + "/assets/css/skins/" + cls + ".css";
  347. $('head').append('<link rel="stylesheet" href="' + cssfile + '" type="text/css" />');
  348. }
  349. return false;
  350. }
  351. function setup() {
  352. var tmp = localStorage.getItem('skin');
  353. if (tmp && $.inArray(tmp, my_skins))
  354. change_skin(tmp);
  355. // 皮肤切换
  356. $("[data-skin]").on('click', function (e) {
  357. if ($(this).hasClass('knob'))
  358. return;
  359. e.preventDefault();
  360. change_skin($(this).data('skin'));
  361. });
  362. // 布局切换
  363. $("[data-layout]").on('click', function () {
  364. change_layout($(this).data('layout'));
  365. });
  366. // 切换子菜单显示和菜单小图标的显示
  367. $("[data-menu]").on('click', function () {
  368. if ($(this).data("menu") == 'show-submenu') {
  369. $("ul.sidebar-menu").toggleClass("show-submenu");
  370. } else {
  371. nav.toggleClass("disable-top-badge");
  372. }
  373. });
  374. // 右侧控制栏切换
  375. $("[data-controlsidebar]").on('click', function () {
  376. change_layout($(this).data('controlsidebar'));
  377. var slide = !AdminLTE.options.controlSidebarOptions.slide;
  378. AdminLTE.options.controlSidebarOptions.slide = slide;
  379. if (!slide)
  380. $('.control-sidebar').removeClass('control-sidebar-open');
  381. });
  382. // 右侧控制栏背景切换
  383. $("[data-sidebarskin='toggle']").on('click', function () {
  384. var sidebar = $(".control-sidebar");
  385. if (sidebar.hasClass("control-sidebar-dark")) {
  386. sidebar.removeClass("control-sidebar-dark")
  387. sidebar.addClass("control-sidebar-light")
  388. } else {
  389. sidebar.removeClass("control-sidebar-light")
  390. sidebar.addClass("control-sidebar-dark")
  391. }
  392. });
  393. // 菜单栏展开或收起
  394. $("[data-enable='expandOnHover']").on('click', function () {
  395. $(this).attr('disabled', true);
  396. AdminLTE.pushMenu.expandOnHover();
  397. if (!$('body').hasClass('sidebar-collapse'))
  398. $("[data-layout='sidebar-collapse']").click();
  399. });
  400. // 重设选项
  401. if ($('body').hasClass('fixed')) {
  402. $("[data-layout='fixed']").attr('checked', 'checked');
  403. }
  404. if ($('body').hasClass('layout-boxed')) {
  405. $("[data-layout='layout-boxed']").attr('checked', 'checked');
  406. }
  407. if ($('body').hasClass('sidebar-collapse')) {
  408. $("[data-layout='sidebar-collapse']").attr('checked', 'checked');
  409. }
  410. if ($('ul.sidebar-menu').hasClass('show-submenu')) {
  411. $("[data-menu='show-submenu']").attr('checked', 'checked');
  412. }
  413. if (nav.hasClass('disable-top-badge')) {
  414. $("[data-menu='disable-top-badge']").attr('checked', 'checked');
  415. }
  416. }
  417. $(window).resize();
  418. },
  419. login: function () {
  420. var lastlogin = localStorage.getItem("lastlogin");
  421. if (lastlogin) {
  422. lastlogin = JSON.parse(lastlogin);
  423. $("#profile-img").attr("src", Backend.api.cdnurl(lastlogin.avatar));
  424. $("#profile-name").val(lastlogin.username);
  425. }
  426. //让错误提示框居中
  427. Fast.config.toastr.positionClass = "toast-top-center";
  428. //本地验证未通过时提示
  429. $("#login-form").data("validator-options", {
  430. invalid: function (form, errors) {
  431. $.each(errors, function (i, j) {
  432. Toastr.error(j);
  433. });
  434. },
  435. target: '#errtips'
  436. });
  437. //为表单绑定事件
  438. Form.api.bindevent($("#login-form"), function (data) {
  439. localStorage.setItem("lastlogin", JSON.stringify({
  440. id: data.id,
  441. username: data.username,
  442. avatar: data.avatar
  443. }));
  444. location.href = Backend.api.fixurl(data.url);
  445. });
  446. }
  447. };
  448. return Controller;
  449. });