index.js 19 KB

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