address.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  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: 'shop/address/index' + location.search,
  8. add_url: 'shop/address/add',
  9. edit_url: 'shop/address/edit',
  10. del_url: 'shop/address/del',
  11. multi_url: 'shop/address/multi',
  12. import_url: 'shop/address/import',
  13. table: 'shop_address',
  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. columns: [
  23. [
  24. {checkbox: true},
  25. {field: 'id', title: __('Id')},
  26. {
  27. field: 'user.username',
  28. title: __('User'),
  29. operate: 'LIKE',
  30. formatter: function (value, row, index) {
  31. // 显示用户头像和用户名
  32. var avatar = row.user && row.user.avatar ? row.user.avatar : '/assets/img/avatar.png';
  33. var username = row.user && row.user.username ? row.user.username : '游客';
  34. var userId = row.user_id || '';
  35. // 处理头像URL
  36. var avatarUrl = avatar;
  37. if (avatar && !avatar.startsWith('http') && !avatar.startsWith('//')) {
  38. avatarUrl = Fast.api.cdnurl ? Fast.api.cdnurl(avatar) : avatar;
  39. }
  40. return '<div style="display:flex;align-items:center;">' +
  41. '<img src="' + avatarUrl + '" style="width:40px;height:40px;border-radius:50%;margin-right:10px;" />' +
  42. '<div>' +
  43. '<div style="color:#337ab7;font-weight:bold;">' + username + '</div>' +
  44. '<div style="color:#999;font-size:12px;">ID: ' + userId + '</div>' +
  45. '</div>' +
  46. '</div>';
  47. }
  48. },
  49. {field: 'province.name', title: __('Province')},
  50. {field: 'city.name', title: __('City')},
  51. {field: 'area.name', title: __('Area')},
  52. {field: 'receiver', title: __('Receiver'), operate: 'LIKE'},
  53. {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
  54. {field: 'address', title: __('Address'), operate: 'LIKE'},
  55. // {field: 'zipcode', title: __('Zipcode'), operate: 'LIKE', visible: false},
  56. {field: 'used_nums', title: __('Usednums')},
  57. {field: 'createtime', title: __('Createtime'), operate: 'RANGE', addclass: 'datetimerange', autocomplete: false, formatter: Table.api.formatter.datetime},
  58. {field: 'updatetime', title: __('Updatetime'), operate: 'RANGE', addclass: 'datetimerange', autocomplete: false, formatter: Table.api.formatter.datetime},
  59. {
  60. field: 'is_default',
  61. title: __('Isdefault'),
  62. searchList: Controller.api.parseConfigJson('isdefaultList'),
  63. table: table,
  64. formatter: Table.api.formatter.toggle
  65. },
  66. {field: 'status', title: __('Status'), searchList: Controller.api.parseConfigJson('statusList'), formatter: Table.api.formatter.status},
  67. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  68. ]
  69. ]
  70. });
  71. // 为表格绑定事件
  72. Table.api.bindevent(table);
  73. },
  74. recyclebin: function () {
  75. // 初始化表格参数配置
  76. Table.api.init({
  77. extend: {
  78. 'dragsort_url': ''
  79. }
  80. });
  81. var table = $("#table");
  82. // 初始化表格
  83. table.bootstrapTable({
  84. url: 'shop/address/recyclebin' + location.search,
  85. pk: 'id',
  86. sortName: 'id',
  87. columns: [
  88. [
  89. {checkbox: true},
  90. {field: 'id', title: __('Id')},
  91. {field: 'title', title: __('Title'), align: 'left'},
  92. {
  93. field: 'deletetime',
  94. title: __('Deletetime'),
  95. operate: 'RANGE',
  96. addclass: 'datetimerange',
  97. formatter: Table.api.formatter.datetime
  98. },
  99. {
  100. field: 'operate',
  101. width: '130px',
  102. title: __('Operate'),
  103. table: table,
  104. events: Table.api.events.operate,
  105. buttons: [
  106. {
  107. name: 'Restore',
  108. text: __('Restore'),
  109. classname: 'btn btn-xs btn-info btn-ajax btn-restoreit',
  110. icon: 'fa fa-rotate-left',
  111. url: 'shop/address/restore',
  112. refresh: true
  113. },
  114. {
  115. name: 'Destroy',
  116. text: __('Destroy'),
  117. classname: 'btn btn-xs btn-danger btn-ajax btn-destroyit',
  118. icon: 'fa fa-times',
  119. url: 'shop/address/destroy',
  120. refresh: true
  121. }
  122. ],
  123. formatter: Table.api.formatter.operate
  124. }
  125. ]
  126. ]
  127. });
  128. // 为表格绑定事件
  129. Table.api.bindevent(table);
  130. },
  131. add: function () {
  132. Controller.api.bindevent();
  133. },
  134. edit: function () {
  135. Controller.api.bindevent();
  136. },
  137. api: {
  138. // 解析Config中的JSON字符串的辅助函数
  139. parseConfigJson: function(configKey, defaultValue) {
  140. var configValue = Config[configKey] || defaultValue || {};
  141. // 如果是字符串,尝试解析JSON
  142. if (typeof configValue === 'string') {
  143. try {
  144. return JSON.parse(configValue);
  145. } catch (e) {
  146. return defaultValue || {};
  147. }
  148. }
  149. return configValue;
  150. },
  151. bindevent: function () {
  152. Form.api.bindevent($("form[role=form]"));
  153. }
  154. }
  155. };
  156. return Controller;
  157. });