serverslevelCtrl.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('serverslevelCtrl', ["$rootScope","$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_data", function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, 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 = false;
  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. var priorityname={};
  32. var names={};
  33. // $scope.transfer= function(name){
  34. // api_bpm_data.fetchDataList('priority',fildDate).then(function(response){
  35. // priorityname = Restangular.stripRestangular(response).list;
  36. // angular.forEach(priorityname,function(item){
  37. // if(item.level==name){
  38. // names=item.level;
  39. // }
  40. // })
  41. // })
  42. // }
  43. $scope.gridOptions.columnDefs = [
  44. { name:'priority.name', displayName:'优先级', width:100, enableFiltering:false},
  45. { name:'resolveTime', displayName:'解决时间(分钟)', width:300, enableFiltering:false},
  46. { name:'responseTime', displayName:'响应时间(分钟)', width:200, enableFiltering:false},
  47. { name:'修改', cellTemplate:'<a class="btn btn-sm btn-info" ng-click="grid.appScope.timedata(row.entity)" tooltip="编辑">' +
  48. '<i class="fa fa-pencil-square-o"/></a>' , width:100,enableFiltering:false}
  49. ];
  50. $scope.timedata = function(selectdatas){
  51. var modalInstance = $modal.open({
  52. templateUrl: 'assets/views/system/tpl/serverschange.html',
  53. controller: function($scope, $modalInstance, api_bpm_data){
  54. $scope.serverdata=selectdatas;
  55. $scope.cancel = function() {
  56. $modalInstance.dismiss('cancel');
  57. };
  58. $scope.changetime = function(servertime){
  59. var fildata={"servicelevelagreement":{"id":servertime.id,"resolveTime":servertime.resolveTime,"responseTime":servertime.responseTime,"availabilityDate":"2016-09-01","terminationDate":"2016-09-28","priority":{"id":servertime.priority.id,"level":servertime.priority.level}}}
  60. api_bpm_data.updData('servicelevelagreement',fildata).then(function(response){
  61. if(response){
  62. if(response.status==200){
  63. SweetAlert.swal({
  64. title:"修改成功!",
  65. type:"success"
  66. },function(){
  67. console.log($scope.serverdata)
  68. })
  69. }else{
  70. SweetAlert.swal({
  71. title:"修改失败!",
  72. type:"error"
  73. })
  74. }
  75. $modalInstance.close();
  76. }
  77. })
  78. }
  79. }
  80. });
  81. }
  82. // $scope.addData = function(){
  83. // console.log($scope.selected)
  84. // var modalInstance = $modal.open({
  85. // templateUrl: 'assets/views/system/tpl/systemclose.html',
  86. // controller: function($scope, $modalInstance, api_bpm_data){
  87. // $scope.options = {
  88. // language: 'zh-cn',
  89. // allowedContent: true,
  90. // entities: false
  91. // };
  92. // $scope.cancel = function() {
  93. // $modalInstance.dismiss('cancel');
  94. // };
  95. // $scope.savercode = function(closedata){
  96. // console.log(closedata)
  97. // $modalInstance.close();
  98. // }
  99. // },
  100. // size:'lg'
  101. // });
  102. // }
  103. $scope.selected = {
  104. items:[]
  105. }
  106. $scope.editted = {
  107. items:[]
  108. }
  109. $scope.gridOptions.onRegisterApi = function(gridApi){
  110. $scope.gridApi = gridApi;
  111. // gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  112. // console.log(rowEntity);
  113. // });
  114. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  115. var filtersData = $scope.memoryfilterData;
  116. filtersData.idx=newPage-1;
  117. filtersData.sum=pageSize;
  118. $scope.refreshData('expand-right',filtersData);
  119. });
  120. gridApi.selection.on.rowSelectionChanged($scope, function(scope){
  121. });
  122. };
  123. var defaultFilterData = {
  124. "idx":0,
  125. "sum":10
  126. };
  127. $scope.memoryfilterData = {
  128. "idx":0,
  129. "sum":10
  130. }
  131. $scope.ldloading = {};
  132. $scope.refreshData = function(style,filterData){
  133. $scope.ldloading[style.replace('-', '_')] = true;
  134. if(angular.isUndefined(filterData)){
  135. filterData = defaultFilterData;
  136. }
  137. $scope.myData = [];
  138. api_bpm_data.fetchDataList('servicelevelagreement',filterData).then(function(data){
  139. var myData = Restangular.stripRestangular(data);
  140. $scope.gridOptions.totalItems = myData.totalNum;
  141. $scope.myData = myData.list;
  142. $scope.ldloading[style.replace('-', '_')] = false;
  143. },function(){
  144. $scope.ldloading[style.replace('-', '_')] = false;
  145. });
  146. };
  147. $scope.refreshData('expand-right', defaultFilterData);
  148. }]);