sysLogAgent.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. app.controller('sysLogAgentCtrl', ['$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: 'time', displayName: '操作时间'},
  29. {
  30. field: 'nickname', displayName: '用户信息',
  31. cellTemplate: '<div class="temp-row ">{{row.entity.nickname + " ("+row.entity.username+ ")"}}</div>'
  32. },
  33. {field: 'ip', displayName: 'IP地址'},
  34. {field: 'address', displayName: '地理位置'},
  35. {field: 'description', minWidth: 500, displayName: '操作内容'},
  36. ];
  37. var fields = $scope.gridOptions.columnDefs;
  38. for (var index in fields) {
  39. var item = fields[index];
  40. if (item && item['minWidth'] == null) {
  41. item['minWidth'] = 100;
  42. }
  43. }
  44. }
  45. $scope.setPagingData = function (data, curPage, pageSize) {
  46. var pagedData = data.data.dataList;
  47. $scope.myData = pagedData;
  48. $scope.gridOptions.totalItems = data.data.total;
  49. };
  50. $scope.getPagedDataAsync = function (curPage, pageSize) {
  51. var params = {
  52. pageSize: pageSize,
  53. pageIndex: curPage
  54. };
  55. if ($scope.$parent.$parent.query) {
  56. var query = $scope.$parent.$parent.query
  57. params.startTime = query.startTime
  58. params.endTime = query.endTime
  59. params.searchKey = query.searchKey
  60. }
  61. $http.get('/superadmin/getAgentLog', {
  62. params: params
  63. }).then(function (data) {
  64. data = data.data
  65. $scope.setPagingData(data, curPage, pageSize);
  66. }).catch(function (data) {
  67. toaster.pop("error", "提示", "获取明细失败");
  68. });
  69. };
  70. function initDataGrid() {
  71. //首次加载表格
  72. $scope.getPagedDataAsync($scope.gridOptions.paginationCurrentPage, $scope.gridOptions.paginationPageSize);
  73. }
  74. setColumnDefs();
  75. initDataGrid();
  76. // 父路由查询后刷新表格
  77. $scope.$on('refreshTableData', function (evt) {
  78. $scope.getPagedDataAsync(1, $scope.gridOptions.paginationPageSize);
  79. });
  80. }]);