inspectCtrl.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('inspectCtrl', ["$rootScope","$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_schedule", "api_bpm_data",function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_schedule,api_bpm_data) {
  6. $scope.langs=i18nService.getAllLangs();
  7. $scope.lang = 'zh-cn';
  8. i18nService.setCurrentLang($scope.lang);
  9. var loginUser=$rootScope.user;
  10. $scope.gridOptions = {};
  11. $scope.gridOptions.data = 'myData';
  12. $scope.gridOptions.enableColumnResizing = true;
  13. $scope.gridOptions.enableFiltering = true;
  14. $scope.gridOptions.enableGridMenu = false;
  15. $scope.gridOptions.enableRowSelection = true;
  16. $scope.gridOptions.showGridFooter = true;
  17. $scope.gridOptions.showColumnFooter = false;
  18. $scope.gridOptions.fastWatch = true;
  19. $scope.gridOptions.useExternalFiltering=true;
  20. $scope.gridOptions.useExternalPagination = true;
  21. $scope.gridOptions.paginationPageSizes = [10];
  22. $scope.gridOptions.paginationPageSize = 10;
  23. $scope.gridOptions.multiSelect = true;
  24. //$scope.gridOptions.rowTemplate= "<div ng-dblclick=\"grid.appScope.onDblClick(row)\" ng-repeat=\"(colRenderIndex, col) in colContainer.renderedColumns track by col.uid\" ui-grid-one-bind-id-grid=\"rowRenderIndex + '-' + col.uid + '-cell'\" class=\"ui-grid-cell\" ng-class=\"{ 'ui-grid-row-header-cell': col.isRowHeader }\" role=\"{{col.isRowHeader ? 'rowheader' : 'gridcell'}}\" ui-grid-cell></div>";
  25. $scope.gridOptions.rowIdentity = function(row) {
  26. return row.id;
  27. };
  28. $scope.gridOptions.getRowIdentity = function(row) {
  29. return row.id;
  30. };
  31. // $scope.transfer= function(deleteFlag){
  32. // if(deleteFlag==true){return "是"}
  33. // else {return "否"}
  34. // }
  35. $scope.gridOptions.columnDefs = [
  36. { name:'item', displayName:'序号', width:50, enableFiltering:false},
  37. { name:'查看', width:60, enableFiltering:false,cellTemplate:'<div class="links cl-effect-1">' +
  38. '<a ng-click="grid.appScope.lookFunction(row.entity)" tooltip="查看" tooltip-placement="left"><i class="ti-eye"></i></a>'+
  39. '</div>' },
  40. { name:'修改', cellTemplate:'<div class="links cl-effect-1"><a ng-click="grid.appScope.selectRowFunction(row.entity)" tooltip="编辑">' +
  41. '<i class="fa fa-pencil-square-o"/></a></div>' , width:60,enableFiltering:false},
  42. { name:'title', displayName:'计划主题', width:200, enableFiltering:false},
  43. { name:'planTime1', displayName:'执行时间', width:100, enableFiltering:false},
  44. { name:'executeUser.name', displayName:'执行人', width:100, enableFiltering:false},
  45. { name:'createTime', displayName:'计划创建时间', width:100, enableFiltering:false}
  46. ];
  47. $scope.addData = function(){
  48. $state.go('app.inspection.editor',{formKey:'inspectionform',service:'api_bpm_data'});
  49. }
  50. $scope.selectRowFunction = function(data){
  51. var datas=delete data.item
  52. var filedata = {
  53. model : {
  54. inspection : data
  55. }
  56. };
  57. $state.go('app.inspection.editor',{formKey:'inspectionform',service:'api_bpm_data',model : JSON.stringify(filedata)});
  58. };
  59. $scope.lookFunction = function(data){
  60. var filedata = {
  61. model : {
  62. inspection : data
  63. }
  64. };
  65. $state.go('app.inspection.form',{formKey:'inspectionform',service:'api_bpm_data',model : JSON.stringify(filedata)});
  66. };
  67. $scope.removeData = function(){
  68. // var rmvList = [$scope.selected.items.id]
  69. var rmvList = [];
  70. angular.forEach($scope.selected.items,function(item){
  71. rmvList.push(item.id);
  72. });
  73. if(rmvList.length>0){
  74. api_bpm_data.rmvData('inspection',rmvList).then(function(response){
  75. if(response.status==200){
  76. SweetAlert.swal({
  77. title: "删除成功!",
  78. type: "success",
  79. confirmButtonColor: "#007AFF"
  80. },function(){
  81. $scope.myData = _.reject($scope.myData, function(o) { return _.includes(rmvList,o.id); });
  82. $scope.selected = {
  83. items:[]
  84. };
  85. });
  86. }else{
  87. SweetAlert.swal({
  88. title: "操作异常!",
  89. text: "系统异常,请稍后重试,或者联系管理员!",
  90. type: "error"
  91. });
  92. }
  93. })
  94. }
  95. }
  96. $scope.selected = {
  97. items:[]
  98. }
  99. $scope.editted = {
  100. items:[]
  101. }
  102. $scope.gridOptions.onRegisterApi = function(gridApi){
  103. // $scope.gridApi = gridApi;
  104. // gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  105. // console.log(rowEntity);
  106. // });
  107. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  108. var filtersData = $scope.memoryfilterData;
  109. filtersData.idx=newPage-1;
  110. filtersData.sum=pageSize;
  111. $scope.refreshData('expand-right',filtersData);
  112. });
  113. gridApi.selection.on.rowSelectionChanged($scope, function(data){
  114. data.grid.appScope.selected.items=data.entity
  115. });
  116. }
  117. var defaultFilterData = {
  118. "idx":0,
  119. "sum":10
  120. };
  121. $scope.memoryfilterData = {
  122. "idx":0,
  123. "sum":10
  124. }
  125. $scope.ldloading = {};
  126. $scope.refreshData = function(style,filterData){
  127. $scope.ldloading[style.replace('-', '_')] = true;
  128. if(angular.isUndefined(filterData)){
  129. filterData = defaultFilterData;
  130. }
  131. $scope.myData = [];
  132. api_bpm_data.fetchDataList('inspection',filterData).then(function(data){
  133. var myData = Restangular.stripRestangular(data);
  134. $scope.gridOptions.totalItems = myData.totalNum;
  135. $scope.myData = myData.list;
  136. for(var i=0;i<$scope.myData.length;i++){
  137. $scope.myData[i]['item']=i+1+filterData.idx*filterData.sum
  138. }
  139. $scope.ldloading[style.replace('-', '_')] = false;
  140. },function(){
  141. $scope.ldloading[style.replace('-', '_')] = false;
  142. });
  143. };
  144. $scope.refreshData('expand-right', defaultFilterData);
  145. }]);