index.js 17 KB

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