groupCtrl.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. 'use strict';
  2. app.controller('grouplistCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "SweetAlert", "$modal", "Restangular", "api_user_data", "api_configure_data", function($rootScope, $scope, $state, $timeout, $interval, SweetAlert, $modal, Restangular, api_user_data, api_configure_data) {
  3. var loginUser = $rootScope.user;
  4. //user tree
  5. var apple_selected, tree, treedata_avm, treedata_geography;
  6. var i = 0;
  7. $scope.bodyHeight = Math.max((window.innerHeight - 290), 500);
  8. // $(window).resize(function() {
  9. // $scope.bodyHeight = Math.max((window.innerHeight - 290), 500);
  10. // });
  11. $rootScope.isMask = false;
  12. // //角色仪表权限
  13. // function dashboardaborad(branch) {
  14. // $scope.dashboard_tree = angular.copy($scope.dashboard_data);
  15. // angular.forEach($scope.dashboard_tree, function(index, i) {
  16. // if (branch.dashboard && branch.dashboard.length > 0) {
  17. // angular.forEach(branch.dashboard, function(item) {
  18. // if (index.id == item.id) {
  19. // $scope.dashboard_tree[i].checks = true;
  20. // }
  21. // })
  22. // }
  23. // })
  24. // }
  25. //组树
  26. $scope.my_tree = {};
  27. $scope.my_user = {};
  28. $scope.try_async_load = function() {
  29. $scope.my_data = [];
  30. $scope.doing_async = true;
  31. api_user_data.fetchDataList('group', { "idx": 0, "sum": 1000 }).then(function(response) {
  32. if (response.status == 200) {
  33. var data = response.list;
  34. var objects = [];
  35. for (var i = 0; i < data.length; i++) {
  36. var object = {};
  37. // object.id = data[i].id;
  38. // if (data[i].parent && data[i].parent.id != 0) {
  39. // object.parent = data[i].parent.id;
  40. // }
  41. angular.extend(object, data[i]);
  42. object.label = object.groupName;
  43. // if (loginUser.id == 1) {
  44. // objects.push(object);
  45. // } else {
  46. // if (object.roletype == 0) {
  47. // objects.push(object);
  48. // }
  49. // }
  50. objects.push(object);
  51. }
  52. $scope.my_data = convertParentToChildList(objects);
  53. $scope.tree_data = angular.copy($scope.my_data);
  54. if ($scope.my_data.length > 0) {
  55. $scope.doing_async = false;
  56. }
  57. } else {
  58. SweetAlert.swal({
  59. title: "系统错误!",
  60. text: "请刷新重试!",
  61. type: "error"
  62. });
  63. }
  64. });
  65. };
  66. function convertListToTree(data, treeMap) {
  67. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  68. var root = null; //Initially set our loop to null
  69. //loop over data
  70. for (var i = 0; i < data.length; i++) {
  71. var datum = data[i];
  72. //each node will have children, so let's give it a "children" poperty
  73. datum.children = [];
  74. //add an entry for this node to the map so that any future children can
  75. //lookup the parent
  76. idToNodeMap[datum.id] = datum;
  77. //Does this node have a parent?
  78. // console.log("datum="+JSON.stringify(datum))
  79. if (typeof datum.parent === "undefined" || datum.parent === null) {
  80. //Doesn't look like it, so this node is the root of the tree
  81. root = datum;
  82. treeMap[datum.id] = root;
  83. } else {
  84. //This node has a parent, so let's look it up using the id
  85. parentNode = idToNodeMap[datum.parent.id];
  86. //We don't need this property, so let's delete it.
  87. // delete datum.parent;
  88. //Let's add the current node as a child of the parent node.
  89. parentNode.children.push(datum);
  90. }
  91. }
  92. return root;
  93. }
  94. function convertParentToChildList(data) {
  95. var treeMap = {};
  96. var list = [];
  97. convertListToTree(data, treeMap);
  98. angular.forEach(treeMap, function(item) {
  99. list.push(item);
  100. });
  101. return list;
  102. }
  103. $scope.try_async_load();
  104. //end power
  105. //tree user
  106. $scope.try_async_powerload = function(items) {
  107. if (items) {
  108. $scope.getbranchs = items.users;
  109. }
  110. // $scope.my_power = [];
  111. var objects = [];
  112. var selected = [];
  113. for (var i = 0; i < $scope.getbranchs.length; i++) {
  114. var object = {};
  115. angular.extend(object, $scope.getbranchs[i]);
  116. object.label = object.name;
  117. objects.push(object);
  118. }
  119. selected = angular.copy($scope.tree_user);
  120. // if (data.length > 0) {
  121. angular.forEach(selected, function(index, i) {
  122. angular.forEach(objects, function(item) {
  123. if (index.id == item.id) {
  124. selected[i].checks = true;
  125. }
  126. })
  127. })
  128. $scope.my_user = selected;
  129. // if ($scope.my_user.length > 0) {
  130. // $scope.doing_asyncuser = false;
  131. // }
  132. };
  133. //tree admin
  134. $scope.my_user = [];
  135. $scope.tile = [];
  136. $scope.try_async_user = function() {
  137. var objects = [];
  138. api_user_data.fetchDataList("user", { "idx": 0, "sum": 1000000 }).then(function(response) {
  139. if (response.status == 200) {
  140. var data = response.list;
  141. var objects = [];
  142. for (var i = 0; i < data.length; i++) {
  143. var object = {};
  144. // object.id = data[i].id;
  145. // if (data[i].parent && data[i].parent.id != 0) {
  146. // object.parent = data[i].parent.id;
  147. // }
  148. angular.extend(object, data[i]);
  149. object.label = object.name;
  150. objects.push(object);
  151. }
  152. $scope.tile = objects;
  153. $scope.my_user = convertParentToChildList(objects);
  154. $scope.tree_user = angular.copy($scope.my_user);
  155. if ($scope.my_user.length > 0) {
  156. $scope.doing_asyncuser = false;
  157. }
  158. } else {
  159. SweetAlert.swal({
  160. title: "系统错误!",
  161. text: "请刷新重试!",
  162. type: "error"
  163. });
  164. }
  165. });
  166. };
  167. $scope.try_async_user();
  168. //点击角色
  169. $scope.group = {};
  170. $scope.change = true;
  171. $scope.my_tree_handler = function(branch) {
  172. $scope.group = branch;
  173. $scope.try_async_powerload(branch);
  174. $scope.change = false;
  175. }
  176. //start remove
  177. $scope.getbranchs = {};
  178. $scope.formbranch = function(branchData) {
  179. $scope.getbranchs = branchData;
  180. }
  181. //change right
  182. $scope.changeData = function() {
  183. var users = [];
  184. $rootScope.isMask = true;
  185. angular.forEach($scope.getbranchs, function(it) {
  186. users.push({ "id": it.id });
  187. })
  188. // var branch = { 'menu': menu };
  189. // angular.extend(branch, { 'id': $scope.role.id, 'role': $scope.role.role, 'rolecode': $scope.role.rolecode, 'roletype': $scope.role.roletype, 'dashboard': $scope.role.dashboard })
  190. var fildata = { "group": { "id": $scope.group.id, "groupName": $scope.group.groupName, "users": users } }
  191. // api_user_data.updData('group', fildata).then(function(response) {
  192. // if (response) {
  193. // if (response.status == 200) {
  194. api_user_data.updData('group', fildata).then(function(response) {
  195. if (response && response.status == 200) {
  196. $scope.try_async_load();
  197. SweetAlert.swal({
  198. title: "提交成功!",
  199. confirmButtonColor: "#007AFF"
  200. }, function() {
  201. $rootScope.isMask = false;
  202. });
  203. } else {
  204. SweetAlert.swal({
  205. title: "系统错误",
  206. text: "系统错误,请稍后重试!",
  207. type: "error",
  208. confirmButtonColor: "#DD6B55"
  209. }, function() {
  210. $rootScope.isMask = false;
  211. });
  212. }
  213. })
  214. // $state.go('app.system.form',{formKey:'system_add_menu', service:'api_configure_data', model : JSON.stringify(modelData)});
  215. }
  216. // //change menu
  217. // $scope.choiceMenu = [];
  218. // $scope.showHandler = function(branch) {
  219. // $scope.choiceMenu = branch;
  220. // }
  221. //add role
  222. $scope.addRole = function() {
  223. var modalInstance = $modal.open({
  224. templateUrl: 'assets/views/system/tpl/group.html',
  225. controller: function($scope, scope, $modalInstance, api_user_data) {
  226. $scope.cancel = function() {
  227. $modalInstance.dismiss('cancel');
  228. };
  229. $scope.ok = function(group) {
  230. var close = true;
  231. for (var i = 0; i < scope.my_data.length; i++) {
  232. if (scope.my_data[i].groupName == group.groupName) {
  233. close = false;
  234. $modalInstance.dismiss('cancel');
  235. SweetAlert.swal({
  236. title: "修改失败!",
  237. text: "该组已存在",
  238. type: "error"
  239. })
  240. break;
  241. } else {}
  242. }
  243. if (close) {
  244. $modalInstance.close(group);
  245. }
  246. }
  247. },
  248. resolve: {
  249. scope: function() {
  250. return $scope;
  251. }
  252. }
  253. });
  254. modalInstance.result.then(function(selectedItem) {
  255. if (selectedItem) {
  256. var fildata = { "group": { "groupName": selectedItem.groupName } }
  257. api_user_data.addData('group', fildata).then(function(response) {
  258. if (response) {
  259. if (response.status == 200) {
  260. SweetAlert.swal({
  261. title: "新增成功!",
  262. type: "success"
  263. }, function() {
  264. $scope.try_async_load();
  265. })
  266. } else {
  267. SweetAlert.swal({
  268. title: "修改失败!",
  269. type: "error"
  270. })
  271. }
  272. // $modalInstance.close();
  273. }
  274. })
  275. }
  276. })
  277. }
  278. //change role
  279. $scope.changeRole = function() {
  280. var modalInstance = $modal.open({
  281. templateUrl: 'assets/views/system/tpl/group.html',
  282. controller: function($scope, scope, $modalInstance, api_user_data) {
  283. $scope.group = scope.group;
  284. $scope.cancel = function() {
  285. $modalInstance.dismiss('cancel');
  286. };
  287. $scope.ok = function(item) {
  288. $modalInstance.close(item);
  289. }
  290. },
  291. resolve: {
  292. scope: function() {
  293. return $scope;
  294. }
  295. }
  296. });
  297. modalInstance.result.then(function(selectedItem) {
  298. if (selectedItem) {
  299. var fildata = { "group": { "id": selectedItem.id, "groupName": selectedItem.groupName, "users": selectedItem.users } }
  300. api_user_data.updData('group', fildata).then(function(response) {
  301. if (response) {
  302. if (response.status == 200) {
  303. SweetAlert.swal({
  304. title: "修改成功!",
  305. type: "success"
  306. }, function() {
  307. $scope.try_async_load();
  308. // $scope.refreshData('expand-right', defaultFilterData);
  309. })
  310. } else {
  311. SweetAlert.swal({
  312. title: "修改失败!",
  313. type: "error"
  314. })
  315. }
  316. // $modalInstance.close();
  317. }
  318. })
  319. }
  320. })
  321. }
  322. //remove role
  323. $scope.removeRole = function() {
  324. var modalInstance = $modal.open({
  325. templateUrl: 'assets/views/delete.html',
  326. controller: function($scope, scope, $modalInstance) {
  327. var rmvList = [];
  328. $scope.title = '工作组删除';
  329. $scope.connect = '确定要删除此工作组?';
  330. rmvList.push(scope.group.id);
  331. $scope.ok = function() {
  332. $modalInstance.close(rmvList);
  333. };
  334. $scope.cancel = function() {
  335. $modalInstance.dismiss('cancel');
  336. };
  337. },
  338. size: 'sm',
  339. resolve: {
  340. scope: function() {
  341. return $scope;
  342. }
  343. }
  344. });
  345. modalInstance.result.then(function(selectedItem) {
  346. if (selectedItem) {
  347. if (selectedItem.length > 0) {
  348. api_user_data.rmvData('group', selectedItem).then(function(response) {
  349. if (response.data) {
  350. SweetAlert.swal({
  351. title: "删除成功!",
  352. type: "success",
  353. confirmButtonColor: "#007AFF"
  354. }, function() {
  355. $scope.try_async_load();
  356. });
  357. } else {
  358. SweetAlert.swal({
  359. title: "操作异常!",
  360. text: "系统异常,请稍后重试,或者联系管理员!",
  361. type: "error"
  362. });
  363. }
  364. })
  365. }
  366. }
  367. })
  368. }
  369. }]);