prioritymatrixCtrl.js 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('prioritymatrixCtrl', ["$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. $scope.gridOptions.columnDefs = [
  32. { name:'influence.name', displayName:'影响度', width:100, enableFiltering:false},
  33. { name:'emergency.name', displayName:'紧急度', width:200, enableFiltering:false},
  34. { name:'priority.name', displayName:'优先级', width:200, enableFiltering:false},
  35. { name:'修改', cellTemplate:'<a class="btn btn-sm btn-info" ng-click="grid.appScope.saveData(row.entity)" tooltip="编辑">' +
  36. '<i class="fa fa-pencil-square-o"/></a>' , width:100,enableFiltering:false}
  37. ];
  38. $scope.saveData = function(selectdata){
  39. var modalInstance = $modal.open({
  40. templateUrl: 'assets/views/system/tpl/systemprioritymatrix.html',
  41. controller: function($scope, $modalInstance, api_bpm_data){
  42. $scope.changeprioritymatrix=true;
  43. $scope.prioritymatrixdata={};
  44. $scope.datalist={};
  45. $scope.influencelist={};
  46. $scope.emergencylist={};
  47. $scope.prioritymatrixdata=selectdata;
  48. var fildDate = {"idx":0,"sum":10}
  49. api_bpm_data.fetchDataList('priority',fildDate).then(function(response){
  50. $scope.datalist = Restangular.stripRestangular(response).list;
  51. })
  52. api_bpm_data.fetchDataList('influence',fildDate).then(function(response){
  53. $scope.influencelist = Restangular.stripRestangular(response).list;
  54. })
  55. api_bpm_data.fetchDataList('emergency',fildDate).then(function(response){
  56. $scope.emergencylist = Restangular.stripRestangular(response).list;
  57. })
  58. $scope.cancel = function() {
  59. $modalInstance.dismiss('cancel');
  60. };
  61. $scope.savercode = function(prioritymatrixdata){
  62. var fildata={"prioritymatrix":{"id":prioritymatrixdata.id,"priority":{"id":prioritymatrixdata.priority.id},"emergency":{"id":prioritymatrixdata.emergency.id},"influence":{"id":prioritymatrixdata.influence.id}}}
  63. api_bpm_data.updData('prioritymatrix',fildata).then(function(response){
  64. if(response){
  65. if(response.status==200){
  66. SweetAlert.swal({
  67. title:"修改成功!",
  68. type:"success"
  69. },function(){
  70. // $scope.refreshData('expand-right', defaultFilterData);
  71. })
  72. }else{
  73. SweetAlert.swal({
  74. title:"修改失败!",
  75. type:"error"
  76. })
  77. }
  78. }
  79. })
  80. $modalInstance.close();
  81. }
  82. }
  83. });
  84. }
  85. $scope.addData = function(){
  86. var modalInstance = $modal.open({
  87. templateUrl: 'assets/views/system/tpl/systemprioritymatrix.html',
  88. controller: function($scope, $modalInstance, api_bpm_data){
  89. $scope.prioritymatrixdata={};
  90. var fildDate = { "idx":0, "sum":10}
  91. api_bpm_data.fetchDataList('priority',fildDate).then(function(response){
  92. $scope.datalist = Restangular.stripRestangular(response).list;
  93. })
  94. api_bpm_data.fetchDataList('influence',fildDate).then(function(response){
  95. $scope.influencelist = Restangular.stripRestangular(response).list;
  96. })
  97. api_bpm_data.fetchDataList('emergency',fildDate).then(function(response){
  98. $scope.emergencylist = Restangular.stripRestangular(response).list;
  99. })
  100. $scope.changeprioritymatrix=false;
  101. $scope.cancel = function() {
  102. $modalInstance.dismiss('cancel');
  103. };
  104. $scope.savercode = function(prioritymatrixdata) {
  105. $modalInstance.close(prioritymatrixdata);
  106. };
  107. }
  108. });
  109. modalInstance.result.then(function(selectedItem) {
  110. // console.log('selectedItem='+JSON.stringify(selectedItem));
  111. if(selectedItem){
  112. var fildata={"prioritymatrix":{"priority":{"id":selectedItem.priority.id},"emergency":{"id":selectedItem.emergency.id},"influence":{"id":selectedItem.influence.id}}}
  113. api_bpm_data.addData('prioritymatrix',fildata).then(function(response){
  114. if(response){
  115. if(response.status==200){
  116. SweetAlert.swal({
  117. title:"新增成功!",
  118. type:"success"
  119. },function(){
  120. $scope.refreshData('expand-right', defaultFilterData);
  121. })
  122. }else{
  123. SweetAlert.swal({
  124. title:"新增失败!",
  125. type:"error"
  126. })
  127. }
  128. }
  129. })
  130. }
  131. });
  132. }
  133. $scope.removeData = function(){
  134. var rmvList = [$scope.selected.items.id]
  135. if(rmvList.length>0){
  136. api_bpm_data.rmvData('prioritymatrix',rmvList).then(function(response){
  137. if(response.status==200){
  138. SweetAlert.swal({
  139. title: "删除成功!",
  140. type: "success",
  141. confirmButtonColor: "#007AFF"
  142. },function(){
  143. $scope.myData = _.reject($scope.myData, function(o) { return _.includes(rmvList,o.id); });
  144. $scope.selected = {
  145. items:[]
  146. };
  147. });
  148. }else{
  149. SweetAlert.swal({
  150. title: "操作异常!",
  151. text: "系统异常,请稍后重试,或者联系管理员!",
  152. type: "error"
  153. });
  154. }
  155. })
  156. }
  157. }
  158. $scope.selected = {
  159. items:[]
  160. }
  161. $scope.editted = {
  162. items:[]
  163. }
  164. $scope.gridOptions.onRegisterApi = function(gridApi){
  165. $scope.gridApi = gridApi;
  166. // gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  167. // console.log(rowEntity);
  168. // });
  169. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  170. var filtersData = $scope.memoryfilterData;
  171. filtersData.idx=newPage-1;
  172. filtersData.sum=pageSize;
  173. $scope.refreshData('expand-right',filtersData);
  174. });
  175. gridApi.selection.on.rowSelectionChanged($scope, function(scope){
  176. scope.grid.appScope.selected.items=scope.entity
  177. });
  178. };
  179. var defaultFilterData = {
  180. "idx":0,
  181. "sum":10
  182. };
  183. $scope.memoryfilterData = {
  184. "idx":0,
  185. "sum":10
  186. }
  187. $scope.ldloading = {};
  188. $scope.refreshData = function(style,filterData){
  189. $scope.ldloading[style.replace('-', '_')] = true;
  190. if(angular.isUndefined(filterData)){
  191. filterData = defaultFilterData;
  192. }
  193. $scope.myData = [];
  194. api_bpm_data.fetchDataList('prioritymatrix',filterData).then(function(data){
  195. var myData = Restangular.stripRestangular(data);
  196. $scope.gridOptions.totalItems = myData.totalNum;
  197. $scope.myData = myData.list;
  198. $scope.ldloading[style.replace('-', '_')] = false;
  199. },function(){
  200. $scope.ldloading[style.replace('-', '_')] = false;
  201. });
  202. };
  203. $scope.refreshData('expand-right', defaultFilterData);
  204. }]);