pre_order.js 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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: 'pre_order/index' + location.search,
  8. add_url: 'pre_order/add',
  9. edit_url: 'pre_order/edit',
  10. del_url: 'pre_order/del',
  11. multi_url: 'pre_order/multi',
  12. import_url: 'pre_order/import',
  13. table: 'pre_order',
  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: 'company_id', title: __('Company_id')},
  29. {field: 'company.name', title: __('Company_name'), operate: 'LIKE'},
  30. {field: 'user_id', title: __('User_id')},
  31. {field: 'user.nickname', title: __('User_nickname'), operate: 'LIKE'},
  32. {field: 'name', title: __('Name'), operate: 'LIKE'},
  33. {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
  34. {field: 'remark', title: __('Remark'), operate: 'LIKE'},
  35. {field: 'car_id', title: __('Car_id'), operate: false, visible:false},
  36. {field: 'car_number', title: __('Car_number'), operate: 'LIKE'},
  37. {field: 'servicetype_id', title: __('Servicetype_id'), operate: false, visible:false},
  38. {field: 'servicetype.title', title: __('Servicetype_title')},
  39. {field: 'pre_time', title: __('Pre_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  40. {field: 'order_time', title: __('Order_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  41. {field: 'cancel_time', title: __('Cancel_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  42. {field: 'cancel_reason', title: __('Cancel_reason'), operate: 'LIKE'},
  43. {field: 'pre_order_status', title: __('Pre_order_status'), searchList: {"0":__('Pre_order_status 0'),"1":__('Pre_order_status 1'),"2":__('Pre_order_status 2')}, formatter: Table.api.formatter.status},
  44. {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  45. {field: 'updatetime', title: __('Updatetime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  46. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  47. ]
  48. ]
  49. });
  50. // 为表格绑定事件
  51. Table.api.bindevent(table);
  52. },
  53. add: function () {
  54. Controller.api.bindevent();
  55. },
  56. edit: function () {
  57. Controller.api.bindevent();
  58. },
  59. api: {
  60. bindevent: function () {
  61. $("#c-car_id").on('change', function () {
  62. var carId = $('#c-car_id').val();
  63. $.ajax({
  64. url:'user_car/index?filter={"id":"'+carId+'"}&op={"id":"="}',
  65. method:'get',
  66. success:function(res){
  67. var rows = res.rows[0];
  68. var carNumber = rows["car_number"];
  69. $("#c-car_number").val(carNumber);
  70. }
  71. });
  72. });
  73. Form.api.bindevent($("form[role=form]"));
  74. }
  75. }
  76. };
  77. return Controller;
  78. });