identity.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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: 'commission/identity/index',
  8. add_url: 'commission/identity/add',
  9. edit_url: 'commission/identity/edit',
  10. del_url: 'commission/identity/del',
  11. multi_url: 'commission/identity/multi',
  12. table: 'shop_commission_identity',
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. pk: 'id',
  20. sortName: 'weigh',
  21. sortOrder: 'asc',
  22. columns: [
  23. [
  24. {checkbox: true},
  25. {field: 'id', title: __('Id'), sortable: true},
  26. {field: 'name', title: __('Name'), operate: 'LIKE', formatter: Table.api.formatter.search},
  27. {field: 'level', title: __('Level'), sortable: true},
  28. {field: 'agent_type_text', title: __('Agent type'), searchList: {"normal": "普通代理商", "province": "省级代理商", "city": "市级代理商", "district": "区域代理商"}, formatter: function(value, row, index) {
  29. var colorMap = {
  30. 'province': 'danger', // 省级-红色
  31. 'city': 'warning', // 市级-橙色
  32. 'district': 'info', // 区域-蓝色
  33. 'normal': 'default' // 普通-默认
  34. };
  35. var color = colorMap[row.agent_type] || 'default';
  36. return '<span class="label label-' + color + '">' + value + '</span>';
  37. }},
  38. {field: 'regional_commission_rate', title: __('Regional rate'), operate: false, formatter: function(value, row, index) {
  39. // 区域代理商(非normal类型)显示分佣比例
  40. if (['province', 'city', 'district'].indexOf(row.agent_type) !== -1) {
  41. return (value || 0) + '%';
  42. }
  43. return '-';
  44. }},
  45. {field: 'description', title: __('Description'), operate: 'LIKE'},
  46. {field: 'status', title: __('Status'), searchList: {"0": __('Hidden'), "1": __('Shown')}, formatter: Table.api.formatter.status},
  47. {field: 'weigh', title: __('Weigh'), sortable: true, operate: false},
  48. {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
  49. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  50. ]
  51. ]
  52. });
  53. // 为表格绑定事件
  54. Table.api.bindevent(table);
  55. },
  56. add: function () {
  57. Controller.api.bindevent();
  58. },
  59. edit: function () {
  60. Controller.api.bindevent();
  61. },
  62. api: {
  63. bindevent: function () {
  64. Form.api.bindevent($("form[role=form]"));
  65. // 代理商类型切换事件
  66. $(document).on('change', 'input[name="row[agent_type]"]', function() {
  67. var agentType = $(this).val();
  68. var rateGroup = $('#regional-rate-group');
  69. var regionalTypes = ['province', 'city', 'district'];
  70. if (regionalTypes.indexOf(agentType) !== -1) {
  71. rateGroup.show();
  72. rateGroup.find('input').attr('data-rule', 'required;range(0~100)');
  73. } else {
  74. rateGroup.hide();
  75. rateGroup.find('input').removeAttr('data-rule');
  76. rateGroup.find('input').val('0.00');
  77. }
  78. });
  79. // 页面加载时初始化显示状态
  80. var checkedAgentType = $('input[name="row[agent_type]"]:checked').val();
  81. var regionalTypes = ['province', 'city', 'district'];
  82. if (regionalTypes.indexOf(checkedAgentType) !== -1) {
  83. $('#regional-rate-group').show();
  84. $('#regional-rate-group').find('input').attr('data-rule', 'required;range(0~100)');
  85. } else {
  86. $('#regional-rate-group').hide();
  87. $('#regional-rate-group').find('input').removeAttr('data-rule');
  88. }
  89. }
  90. }
  91. };
  92. return Controller;
  93. });