index.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. define(['jquery', 'bootstrap', 'backend', 'addtabs', 'adminlte'], function ($, undefined, Backend, undefined, AdminLTE) {
  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. //切换左侧sidebar显示隐藏
  16. $(document).on("click", ".sidebar-menu li > a", function (e) {
  17. $(".sidebar-menu li").removeClass("active");
  18. //当外部触发隐藏的a时,触发父辈a的事件
  19. if (!$(this).closest("ul").is(":visible")) {
  20. //如果不需要左侧的菜单栏联动可以注释下面一行即可
  21. $(this).closest("ul").prev().trigger("click");
  22. }
  23. var visible = $(this).next("ul").is(":visible");
  24. if (!visible) {
  25. $(this).parents("li").addClass("active");
  26. } else {
  27. }
  28. e.stopPropagation();
  29. });
  30. //全屏事件
  31. $(document).on('click', "[data-toggle='fullscreen']", function () {
  32. var doc = document.documentElement;
  33. if ($(document.body).hasClass("full-screen")) {
  34. $(document.body).removeClass("full-screen");
  35. document.exitFullscreen ? document.exitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitExitFullscreen && document.webkitExitFullscreen();
  36. } else {
  37. $(document.body).addClass("full-screen");
  38. doc.requestFullscreen ? doc.requestFullscreen() : doc.mozRequestFullScreen ? doc.mozRequestFullScreen() : doc.webkitRequestFullscreen ? doc.webkitRequestFullscreen() : doc.msRequestFullscreen && doc.msRequestFullscreen();
  39. }
  40. });
  41. //绑定tabs事件
  42. $('#nav').addtabs({iframeHeight: "100%"});
  43. if (location.hash.indexOf("#!") === 0) {
  44. var url = decodeURIComponent(location.hash.substring(2));
  45. //刷新页面后将左侧对应的LI展开
  46. $("ul.sidebar-menu a[href='" + url + "']").trigger("click");
  47. } else {
  48. $("ul.sidebar-menu li.active a").trigger("click");
  49. }
  50. /**
  51. * List of all the available skins
  52. *
  53. * @type Array
  54. */
  55. var my_skins = [
  56. "skin-blue",
  57. "skin-black",
  58. "skin-red",
  59. "skin-yellow",
  60. "skin-purple",
  61. "skin-green",
  62. "skin-blue-light",
  63. "skin-black-light",
  64. "skin-red-light",
  65. "skin-yellow-light",
  66. "skin-purple-light",
  67. "skin-green-light"
  68. ];
  69. setup();
  70. /**
  71. * Toggles layout classes
  72. *
  73. * @param String cls the layout class to toggle
  74. * @returns void
  75. */
  76. function change_layout(cls) {
  77. $("body").toggleClass(cls);
  78. AdminLTE.layout.fixSidebar();
  79. //Fix the problem with right sidebar and layout boxed
  80. if (cls == "layout-boxed")
  81. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  82. if ($('body').hasClass('fixed') && cls == 'fixed') {
  83. AdminLTE.pushMenu.expandOnHover();
  84. AdminLTE.layout.activate();
  85. }
  86. AdminLTE.controlSidebar._fix($(".control-sidebar-bg"));
  87. AdminLTE.controlSidebar._fix($(".control-sidebar"));
  88. }
  89. /**
  90. * Replaces the old skin with the new skin
  91. * @param String cls the new skin class
  92. * @returns Boolean false to prevent link's default action
  93. */
  94. function change_skin(cls) {
  95. $.each(my_skins, function (i) {
  96. $("body").removeClass(my_skins[i]);
  97. });
  98. $("body").addClass(cls);
  99. store('skin', cls);
  100. return false;
  101. }
  102. /**
  103. * Store a new settings in the browser
  104. *
  105. * @param String name Name of the setting
  106. * @param String val Value of the setting
  107. * @returns void
  108. */
  109. function store(name, val) {
  110. if (typeof (Storage) !== "undefined") {
  111. localStorage.setItem(name, val);
  112. } else {
  113. window.alert('Please use a modern browser to properly view this template!');
  114. }
  115. }
  116. /**
  117. * Get a prestored setting
  118. *
  119. * @param String name Name of of the setting
  120. * @returns String The value of the setting | null
  121. */
  122. function get(name) {
  123. if (typeof (Storage) !== "undefined") {
  124. return localStorage.getItem(name);
  125. } else {
  126. window.alert('Please use a modern browser to properly view this template!');
  127. }
  128. }
  129. /**
  130. * Retrieve default settings and apply them to the template
  131. *
  132. * @returns void
  133. */
  134. function setup() {
  135. var tmp = get('skin');
  136. if (tmp && $.inArray(tmp, my_skins))
  137. change_skin(tmp);
  138. // 皮肤切换
  139. $("[data-skin]").on('click', function (e) {
  140. if ($(this).hasClass('knob'))
  141. return;
  142. e.preventDefault();
  143. change_skin($(this).data('skin'));
  144. });
  145. // 布局切换
  146. $("[data-layout]").on('click', function () {
  147. change_layout($(this).data('layout'));
  148. });
  149. // 切换子菜单显示和菜单小图标的显示
  150. $("[data-menu]").on('click', function () {
  151. console.log($(this).data("menu"));
  152. if ($(this).data("menu") == 'show-submenu') {
  153. $("ul.sidebar-menu").toggleClass("show-submenu");
  154. } else {
  155. $(".nav-addtabs").toggleClass("disable-top-badge");
  156. }
  157. });
  158. // 右侧控制栏切换
  159. $("[data-controlsidebar]").on('click', function () {
  160. change_layout($(this).data('controlsidebar'));
  161. var slide = !AdminLTE.options.controlSidebarOptions.slide;
  162. AdminLTE.options.controlSidebarOptions.slide = slide;
  163. if (!slide)
  164. $('.control-sidebar').removeClass('control-sidebar-open');
  165. });
  166. // 右侧控制栏背景切换
  167. $("[data-sidebarskin='toggle']").on('click', function () {
  168. var sidebar = $(".control-sidebar");
  169. if (sidebar.hasClass("control-sidebar-dark")) {
  170. sidebar.removeClass("control-sidebar-dark")
  171. sidebar.addClass("control-sidebar-light")
  172. } else {
  173. sidebar.removeClass("control-sidebar-light")
  174. sidebar.addClass("control-sidebar-dark")
  175. }
  176. });
  177. // 菜单栏展开或收起
  178. $("[data-enable='expandOnHover']").on('click', function () {
  179. $(this).attr('disabled', true);
  180. AdminLTE.pushMenu.expandOnHover();
  181. if (!$('body').hasClass('sidebar-collapse'))
  182. $("[data-layout='sidebar-collapse']").click();
  183. });
  184. // 重设选项
  185. if ($('body').hasClass('fixed')) {
  186. $("[data-layout='fixed']").attr('checked', 'checked');
  187. }
  188. if ($('body').hasClass('layout-boxed')) {
  189. $("[data-layout='layout-boxed']").attr('checked', 'checked');
  190. }
  191. if ($('body').hasClass('sidebar-collapse')) {
  192. $("[data-layout='sidebar-collapse']").attr('checked', 'checked');
  193. }
  194. if ($('ul.sidebar-menu').hasClass('show-submenu')) {
  195. $("[data-menu='show-submenu']").attr('checked', 'checked');
  196. }
  197. if ($('ul.nav-addtabs').hasClass('disable-top-badge')) {
  198. $("[data-menu='disable-top-badge']").attr('checked', 'checked');
  199. }
  200. }
  201. $(window).resize();
  202. },
  203. login: function () {
  204. $("#login-form").validator({
  205. timely: 2, theme: 'yellow_right_effect',
  206. fields: {
  207. username: "required",
  208. password: "required",
  209. },
  210. valid: function (form) {
  211. form.submit();
  212. }
  213. });
  214. $.ajax({
  215. url: 'ajax/dailybg',
  216. dataType: 'json',
  217. success: function (ret) {
  218. if (ret.code === 1) {
  219. $("body").css("background", "url(" + ret.data.url + ")");
  220. $("body").css("background-size", "cover");
  221. }
  222. }
  223. });
  224. }
  225. };
  226. return Controller;
  227. });