businessStatsChargeCard.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. app.controller('businessStatsChargeCardCtrl', ['$scope', '$http', '$timeout', '$state', '$interval', 'uiGridConstants', 'i18nService', 'toaster', function ($scope, $http, $timeout, $state, $interval, uiGridConstants, i18nService, toaster) {
  2. $scope.gridOptions = {
  3. data: 'myData',
  4. showGridFooter: true, //是否显示grid footer
  5. //-------- 分页属性 ----------------
  6. paginationPageSizes: [10, 20, 50, 100], //每页显示个数可选项
  7. paginationCurrentPage: 1, //当前页码
  8. paginationPageSize: 10, //每页显示个数
  9. totalItems: 0,// 总数量
  10. useExternalPagination: true,//是否使用分页按钮
  11. //过滤
  12. enableFiltering: false,
  13. columnDefs: [],
  14. // 菜单
  15. enableGridMenu: true,
  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);
  22. }
  23. });
  24. }
  25. };
  26. function setColumnDefs() {
  27. $scope.gridOptions.columnDefs = [
  28. {field: 'orderNo', displayName: '系统单号'},
  29. {field: 'gatewayOrderNo', displayName: '支付单号'},
  30. {field: 'cardNo', displayName: '卡号'},
  31. {field: 'userNickname', displayName: '用户昵称'},
  32. {field: 'dealerName', displayName: '所属经销商'},
  33. {field: 'agentName', displayName: '所属代理商'},
  34. {field: 'groupName', displayName: '地址名称'},
  35. {field: 'logicalCode', displayName: '设备编号'},
  36. {field: 'devType', displayName: '设备类型'},
  37. {
  38. field: 'chargeMoney', displayName: '充值金额',
  39. cellTemplate: '<div class="temp-row text-dark-dker text-md" ng-bind="row.entity.chargeMoney | currency:\'¥\'"></div>'
  40. },
  41. {
  42. field: 'chargeTime', displayName: '充值日期',
  43. cellTemplate: '<div class="temp-row" ng-bind="row.entity.chargeTime| date:\'yyyy-MM-dd HH:mm:ss\'"></div>'
  44. },
  45. ];
  46. var fields = $scope.gridOptions.columnDefs;
  47. for (var index in fields) {
  48. var item = fields[index];
  49. if (item && item['minWidth'] == null) {
  50. item['minWidth'] = 100;
  51. }
  52. }
  53. }
  54. $scope.setPagingData = function (data, curPage, pageSize) {
  55. var pagedData = data.data.dataList;
  56. $scope.myData = pagedData;
  57. $scope.gridOptions.totalItems = data.data.total;
  58. };
  59. $scope.getPagedDataAsync = function (curPage, pageSize) {
  60. var params = {
  61. pageSize: pageSize,
  62. pageIndex: curPage
  63. };
  64. if ($scope.$parent.$parent.query) {
  65. var query = $scope.$parent.$parent.query
  66. params.agentId = query.agent.id
  67. params.dealerId = query.dealer.value
  68. params.startTime = query.startTime
  69. params.endTime = query.endTime
  70. }
  71. $http.get('/manager/getRechargeCardRecords', {
  72. params: params
  73. }).then(function (data) {
  74. $scope.setPagingData(data.data, curPage, pageSize);
  75. }).catch(function (data) {
  76. toaster.pop("error", "提示", "获取明细失败");
  77. });
  78. };
  79. function initDataGrid() {
  80. //首次加载表格
  81. $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
  82. }
  83. setColumnDefs();
  84. initDataGrid();
  85. // 父路由查询后刷新表格
  86. $scope.$on('refreshTableData', function (evt) {
  87. $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize);
  88. });
  89. }]);