frontend.js 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. define(['jquery', 'bootstrap', 'toastr', 'layer', 'config'], function ($, undefined, Toastr, Layer, Config) {
  2. var Frontend = {
  3. config: {
  4. //toastr默认配置
  5. toastr: {
  6. "closeButton": true,
  7. "debug": false,
  8. "newestOnTop": false,
  9. "progressBar": false,
  10. "positionClass": "toast-top-center",
  11. "preventDuplicates": false,
  12. "onclick": null,
  13. "showDuration": "300",
  14. "hideDuration": "1000",
  15. "timeOut": "5000",
  16. "extendedTimeOut": "1000",
  17. "showEasing": "swing",
  18. "hideEasing": "linear",
  19. "showMethod": "fadeIn",
  20. "hideMethod": "fadeOut"
  21. }
  22. },
  23. api: {
  24. ajax: function (options, success, failure) {
  25. var index = Frontend.api.layer.load();
  26. options = $.extend({
  27. type: "POST",
  28. dataType: 'json',
  29. success: function (data) {
  30. Frontend.api.layer.close(index);
  31. if (data.hasOwnProperty("code")) {
  32. var content = data.hasOwnProperty("content") && data.content != "" ? data.content : "";
  33. if (data.code == 0) {
  34. if (typeof success == 'function') {
  35. var onAfterResult = success.call(undefined, content);
  36. if (!onAfterResult) {
  37. return false;
  38. }
  39. }
  40. Toastr.success(content ? content : __('Operation completed'));
  41. } else {
  42. Toastr.error(content ? content : __('Operation failed'));
  43. }
  44. } else {
  45. Toastr.error(__('Unknown data format'));
  46. }
  47. }, error: function () {
  48. Frontend.api.layer.close(index);
  49. Toastr.error(__('Network error'));
  50. }
  51. }, options);
  52. $.ajax(options);
  53. },
  54. //修复URL
  55. fixurl: function (url) {
  56. if (url.substr(0, 1) !== "/") {
  57. var r = new RegExp('^(?:[a-z]+:)?//', 'i');
  58. if (!r.test(url)) {
  59. url = (Config.moduleurl) + "/" + url;
  60. }
  61. }
  62. return url;
  63. },
  64. //上传文件
  65. upload: function (file, callback) {
  66. var data = new FormData();
  67. data.append("file", file);
  68. $.ajax({
  69. url: "ajax/upload",
  70. data: data,
  71. cache: false,
  72. contentType: false,
  73. processData: false,
  74. type: 'POST',
  75. dataType: 'json',
  76. success: function (data) {
  77. if (data.hasOwnProperty("code")) {
  78. var content = data.hasOwnProperty("content") && data.content != "" ? data.content : "";
  79. if (data.code == 0) {
  80. $('.summernote').summernote("insertImage", data.content, 'filename');
  81. Toastr.success(__('Operation completed'));
  82. } else {
  83. Toastr.error(content ? content : __('Operation failed'));
  84. }
  85. } else {
  86. Toastr.error(__('Unknown data format'));
  87. }
  88. }, error: function () {
  89. Toastr.error(__('Network error'));
  90. }
  91. });
  92. },
  93. open: function (url, title, options) {
  94. title = title == undefined ? "" : title;
  95. url = Frontend.api.fixurl(url);
  96. url = url + (url.indexOf("?") > -1 ? "&" : "?") + "dialog=1";
  97. var area;
  98. if ($(window).width() < 800) {
  99. area = ["95%", "95%"];
  100. } else {
  101. area = ['800px', '600px'];
  102. }
  103. Frontend.api.layer.open($.extend({
  104. type: 2,
  105. title: title,
  106. shadeClose: true,
  107. shade: false,
  108. maxmin: true,
  109. moveOut: true,
  110. area: area,
  111. content: url,
  112. zIndex: Frontend.api.layer.zIndex,
  113. skin: 'layui-layer-noborder',
  114. success: function (layero, index) {
  115. //$(layero).removeClass("layui-layer-border");
  116. Frontend.api.layer.setTop(layero);
  117. var frame = Frontend.api.layer.getChildFrame('html', index);
  118. var layerfooter = frame.find(".layer-footer");
  119. if (layerfooter.size() > 0) {
  120. var footer = $("<div />").addClass('layui-layer-footer row');
  121. layerfooter.clone(true).removeClass("hidden").appendTo(footer);
  122. footer.appendTo(layero.find('.layui-layer-content'));
  123. }
  124. var heg = frame.outerHeight();
  125. var titHeight = layero.find('.layui-layer-title').outerHeight() || 0;
  126. var btnHeight = layero.find('.layui-layer-btn').outerHeight() || 0;
  127. var oldheg = heg + titHeight + btnHeight;
  128. // 如果有.layer-footer或窗口小于600则重新排
  129. if (layerfooter.size() > 0 || oldheg < 600) {
  130. var footerHeight = layero.find('.layui-layer-footer').outerHeight() || 0;
  131. if (oldheg >= 600) {
  132. heg = Math.min(600, oldheg) - titHeight - btnHeight - footerHeight;
  133. }
  134. layero.css({height: heg + titHeight + btnHeight + footerHeight});
  135. layero.find("iframe").css({height: heg});
  136. }
  137. //绑定事件
  138. if (layerfooter.size() > 0) {
  139. footer.on("click", ".btn", function () {
  140. $(".btn:eq(" + $(this).index() + ")", layerfooter).trigger("click");
  141. });
  142. }
  143. }
  144. }, options ? options : {}));
  145. return false;
  146. },
  147. success: function (options, callback) {
  148. var type = typeof options === 'function';
  149. if (type) {
  150. callback = options;
  151. }
  152. return Frontend.api.layer.msg(__('Operation completed'), $.extend({
  153. offset: 0, icon: 1
  154. }, type ? {} : options));
  155. },
  156. error: function (options, callback) {
  157. var type = typeof options === 'function';
  158. if (type) {
  159. callback = options;
  160. }
  161. return Frontend.api.layer.msg(__('Operation failed'), $.extend({
  162. offset: 0, icon: 2
  163. }, type ? {} : options));
  164. },
  165. toastr: Toastr,
  166. layer: Layer
  167. },
  168. lang: function () {
  169. var args = arguments,
  170. string = args[0],
  171. i = 1;
  172. string = Lang[string] != undefined ? Lang[string] : string;
  173. return string.replace(/%((%)|s|d)/g, function (m) {
  174. // m is the matched format, e.g. %s, %d
  175. var val = null;
  176. if (m[2]) {
  177. val = m[2];
  178. } else {
  179. val = args[i];
  180. // A switch statement so that the formatter can be extended. Default is %s
  181. switch (m) {
  182. case '%d':
  183. val = parseFloat(val);
  184. if (isNaN(val)) {
  185. val = 0;
  186. }
  187. break;
  188. }
  189. i++;
  190. }
  191. return val;
  192. });
  193. }
  194. };
  195. //将Layer暴露到全局中去
  196. window.Layer = Layer;
  197. //将Toastr暴露到全局中去
  198. window.Toastr = Toastr;
  199. //将语言方法暴露到全局中去
  200. window.__ = Frontend.lang;
  201. //Toastr定义
  202. Toastr.options = Frontend.config.toastr;
  203. return Frontend;
  204. });