prioritymatrixCtrl.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  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, 20, 50, 100];
  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: 'item',
  33. displayName: '序号',
  34. width: 50,
  35. enableFiltering: false
  36. },
  37. { name: 'influence.name', displayName: '影响度', width: '25%', enableFiltering: false },
  38. { name: 'emergency.name', displayName: '紧急度', width: '25%', enableFiltering: false },
  39. { name: 'priority.name', displayName: '优先级', width: '25%', enableFiltering: false },
  40. {
  41. name: '编辑',
  42. cellTemplate: '<div><div class="cl-effect-1 ui-grid-cell-contents pull-left" >' +
  43. '<a ng-click="grid.appScope.saveData(row.entity)" class="bianjifont">编辑</a>' +
  44. '</div></div>',
  45. enableFiltering: false
  46. }
  47. ];
  48. $scope.saveData = function(selectdata) {
  49. var modalInstance = $modal.open({
  50. templateUrl: 'assets/views/system/tpl/systemprioritymatrix.html',
  51. controller: function($scope, $modalInstance, api_bpm_data) {
  52. $scope.changeprioritymatrix = true;
  53. $scope.prioritymatrixdata = {};
  54. $scope.datalist = {};
  55. $scope.influencelist = {};
  56. $scope.emergencylist = {};
  57. $scope.prioritymatrixdata = selectdata;
  58. var fildDate = { "idx": 0, "sum": 10 }
  59. api_bpm_data.fetchDataList('priority', fildDate).then(function(response) {
  60. $scope.datalist = Restangular.stripRestangular(response).list;
  61. })
  62. api_bpm_data.fetchDataList('influence', fildDate).then(function(response) {
  63. $scope.influencelist = Restangular.stripRestangular(response).list;
  64. })
  65. api_bpm_data.fetchDataList('emergency', fildDate).then(function(response) {
  66. $scope.emergencylist = Restangular.stripRestangular(response).list;
  67. })
  68. $scope.cancel = function() {
  69. $modalInstance.dismiss('cancel');
  70. };
  71. $scope.savercode = function(prioritymatrixdata) {
  72. var fildata = { "prioritymatrix": { "id": prioritymatrixdata.id, "priority": { "id": prioritymatrixdata.priority.id }, "emergency": { "id": prioritymatrixdata.emergency.id }, "influence": { "id": prioritymatrixdata.influence.id } } }
  73. api_bpm_data.updData('prioritymatrix', fildata).then(function(response) {
  74. if (response) {
  75. if (response.status == 200) {
  76. SweetAlert.swal({
  77. title: "修改成功!",
  78. type: "success"
  79. }, function() {
  80. // $scope.refreshData('expand-right', defaultFilterData);
  81. })
  82. } else {
  83. SweetAlert.swal({
  84. title: "修改失败!",
  85. type: "error"
  86. })
  87. }
  88. }
  89. })
  90. $modalInstance.close();
  91. }
  92. }
  93. });
  94. }
  95. $scope.addData = function() {
  96. var modalInstance = $modal.open({
  97. templateUrl: 'assets/views/system/tpl/systemprioritymatrix.html',
  98. controller: function($scope, $modalInstance, api_bpm_data) {
  99. $scope.prioritymatrixdata = {};
  100. var fildDate = { "idx": 0, "sum": 10 }
  101. api_bpm_data.fetchDataList('priority', fildDate).then(function(response) {
  102. $scope.datalist = Restangular.stripRestangular(response).list;
  103. })
  104. api_bpm_data.fetchDataList('influence', fildDate).then(function(response) {
  105. $scope.influencelist = Restangular.stripRestangular(response).list;
  106. })
  107. api_bpm_data.fetchDataList('emergency', fildDate).then(function(response) {
  108. $scope.emergencylist = Restangular.stripRestangular(response).list;
  109. })
  110. $scope.changeprioritymatrix = false;
  111. $scope.cancel = function() {
  112. $modalInstance.dismiss('cancel');
  113. };
  114. $scope.savercode = function(prioritymatrixdata) {
  115. $modalInstance.close(prioritymatrixdata);
  116. };
  117. }
  118. });
  119. modalInstance.result.then(function(selectedItem) {
  120. // console.log('selectedItem='+JSON.stringify(selectedItem));
  121. if (selectedItem) {
  122. var fildata = { "prioritymatrix": { "priority": { "id": selectedItem.priority.id }, "emergency": { "id": selectedItem.emergency.id }, "influence": { "id": selectedItem.influence.id } } }
  123. api_bpm_data.addData('prioritymatrix', fildata).then(function(response) {
  124. if (response) {
  125. if (response.status == 200) {
  126. SweetAlert.swal({
  127. title: "新增成功!",
  128. type: "success"
  129. }, function() {
  130. $scope.refreshData('expand-right', defaultFilterData);
  131. })
  132. } else {
  133. SweetAlert.swal({
  134. title: "新增失败!",
  135. type: "error"
  136. })
  137. }
  138. }
  139. })
  140. }
  141. });
  142. }
  143. $scope.removeData = function() {
  144. var modalInstance = $modal.open({
  145. templateUrl: 'assets/views/delete.html',
  146. controller: function($scope, scope, $modalInstance, api_bpm_data) {
  147. var rmvList = [scope.selected.items.id];
  148. $scope.title = '优先级规则删除';
  149. $scope.connect = '确定要删除此优先级规则?';
  150. $scope.ok = function() {
  151. $modalInstance.close(rmvList);
  152. // }
  153. };
  154. $scope.cancel = function() {
  155. $modalInstance.dismiss('cancel');
  156. };
  157. },
  158. size: 'sm',
  159. resolve: {
  160. scope: function() {
  161. return $scope;
  162. }
  163. }
  164. });
  165. modalInstance.result.then(function(selectedItem) {
  166. if (selectedItem) {
  167. if (selectedItem.length > 0) {
  168. api_bpm_data.rmvData('prioritymatrix', selectedItem).then(function(response) {
  169. if (response.status == 200) {
  170. SweetAlert.swal({
  171. title: "删除成功!",
  172. type: "success",
  173. confirmButtonColor: "#007AFF"
  174. }, function() {
  175. $scope.myData = _.reject($scope.myData, function(o) { return _.includes(selectedItem, o.id); });
  176. $scope.selected = {
  177. items: []
  178. };
  179. $scope.gridOptions.totalItems = $scope.gridOptions.totalItems - selectedItem.length
  180. $scope.gridApi.grid.selection.selectedCount = 0;
  181. });
  182. } else {
  183. SweetAlert.swal({
  184. title: "操作异常!",
  185. text: "系统异常,请稍后重试,或者联系管理员!",
  186. type: "error"
  187. });
  188. }
  189. })
  190. }
  191. // }
  192. }
  193. })
  194. }
  195. // $scope.removeData = function() {
  196. // var rmvList = [$scope.selected.items.id]
  197. // if (rmvList.length > 0) {
  198. // api_bpm_data.rmvData('prioritymatrix', rmvList).then(function(response) {
  199. // if (response.status == 200) {
  200. // SweetAlert.swal({
  201. // title: "删除成功!",
  202. // type: "success",
  203. // confirmButtonColor: "#007AFF"
  204. // }, function() {
  205. // $scope.myData = _.reject($scope.myData, function(o) { return _.includes(rmvList, o.id); });
  206. // $scope.selected = {
  207. // items: []
  208. // };
  209. // });
  210. // } else {
  211. // SweetAlert.swal({
  212. // title: "删除失败!",
  213. // text: response.msg,
  214. // type: "error"
  215. // });
  216. // }
  217. // })
  218. // }
  219. // }
  220. $scope.selected = {
  221. items: []
  222. }
  223. $scope.editted = {
  224. items: []
  225. }
  226. $scope.gridOptions.onRegisterApi = function(gridApi) {
  227. $scope.gridApi = gridApi;
  228. // gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  229. // console.log(rowEntity);
  230. // });
  231. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  232. var filtersData = $scope.memoryfilterData;
  233. filtersData.idx = newPage - 1;
  234. filtersData.sum = pageSize;
  235. defaultFilterData = filtersData;
  236. $scope.refreshData('expand-right', filtersData);
  237. });
  238. gridApi.selection.on.rowSelectionChanged($scope, function(scope) {
  239. scope.grid.appScope.selected.items = scope.entity
  240. });
  241. };
  242. var defaultFilterData = {
  243. "idx": 0,
  244. "sum": 10
  245. };
  246. $scope.memoryfilterData = {
  247. "idx": 0,
  248. "sum": 10
  249. }
  250. $scope.ldloading = {};
  251. $scope.refreshData = function(style, filterData) {
  252. $scope.ldloading[style.replace('-', '_')] = true;
  253. if (angular.isUndefined(filterData)) {
  254. filterData = defaultFilterData;
  255. }
  256. $scope.myData = [];
  257. $scope.selected = { items: [] };
  258. if ($scope.gridApi) {
  259. $scope.gridApi.grid.selection.selectedCount = 0;
  260. }
  261. api_bpm_data.fetchDataList('prioritymatrix', filterData).then(function(data) {
  262. var myData = Restangular.stripRestangular(data);
  263. $scope.gridOptions.totalItems = myData.totalNum;
  264. $scope.myData = myData.list;
  265. for (var i = 0; i < $scope.myData.length; i++) {
  266. $scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum
  267. }
  268. $scope.ldloading[style.replace('-', '_')] = false;
  269. }, function() {
  270. $scope.ldloading[style.replace('-', '_')] = false;
  271. });
  272. };
  273. $scope.refreshData('expand-right', defaultFilterData);
  274. }]);