diyform.js 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. //设置弹窗宽高
  3. Fast.config.openArea = ['80%', '80%'];
  4. var Controller = {
  5. index: function () {
  6. // 初始化表格参数配置
  7. Table.api.init({
  8. extend: {
  9. index_url: 'cms/diyform/index',
  10. add_url: 'cms/diyform/add',
  11. edit_url: 'cms/diyform/edit',
  12. del_url: 'cms/diyform/del',
  13. multi_url: 'cms/diyform/multi',
  14. table: 'cms_model',
  15. }
  16. });
  17. var table = $("#table");
  18. // 初始化表格
  19. table.bootstrapTable({
  20. url: $.fn.bootstrapTable.defaults.extend.index_url,
  21. pk: 'id',
  22. sortName: 'id',
  23. columns: [
  24. [
  25. {checkbox: true},
  26. {field: 'id', title: __('Id')},
  27. {field: 'name', title: __('Name'), operate: 'like'},
  28. {field: 'table', title: __('Table')},
  29. {
  30. field: 'createtime',
  31. sortable: true,
  32. visible: false,
  33. title: __('Createtime'),
  34. operate: 'RANGE',
  35. addclass: 'datetimerange',
  36. formatter: Table.api.formatter.datetime
  37. },
  38. {
  39. field: 'updatetime',
  40. sortable: true,
  41. visible: false,
  42. title: __('Updatetime'),
  43. operate: 'RANGE',
  44. addclass: 'datetimerange',
  45. formatter: Table.api.formatter.datetime
  46. },
  47. {
  48. field: 'url', title: __('Url'), operate: false, formatter: function (value, row, index) {
  49. return '<a href="' + value + '" target="_blank" class="btn btn-default btn-xs"><i class="fa fa-link"></i></a>';
  50. }
  51. },
  52. {
  53. field: 'spiders', title: __('Spiders'), visible: Config.spiderRecord || false, operate: false, formatter: function (value, row, index) {
  54. if (!$.isArray(value) || value.length === 0) {
  55. return '-';
  56. }
  57. var html = [];
  58. $.each(value, function (i, j) {
  59. var color = 'default', title = '暂无来访记录';
  60. if (j.status === 'today') {
  61. color = 'danger';
  62. title = "今天有来访记录";
  63. } else if (j.status === 'pass') {
  64. color = 'success';
  65. title = "最后来访日期:" + j.date;
  66. }
  67. html.push('<span class="label label-' + color + '" data-toggle="tooltip" data-title="' + j.title + ' ' + title + '">' + j.title.substr(0, 1) + '</span>');
  68. });
  69. return html.join(" ");
  70. }
  71. },
  72. {
  73. field: 'datalist', title: __('Operate'), table: table, operate: false,
  74. buttons: [
  75. {
  76. name: 'content',
  77. text: __('数据列表'),
  78. classname: 'btn btn-xs btn-success btn-addtabs',
  79. icon: 'fa fa-file',
  80. url: 'cms/diydata/index/diyform_id/{ids}'
  81. },
  82. {
  83. name: 'fields',
  84. text: __('字段列表'),
  85. classname: 'btn btn-xs btn-info btn-fields btn-addtabs',
  86. icon: 'fa fa-list',
  87. url: 'cms/fields/index/source/diyform/source_id/{ids}'
  88. },
  89. ],
  90. formatter: Table.api.formatter.buttons
  91. },
  92. {field: 'status', title: __('Status'), searchList: {"normal": __('Normal'), "hidden": __('Hidden')}, formatter: Table.api.formatter.status},
  93. {
  94. field: 'operate',
  95. title: __('Operate'),
  96. table: table,
  97. events: Table.api.events.operate,
  98. formatter: Table.api.formatter.operate
  99. }
  100. ]
  101. ]
  102. });
  103. // 为表格绑定事件
  104. Table.api.bindevent(table);
  105. },
  106. add: function () {
  107. //获取标题拼音
  108. var si;
  109. $(document).on("keyup", "#c-name", function () {
  110. var value = $(this).val();
  111. if (value != '' && !value.match(/\n/)) {
  112. clearTimeout(si);
  113. si = setTimeout(function () {
  114. Fast.api.ajax({
  115. loading: false,
  116. url: "cms/ajax/get_title_pinyin",
  117. data: {title: value}
  118. }, function (data, ret) {
  119. $("#c-table").val("cms_diyform_" + data.pinyin);
  120. $("#c-diyname").val(data.pinyin.substr(0, 100));
  121. return false;
  122. }, function (data, ret) {
  123. return false;
  124. });
  125. }, 200);
  126. }
  127. });
  128. Controller.api.bindevent();
  129. },
  130. edit: function () {
  131. Controller.api.bindevent();
  132. },
  133. api: {
  134. bindevent: function () {
  135. $.validator.config({
  136. rules: {
  137. diyname: function (element) {
  138. if (element.value.toString().match(/^\d+$/)) {
  139. return __('Can not be only digital');
  140. }
  141. if (!element.value.toString().match(/^[a-zA-Z0-9\-_]+$/)) {
  142. return __('Please input character or digital');
  143. }
  144. return $.ajax({
  145. url: 'cms/diyform/check_element_available',
  146. type: 'POST',
  147. data: {id: $("#diyform-id").val(), name: element.name, value: element.value},
  148. dataType: 'json'
  149. });
  150. }
  151. }
  152. });
  153. Form.api.bindevent($("form[role=form]"));
  154. }
  155. }
  156. };
  157. return Controller;
  158. });