app.controller('insuranceOrderCtrl', ['$scope', '$filter', '$http', '$stateParams', '$timeout', 'uiGridConstants', 'i18nService', 'toaster', function ($scope, $filter, $http, $stateParams, $timeout, uiGridConstants, i18nService, toaster,) { i18nService.setCurrentLang("zh-cn"); moment.locale('zh-cn'); $scope.startTimeOpen = false; $scope.endTimeOpen = false; $scope.timeChange = function (newDate, oldDate) { $scope.startTimeOpen = false; $scope.endTimeOpen = false; }; $scope.gridOptions = { data: 'myData', showGridFooter: true, //是否显示grid footer // rowHeight: 80, //-------- 分页属性 ---------------- paginationPageSizes: [10, 20, 50, 100], //每页显示个数可选项 paginationCurrentPage: 1, //当前页码 paginationPageSize: 10, //每页显示个数 totalItems: 0,// 总数量 useExternalPagination: true,//是否使用分页按钮 //过滤 // enableFiltering: true, columnDefs: [], //---------------api--------------------- onRegisterApi: function (gridApi) { $scope.gridApi = gridApi; gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) { if ($scope.setPagingData) { $scope.getPagedDataAsync(newPage, pageSize, true);//翻页是强制刷新 } }); } }; //查询条件 var condition = $scope.condition = { searchKey: '', }; //查询条件 $scope.query = { startTime: moment().format("YYYY-MM-DD"), endTime: moment().format("YYYY-MM-DD"), }; //事件 $scope.event = { search: function () { $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize); }, }; function setColumnDefs() { $scope.gridOptions.columnDefs = [ { field: 'openId', displayName: '用户openId', }, { field: 'price', displayName: '保单金额', }, { field: 'dealerName', displayName: '经销商', }, { field: 'userNickname', displayName: '用户昵称', }, { field: 'devNo', displayName: '设备IMEI', }, { field: 'logicalCode', displayName: '设备逻辑号', }, { field: 'groupName', displayName: '地址分组名', }, { field: 'startTime', displayName: '有效起始时间', }, { field: 'endTime', displayName: '有效终止时间', }, { field: 'dateTimeAdded', displayName: '投保时间', }, { field: "via", displayName: "订单类型" }, { field: "refunded", displayName: "是否退款" }, { field: 'operation', displayName: '操作', enableFiltering: false, enableSorting: false, enableHiding: false,//禁止在列选择器中隐藏 enableColumnMenu: false,// 是否显示列头部菜单按钮 minWidth: 100, cellTemplate: '
' }, ]; var fields = $scope.gridOptions.columnDefs; for (var index in fields) { var item = fields[index]; if (item && item['minWidth'] == null) { item['minWidth'] = 100; } } } $scope.setPagingData = function (data) { var pagedData = data.data.dataList; $scope.myData = pagedData; $scope.gridOptions.totalItems = data.data.total; }; $scope.getPagedDataAsync = function (curPage, pageSize,) { if ($scope.gridOptionsLoading) { return; } var params = { pageSize: pageSize, pageIndex: curPage, }; params.outTradeNo = condition.searchKey $scope.gridOptionsLoading = true; $http.get('/superadmin/getInsuranceOrder', { params: params }).then(function (data) { data = data.data $scope.gridOptionsLoading = false; $scope.setPagingData(data, curPage, pageSize); }).catch(function (data) { toaster.pop("error", "提示", "获取数据列表失败"); }); }; function initDataGrid() { //首次加载表格 $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize); } setColumnDefs(); initDataGrid(); $scope.refund = function (entity) { var url = "/superadmin/refundInsuranceOrder"; $.confirm({ content: '确定退款处理?', buttons: { ok: { btnClass: 'btn-red', action: function () { $http({ method: 'POST', url: url, data: { id: entity.id, } }).then(function (response) { if (response.data.result) { toaster.pop("success", "提示", "提交成功!"); } else { toaster.pop("error", "提示", "提交失败!"); } $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize); }, function () { toaster.pop("error", "提示", "提交失败!"); }); } }, } }); }; }]);