cmdbplan.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('cmdbplanCtrl', ["$rootScope","$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_configure_data", function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_configure_data) {
  6. $scope.langs=i18nService.getAllLangs();
  7. $scope.lang = 'zh-cn';
  8. i18nService.setCurrentLang($scope.lang);
  9. var loginUser=$rootScope.user;
  10. //$scope.allright=false;
  11. //$scope.allrightnot=true;
  12. $scope.gridOptions = {};
  13. $scope.gridOptions.data = 'myData';
  14. $scope.gridOptions.enableColumnResizing = true;
  15. $scope.gridOptions.enableFiltering = true;
  16. $scope.gridOptions.enableGridMenu = false;
  17. $scope.gridOptions.enableRowSelection = true;
  18. $scope.gridOptions.showGridFooter = true;
  19. $scope.gridOptions.showColumnFooter = false;
  20. $scope.gridOptions.fastWatch = true;
  21. $scope.gridOptions.useExternalFiltering=true;
  22. $scope.gridOptions.useExternalPagination = true;
  23. $scope.gridOptions.paginationPageSizes = [10];
  24. $scope.gridOptions.paginationPageSize = 10;
  25. $scope.gridOptions.multiSelect = true;
  26. //$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>";
  27. $scope.gridOptions.rowIdentity = function(row) {
  28. return row.id;
  29. };
  30. $scope.gridOptions.getRowIdentity = function(row) {
  31. return row.id;
  32. };
  33. $scope.transferRole = function(roles){
  34. var tempValue="";
  35. angular.forEach(roles,function(item){
  36. if(tempValue!=""){
  37. tempValue = tempValue + "/" ;
  38. }
  39. tempValue = tempValue + item.role;
  40. })
  41. return tempValue;
  42. }
  43. //remote data
  44. $scope.gridOptions.columnDefs = [
  45. { name:'category', displayName:'分类', width:100,enableFiltering:false},
  46. { name:'state', displayName:'状态', width:140, enableFiltering:false},
  47. { name:'cmdb', displayName:'配置项关系', width:100, enableFiltering:false},
  48. // { name:'closecode', displayName:'关闭代码', width:100, enableFiltering:false},
  49. // { name:'parent.title', displayName:'服务级别协议', width:100,enableFiltering:false},
  50. // { name:'parent.title', displayName:'业务规则', width:100,enableFiltering:false},
  51. // { name:'role', cellTemplate:'<div class="ui-grid-cell-contents">{{grid.appScope.transferRole(row.entity.role)}}</div>', displayName:'角色', width:140},
  52. { name:'编辑', cellTemplate:'<a class="btn btn-sm btn-info" ng-click="grid.appScope.saveData(row.entity)" tooltip="编辑">' +
  53. '<i class="fa fa-pencil-square-o"/></a>' , width:100,enableFiltering:false}
  54. //'<div class="links cl-effect-1">' +
  55. // '<a ng-click="grid.appScope.selectRowFunction(row.entity)" tooltip="编辑" tooltip-placement="left"><i class="fa fa-pencil-square-o"></i></a>'+
  56. // '</div>' , width:100, enableFiltering:false}
  57. ];
  58. $scope.saveData = function(data){
  59. var modelData = {
  60. model : {
  61. menu : data
  62. }
  63. };
  64. // console.log("modelData="+JSON.stringify(modelData));
  65. $state.go('app.system.form_editor',{formKey:'system_edit_navmanager', service:'api_configure_data',model : JSON.stringify(modelData)}
  66. );
  67. };
  68. // $scope.addData = function(){
  69. // $state.go('app.system.form',{formKey:'system_edit_navmanager', service:'api_configure_data',}
  70. // );
  71. // }
  72. $scope.removeData = function(){
  73. var rmvList = [];
  74. angular.forEach($scope.selected.items,function(item){
  75. rmvList.push(item.id);
  76. });
  77. if(rmvList.length>0){
  78. api_configure_data.rmvData('menu',rmvList).then(function(response){
  79. if(response.data){
  80. SweetAlert.swal({
  81. title: "删除成功!",
  82. type: "success",
  83. confirmButtonColor: "#007AFF"
  84. },function(){
  85. $scope.myData = _.reject($scope.myData, function(o) { return _.includes(rmvList,o.id); });
  86. $scope.selected = {
  87. items:[]
  88. };
  89. });
  90. }else{
  91. SweetAlert.swal({
  92. title: "操作异常!",
  93. text: "系统异常,请稍后重试,或者联系管理员!",
  94. type: "error"
  95. });
  96. }
  97. })
  98. }
  99. }
  100. $scope.selected = {
  101. items:[]
  102. }
  103. $scope.editted = {
  104. items:[]
  105. }
  106. $scope.gridOptions.onRegisterApi = function(gridApi){
  107. $scope.gridApi = gridApi;
  108. gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  109. console.log(rowEntity);
  110. });
  111. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  112. var filtersData = $scope.memoryfilterData;
  113. filtersData.idx=newPage-1;
  114. filtersData.sum=pageSize;
  115. $scope.refreshData('expand-right',filtersData);
  116. });
  117. gridApi.selection.on.rowSelectionChanged($scope, function(scope){
  118. var j=0;
  119. for(var i=0;i<=scope.grid.appScope.selected.items.length;i++){
  120. if(scope.grid.appScope.selected.items[i]==scope.entity){
  121. j++;
  122. break;
  123. }
  124. }
  125. // console.log("j="+j)
  126. if(j==1){
  127. scope.grid.appScope.selected.items.splice(i,1);
  128. }else{
  129. scope.grid.appScope.selected.items.push(scope.entity)
  130. }
  131. //console.log("scope.grid.appScope.selected.items="+JSON.stringify(scope.grid.appScope.selected.items));
  132. //console.log("scope.entity="+JSON.stringify(scope.entity));
  133. });
  134. gridApi.core.on.filterChanged( $scope, function() {
  135. var grid = this.grid;
  136. var filtersData = {
  137. idx:0,
  138. sum:10
  139. };
  140. angular.forEach(grid.columns,function(item){
  141. if(item.enableFiltering){
  142. if(angular.isDefined(item.filters[0].term)&&item.filters[0].term!=''){
  143. if(angular.isUndefined(filtersData['menu'])){
  144. filtersData['menu']={};
  145. }
  146. filtersData['menu'][item.field]=item.filters[0].term;
  147. }
  148. }
  149. });
  150. // $scope.memoryfilterData = filterData
  151. $scope.refreshData('expand-right', filtersData);
  152. });
  153. };
  154. var defaultFilterData = {
  155. "idx":0,
  156. "sum":10
  157. };
  158. $scope.memoryfilterData = {
  159. "idx":0,
  160. "sum":10
  161. }
  162. $scope.ldloading = {};
  163. $scope.refreshData = function(style,filterData){
  164. $scope.ldloading[style.replace('-', '_')] = true;
  165. if(angular.isUndefined(filterData)){
  166. filterData = defaultFilterData;
  167. }
  168. if(angular.isDefined($scope.searchTypes)){
  169. filterData['searchType'] = $scope.searchTypes;
  170. }
  171. $scope.myData = [];
  172. api_configure_data.fetchDataList('menu',filterData).then(function(data){
  173. var myData = Restangular.stripRestangular(data);
  174. $scope.gridOptions.totalItems = myData.totalNum;
  175. $scope.myData = myData.list;
  176. $scope.ldloading[style.replace('-', '_')] = false;
  177. },function(){
  178. $scope.ldloading[style.replace('-', '_')] = false;
  179. });
  180. };
  181. $scope.refreshData('expand-right', defaultFilterData);
  182. }]);