inspectionScopeCtrl.js 42 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231
  1. app.controller("inspectionScope", [
  2. "$rootScope",
  3. "$scope",
  4. "$state",
  5. "$timeout",
  6. "$interval",
  7. "SweetAlert",
  8. "$modal",
  9. "Restangular",
  10. "api_bpm_data",
  11. "api_solution",
  12. "api_user_data",
  13. "api_wechatfile",
  14. "api_sysinfo",
  15. "api_statistic",
  16. "api_bpm",
  17. "jry_api_bpm",
  18. "api_simple",
  19. function (
  20. $rootScope,
  21. $scope,
  22. $state,
  23. $timeout,
  24. $interval,
  25. SweetAlert,
  26. $modal,
  27. Restangular,
  28. api_bpm_data,
  29. api_solution,
  30. api_user_data,
  31. api_wechatfile,
  32. api_sysinfo,
  33. api_statistic,
  34. api_bpm,
  35. jry_api_bpm,
  36. api_simple
  37. ) {
  38. var loginUser = $rootScope.user;
  39. $scope.everyDay = {
  40. time: new Date(),
  41. everyDayNotices: [
  42. {id:0 ,name:'线上', checked:false},
  43. {id:1 ,name:'线下', checked:false}
  44. ]
  45. }
  46. // 回显数据 start
  47. $scope.stateModel = {id: $state.params.id};
  48. $scope.getInspectionById= function () {
  49. api_user_data.fetchgetData("inspection", $state.params.id).then((res) => {
  50. console.log(res.data)
  51. if(res.status == 200){
  52. $scope.stateModel = res.data;
  53. console.log($scope.stateModel);
  54. $scope.modelName = $scope.stateModel.modelName || $scope.stateModel.title;
  55. $scope.everyDay = {
  56. time: $scope.stateModel.dayMsgTime?new Date($scope.stateModel.dayMsgTime):new Date(),
  57. everyDayNotices: [
  58. {id:0 ,name:'线上', checked:$scope.stateModel.dayMsgOnline == 1},
  59. {id:1 ,name:'线下', checked:$scope.stateModel.dayMsgOffline == 1}
  60. ]
  61. }
  62. if ($scope.stateModel.model != 1) {
  63. $scope.stateModel.model = 0;
  64. }
  65. // 通知规则
  66. console.log($scope.incidentManageruserList)
  67. console.log($scope.notice.inspectionMsgRules)
  68. $scope.notice.user = [];
  69. var msgRuleIds = $scope.stateModel.msgRules?$scope.stateModel.msgRules.split(','):[];
  70. var msgUserIds = $scope.stateModel.msgUsers?$scope.stateModel.msgUsers.split(','):[];
  71. if(msgRuleIds.length){
  72. msgRuleIds.forEach(v => {
  73. for (let i = 0; i < $scope.notice.inspectionMsgRules.length; i++) {
  74. if($scope.notice.inspectionMsgRules[i].id == v){
  75. $scope.notice.inspectionMsgRules[i].checked = true;
  76. }
  77. }
  78. })
  79. }
  80. if(msgUserIds.length){
  81. msgUserIds.forEach(v => {
  82. let item = $scope.incidentManageruserList.find(vv => vv.id == v);
  83. if(item){
  84. $scope.notice.user.push(item);
  85. }
  86. })
  87. }
  88. }
  89. });
  90. };
  91. console.log($state.params.id)
  92. // $scope.stateModel = JSON.parse($state.params.model);
  93. // console.log($scope.stateModel);
  94. // $scope.modelName = $scope.stateModel.modelName || $scope.stateModel.title;
  95. // if ($scope.stateModel.model != 1) {
  96. // $scope.stateModel.model = 0;
  97. // }
  98. // 回显数据 end
  99. // 通知 start
  100. // 获取事件经理角色的人
  101. $scope.incidentManageruserList = [];
  102. $scope.getUserListByRole = function () {
  103. var postData = {
  104. idx: 0,
  105. sum: 1000,
  106. "user": {
  107. "roledata": {
  108. "rolecode": "incident manager"
  109. },
  110. "simple": true
  111. }
  112. };
  113. api_user_data.fetchDataList("user", postData).then((res) => {
  114. $scope.incidentManageruserList = res.list;
  115. $scope.getInspectionById();
  116. });
  117. };
  118. // 通知规则
  119. $scope.notice = {
  120. user: [],
  121. inspectionMsgRules: []
  122. }
  123. $scope.getInspectionMsgRules = function(){
  124. var postData = {
  125. key: "inspection_msg_rules",
  126. type: "list"
  127. }
  128. api_wechatfile.getDictionary(postData).then(function (res) {
  129. $scope.notice.inspectionMsgRules = res.map(v => ({...v, checked:false}));
  130. $scope.getUserListByRole();
  131. })
  132. }
  133. $scope.getInspectionMsgRules();
  134. // 通知 end
  135. $scope.xinzeng = false;
  136. $scope.shanchu = false;
  137. $scope.bianji = false;
  138. for (var i = 0; i < loginUser.menu.length; i++) {
  139. if (loginUser.menu[i].link == "shijianshezhi_xinzeng") {
  140. $scope.xinzeng = true;
  141. }
  142. if (loginUser.menu[i].link == "shijianshezhi_shanchu") {
  143. $scope.shanchu = true;
  144. }
  145. if (loginUser.menu[i].link == "shijianshezhi_bianji") {
  146. $scope.bianji = true;
  147. }
  148. }
  149. $scope.listDataTop = [];
  150. $scope.listDataBottom = [];
  151. $scope.leftListIdx = -1;
  152. $scope.leftListName = "巡检范围";
  153. $scope.leftListCli = function (idx, data) {
  154. $scope.leftListIdx = idx;
  155. // $scope.stateModel = data;
  156. $scope.stateModel.currentId = data.id;
  157. $scope.modelName = data.modelName;
  158. $scope.copyInspection.tree = [];
  159. $scope.selectedInspection.isShowZtree = false;
  160. setTimeout(() => {
  161. $scope.selectedInspection.isShowZtree = true;
  162. }, 0);
  163. };
  164. // 全选
  165. // 把指令的方法绑定到控制器
  166. $scope.setDirectiveFn = function (fn) {
  167. $scope.selectAll = fn;
  168. }
  169. // 事件分类开始
  170. var loginUser = $rootScope.user;
  171. //组
  172. api_user_data
  173. .fetchDataList("group", { idx: 0, sum: 1000 })
  174. .then(function (data) {
  175. $scope.group = data.list;
  176. });
  177. api_wechatfile
  178. .getDictionary({ key: "incident_priority", type: "list" })
  179. .then(function (data) {
  180. $scope.priority = data;
  181. });
  182. /* ----- tree----- */
  183. var i = 0;
  184. $scope.out = [];
  185. $scope.outdata = [];
  186. $scope.subdata = {};
  187. $scope.sub1data = {};
  188. $scope.addcate = false;
  189. $scope.add1cate = false;
  190. $scope.changecate = false;
  191. $scope.filterTree = function (data, id) {
  192. data = angular.copy(data);
  193. var newTree = data.filter((x) => x.id !== id);
  194. newTree.forEach(
  195. (x) => x.children && (x.children = $scope.filterTree(x.children, id))
  196. );
  197. return newTree;
  198. };
  199. $scope.userOrGroupType = {}; //当前节点运维组/运维人员
  200. $scope.dataSave = []; //储存$scope.tree_data
  201. $scope.group_user = {
  202. // offlineGroup:{},//线下组
  203. // onlineUser:{}//线上人
  204. };
  205. $scope.selectedInspection = {
  206. tree: {},
  207. isShowZtree: true,
  208. };
  209. $scope.copyInspection = {
  210. tree: [],
  211. };
  212. $scope.timerZtree = null;
  213. $scope.timerZtreeCopy = null;
  214. // 新增
  215. $scope.addType1 = function (type) {
  216. console.log();
  217. // ===============================================
  218. var modalInstance = $modal.open({
  219. templateUrl: "assets/views/system/tpl/inspectionchange.html",
  220. controller: function ($scope, scope, $modalInstance) {
  221. $scope.type = type;
  222. $scope.add1data = {};
  223. $scope.thisParent = {}; //当前点击节点的父节点
  224. $scope.filterTree = function (data, id) {
  225. data = angular.copy(data);
  226. var newTree = data.filter((x) => x.id !== id);
  227. newTree.forEach(
  228. (x) =>
  229. x.children && (x.children = $scope.filterTree(x.children, id))
  230. );
  231. return newTree;
  232. };
  233. $scope.try_async_1load = function () {
  234. $scope.my_1data = [];
  235. var data = { idx: 0, sum: 1000, inspectionType: { deleteFlag: 0 } };
  236. api_bpm_data
  237. .fetchDataList("inspectionType", data)
  238. .then(function (response) {
  239. var data = response.list;
  240. data = data.filter((v) => !v.parent); //只显示一级
  241. var objects = [];
  242. for (var i = 0; i < data.length; i++) {
  243. var object = {};
  244. object.id = data[i].id;
  245. if (angular.isDefined(data[i].user)) {
  246. object.user = data[i].user || {};
  247. }
  248. if (angular.isDefined(data[i].group)) {
  249. object.group = data[i].group || {};
  250. }
  251. if (angular.isDefined(data[i].parent)) {
  252. object.parent = data[i].parent;
  253. }
  254. object.label = data[i].type;
  255. objects.push(object);
  256. }
  257. $scope.my_1data = convertParentToChildList(objects);
  258. $scope.tree_1data = angular.copy($scope.my_1data);
  259. // 把选中的巡检范围当作父类回显
  260. if (scope.selectedInspection.tree.id) {
  261. // 区分新增和修改
  262. if (type == "add") {
  263. $scope.thisParent = data.find(
  264. (v) => v.id == scope.selectedInspection.tree.id
  265. );
  266. if ($scope.thisParent) {
  267. $scope.thisParent.label = $scope.thisParent.type;
  268. $scope.thisParent.isExpanded = true;
  269. $scope.thisParent.selected = true;
  270. $scope.addparent = true;
  271. } else {
  272. $scope.addparent = false;
  273. }
  274. } else if (type == "edit") {
  275. // 编辑
  276. console.log($scope.my_1data, "原始数据");
  277. $scope.tree_1data = $scope.my_1data.filter(
  278. (v) => v.id != scope.selectedInspection.tree.id
  279. ); //过滤本条
  280. $scope.thisParent = data.find(
  281. (v) => v.id == scope.selectedInspection.tree.pId
  282. );
  283. if ($scope.thisParent) {
  284. $scope.thisParent.label = $scope.thisParent.type;
  285. $scope.thisParent.isExpanded = true;
  286. $scope.thisParent.selected = true;
  287. $scope.addparent = true;
  288. } else {
  289. $scope.addparent = false;
  290. }
  291. $scope.add1data.type = scope.selectedInspection.tree.name;
  292. $scope.add1data.id = scope.selectedInspection.tree.id;
  293. }
  294. } else {
  295. $scope.addparent = false;
  296. }
  297. });
  298. };
  299. $scope.try_async_1load();
  300. function convertListToTree(data, treeMap) {
  301. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  302. var root = null; //Initially set our loop to null
  303. //loop over data
  304. for (var i = 0; i < data.length; i++) {
  305. var datum = data[i];
  306. //each node will have children, so let's give it a "children" poperty
  307. datum.children = [];
  308. //add an entry for this node to the map so that any future children can
  309. //lookup the parent
  310. idToNodeMap[datum.id] = datum;
  311. //Does this node have a parent?
  312. // console.log("datum="+JSON.stringify(datum))
  313. if (typeof datum.parent === "undefined") {
  314. //Doesn't look like it, so this node is the root of the tree
  315. root = datum;
  316. treeMap[datum.id] = root;
  317. } else {
  318. //This node has a parent, so let's look it up using the id
  319. parentNode = idToNodeMap[datum.parent.id];
  320. //We don't need this property, so let's delete it.
  321. // delete datum.parent;
  322. //Let's add the current node as a child of the parent node.
  323. parentNode.children.push(datum);
  324. }
  325. }
  326. return root;
  327. }
  328. function convertParentToChildList(data) {
  329. var treeMap = {};
  330. var list = [];
  331. convertListToTree(data, treeMap);
  332. angular.forEach(treeMap, function (item) {
  333. list.push(item);
  334. });
  335. return list;
  336. }
  337. // ------------------------------------------------
  338. $scope.title = type == "add" ? "巡检范围新增" : "巡检范围修改";
  339. $scope.cancel = function () {
  340. $modalInstance.dismiss("cancel");
  341. };
  342. $scope.savercode = function (data) {
  343. if (data && data.type) {
  344. if ($scope.addparent) {
  345. data.parent = $scope.add1data.parent || $scope.thisParent;
  346. } else {
  347. data.parent = null;
  348. }
  349. scope.selectedInspection.tree = {};
  350. $modalInstance.close(data);
  351. } else {
  352. SweetAlert.swal(
  353. {
  354. title: "新增失败!",
  355. text: "请填写必填项!",
  356. type: "error",
  357. confirmButtonColor: "#DD6B55",
  358. },
  359. function () {}
  360. );
  361. }
  362. };
  363. },
  364. resolve: {
  365. scope: function () {
  366. return $scope;
  367. },
  368. },
  369. });
  370. // liaomingming
  371. modalInstance.result.then(function (selectedItem) {
  372. console.log($scope);
  373. if (selectedItem.type) {
  374. selectedItem.deleteFlag = 0;
  375. selectedItem.formUiName = "inspection_LinHu_detail";
  376. selectedItem.formUiEdit = "inspection_LinHu_confirm";
  377. selectedItem.processKey = "bpm_inspection";
  378. var filedata = { inspectionType: selectedItem };
  379. console.log(filedata);
  380. // return;
  381. api_bpm_data[type == "add" ? "addData" : "updData"](
  382. "inspectionType",
  383. filedata
  384. ).then(function (response) {
  385. if (response) {
  386. if (response.status == 200) {
  387. $scope.selectedInspection.isShowZtree = false;
  388. setTimeout(() => {
  389. $scope.selectedInspection.isShowZtree = true;
  390. }, 0);
  391. SweetAlert.swal({
  392. title: type == "add" ? "增加成功!" : "修改成功!",
  393. type: "success",
  394. });
  395. } else {
  396. SweetAlert.swal({
  397. title: type == "add" ? "增加失败!" : "修改失败!",
  398. type: "error",
  399. });
  400. }
  401. }
  402. });
  403. } else {
  404. SweetAlert.swal(
  405. {
  406. title: "新增失败!",
  407. text: "请填写必填项!",
  408. type: "error",
  409. confirmButtonColor: "#DD6B55",
  410. },
  411. function () {}
  412. );
  413. }
  414. });
  415. };
  416. /* -----start remove incidet category----- */
  417. // 删除
  418. $scope.remove1 = function () {
  419. var modalInstance = $modal.open({
  420. templateUrl: "assets/views/delete.html",
  421. controller: function ($scope, scope, $modalInstance, api_bpm_data) {
  422. $scope.title = "巡检范围删除?";
  423. $scope.connect = "确定要删除此巡检范围?";
  424. $scope.ok = function () {
  425. $modalInstance.close(scope.selectedInspection.tree);
  426. };
  427. $scope.cancel = function () {
  428. $modalInstance.dismiss("cancel");
  429. };
  430. },
  431. size: "sm",
  432. resolve: {
  433. scope: function () {
  434. return $scope;
  435. },
  436. },
  437. });
  438. modalInstance.result.then(function (selectedItem) {
  439. if (selectedItem) {
  440. var rmvList = [];
  441. rmvList.push(selectedItem.id);
  442. if (selectedItem.children && selectedItem.children.length > 0) {
  443. SweetAlert.swal({
  444. title: "删除失败!",
  445. text: "请先删除选中的范围的子级",
  446. type: "error",
  447. });
  448. } else {
  449. api_bpm_data
  450. .rmvData("inspectionType", rmvList)
  451. .then(function (response) {
  452. if (response.data) {
  453. SweetAlert.swal(
  454. {
  455. title: "删除成功!",
  456. type: "success",
  457. confirmButtonColor: "#007AFF",
  458. },
  459. function () {
  460. $scope.selectedInspection.isShowZtree = false;
  461. setTimeout(() => {
  462. $scope.selectedInspection.isShowZtree = true;
  463. }, 0);
  464. }
  465. );
  466. } else {
  467. SweetAlert.swal({
  468. title: "操作异常!",
  469. text: "系统异常,请稍后重试,或者联系管理员!",
  470. type: "error",
  471. });
  472. }
  473. });
  474. }
  475. }
  476. });
  477. };
  478. /* -----end remove incidet category----- */
  479. function convertListToTree(data, treeMap) {
  480. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  481. var root = null; //Initially set our loop to null
  482. //loop over data
  483. for (var i = 0; i < data.length; i++) {
  484. var datum = data[i];
  485. //each node will have children, so let's give it a "children" poperty
  486. datum.children = [];
  487. //add an entry for this node to the map so that any future children can
  488. //lookup the parent
  489. idToNodeMap[datum.id] = datum;
  490. //Does this node have a parent?
  491. // console.log("datum="+JSON.stringify(datum))
  492. if (typeof datum.parent === "undefined") {
  493. //Doesn't look like it, so this node is the root of the tree
  494. root = datum;
  495. treeMap[datum.id] = root;
  496. } else {
  497. //This node has a parent, so let's look it up using the id
  498. parentNode = idToNodeMap[datum.parent.id];
  499. //We don't need this property, so let's delete it.
  500. // delete datum.parent;
  501. //Let's add the current node as a child of the parent node.
  502. parentNode.children.push(datum);
  503. }
  504. }
  505. return root;
  506. }
  507. function convertParentToChildList(data) {
  508. var treeMap = {};
  509. var list = [];
  510. convertListToTree(data, treeMap);
  511. angular.forEach(treeMap, function (item) {
  512. list.push(item);
  513. });
  514. return list;
  515. }
  516. $scope.closethis = function (formdata) {
  517. formdata.category = "";
  518. formdata.parent.category = "";
  519. };
  520. /* -----start submit incidet category----- */
  521. // 保存设置
  522. $scope.selectedchangecategory = { value: {} };
  523. $scope.$watch("selectedchangecategory.value", function (newVal) {
  524. console.log(newVal);
  525. if (newVal.user) {
  526. $scope.group_user["onlineUser"] = newVal.user || undefined;
  527. } else {
  528. $scope.group_user["onlineUser"] = undefined;
  529. }
  530. if (newVal.group) {
  531. $scope.group_user["offlineGroup"] = newVal.group || undefined;
  532. } else {
  533. $scope.group_user["offlineGroup"] = undefined;
  534. }
  535. });
  536. $scope.editInspection = function (tree, id, newVal, type) {
  537. tree.forEach((v) => {
  538. if (v.id == id) {
  539. v[type] = newVal;
  540. } else if (v.children) {
  541. $scope.editInspection(v.children, id, newVal, type);
  542. }
  543. });
  544. };
  545. $scope.$watch("group_user.offlineGroup", function (newVal) {
  546. console.log($scope.selectedchangecategory.value);
  547. console.log($scope.copyInspection.tree);
  548. console.log(newVal, "group");
  549. $scope.editInspection(
  550. $scope.copyInspection.tree,
  551. $scope.selectedchangecategory.value.id,
  552. newVal,
  553. "group"
  554. );
  555. if (newVal && newVal.id) {
  556. $scope.selectedchangecategory.value.group = newVal;
  557. } else {
  558. delete $scope.selectedchangecategory.value.group;
  559. }
  560. });
  561. $scope.$watch("group_user.onlineUser", function (newVal) {
  562. // console.log($scope.selectedchangecategory.value)
  563. // console.log($scope.copyInspection.tree)
  564. // console.log(newVal, 'user')
  565. $scope.editInspection(
  566. $scope.copyInspection.tree,
  567. $scope.selectedchangecategory.value.id,
  568. newVal,
  569. "user"
  570. );
  571. if (newVal && newVal.id) {
  572. $scope.selectedchangecategory.value.user = newVal;
  573. } else {
  574. delete $scope.selectedchangecategory.value.user;
  575. }
  576. });
  577. // 保存设置 liaomingming
  578. $scope.submit1change = function () {
  579. console.log($scope.everyDay);
  580. console.log($scope.notice);
  581. console.log($scope.copyInspection.tree);
  582. console.log($scope.stateModel);
  583. if ($scope.stateModel.model === 0) {
  584. // 不设置为模块的时候需要弹窗提示
  585. var modalInstance = $modal.open({
  586. templateUrl: "assets/views/system/tpl/inspectionModel.html",
  587. controller: function ($scope, scope, $modalInstance) {
  588. $scope.add1data = { model: false };
  589. $scope.title = "提示";
  590. $scope.cancel = function () {
  591. $modalInstance.dismiss("cancel");
  592. };
  593. $scope.savercode = function (data) {
  594. console.log(scope.copyInspection.tree);
  595. scope.stateModel.model = data.model ? 1 : 0;
  596. scope.saveCommon(scope);
  597. $modalInstance.close(data);
  598. };
  599. },
  600. resolve: {
  601. scope: function () {
  602. return $scope;
  603. },
  604. },
  605. });
  606. modalInstance.result.then(function (selectedItem) {});
  607. return;
  608. }
  609. $scope.saveCommon($scope);
  610. };
  611. // 暂存
  612. $scope.submit1change_save = function (flag) {
  613. $rootScope.isMask = true;
  614. var arr = $scope.TreeToArr($scope.copyInspection.tree, []);
  615. $scope.stateModel.modelName = $scope.modelName;
  616. $scope.stateModel.typeIds = arr.map((v) => v.id).toString();
  617. arr = arr.map((v) => ({
  618. inspection: $scope.stateModel.id,
  619. inspectionType: v.id,
  620. inspectionTypeName: v.name,
  621. parent: v.parent,
  622. user: v.user?v.user.id:undefined,
  623. userName: v.user?v.user.name:undefined,
  624. group: v.group?v.group.id:undefined,
  625. groupName: v.group?v.group.groupName:undefined,
  626. }));
  627. // 一条都没选择
  628. if (arr.length === 0) {
  629. arr.push({ inspection: $scope.stateModel.id });
  630. }
  631. console.log(arr);
  632. // return;
  633. api_simple.addListData("inspectionBind", arr).then(function (response) {
  634. if (response) {
  635. if (response.status == 200) {
  636. var filedata = {
  637. close: "关闭",
  638. save: "暂存",
  639. submit: "下一步",
  640. inspection: $scope.stateModel,
  641. };
  642. console.log($scope.notice);
  643. var inspectionMsgRules = $scope.notice.inspectionMsgRules.filter(v => v.checked);
  644. var user = $scope.notice.user;
  645. if(inspectionMsgRules.length){
  646. filedata.inspection.msgRules = inspectionMsgRules.map(v=>v.id).toString()
  647. }else{
  648. delete filedata.inspection.msgRules;
  649. }
  650. if(user.length){
  651. filedata.inspection.msgUsers = user.map(v=>v.id).toString()
  652. }else{
  653. delete filedata.inspection.msgUsers;
  654. }
  655. var dayMsgOnline = $scope.everyDay.everyDayNotices.find(v => v.id === 0).checked;//线上
  656. var dayMsgOffline = $scope.everyDay.everyDayNotices.find(v => v.id === 1).checked;//线下
  657. var dayMsgTime = $scope.everyDay.time;
  658. filedata.inspection.dayMsgOnline = dayMsgOnline ? 1: 0;
  659. filedata.inspection.dayMsgOffline = dayMsgOffline ? 1: 0;
  660. filedata.inspection.dayMsgTime = dayMsgTime ? (new Date(dayMsgTime).getTime()): (new Date().getTime());
  661. // 修改巡检计划 baba
  662. api_bpm_data
  663. .addData("inspection", filedata)
  664. .then(function (response) {
  665. $rootScope.isMask = false;
  666. if (response) {
  667. if (response.status == 200) {
  668. SweetAlert.swal(
  669. {
  670. title: "暂存成功!",
  671. type: "success",
  672. },
  673. function () {
  674. if(flag){
  675. $state.go('app.inspection.editor', {
  676. formKey: 'inspectionform',
  677. service: 'api_bpm_data',
  678. model: JSON.stringify({
  679. model: {
  680. inspection: filedata.inspection
  681. }
  682. })
  683. });
  684. }else{
  685. $scope.selectedchangecategory.value = {};
  686. $scope.copyInspection.tree = [];
  687. $scope.changecateObj.changecate = false;
  688. $scope.selectedInspection.isShowZtree = false;
  689. setTimeout(()=>{
  690. $scope.selectedInspection.isShowZtree = true;
  691. },0)
  692. }
  693. }
  694. );
  695. } else {
  696. SweetAlert.swal({
  697. title: "保存失败!",
  698. type: "error",
  699. });
  700. }
  701. }
  702. });
  703. } else {
  704. $rootScope.isMask = false;
  705. SweetAlert.swal({
  706. title: "保存失败!",
  707. type: "error",
  708. });
  709. }
  710. }else{
  711. $rootScope.isMask = false;
  712. }
  713. });
  714. };
  715. // 上一步
  716. $scope.submit1change_prev = function(){
  717. SweetAlert.swal(
  718. {
  719. title: "您是否暂存当前设置!",
  720. type: "warning",
  721. showCancelButton: true,
  722. confirmButtonColor: "#DD6B55",
  723. confirmButtonText: "是",
  724. cancelButtonText: "否",
  725. },
  726. function (isConfirm) {
  727. if (isConfirm) {
  728. $scope.submit1change_save(true);
  729. }else{
  730. window.history.back();
  731. }
  732. }
  733. );
  734. }
  735. $scope.closeModel = function () {
  736. $state.go("app.inspection.inspectPlan"); //跳转巡检计划列表
  737. };
  738. $scope.TreeToArr = function (tree, arr) {
  739. tree.forEach((v) => {
  740. if (v.children) {
  741. arr.push(v);
  742. $scope.TreeToArr(v.children, arr);
  743. } else {
  744. arr.push(v);
  745. }
  746. });
  747. return arr;
  748. };
  749. $scope.saveCommon = function ($scope) {
  750. if (!$scope.modelName.trim()) {
  751. SweetAlert.swal({
  752. title: "策略名称不能为空!",
  753. type: "error",
  754. });
  755. return;
  756. }
  757. $rootScope.isMask = true;
  758. var arr = $scope.TreeToArr($scope.copyInspection.tree, []);
  759. $scope.stateModel.modelName = $scope.modelName;
  760. $scope.stateModel.typeIds = arr.map((v) => v.id).toString();
  761. arr = arr.map((v) => ({
  762. inspection: $scope.stateModel.id,
  763. inspectionType: v.id,
  764. inspectionTypeName: v.name,
  765. parent: v.parent,
  766. user: v.user?v.user.id:undefined,
  767. userName: v.user?v.user.name:undefined,
  768. group: v.group?v.group.id:undefined,
  769. groupName: v.group?v.group.groupName:undefined,
  770. }));
  771. // 一条都没选择
  772. if (arr.length === 0) {
  773. arr.push({ inspection: $scope.stateModel.id });
  774. }
  775. console.log(arr);
  776. // return;
  777. api_simple.addListData("inspectionBind", arr).then(function (response) {
  778. $rootScope.isMask = false;
  779. if (response) {
  780. if (response.status == 200) {
  781. $scope.stateModel.status = { id: 120 }; //强制扭转状态为正常
  782. var filedata = {
  783. close: "关闭",
  784. save: "暂存",
  785. submit: "下一步",
  786. inspection: $scope.stateModel,
  787. };
  788. console.log($scope.notice);
  789. var inspectionMsgRules = $scope.notice.inspectionMsgRules.filter(v => v.checked);
  790. var user = $scope.notice.user;
  791. if(inspectionMsgRules.length){
  792. filedata.inspection.msgRules = inspectionMsgRules.map(v=>v.id).toString()
  793. }else{
  794. delete filedata.inspection.msgRules;
  795. }
  796. if(user.length){
  797. filedata.inspection.msgUsers = user.map(v=>v.id).toString()
  798. }else{
  799. delete filedata.inspection.msgUsers;
  800. }
  801. var dayMsgOnline = $scope.everyDay.everyDayNotices.find(v => v.id === 0).checked;//线上
  802. var dayMsgOffline = $scope.everyDay.everyDayNotices.find(v => v.id === 1).checked;//线下
  803. var dayMsgTime = $scope.everyDay.time;
  804. filedata.inspection.dayMsgOnline = dayMsgOnline ? 1: 0;
  805. filedata.inspection.dayMsgOffline = dayMsgOffline ? 1: 0;
  806. filedata.inspection.dayMsgTime = dayMsgTime ? (new Date(dayMsgTime).getTime()): (new Date().getTime());
  807. // 修改巡检计划 baba
  808. api_bpm_data
  809. .addData("inspection", filedata)
  810. .then(function (response) {
  811. if (response) {
  812. if (response.status == 200) {
  813. SweetAlert.swal(
  814. {
  815. title: "保存成功!",
  816. type: "success",
  817. },
  818. function () {
  819. $state.go("app.inspection.inspectPlan"); //跳转巡检计划列表
  820. }
  821. );
  822. } else {
  823. SweetAlert.swal({
  824. title: "保存失败!",
  825. type: "error",
  826. });
  827. }
  828. }
  829. });
  830. } else {
  831. SweetAlert.swal({
  832. title: "保存失败!",
  833. type: "error",
  834. });
  835. }
  836. }
  837. });
  838. };
  839. $scope.add1data = {};
  840. $scope.addparent = false;
  841. // 事件分类结束
  842. // 获取组数据
  843. $scope.getGroupList = function () {
  844. var postData = {
  845. idx: 0,
  846. sum: 1000,
  847. group: { selectType: "nouser" },
  848. };
  849. api_user_data.fetchDataList("group", postData).then((res) => {
  850. $scope.groupList = res.list;
  851. });
  852. };
  853. $scope.getGroupList();
  854. // 获取巡检计划数据
  855. $scope.getGroupList = function (model) {
  856. var postData = {
  857. idx: 0,
  858. sum: 3,
  859. inspection: { model: model },
  860. };
  861. api_user_data.fetchDataList("inspection", postData).then((res) => {
  862. if (model == 1) {
  863. $scope.listDataTop = res.list; //巡检范围策略模板
  864. } else {
  865. $scope.listDataBottom = res.list; //往期巡检范围策略
  866. }
  867. });
  868. };
  869. $scope.getGroupList(1);
  870. $scope.getGroupList();
  871. // 获取人数据
  872. $scope.getUserList = function () {
  873. var postData = {
  874. idx: 0,
  875. sum: 1000,
  876. user: {
  877. name: "",
  878. selectType: "pinyin_qs",
  879. },
  880. };
  881. api_user_data.fetchDataList("user", postData).then((res) => {
  882. $scope.userList = res.list;
  883. });
  884. };
  885. $scope.getUserList();
  886. $scope.changecateObj = {
  887. changecate: false,
  888. };
  889. // 缓存的绑定数据-http
  890. $scope.cacheHttp = {
  891. value: [],
  892. };
  893. },
  894. ]);
  895. app.directive("zTree", function () {
  896. // ztree liaomingming
  897. return {
  898. restrict: "EA",
  899. scope: {
  900. selectInspectionType: "=",
  901. copyInspectionType: "=",
  902. stateModel: "=",
  903. changecate: "=",
  904. cachehttp: "=",
  905. setFn: '&'
  906. },
  907. controller: function ($rootScope,$scope, $element, api_bpm_data, api_simple) {
  908. console.log($scope);
  909. getTreeInfo();
  910. function getTreeInfo() {
  911. $rootScope.isMask = true;
  912. $scope.treeInfo = [];
  913. var data = { idx: 0, sum: 1000, inspectionType: { deleteFlag: 0 } };
  914. $scope.isShowZtree = false;
  915. api_bpm_data
  916. .fetchDataList("inspectionType", data)
  917. .then(function (response) {
  918. var data = response.list;
  919. console.log(data);
  920. var objects = [];
  921. for (var i = 0; i < data.length; i++) {
  922. var object = {};
  923. object.id = data[i].id;
  924. if (angular.isDefined(data[i].user)) {
  925. object.user = data[i].user || {};
  926. }
  927. if (angular.isDefined(data[i].group)) {
  928. object.group = data[i].group || {};
  929. }
  930. if (angular.isDefined(data[i].parent)) {
  931. object.parent = data[i].parent;
  932. object.pId = data[i].parent.id;
  933. } else {
  934. object.pId = 0;
  935. }
  936. object.name = data[i].type;
  937. objects.push(object);
  938. }
  939. $scope.treeInfo = convertParentToChildList(objects);
  940. $scope.treeInfo = deleteEmputyChildren($scope.treeInfo);
  941. console.log($scope.treeInfo);
  942. // ==================start================
  943. api_simple
  944. .fetchDataList("inspectionBind", {
  945. idx: 0,
  946. sum: 1000,
  947. inspectionBind: { inspection: $scope.stateModel.currentId || $scope.stateModel.id },
  948. })
  949. .then(function (response) {
  950. $rootScope.isMask = false;
  951. $.fn.zTree.destroy("z-tree");
  952. $.fn.zTree.init($($element), setting, $scope.treeInfo);
  953. $scope.isShowZtree = true;
  954. var result = response.list || [];
  955. $scope.cachehttp = angular.copy(result);
  956. result = result.map((v) => v.inspectionType);
  957. console.log(result);
  958. var zTree = $.fn.zTree.getZTreeObj("z-tree");
  959. var nodesAll = zTree.transformToArray(zTree.getNodes());//全部节点转换成数组array
  960. $('#c_all').prop('checked', nodesAll.length === result.length);
  961. result.forEach((v) => {
  962. // 设置路径树节点选中
  963. // 1、根据id获取树的某个节点:
  964. var node = zTree.getNodeByParam("id", v);
  965. // 2、设置node节点选中状态:
  966. // zTree.selectNode(node);
  967. // 3、设置node节点checked选中:
  968. node.checked = true;
  969. //注:设置checked属性之后,一定要更新该节点
  970. zTree.updateNode(node);
  971. // console.log($scope.copyInspectionType)
  972. // zTree.expandNode(node);
  973. // setTimeout(() => {
  974. // zTreeOnCheck(null, null, node);
  975. // }, 0);
  976. });
  977. // zTree.expandAll(false);
  978. //展示选中的数据
  979. var arr = [];
  980. $scope.cachehttp.forEach(v=>{
  981. arr.push({
  982. id: v.inspectionType,
  983. name: v.inspectionTypeName,
  984. group: v.group?{id:v.group,groupName:v.groupName}:undefined,
  985. user: v.user?{id:v.user,name:v.userName}:undefined,
  986. parent: v.parent ? { id: v.parent.inspectionType } : undefined,
  987. pId: v.parent ? v.parent.inspectionType : 0,
  988. });
  989. })
  990. $scope.copyInspectionType = tranListToTreeData(arr);
  991. });
  992. // ==================end================
  993. });
  994. }
  995. function deleteEmputyChildren(data) {
  996. data.forEach((v) => {
  997. if (v.children.length) {
  998. deleteEmputyChildren(v.children);
  999. } else {
  1000. delete v.children;
  1001. }
  1002. });
  1003. return data;
  1004. }
  1005. function convertParentToChildList(data) {
  1006. var treeMap = {};
  1007. var list = [];
  1008. convertListToTree(data, treeMap);
  1009. angular.forEach(treeMap, function (item) {
  1010. list.push(item);
  1011. });
  1012. return list;
  1013. }
  1014. function convertListToTree(data, treeMap) {
  1015. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  1016. var root = null; //Initially set our loop to null
  1017. //loop over data
  1018. for (var i = 0; i < data.length; i++) {
  1019. var datum = data[i];
  1020. //each node will have children, so let's give it a "children" poperty
  1021. datum.children = [];
  1022. //add an entry for this node to the map so that any future children can
  1023. //lookup the parent
  1024. idToNodeMap[datum.id] = datum;
  1025. //Does this node have a parent?
  1026. // console.log("datum="+JSON.stringify(datum))
  1027. // if (typeof datum.parent === "undefined") {
  1028. if (datum.pId === 0) {
  1029. //Doesn't look like it, so this node is the root of the tree
  1030. root = datum;
  1031. treeMap[datum.id] = root;
  1032. } else {
  1033. //This node has a parent, so let's look it up using the id
  1034. // parentNode = idToNodeMap[datum.parent.id];
  1035. parentNode = idToNodeMap[datum.pId];
  1036. //We don't need this property, so let's delete it.
  1037. // delete datum.parent;
  1038. //Let's add the current node as a child of the parent node.
  1039. parentNode.children.push(datum);
  1040. }
  1041. }
  1042. return root;
  1043. }
  1044. var setting = {
  1045. check: {
  1046. enable: true,
  1047. chkStyle: "checkbox",
  1048. chkboxType: { Y: "ps", N: "ps" },
  1049. },
  1050. callback: {
  1051. onClick: onMouseDown,
  1052. onCheck: zTreeOnCheck,
  1053. },
  1054. view: {
  1055. showIcon: false,
  1056. showLine: false,
  1057. },
  1058. };
  1059. // $.fn.zTree.init($($element), setting, $scope.treeInfo);
  1060. //点击菜单项
  1061. function onMouseDown(event, treeId, treeNode) {
  1062. console.log(event, treeId, treeNode);
  1063. $scope.selectInspectionType = treeNode;
  1064. }
  1065. // 点击复选框
  1066. function zTreeOnCheck(event, treeId, treeNode) {
  1067. console.log(event, treeId, treeNode);
  1068. $scope.changecate = false;
  1069. var treeObj = $.fn.zTree.getZTreeObj("z-tree");
  1070. var nodesAll = treeObj.transformToArray(treeObj.getNodes());//全部节点转换成数组array
  1071. var nodes_arr = treeObj.getCheckedNodes(true);
  1072. var nodes = angular.copy(nodes_arr);
  1073. $('#c_all').prop('checked', nodesAll.length === nodes_arr.length);
  1074. console.log(nodes);
  1075. if ($scope.cachehttp && $scope.cachehttp.length) {
  1076. var result = angular.copy($scope.cachehttp);
  1077. zTreeOnCheckCommon(result, nodes);
  1078. } else {
  1079. api_simple
  1080. .fetchDataList("inspectionBind", {
  1081. idx: 0,
  1082. sum: 1000,
  1083. inspectionBind: { inspection: $scope.stateModel.id },
  1084. })
  1085. .then(function (response) {
  1086. var result = response.list || [];
  1087. zTreeOnCheckCommon(result, nodes);
  1088. });
  1089. }
  1090. }
  1091. function tranListToTreeData(nodes){
  1092. var arr = nodes.filter((v) => v.pId === 0);
  1093. arr.forEach((v) => {
  1094. // v.children = [];
  1095. delete v.children;
  1096. });
  1097. arr.forEach((v) => {
  1098. nodes.forEach((vv) => {
  1099. if (vv.pId == v.id) {
  1100. if(v.children){
  1101. v.children.push(vv);
  1102. }else{
  1103. v.children = [vv];
  1104. }
  1105. }
  1106. });
  1107. });
  1108. return arr;
  1109. }
  1110. $scope.clickDirective = function () {
  1111. console.log('全选');
  1112. var zTree = $.fn.zTree.getZTreeObj("z-tree");//得到tree对象 treeMenu是我的treeid
  1113. var node = zTree.getNodes();//得到全部节点
  1114. var nodes = zTree.transformToArray(node);//全部节点转换成数组array
  1115. var checkNode = zTree.getCheckedNodes().length;//得到被选中的节点数量,zTree.getCheckedNodes()和zTree.getCheckedNodes(true)一样,可以传参(true/false),默认是true
  1116. if (checkNode < nodes.length) {//已选中的节点数小于总数 - 全选
  1117. zTree.checkAllNodes(true);//给全部节点设置为true
  1118. zTreeOnCheckCommon([], nodes)
  1119. } else{
  1120. zTree.checkAllNodes(false);//给全部节点设置为false
  1121. zTreeOnCheckCommon([], [])
  1122. }
  1123. }
  1124. $scope.setFn.call($scope, {
  1125. params: $scope.clickDirective
  1126. })
  1127. // 点击复选框-common
  1128. function zTreeOnCheckCommon(result, nodes) {
  1129. // 如果有值,则不覆盖
  1130. if($scope.copyInspectionType.length){
  1131. result = [];
  1132. $scope.copyInspectionType.forEach(v=>{
  1133. result.push(v);
  1134. if(v.children && v.children.length){
  1135. v.children.forEach(vv=>{
  1136. result.push(vv);
  1137. })
  1138. }
  1139. })
  1140. }else{
  1141. result = result.map((v) => ({
  1142. id: v.inspectionType,
  1143. name: v.inspectionTypeName,
  1144. group: v.group?{id:v.group,groupName:v.groupName}:undefined,
  1145. user: v.user?{id:v.user,name:v.userName}:undefined,
  1146. parent: v.parent ? { id: v.parent.inspectionType } : undefined,
  1147. pId: v.parent ? v.parent.inspectionType : 0,
  1148. }));
  1149. }
  1150. for (var i = 0; i < nodes.length; i++) {
  1151. for (var j = 0; j < result.length; j++) {
  1152. if (nodes[i].id == result[j].id) {
  1153. nodes[i] = angular.copy(result[j]);
  1154. }
  1155. }
  1156. }
  1157. $scope.copyInspectionType = tranListToTreeData(nodes);
  1158. }
  1159. },
  1160. };
  1161. });
  1162. app.directive("zTreeCopy", function () {
  1163. // ztree liaomingming
  1164. return {
  1165. restrict: "EA",
  1166. scope: {
  1167. copyInspectionType: "=",
  1168. changecate: "=",
  1169. selectedchangecategory: "=",
  1170. },
  1171. link: function (scope, element, attrs) {
  1172. scope.$watch("copyInspectionType", function (newVal) {
  1173. console.log(newVal);
  1174. var setting = {
  1175. view: {
  1176. showIcon: false,
  1177. showLine: false,
  1178. },
  1179. callback: {
  1180. onClick: onMouseDown,
  1181. },
  1182. };
  1183. $.fn.zTree.destroy("z-tree-copy");
  1184. $.fn.zTree.init($(element), setting, newVal);
  1185. // var treeObj = $.fn.zTree.init($(element), setting, newVal);
  1186. // treeObj.expandAll(true);
  1187. });
  1188. //点击菜单项
  1189. function onMouseDown(event, treeId, treeNode) {
  1190. console.log(event, treeId, treeNode);
  1191. scope.selectedchangecategory = treeNode;
  1192. scope.changecate = true;
  1193. console.log(scope.copyInspectionType);
  1194. }
  1195. },
  1196. controller: function ($scope, $element, api_bpm_data) {},
  1197. };
  1198. });