businessStatsConsumption.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. app.controller('businessStatsConsumptionCtrl', ['$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: 'userNickname', displayName: '用户昵称'},
  30. {field: 'dealerName', displayName: '所属经销商'},
  31. {field: 'agentName', displayName: '所属代理商'},
  32. {field: 'groupName', displayName: '地址名称'},
  33. {field: 'logicalCode', displayName: '设备编号'},
  34. {field: 'devType', displayName: '设备类型'},
  35. {
  36. field: 'coins', displayName: '付款币数',
  37. cellTemplate: '<div class="temp-row text-dark-dker text-md" ng-bind="row.entity.coins"></div>'
  38. },
  39. {
  40. field: 'createdTime', displayName: '消费日期',
  41. cellTemplate: '<div class="temp-row" ng-bind="row.entity.createdTime| date:\'yyyy-MM-dd HH:mm:ss\'"></div>'
  42. },
  43. ];
  44. var fields = $scope.gridOptions.columnDefs;
  45. for (var index in fields) {
  46. var item = fields[index];
  47. if (item && item['minWidth'] == null) {
  48. item['minWidth'] = 100;
  49. }
  50. }
  51. }
  52. $scope.setPagingData = function (data, curPage, pageSize) {
  53. var pagedData = data.data.dataList;
  54. $scope.myData = pagedData;
  55. $scope.gridOptions.totalItems = data.data.total;
  56. };
  57. $scope.getPagedDataAsync = function (curPage, pageSize) {
  58. var params = {
  59. pageSize: pageSize,
  60. pageIndex: curPage
  61. };
  62. if ($scope.$parent.$parent.query) {
  63. var query = $scope.$parent.$parent.query
  64. params.agentId = query.agent.id
  65. params.dealerId = query.dealer.value
  66. params.startTime = query.startTime
  67. params.endTime = query.endTime
  68. }
  69. $http.get('/manager/getConsumptionRecord', {
  70. params: params
  71. }).then(function (data) {
  72. $scope.setPagingData(data.data, curPage, pageSize);
  73. }).catch(function (data) {
  74. toaster.pop("error", "提示", "获取明细失败");
  75. });
  76. };
  77. function initDataGrid() {
  78. //首次加载表格
  79. $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
  80. }
  81. setColumnDefs();
  82. initDataGrid();
  83. // 父路由查询后刷新表格
  84. $scope.$on('refreshTableData', function (evt) {
  85. $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize);
  86. });
  87. }]);