plan_field.js 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'equipment/plan_field/index' + location.search,
  8. add_url: 'equipment/plan_field/add',
  9. edit_url: 'equipment/plan_field/edit',
  10. del_url: 'equipment/plan_field/del',
  11. multi_url: 'equipment/plan_field/multi',
  12. import_url: 'equipment/plan_field/import',
  13. table: 'equipment_plan_field',
  14. }
  15. });
  16. var table = $("#table");
  17. // 初始化表格
  18. table.bootstrapTable({
  19. url: $.fn.bootstrapTable.defaults.extend.index_url,
  20. pk: 'id',
  21. sortName: 'id',
  22. fixedColumns: true,
  23. fixedRightNumber: 1,
  24. columns: [
  25. [
  26. {checkbox: true},
  27. {field: 'id', title: __('Id')},
  28. {field: 'label', title: __('Label'), operate: 'LIKE'},
  29. {field: 'name', title: __('Name')},
  30. {field: 'type', title: __('Type')},
  31. {field: 'default', title: __('Default')},
  32. {field: 'sort', title: __('Sort')},
  33. {field: 'status', title: __('Status'), searchList: {"normal":__('Normal'),"hidden":__('Hidden')}, formatter: Table.api.formatter.status},
  34. {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  35. {field: 'updatetime', title: __('Updatetime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  36. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  37. ]
  38. ]
  39. });
  40. // 为表格绑定事件
  41. Table.api.bindevent(table);
  42. },
  43. fields: function () {
  44. // 初始化表格参数配置
  45. Table.api.init({
  46. extend: {
  47. index_url: 'equipment/plan_field/fields' + location.search,
  48. table: 'equipment_plan_field',
  49. }
  50. });
  51. var table = $("#table");
  52. // 初始化表格
  53. table.bootstrapTable({
  54. url: $.fn.bootstrapTable.defaults.extend.index_url,
  55. pk: 'id',
  56. sortName: 'id',
  57. fixedColumns: true,
  58. fixedRightNumber: 1,
  59. columns: [
  60. [
  61. {field: 'label', title: __('FieldName'), operate: false},
  62. {field: 'type_text', title: __('FieldType'), operate: false, formatter: Table.api.formatter.label},
  63. {field: 'options', title: __('FieldOption'), operate: false, formatter: function (value, row) {
  64. var typeArr = ['radio', 'multiple'];
  65. if(typeArr.indexOf(row.type) === -1){
  66. return '';
  67. } else {
  68. return unescape(value.replace(/\\u/g, '%u'));
  69. }}
  70. },
  71. {field: 'default', title: __('FieldDefault'), operate: false},
  72. {field: 'require', title: __('Require'), operate: false, searchList: {"0":__('NotRequire'), "1":__('IsRequire')}, formatter: Table.api.formatter.label}
  73. ]
  74. ],
  75. search: false,
  76. showToggle: false,
  77. showColumns: false,
  78. showExport: false,
  79. commonSearch: false
  80. });
  81. // 为表格绑定事件
  82. Table.api.bindevent(table);
  83. },
  84. recyclebin: function () {
  85. // 初始化表格参数配置
  86. Table.api.init({
  87. extend: {
  88. 'dragsort_url': ''
  89. }
  90. });
  91. var table = $("#table");
  92. // 初始化表格
  93. table.bootstrapTable({
  94. url: 'equipment/plan_field/recyclebin' + location.search,
  95. pk: 'id',
  96. sortName: 'id',
  97. columns: [
  98. [
  99. {checkbox: true},
  100. {field: 'id', title: __('Id')},
  101. {field: 'name', title: __('Name'), align: 'left'},
  102. {
  103. field: 'deletetime',
  104. title: __('Deletetime'),
  105. operate: 'RANGE',
  106. addclass: 'datetimerange',
  107. formatter: Table.api.formatter.datetime
  108. },
  109. {
  110. field: 'operate',
  111. width: '130px',
  112. title: __('Operate'),
  113. table: table,
  114. events: Table.api.events.operate,
  115. buttons: [
  116. {
  117. name: 'Restore',
  118. text: __('Restore'),
  119. classname: 'btn btn-xs btn-info btn-ajax btn-restoreit',
  120. icon: 'fa fa-rotate-left',
  121. url: 'equipment/plan_field/restore',
  122. refresh: true
  123. },
  124. {
  125. name: 'Destroy',
  126. text: __('Destroy'),
  127. classname: 'btn btn-xs btn-danger btn-ajax btn-destroyit',
  128. icon: 'fa fa-times',
  129. url: 'equipment/plan_field/destroy',
  130. refresh: true
  131. }
  132. ],
  133. formatter: Table.api.formatter.operate
  134. }
  135. ]
  136. ]
  137. });
  138. // 为表格绑定事件
  139. Table.api.bindevent(table);
  140. },
  141. add: function () {
  142. var _this = this;
  143. var fieldType = $('#field-type').val();
  144. _this.changeField(fieldType);
  145. $(document).on("change", "#field-type", function () {
  146. var fieldType = $('#field-type').val();
  147. _this.changeField(fieldType);
  148. });
  149. Form.api.bindevent($("form[role=form]"), function(data, ret){
  150. //这里是表单提交处理成功后的回调函数,接收来自php的返回数据
  151. Fast.api.close(data); //这里是重点
  152. // Toastr.success("成功"); //这个可有可无
  153. }, function(data, ret){
  154. // Toastr.success("失败");
  155. });
  156. // Controller.api.bindevent();
  157. },
  158. edit: function () {
  159. var _this = this;
  160. var fieldType = $('#field-type').val();
  161. _this.changeField(fieldType);
  162. $(document).on("change", "#field-type", function () {
  163. var fieldType = $('#field-type').val();
  164. _this.changeField(fieldType);
  165. });
  166. Form.api.bindevent($("form[role=form]"), function(data, ret){
  167. //这里是表单提交处理成功后的回调函数,接收来自php的返回数据
  168. Fast.api.close(data); //这里是重点
  169. // Toastr.success("成功"); //这个可有可无
  170. }, function(data, ret){
  171. // Toastr.success("失败");
  172. });
  173. // Controller.api.bindevent();
  174. },
  175. api: {
  176. bindevent: function () {
  177. Form.api.bindevent($("form[role=form]"));
  178. }
  179. },
  180. changeField: function (fieldType) {
  181. if(fieldType === 'image') {
  182. $('.field-default').hide();
  183. $('.field-options').hide();
  184. }
  185. if(fieldType === 'text' || fieldType === 'textarea' || fieldType === 'number') {
  186. $('.field-default').show();
  187. $('.field-options').hide();
  188. }
  189. if(fieldType === 'true-false' || fieldType === 'radio' || fieldType === 'multiple') {
  190. $('.field-default').hide();
  191. $('.field-options').show();
  192. }
  193. }
  194. };
  195. return Controller;
  196. });