groupCtrl.js 8.1 KB

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