userConsume.js 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. app.controller('userConsumeCtrl', ['$scope', '$filter', '$http', '$stateParams', '$timeout', 'uiGridConstants', 'i18nService', 'toaster', function ($scope, $filter, $http, $stateParams, $timeout, uiGridConstants, i18nService, toaster,) {
  2. i18nService.setCurrentLang("zh-cn");
  3. $scope.gridOptions = {
  4. data: 'myData',
  5. showGridFooter: true, //是否显示grid footer
  6. // rowHeight: 80,
  7. //-------- 分页属性 ----------------
  8. paginationPageSizes: [10, 20, 50, 100], //每页显示个数可选项
  9. paginationCurrentPage: 1, //当前页码
  10. paginationPageSize: 10, //每页显示个数
  11. totalItems: 0,// 总数量
  12. useExternalPagination: true,//是否使用分页按钮
  13. //过滤
  14. // enableFiltering: true,
  15. columnDefs: [],
  16. //---------------api---------------------
  17. onRegisterApi: function (gridApi) {
  18. $scope.gridApi = gridApi;
  19. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  20. if ($scope.setPagingData) {
  21. $scope.getPagedDataAsync(newPage, pageSize, true);//翻页是强制刷新
  22. }
  23. });
  24. }
  25. };
  26. function getOneRow() {
  27. var rows = $scope.gridApi.selection.getSelectedRows();
  28. if (rows.length === 0) {
  29. toaster.pop("info", "提示", "请选择数据!");
  30. return false;
  31. }
  32. if (rows.length > 1) {
  33. toaster.pop("info", "提示", "只能选中编辑一条数据");
  34. return false;
  35. }
  36. return rows[0]
  37. }
  38. //枚举常量
  39. $scope.enum = {};
  40. var searchType = $scope.enum.searchType = [
  41. {value: 'wxOrderNo', label: "按订单编号查询充值订单", desc: '输入订单编号'},
  42. {value: 'orderNo', label: "按交易编号查询充值订单", desc: '输入交易编号'},
  43. {value: 'consumeOrderNo', label: "按消费编号查询消费订单", desc: '输入消费订单'},
  44. {value: 'logicalCodeRecharge', label: "按设备编号查询充值订单", desc: '输入设备编号'},
  45. {value: 'logicalCodeConsume', label: "按设备编号查询消费订单", desc: '输入设备编号'},
  46. ];
  47. //查询条件
  48. var condition = $scope.condition = {
  49. searchType: searchType[0],
  50. searchKey: '',
  51. };
  52. //事件
  53. $scope.event = {
  54. statusChange: function (key, item) {
  55. condition[key] = {}
  56. condition[key].value = item.value;
  57. condition[key].label = item.label;
  58. condition[key].desc = item.desc;
  59. },
  60. search: function () {
  61. // 就在当前 厂商|代理商|经销商的域下进行搜索
  62. if (condition.searchKey === "") {
  63. $.confirm({
  64. content: '条件为空,数据量较大,确定继续?',
  65. buttons: {
  66. ok: {
  67. text: '搜索',
  68. action: function () {
  69. $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize, true);
  70. }
  71. },
  72. }
  73. });
  74. } else {
  75. $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize);
  76. }
  77. },
  78. refundCash: function () {
  79. var entity = getOneRow();
  80. if (!entity) {
  81. return
  82. }
  83. $.confirm({
  84. content: `输入退费金额:<input type="text" value="${entity.money}" id="refundMoney" placeholder="输入退费金额"/>`,
  85. buttons: {
  86. ok: {
  87. btnClass: 'btn-red',
  88. action: function () {
  89. var refundMoney = $('#refundMoney').val()
  90. if(!refundMoney){
  91. return false
  92. }
  93. $http({
  94. method: 'POST',
  95. url: '/superadmin/refundCashFromRecharge',
  96. data: {money: refundMoney, orderNo: entity.orderNo}
  97. }).then(function (response) {
  98. if (response.data.result) {
  99. toaster.pop("success", "提示", "退费成功!");
  100. } else {
  101. toaster.pop("error", "提示", "退费失败!");
  102. }
  103. }, function (response) {
  104. toaster.pop("error", "提示", "操作失败!");
  105. });
  106. }
  107. },
  108. }
  109. });
  110. },
  111. };
  112. function setColumnDefs() {
  113. $scope.gridOptions.columnDefs = [
  114. {
  115. field: 'wxOrderNo',
  116. displayName: '订单编号',
  117. cellTemplate: '<div class="temp-row" >{{row.entity.wxOrderNo}}</div>'
  118. },
  119. {
  120. field: 'orderNo',
  121. displayName: '交易编号',
  122. cellTemplate: '<div class="temp-row" >{{row.entity.orderNo}}</div>'
  123. },
  124. {
  125. field: 'orderResult', displayName: '订单状态',
  126. },
  127. {field: 'rechargeUser', displayName: '充值客户',},
  128. {field: 'rechargeType', displayName: '充值类型',},
  129. {field: 'money', displayName: '支付金额',},
  130. {field: 'coins', displayName: '购买金币',},
  131. {
  132. field: 'orderDetail',
  133. displayName: '订单明细',
  134. cellTemplate: '<div class="temp-row" ng-click="grid.appScope.showInfoDetailInfo(\'订单明细\',\'orderDetail\',row.entity)" >{{row.entity.orderDetail}}</div>'
  135. },
  136. {field: 'orderCreateTime', displayName: '订单创建时间',},
  137. {field: 'logicalCode', displayName: '设备编号',},
  138. {field: 'devNo', displayName: '设备IMEI',},
  139. {field: 'devTypeCode', displayName: '设备类型',},
  140. {field: 'consumeOrderNo', displayName: '消费订单编号',},
  141. {field: 'consumeUser', displayName: '消费客户',},
  142. {field: 'consumeCoins', displayName: '消费金币',},
  143. {field: 'consumeResult', displayName: '消费订单状态',},
  144. {field: 'failedReason', displayName: '消费失败原因',},
  145. {field: 'consumeOrderCreateTime', displayName: '消费订单创建时间',},
  146. {
  147. field: 'consumeDetail',
  148. displayName: '消费明细',
  149. cellTemplate: '<div class="temp-row" ng-click="grid.appScope.showInfoDetailInfo(\'消费明细\',\'consumeDetail\',row.entity)" >{{row.entity.consumeDetail}}</div>'
  150. },
  151. {
  152. field: 'consumeDict',
  153. displayName: '消费详情',
  154. cellTemplate: '<div class="temp-row" ng-click="grid.appScope.showInfoDetailInfo(\'消费详情\',\'consumeDict\',row.entity)" >{{row.entity.consumeDict}}</div>'
  155. },
  156. ];
  157. var fields = $scope.gridOptions.columnDefs;
  158. for (var index in fields) {
  159. var item = fields[index];
  160. if (item && item['minWidth'] == null) {
  161. item['minWidth'] = 100;
  162. }
  163. }
  164. }
  165. $scope.setPagingData = function (data) {
  166. var pagedData = data.data.dataList;
  167. $scope.myData = pagedData;
  168. $scope.gridOptions.totalItems = data.data.total;
  169. };
  170. $scope.getPagedDataAsync = function (curPage, pageSize, force) {
  171. if ($scope.gridOptionsLoading) {
  172. return;
  173. }
  174. var params = {
  175. pageSize: pageSize,
  176. pageIndex: curPage,
  177. };
  178. if (condition.searchType.value !== '') {
  179. params.searchType = condition.searchType.value
  180. }
  181. if (condition.searchKey !== "") {
  182. params.searchKey = condition.searchKey
  183. }
  184. // 如果没有条件,则不查询,因为数据量太大,加载太卡!
  185. if (force) {
  186. // nothing
  187. } else if (!params.searchKey) {
  188. toaster.pop("info", "温馨提示", "请输入查询条件进行查询");
  189. return
  190. }
  191. $scope.gridOptionsLoading = true;
  192. $http.get('/superadmin/getOrderDetailList', {
  193. params: params
  194. }).then(function (data) {
  195. data = data.data
  196. $scope.gridOptionsLoading = false;
  197. $scope.setPagingData(data, curPage, pageSize);
  198. }).catch(function (data) {
  199. toaster.pop("error", "提示", "获取数据列表失败");
  200. });
  201. };
  202. function initDataGrid() {
  203. //首次加载表格
  204. $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
  205. }
  206. setColumnDefs();
  207. initDataGrid();
  208. $scope.showInfoDetailInfo = function (title, key, content) {
  209. var detail = content[key]
  210. $scope.infoDetail = {title: title, content: detail};
  211. $(".devManageMain #detailInfoPanel").modal();
  212. };
  213. $scope.closeDetailPanel = function () {
  214. $(".devManageMain #detailInfoPanel").modal("hide");
  215. };
  216. }]);