Untitled-6 75 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513
  1. 'use strict';
  2. var cmdbFormly = angular.module('formlyCMDB', [
  3. 'formly', 'formlyBootstrap', 'ui.bootstrap',
  4. 'ngSanitize', 'ui.select', 'ui.grid'
  5. ]);
  6. app.requires.push('formlyCMDB');
  7. cmdbFormly.controller('gdzc_meansformCtrl', ['$rootScope', '$scope', '$parse', '$injector', '$http', '$q', '$state', '$stateParams', '$modal', '$timeout', '$interval', 'i18nService', 'SweetAlert', 'FileUploader', 'Restangular', 'UserRestangular', 'BpmRestangular', 'api_configure_form', 'api_configure_data', 'api_bpm_domain', 'api_bpm_data', 'api_user_data', 'api_cmdb', 'api_sysinfo',
  8. function($rootScope, $scope, $parse, $injector, $http, $q, $state, $stateParams, $modal, $timeout, $interval, i18nService, SweetAlert, FileUploader, Restangular, UserRestangular, BpmRestangular, api_configure_form, api_configure_data, api_bpm_domain, api_bpm_data, api_user_data, api_cmdb, api_sysinfo) {
  9. // $scope.haha=true;
  10. $scope.langs = i18nService.getAllLangs();
  11. $scope.lang = 'zh-cn';
  12. i18nService.setCurrentLang($scope.lang);
  13. $scope.width = { 'width': document.getElementById("mapwidth").offsetWidth - 201 };
  14. $scope.widthonly = document.getElementById("mapwidth").offsetWidth - 201;
  15. window.onresize = function() {
  16. if (document.getElementById("mapwidth")) {
  17. $scope.width = { 'width': document.getElementById("mapwidth").offsetWidth - 201 };
  18. $scope.widthonly = document.getElementById("mapwidth").offsetWidth - 201;
  19. }
  20. }
  21. $scope.widthonly = function() {
  22. if (document.getElementById("mapwidth")) {
  23. return document.getElementById("mapwidth").offsetWidth - 201;
  24. }
  25. }
  26. var vm = this;
  27. vm.options = {};
  28. vm.exampleTitle = ['expressionProperties', 'model property'];
  29. vm.fields = [];
  30. vm.model = {};
  31. vm.model["loginUser"] = $rootScope.user;
  32. var that = $injector;
  33. var parse = $parse;
  34. var formKey = "";
  35. var pdKey = "";
  36. if (angular.isDefined($state.current.pdKey) && $state.current.pdKey != "") {
  37. pdKey = $state.current.pdKey;
  38. //console.log("pdKey::"+$state.current.pdKey);
  39. }
  40. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  41. formKey = $stateParams.formKey;
  42. // console.log(formKey);
  43. //console.log("formKey::"+$stateParams.formKey);
  44. }
  45. //关系图
  46. var dom = document.getElementById("meansmap");
  47. var myChart = echarts.init(dom);
  48. var app = {};
  49. var option = null;
  50. $scope.guanlianable = false;
  51. $scope.cmdbtype = {};
  52. myChart.showLoading();
  53. var startdata = JSON.parse($stateParams.model).model;
  54. var data = [{
  55. // "node": startdata.props.hw_mingcheng,
  56. // "id": startdata.id,
  57. // "uuid": startdata.uuid,
  58. // "endpoint": [
  59. // // "节点6",
  60. // // "节点8"
  61. // ],
  62. // "service": [
  63. // // "java.local.name_1",
  64. // // "java.local.name_11"
  65. // ]
  66. // }, {
  67. // "node": "测试",
  68. // "id": 1,
  69. // "uuid": 1,
  70. // "endpoint": [
  71. // { "node": "节点6", "link": "连接" }
  72. // ],
  73. // "service": [
  74. // "java.local.name_1",
  75. // // "java.local.name_11"
  76. // ]
  77. // }, {
  78. // "node": "节点6",
  79. // "id": 2,
  80. // "uuid": 2,
  81. // "endpoint": [
  82. // { "node": "测试", "link": "连接" }
  83. // ],
  84. // "service": [
  85. // // "java.local.name_1",
  86. // "java.local.name_11"
  87. // ]
  88. // }
  89. // {
  90. "node": "节点2",
  91. "endpoint": [
  92. "节点6",
  93. "节点7"
  94. ],
  95. "service": [
  96. "java.local.name_2",
  97. "java.local.name_22"
  98. ]
  99. }, {
  100. "node": "节点4",
  101. "endpoint": [
  102. "节点6"
  103. ],
  104. "service": [
  105. "java.local.name_4",
  106. "java.local.name_44"
  107. ]
  108. }, {
  109. "node": "节点5",
  110. "endpoint": [
  111. "节点6"
  112. ],
  113. "service": [
  114. "java.local.name_5",
  115. ]
  116. }
  117. // }, {
  118. // "node": "节点6",
  119. // "endpoint": [
  120. // "节点1",
  121. // ],
  122. // "service": [
  123. // "java.local.name_6",
  124. // "java.local.name_66"
  125. // ]
  126. // }, {
  127. // "node": "节点7",
  128. // "endpoint": [
  129. // "节点6",
  130. // "节点2"
  131. // ],
  132. // "service": [
  133. // "java.local.name_7",
  134. // "java.local.name_77"
  135. // ]
  136. // }
  137. ];
  138. function get_nodes(data) {
  139. var nodes = [];
  140. var tmp_nodes = [];
  141. for (var nodes_i in data) {
  142. tmp_nodes.push(data[nodes_i].node);
  143. nodes.push({
  144. 'name': data[nodes_i].node,
  145. "id": data[nodes_i].id,
  146. "uuid": data[nodes_i].uuid
  147. });
  148. }
  149. return nodes;
  150. }
  151. function get_links(data) {
  152. var links = [];
  153. for (var nodes_i in data) {
  154. var node = data[nodes_i].node;
  155. var endpoint = data[nodes_i].endpoint;
  156. var service = data[nodes_i].service;
  157. // console.log(service);
  158. for (var service_i in endpoint) {
  159. links.push({
  160. 'source': node,
  161. 'target': endpoint[service_i],
  162. 'label': {
  163. 'normal': {
  164. 'show': false,
  165. 'textStyle': {
  166. 'fontSize': 5
  167. },
  168. 'formatter': service
  169. }
  170. },
  171. 'lineStyle': {
  172. 'normal': {
  173. 'curveness': 0.1
  174. }
  175. }
  176. })
  177. }
  178. }
  179. for (var i = 0, len1 = links.length; i < len1; i++) {
  180. for (var j = i, len2 = len1 - 1; j < len2; j++) {
  181. if (links[i].source == links[j].target) {
  182. links[j].lineStyle.normal.curveness = -0.1;
  183. }
  184. }
  185. }
  186. // console.log(links);
  187. return links;
  188. }
  189. myChart.hideLoading();
  190. var option = {
  191. title: {
  192. text: '调用关系demo'
  193. },
  194. // tooltip: {
  195. //formatter: '调用方法'
  196. // },
  197. animationDurationUpdate: 1500,
  198. animationEasing: 'cubicOut',
  199. animationEasingUpdate: 'quinticInOut',
  200. series: [{
  201. type: 'graph',
  202. layout: 'circular',
  203. // layout:'none',
  204. focusNodeAdjacency: true,
  205. legendHoverLink: true,
  206. hoverAnimation: true,
  207. symbolSize: 50,
  208. //edgeSymbolSize: 50,
  209. roam: true,
  210. symbol: "roundRect",
  211. label: {
  212. normal: {
  213. show: true,
  214. }
  215. },
  216. edgeSymbol: ['circle', 'arrow'],
  217. edgeSymbolSize: [4, 15],
  218. edgeLabel: {
  219. normal: {
  220. textStyle: {
  221. fontSize: 20
  222. }
  223. }
  224. },
  225. data: get_nodes(data),
  226. links: get_links(data),
  227. lineStyle: {
  228. normal: {
  229. opacity: 0.9,
  230. width: 2,
  231. curveness: 0,
  232. type: 'dashed'
  233. }
  234. }
  235. }, ]
  236. };
  237. // //添加点击事件
  238. // myChart.on('click', function(params) {
  239. // // 弹窗打印数据的名称
  240. // console.log(params);
  241. // if (params.dataType == "node") {
  242. // alert("机器属性:" + params.name);
  243. // } else if (params.dataType == "edge") {
  244. // alert("调用方法:" + params.data.label.normal.formatter);
  245. // }
  246. // });
  247. if (option && typeof option === "object") {
  248. myChart.setOption(option, true);
  249. }
  250. function getchild(itemone, result, param) {
  251. angular.forEach(itemone, function(itemtwo, i) {
  252. if (itemtwo.id == param.id) {
  253. itemtwo.children = [];
  254. if (result && result.length > 0) {
  255. angular.forEach(result, function(ite) {
  256. itemone[i].children.push({ "id": ite.id, "name": ite.props.hw_mingcheng, "uuid": ite.uuid });
  257. })
  258. }
  259. } else {
  260. if (itemtwo.children) {
  261. getchild(itemone[i].children, result, param)
  262. }
  263. }
  264. })
  265. // return itemone;
  266. }
  267. function getinternetAlarm(getmodel) {
  268. // console.log($scope);
  269. api_cmdb.findRefById(getmodel.id).then(function(result) {
  270. getchild(option.series[0].data, result.data.node, getmodel);
  271. console.log(option)
  272. myChart.setOption(option, true);
  273. myChart.hideLoading();
  274. })
  275. }
  276. // getinternetAlarm(startdata);
  277. myChart.on("click", clickFun);
  278. function clickFun(param) {
  279. if (typeof param.seriesIndex == 'undefined') {
  280. return;
  281. }
  282. if (param.type == 'click') {
  283. $scope.guanlianable = true;
  284. $scope.cmdbtype = param;
  285. $scope.$apply();
  286. getinternetAlarm(param.data);
  287. // if (!param.data.children || param.data.children.length == 0) {
  288. // getinternetAlarm(param.data);
  289. // } else {
  290. // }
  291. }
  292. }
  293. $scope.changemeans = function() {
  294. var modalInstance = $modal.open({
  295. templateUrl: 'assets/views/means/tpl/meansmap.html',
  296. controller: function($scope, scope, $modalInstance) {
  297. $scope.key = {};
  298. $scope.guanxi = { "cmdbname": {}, "name": '' };
  299. $scope.linktypeOptions = scope.linktypeOptions;
  300. $scope.guanxidata = [
  301. { id: 0, name: '连接', value: 'link' },
  302. { id: 1, name: '安装部署', value: 'link' },
  303. { id: 2, name: '归属', value: 'link' },
  304. { id: 3, name: '使用', value: 'link' },
  305. { id: 4, name: '互备', value: 'link' },
  306. { id: 5, name: '主备', value: 'link' }
  307. ];
  308. $scope.ok = function(key) {
  309. $modalInstance.close(key);
  310. };
  311. $scope.openModal = function(size, options, modal) {
  312. var modalInstance = $modal.open({
  313. templateUrl: 'assets/views/customform/tpl/cmdb/add_shebei.html',
  314. controller: function($scope, i18nService, $modalInstance, api_configure_data, api_configure_form, api_cmdb) {
  315. $scope.langs = i18nService.getAllLangs();
  316. $scope.lang = 'zh-cn';
  317. i18nService.setCurrentLang($scope.lang);
  318. $scope.gridOptions = {};
  319. $scope.gridOptions.data = 'myDatatwo';
  320. $scope.gridOptions.enableColumnResizing = true;
  321. $scope.gridOptions.enableFiltering = false;
  322. $scope.gridOptions.enableGridMenu = false;
  323. $scope.gridOptions.showGridFooter = true;
  324. $scope.gridOptions.showColumnFooter = false;
  325. $scope.gridOptions.fastWatch = true;
  326. $scope.gridOptions.useExternalFiltering = true;
  327. $scope.gridOptions.useExternalPagination = true;
  328. $scope.gridOptions.paginationPageSizes = [10, 20, 50, 100];
  329. $scope.gridOptions.paginationPageSize = 10;
  330. $scope.gridOptions.multiSelect = false;
  331. $scope.gridOptions.rowIdentity = function(row) {
  332. return row.id;
  333. };
  334. $scope.gridOptions.getRowIdentity = function(row) {
  335. return row.id;
  336. };
  337. // $scope.gridOptions.rowTemplate = "<div ng-dblclick=\"grid.appScope.pdList.onDblClick(row,$event)\" 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>";
  338. $scope.gridOptions.columnDefs = [
  339. { name: 'item', displayName: '序号', width: 80, enableFiltering: false },
  340. { name: 'uuid', displayName: '内部编号', width: 120 },
  341. { name: 'props.hw_mingcheng', displayName: '资产名称', width: 100 },
  342. { name: 'props.hw_cifilterClassic', displayName: '资产类型', width: 80, enableFiltering: false },
  343. // { name: 'type', displayName: '资产型号', width: 100, enableFiltering: false },
  344. { name: 'props.hw_state', displayName: '资产状态', width: 150, enableFiltering: false },
  345. { name: 'props.hwnw_area', displayName: '资产地点', width: 130, enableFiltering: false },
  346. { name: 'createtime', displayName: '申请时间', enableFiltering: false }
  347. ];
  348. // $scope.selectButtonClick
  349. var defaultFilterData = {
  350. // "assignee":2,
  351. // "sign":"basehwitndl",
  352. // "applicationForm": { "hw_state": "在线" },
  353. "idx": 0,
  354. "sum": 10
  355. };
  356. $scope.memoryfilterData = {
  357. // "assignee":2,
  358. // "sign":"basehwitndl",
  359. // "applicationForm": { "hw_state": "在线" },
  360. "idx": 0,
  361. "sum": 10
  362. }
  363. $scope.refreshData = function(style, filterData) {
  364. if (angular.isUndefined(filterData)) {
  365. filterData = defaultFilterData;
  366. }
  367. $scope.myDatatwo = [];
  368. // $scope.gridOptions['sum']=filterData.sum;
  369. api_cmdb.query(filterData).then(function(data) {
  370. // $scope.callsPending--;
  371. var filterData = $scope.memoryfilterData;
  372. var myDatatwo = Restangular.stripRestangular(data);
  373. $scope.gridOptions['totalItems'] = data.total;
  374. for (var i = 0; i < myDatatwo.data.node.length; i++) {
  375. myDatatwo.data.node[i].createtime = moment(myDatatwo.data.node[i].createtime).format('YYYY-MM-DD');
  376. }
  377. $scope.myDatatwo = myDatatwo.data.node;
  378. for (var i = 0; i < $scope.myDatatwo.length; i++) {
  379. $scope.myDatatwo[i]['item'] = i + 1 + filterData.idx * filterData.sum
  380. }
  381. }, function() {});
  382. };
  383. $scope.refreshData('expand-right', defaultFilterData);
  384. $scope.gridOptions.onRegisterApi = function(gridApi) {
  385. $scope.gridApi = gridApi;
  386. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  387. var filtersData = $scope.memoryfilterData;
  388. filtersData.idx = newPage - 1;
  389. filtersData.sum = pageSize;
  390. // $scope.loadData(filtersData);
  391. $scope.refreshData('expand-right', filtersData);
  392. //console.log(pageSize);
  393. // $scope.loadData({"idx":newPage-1,"sum":pageSize});
  394. });
  395. // gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  396. // $scope.selected.items.push(data.entity);
  397. //console.log(data);
  398. gridApi.selection.on.rowSelectionChanged($scope, function(scope, ect) {
  399. if (scope.isSelected) {
  400. scope.grid.appScope.selected.items.push(scope.entity)
  401. } else {
  402. for (var i = 0; i <= scope.grid.appScope.selected.items.length; i++) {
  403. if (scope.grid.appScope.selected.items[i].id == scope.entity.id) {
  404. scope.grid.appScope.selected.items.splice(i, 1);
  405. break;
  406. }
  407. }
  408. }
  409. $scope.mySelectedRows = $scope.gridApi.selection.getSelectedRows();
  410. });
  411. // });
  412. gridApi.selection.on.rowSelectionChangedBatch($scope, function(rows) {
  413. // $scope.selected.items = data.entity;
  414. //console.log(data);
  415. var selectitem = [];
  416. selectitem = angular.copy($scope.selected.items);
  417. for (var j = 0; j < rows.length; j++) {
  418. if (rows[j].isSelected == true) {
  419. selectitem.push(rows[j].entity);
  420. } else {
  421. delete selectitem[j];
  422. // rows.splice(j, 1);
  423. }
  424. }
  425. $scope.selected.items = [];
  426. for (var i = 0; i < selectitem.length; i++) {
  427. if (selectitem[i]) {
  428. $scope.selected.items.push(selectitem[i]);
  429. }
  430. }
  431. });
  432. // gridApi.selection.on.selectAllRows = function(row) { //GridRow
  433. // // if (row.entity.age > 45) {
  434. // row.grid.api.selection.selectRow(row.entity); // 选中行
  435. // // }
  436. // };
  437. gridApi.core.on.filterChanged($scope, function() {
  438. var grid = this.grid;
  439. var filtersData = {
  440. idx: 0,
  441. sum: 10,
  442. "user": { "roledata": { "rolecode": "roleset" }, "selectType": "1" }
  443. };
  444. angular.forEach(grid.columns, function(item) {
  445. if (item.enableFiltering) {
  446. // console.log("item.filters[0]=" + JSON.stringify(item.filters));
  447. if (angular.isDefined(item.filters[0].term) && item.filters[0].term != '') {
  448. if (angular.isUndefined(filtersData['user'])) {
  449. filtersData['user'] = {};
  450. }
  451. filtersData['user'][item.field] = item.filters[0].term;
  452. }
  453. }
  454. });
  455. $scope.memoryfilterData = filtersData;
  456. // $scope.loadData(filtersData);
  457. });
  458. };
  459. $scope.onDblClick = function(data, event) {
  460. // $scope.selected.items = data.entity;
  461. $scope.selectButtonClick(data, event);
  462. };
  463. // $scope.loadData = function(filterData) {
  464. // // console.log("filtersData=111" + JSON.stringify(filterData))
  465. // items.fetchItems(filterData, APIService).then(function(data) {
  466. // var myDatatwo = Restangular.stripRestangular(data);
  467. // $scope.gridOptions.totalItems = myDatatwo.totalNum;
  468. // $scope.myDatatwo = myDatatwo.list;
  469. // });
  470. // };
  471. //树形图
  472. var apple_selected, tree, treedata_avm, treedata_geography;
  473. $scope.my_tree_handler = function(branch) {
  474. //var _ref;
  475. var classify = $scope.classify = branch.prefix.toLowerCase() + branch.sign;
  476. api_cmdb.query({ 'sign': classify }).then(function(data) {
  477. var myDatalingbei = Restangular.stripRestangular(data);
  478. // console.log(myData.data.node);
  479. if (myDatalingbei.data && myDatalingbei.status == 200) {
  480. var ret = myDatalingbei.data;
  481. redrawSvg(myDatalingbei);
  482. }
  483. });
  484. };
  485. $scope.my_data = [];
  486. function convertListToTree(data, treeMap) {
  487. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  488. var root = null; //Initially set our loop to null
  489. var parentNode = null;
  490. //loop over data
  491. for (var i = 0; i < data.length; i++) {
  492. var datum = data[i];
  493. //each node will have children, so let's give it a "children" poperty
  494. datum.children = [];
  495. //add an entry for this node to the map so that any future children can
  496. //lookup the parent
  497. idToNodeMap[datum.id] = datum;
  498. //Does this node have a parent?
  499. if (typeof datum.parent === "undefined" || datum.parent == null) {
  500. //Doesn't look like it, so this node is the root of the tree
  501. root = datum;
  502. treeMap[datum.id] = root;
  503. } else {
  504. //This node has a parent, so let's look it up using the id
  505. parentNode = idToNodeMap[datum.parent.id];
  506. //We don't need this property, so let's delete it.
  507. delete datum.parent;
  508. //Let's add the current node as a child of the parent node.
  509. parentNode.children.push(datum);
  510. }
  511. }
  512. return root;
  513. }
  514. function convertParentToChildList(data) {
  515. var treeMap = {};
  516. var list = [];
  517. convertListToTree(data, treeMap);
  518. angular.forEach(treeMap, function(item) {
  519. list.push(item);
  520. });
  521. return list;
  522. }
  523. $scope.my_tree = tree = {};
  524. $scope.try_async_load = function() {
  525. $scope.my_data = [];
  526. $scope.select_treedata = [];
  527. $scope.doing_async = true;
  528. api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  529. //console.log(result['list']);
  530. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  531. $scope.doing_async = false;
  532. // tree.expand_all();
  533. //console.log(treelist);
  534. });
  535. };
  536. $scope.select_treedata = [];
  537. $scope.propTypeOptions = [];
  538. $scope.try_async_load();
  539. $scope.onFilterremove = function(item) {
  540. console.log(item)
  541. }
  542. $scope.searchdata = {};
  543. $scope.clear = function() {
  544. $scope.searchdata = {};
  545. $scope.cifilter_classic = {};
  546. $scope.try_async_load();
  547. var fildata = {
  548. idx: 0,
  549. sum: 10,
  550. }
  551. $scope.memoryfilterData = fildata;
  552. $scope.refreshData('expand-right', fildata);
  553. }
  554. $scope.cifilter_classic = {};
  555. $scope.chiceIncident = function(item) {
  556. var fildata = defaultFilterData;
  557. // fildata.applicationForm = {};
  558. // sign: basehwnwswt
  559. if (item && item.id) {
  560. var classify = item.prefix.toLowerCase() + item.sign;
  561. fildata.sign = classify
  562. }
  563. $scope.gridOptions.paginationCurrentPage = 1;
  564. var transitiondata = angular.copy(item);
  565. $scope.refreshData('expand-right', fildata);
  566. }
  567. $scope.applicadata = [];
  568. $scope.onFilterCallback = function(item) {
  569. var tempclassify = item.prefix.toLowerCase() + item.sign;
  570. api_configure_form.renderTabForm(tempclassify).then(function(data) {
  571. var myData = Restangular.stripRestangular(data);
  572. $scope.applicadata = myData[0].form.fields;
  573. });
  574. // }
  575. }
  576. // $scope.loadData({
  577. // idx: 0,
  578. // sum: 10,
  579. // "user": { "roledata": { "rolecode": "roleset" }, "selectType": "1" }
  580. // });
  581. $scope.selected = {
  582. items: []
  583. };
  584. $scope.ok = function() {
  585. // if(onDataCallback&&angular.isFunction(onDataCallback)){
  586. // onDataCallback($scope.selected.item, parentScope);
  587. // }
  588. $modalInstance.close($scope.selected.items);
  589. };
  590. $scope.cancel = function() {
  591. $modalInstance.dismiss('cancel');
  592. };
  593. },
  594. size: 'lg'
  595. });
  596. modalInstance.result.then(function(selectedItem) {
  597. $scope.guanxi.cmdbname = selectedItem[0];
  598. }, function() {});
  599. }
  600. $scope.cancel = function() {
  601. $modalInstance.dismiss('cancel');
  602. };
  603. },
  604. size: 'sm',
  605. resolve: {
  606. scope: function() {
  607. return $scope;
  608. }
  609. }
  610. });
  611. modalInstance.result.then(function(selectedItem) {
  612. if (selectedItem) {
  613. var fildata = { "id": -1, "name": selectedItem.name.value, "source": selectedItem.cmdbname.id, "target": $scope.cmdbtype.data.id, "left": true, "right": false, "props": {} }
  614. api_cmdb.createRef(fildata).then(function(response) {
  615. if (response && response.status == 200) {
  616. } else {
  617. }
  618. });
  619. } else {
  620. // SweetAlert.swal({
  621. // title: "未选择资产关系!",
  622. // text: "请选择资产关系",
  623. // type: "error"
  624. // })
  625. }
  626. });
  627. }
  628. //关系图end
  629. //用户测试数据,后续从header的auth中获取
  630. var userId = 2;
  631. userId = $rootScope.user.id;
  632. //==============处理表单设计数据 开始====================
  633. //处理组件加载后台数据选项的方法
  634. function refreshSelectOptions(searchVal, field) {
  635. if (field.templateOptions.optionsUrl) {
  636. var process = BpmRestangular.all("");
  637. if (field.templateOptions.ApiService) {
  638. process = UserRestangular.all("");
  639. }
  640. process.customPOST({ "idx": 0, "sum": 1000 }, field.templateOptions.optionsUrl).then(function(result) {
  641. if (!field.templateOptions.options) {
  642. field.templateOptions.options = [];
  643. }
  644. if (field.templateOptions.optionsDataKey) {
  645. field.templateOptions.options = result[field.templateOptions.optionsDataKey];
  646. } else {
  647. field.templateOptions.options = result;
  648. }
  649. });
  650. }
  651. }
  652. function decodeVMTabForm(model, tabs) {
  653. var result = { model: {}, tabs: [] };
  654. var mdata = angular.fromJson(model);
  655. angular.extend(result.model, mdata);
  656. angular.forEach(tabs, function(tab) {
  657. tab.form.model = vm.model;
  658. angular.forEach(tab.form.fields, function(field) {
  659. if (field.key == "") {
  660. delete field.key;
  661. }
  662. if (angular.isDefined(field.extjson) && field.extjson != "") {
  663. var extObj = angular.fromJson(field.extjson);
  664. angular.extend(field.templateOptions, extObj.templateOptions);
  665. delete extObj.templateOptions;
  666. for (var prop in extObj) {
  667. if (new RegExp("Expression").test(prop)) {
  668. //var obj = $scope.$eval(extObj[prop]);
  669. //extObj[prop] = $scope.$eval(extObj[prop]);
  670. if (extObj[prop] != null) {
  671. if (new RegExp("function").test(extObj[prop])) {
  672. var propValue = eval(extObj[prop]);
  673. extObj[prop] = propValue;
  674. } else {
  675. //console.log(extObj[prop]);
  676. var obj = $scope.$eval(extObj[prop]);
  677. extObj[prop] = obj;
  678. //console.log(obj);
  679. }
  680. }
  681. } else if (new RegExp("expressionProperties").test(prop)) {
  682. for (var p in extObj[prop]) {
  683. if (new RegExp("function").test(extObj[prop][p])) {
  684. var propValue = eval(extObj[prop][p]);
  685. extObj[prop][p] = propValue;
  686. } else {
  687. //if(p.indexOf("'")>=0){
  688. // var obj = $scope.$eval(extObj[prop][p]);
  689. // extObj[prop][$scope.$eval(p)]=obj;
  690. //}
  691. }
  692. }
  693. } else if ("watcher" == prop) {
  694. if (angular.isArray(extObj[prop])) {
  695. angular.forEach(extObj[prop], function(item, index) {
  696. for (var p in item) {
  697. if (new RegExp("function").test(item[p])) {
  698. var propValue = eval(item[p]);
  699. extObj[prop][index][p] = propValue;
  700. }
  701. }
  702. });
  703. } else if (angular.isObject(extObj[prop])) {
  704. for (var p in extObj[prop]) {
  705. if (new RegExp("function").test(extObj[prop][p])) {
  706. var propValue = eval(extObj[prop][p]);
  707. extObj[prop][p] = propValue;
  708. }
  709. }
  710. }
  711. }
  712. }
  713. angular.extend(field, extObj);
  714. delete field.extjson;
  715. }
  716. if (field.extjson == "") {
  717. delete field.extjson;
  718. }
  719. if (angular.isDefined(field.templateOptions)) {
  720. var templateOs = field.templateOptions;
  721. for (var property in templateOs) {
  722. //console.log(property);
  723. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  724. if (new RegExp("function").test(templateOs[property])) {
  725. var propValue = eval(templateOs[property]);
  726. field.templateOptions[property] = propValue;
  727. } else {
  728. if (that.has(templateOs[property])) {
  729. field.templateOptions[property] = that.get(templateOs[property]);
  730. } else {
  731. field.templateOptions[property] = templateOs[property];
  732. }
  733. }
  734. } else if (templateOs[property] == null) {
  735. //delete field.templateOptions[property];
  736. } else {}
  737. }
  738. }
  739. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  740. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  741. angular.extend(field.templateOptions, extObj);
  742. delete field.templateOptions.extjson;
  743. }
  744. //...
  745. if (field.templateOptions) {
  746. //处理远程获取数据控件方法调用
  747. if (field.templateOptions.optionsUrl) {
  748. field.templateOptions.refresh = refreshSelectOptions;
  749. }
  750. //处理嵌套属性数据绑定/
  751. if (field.templateOptions.pkey) {
  752. var pmodel, i = 0;
  753. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  754. if (i == 0) {
  755. if (result.model[p] == null) {
  756. result.model[p] = {};
  757. }
  758. pmodel = result.model[p];
  759. i++;
  760. } else {
  761. if (pmodel[p] == null) {
  762. pmodel[p] = {};
  763. }
  764. pmodel = pmodel[p];
  765. }
  766. });
  767. if (pmodel != null) {
  768. field.model = pmodel;
  769. if (pmodel[field.key] == null) {
  770. pmodel[field.key] = null;
  771. }
  772. }
  773. } else {
  774. if (result.model[field.key] == null) {
  775. result.model[field.key] = null;
  776. }
  777. }
  778. //处理弹出框组件初始化
  779. if (field.type == "ui-input-selectmodal") {
  780. field.templateOptions.modal = $modal;
  781. //field.templateOptions.Restangular = Restangular;
  782. } else if (field.type == "ui-userselect") {
  783. field.templateOptions.modal = $modal;
  784. //field.templateOptions.Restangular = Restangular;
  785. } else if (field.type == "ui-multiuserselect") {
  786. field.templateOptions.modal = $modal;
  787. } else if (field.type == "ui-modelselect") {
  788. field.templateOptions.modal = $modal;
  789. //field.templateOptions.Restangular = Restangular;
  790. } else if (field.type == "ui-dropfile") {
  791. field.templateOptions.fileUploader = new FileUploader({
  792. url: '/uploader'
  793. });
  794. field.templateOptions.taskId = $stateParams.taskId;
  795. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  796. field.templateOptions.userId = $rootScope.user.id;
  797. //field.ApiService=api_bpm_domain;
  798. } else if (field.type == "ui-dropfiletable") {
  799. if (field.templateOptions.processInstanceId) {
  800. } else {
  801. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  802. }
  803. } else if (field.type == "ui-repeatSection") {
  804. var repeatForm = {
  805. model: {
  806. },
  807. fields: field.templateOptions.fields
  808. };
  809. repeatForm.model[field.key] = [];
  810. decodeVMTabForm(repeatForm);
  811. }
  812. }
  813. // console.log(field);
  814. //field
  815. //result.fields.push(field);
  816. })
  817. });
  818. vm.originalTabs = angular.copy(vm.form);
  819. }
  820. //解析自定义表单设计数据
  821. function decodeVMForm(vmForm) {
  822. var result = { model: {}, tabs: [] };
  823. //设置模型实体数据 begin
  824. // var mdata = vmForm.model;
  825. //解析数据实体
  826. var mdata = angular.fromJson(vmForm.model); //JSON.parse(field.extjson);
  827. angular.extend(result.model, mdata);
  828. //设置模型实体数据 end
  829. //解析设计数据生成表单项 begin
  830. var fields = [];
  831. //处理修改设计数据中展示设置
  832. angular.forEach(vmForm.tabs, function(field) {
  833. if (field.key == "") {
  834. delete field.key;
  835. }
  836. if (angular.isDefined(field.extjson)) {
  837. var extObj = angular.fromJson(field.extjson); //JSON.parse(field.extjson);
  838. angular.extend(field.templateOptions, extObj.templateOptions);
  839. delete extObj.templateOptions;
  840. for (var prop in extObj) {
  841. if (new RegExp("Expression").test(prop)) {
  842. //var obj = $scope.$eval(extObj[prop]);
  843. //extObj[prop] = $scope.$eval(extObj[prop]);
  844. if (extObj[prop] != null) {
  845. if (new RegExp("function").test(extObj[prop])) {
  846. var propValue = eval(extObj[prop]);
  847. extObj[prop] = propValue;
  848. } else {
  849. //console.log(extObj[prop]);
  850. var obj = $scope.$eval(extObj[prop]);
  851. extObj[prop] = obj;
  852. //console.log(obj);
  853. }
  854. }
  855. } else if (new RegExp("expressionProperties").test(prop)) {
  856. for (var p in extObj[prop]) {
  857. if (new RegExp("function").test(extObj[prop][p])) {
  858. var propValue = eval(extObj[prop][p]);
  859. extObj[prop][p] = propValue;
  860. } else {
  861. //if(p.indexOf("'")>=0){
  862. // var obj = $scope.$eval(extObj[prop][p]);
  863. // extObj[prop][$scope.$eval(p)]=obj;
  864. //}
  865. }
  866. }
  867. } else if ("watcher" == prop) {
  868. if (angular.isArray(extObj[prop])) {
  869. angular.forEach(extObj[prop], function(item, index) {
  870. for (var p in item) {
  871. if (new RegExp("function").test(item[p])) {
  872. var propValue = eval(item[p]);
  873. extObj[prop][index][p] = propValue;
  874. }
  875. }
  876. });
  877. } else if (angular.isObject(extObj[prop])) {
  878. for (var p in extObj[prop]) {
  879. if (new RegExp("function").test(extObj[prop][p])) {
  880. var propValue = eval(extObj[prop][p]);
  881. extObj[prop][p] = propValue;
  882. }
  883. }
  884. }
  885. }
  886. }
  887. angular.extend(field, extObj);
  888. delete field.extjson;
  889. }
  890. if (angular.isDefined(field.templateOptions)) {
  891. var templateOs = field.templateOptions;
  892. for (var property in templateOs) {
  893. //console.log(property);
  894. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  895. if (new RegExp("function").test(templateOs[property])) {
  896. var propValue = eval(templateOs[property]);
  897. field.templateOptions[property] = propValue;
  898. } else {
  899. if (that.has(templateOs[property])) {
  900. field.templateOptions[property] = that.get(templateOs[property]);
  901. } else {
  902. field.templateOptions[property] = templateOs[property];
  903. }
  904. }
  905. } else if (templateOs[property] == null) {
  906. //delete field.templateOptions[property];
  907. } else {}
  908. }
  909. }
  910. console.log(field);
  911. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  912. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  913. angular.extend(field.templateOptions, extObj);
  914. delete field.templateOptions.extjson;
  915. }
  916. //...
  917. if (field.templateOptions) {
  918. //处理远程获取数据控件方法调用
  919. if (field.templateOptions.optionsUrl) {
  920. field.templateOptions.refresh = refreshSelectOptions;
  921. }
  922. //处理嵌套属性数据绑定/
  923. if (field.templateOptions.pkey) {
  924. var pmodel, i = 0;
  925. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  926. if (i == 0) {
  927. if (result.model[p] == null) {
  928. result.model[p] = {};
  929. }
  930. pmodel = result.model[p];
  931. i++;
  932. } else {
  933. if (pmodel[p] == null) {
  934. pmodel[p] = {};
  935. }
  936. pmodel = pmodel[p];
  937. }
  938. });
  939. if (pmodel != null) {
  940. field.model = pmodel;
  941. if (pmodel[field.key] == null) {
  942. pmodel[field.key] = null;
  943. }
  944. }
  945. } else {
  946. if (result.model[field.key] == null) {
  947. result.model[field.key] = null;
  948. }
  949. }
  950. //处理弹出框组件初始化
  951. if (field.type == "ui-input-selectmodal") {
  952. field.templateOptions.modal = $modal;
  953. //field.templateOptions.Restangular = Restangular;
  954. } else if (field.type == "ui-userselect") {
  955. field.templateOptions.modal = $modal;
  956. //field.templateOptions.Restangular = Restangular;
  957. } else if (field.type == "ui-multiuserselect") {
  958. field.templateOptions.modal = $modal;
  959. } else if (field.type == "ui-modelselect") {
  960. field.templateOptions.modal = $modal;
  961. //field.templateOptions.Restangular = Restangular;
  962. } else if (field.type == "ui-dropfile") {
  963. field.templateOptions.fileUploader = new FileUploader({
  964. url: '/uploader'
  965. });
  966. field.templateOptions.taskId = $stateParams.taskId;
  967. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  968. field.templateOptions.userId = $rootScope.user.id;
  969. //field.ApiService=api_bpm_domain;
  970. } else if (field.type == "ui-dropfiletable") {
  971. if (field.templateOptions.processInstanceId) {
  972. } else {
  973. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  974. }
  975. } else if (field.type == "ui-repeatSection") {
  976. var repeatForm = {
  977. model: {
  978. },
  979. fields: field.templateOptions.fields
  980. };
  981. repeatForm.model[field.key] = [];
  982. decodeVMForm(repeatForm);
  983. }
  984. }
  985. // console.log(field);
  986. result.fields.push(field);
  987. });
  988. angular.extend($scope.vm.fields, result.fields);
  989. angular.extend($scope.vm.model, result.model);
  990. $scope.formData = vmForm;
  991. //console.log($scope.vm);
  992. //解析设计数据生成表单项 end
  993. return result;
  994. }
  995. //======================处理表单设计数据 结束========================
  996. $scope.ldloading = {};
  997. function filter(obj) {
  998. angular.forEach(obj, function(key, value) {
  999. if (value === "" || value === null) {
  1000. delete obj[key];
  1001. } else if (Object.prototype.toString.call(value) === '[object Object]') {
  1002. filter(value);
  1003. } else if (angular.isArray(value)) {
  1004. angular.forEach(value, function(item) {
  1005. filter(item);
  1006. });
  1007. }
  1008. });
  1009. }
  1010. function invokeOnAllFormOptions(fn) {
  1011. angular.forEach(vm.tabs, function(tab) {
  1012. if (tab.form.options && tab.form.options[fn]) {
  1013. tab.form.options[fn]();
  1014. }
  1015. });
  1016. }
  1017. function encodeCIData(data, ciId) {
  1018. /*
  1019. create/update state:未审核
  1020. create createtime:系统时间
  1021. create/update lastupdatetime : 系统时间
  1022. label:ci分类
  1023. */
  1024. if (ciId) {
  1025. var baseprop = ['uuid', 'name', 'type', 'label', 'status', 'createtime', 'lastupdatetime', 'props']; //state|audittime//createtime//removeflag|removetime//configperson//lastupdateperson//manager//useradmin
  1026. var extraprop = 'props';
  1027. data[extraprop] = {};
  1028. for (var key in data) {
  1029. // console.log(data[key]);
  1030. if (_.indexOf(baseprop, key) >= 0) {
  1031. continue;
  1032. } else {
  1033. data[extraprop][key] = data[key];
  1034. delete data[key];
  1035. }
  1036. }
  1037. if ($rootScope.user) {
  1038. data[extraprop]['lastupdateperson'] = $rootScope.user.name;
  1039. data[extraprop]['configperson'] = $rootScope.user.name;
  1040. var isCMAdminFlag = false;
  1041. angular.forEach($rootScope.user.role, function(roleItem) {
  1042. if (roleItem.rolecode == "cmdb charge") {
  1043. isCMAdminFlag = true;
  1044. }
  1045. })
  1046. if (!isCMAdminFlag) {
  1047. data[extraprop]['state'] = '1';
  1048. }
  1049. }
  1050. if (data.props.id) {
  1051. } else {
  1052. data.label = ciId;
  1053. }
  1054. return data;
  1055. }
  1056. return undefined;
  1057. }
  1058. function decodeCIModel(data) {
  1059. var extraprop = 'props';
  1060. if (data[extraprop]) {
  1061. for (var key in data[extraprop]) {
  1062. data[key] = data[extraprop][key];
  1063. }
  1064. delete data[extraprop];
  1065. }
  1066. data['iscmadmin'] = false;
  1067. angular.forEach($rootScope.user.role, function(roleItem) {
  1068. if (roleItem.rolecode == "cmdb charge") {
  1069. data['iscmadmin'] = true;
  1070. }
  1071. })
  1072. return data;
  1073. };
  1074. vm.remove = function(data, style) {
  1075. $scope.ldloading[style.replace('-', '_')] = true;
  1076. // var cidata = {
  1077. // label: data.label,
  1078. // id: data.id,
  1079. // uuid: data.uuid,
  1080. // name: data.name,
  1081. // props: {}
  1082. // };
  1083. // if (cidata.id) {
  1084. // cidata.props['removeflag'] = true;
  1085. // cidata.props['lastupdateperson'] = vm.model.loginUser;
  1086. //cidata.props['removetime']=new Date();
  1087. var modalInstance = $modal.open({
  1088. templateUrl: 'assets/views/delete.html',
  1089. controller: function($scope, scope, $modalInstance, api_bpm_data) {
  1090. var cidata = {
  1091. label: data.label,
  1092. id: data.id,
  1093. uuid: data.uuid,
  1094. name: data.name,
  1095. props: {}
  1096. };
  1097. if (cidata.id) {
  1098. cidata.props['removeflag'] = true;
  1099. cidata.props['lastupdateperson'] = vm.model.loginUser;
  1100. $scope.ok = function() {
  1101. $modalInstance.close(cidata);
  1102. };
  1103. $scope.cancel = function() {
  1104. $modalInstance.dismiss('cancel');
  1105. };
  1106. }
  1107. },
  1108. size: 'sm',
  1109. resolve: {
  1110. scope: function() {
  1111. return $scope;
  1112. }
  1113. }
  1114. });
  1115. modalInstance.result.then(function(selectedItem) {
  1116. if (selectedItem) {
  1117. // if (selectedItem.length > 0) {
  1118. api_cmdb.put(selectedItem, selectedItem.id).then(function(response) {
  1119. if (response) {
  1120. var resData = Restangular.stripRestangular(response);
  1121. SweetAlert.swal({
  1122. title: "删除成功!",
  1123. confirmButtonColor: "#007AFF"
  1124. }, function() {
  1125. $state.go("app.means.listd");
  1126. // $state.go("app.means.list");
  1127. // $scope.refreshform();
  1128. // reinitTabForm($scope.classify);
  1129. });
  1130. } else {
  1131. SweetAlert.swal({
  1132. title: "系统错误",
  1133. text: "系统错误,请稍后重试!",
  1134. type: "error",
  1135. confirmButtonColor: "#DD6B55"
  1136. });
  1137. }
  1138. $scope.ldloading[style.replace('-', '_')] = false;
  1139. });
  1140. // } else {
  1141. // SweetAlert.swal({
  1142. // title: "操作异常!",
  1143. // text: "系统异常,请稍后重试,或者联系管理员!",
  1144. // type: "error"
  1145. // });
  1146. // }
  1147. }
  1148. })
  1149. }
  1150. // })
  1151. // api_cmdb.put(cidata,data.id).then(function(response){
  1152. // if(response){
  1153. // var resData = Restangular.stripRestangular(response);
  1154. // SweetAlert.swal({
  1155. // title: "删除成功!",
  1156. // confirmButtonColor: "#007AFF"
  1157. // },function(){
  1158. // $state.go("app.means.list");
  1159. // // $scope.refreshform();
  1160. // // reinitTabForm($scope.classify);
  1161. // });
  1162. // }else{
  1163. // SweetAlert.swal({
  1164. // title: "系统错误",
  1165. // text: "系统错误,请稍后重试!",
  1166. // type: "error",
  1167. // confirmButtonColor: "#DD6B55"
  1168. // });
  1169. // }
  1170. // $scope.ldloading[style.replace('-', '_')] = false;
  1171. // });
  1172. // } else {
  1173. // $timeout(function() {
  1174. // $scope.ldloading[style.replace('-', '_')] = false;
  1175. // }, 2000);
  1176. // }
  1177. // }
  1178. function formValid() {
  1179. angular.forEach(vm.tabs, function(item) {
  1180. //item.
  1181. })
  1182. }
  1183. // 显示对应索引
  1184. $scope.xianshi = 0;
  1185. $scope.toindex = function(res) {
  1186. $scope.xianshi = res;
  1187. }
  1188. $scope.closeModel = function() {
  1189. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  1190. if ($stateParams.formKey == "means_editor" || $stateParams.formKey == "means_edit") {
  1191. $state.go('app.means.listd', {});
  1192. // $state.go('app.means.list', {});
  1193. }
  1194. event.preventDefault();
  1195. }
  1196. }
  1197. vm.submit = function(data, ciId, templateitem, style) {
  1198. // $scope.ldloading[style.replace('-', '_')] = true;
  1199. // console.log(vm.form.$$parentForm.$valid);
  1200. if (vm.form.$$parentForm.$valid) {
  1201. invokeOnAllFormOptions('updateInitialValue');
  1202. //alert(JSON.stringify(vm.model), null, 2);
  1203. //vm.options.updateInitialValue();
  1204. //console.log(vm.model);
  1205. var cidata = encodeCIData(vm.model, ciId);
  1206. if (cidata) {
  1207. //var cidata = ;
  1208. if (cidata.props.id) {
  1209. //修改
  1210. api_cmdb.put(cidata, ciId).then(function(response) {
  1211. if (response) {
  1212. var resData = Restangular.stripRestangular(response);
  1213. SweetAlert.swal({
  1214. title: "保存成功!",
  1215. confirmButtonColor: "#007AFF",
  1216. type: "success"
  1217. }, function() {
  1218. $scope.ldloading[style.replace('-', '_')] = false;
  1219. // $scope.refreshform();
  1220. $state.go("app.means.listd");
  1221. // $state.go("app.means.list");
  1222. });
  1223. } else {
  1224. SweetAlert.swal({
  1225. title: "系统错误",
  1226. text: "系统错误,请稍后重试!",
  1227. type: "error",
  1228. confirmButtonColor: "#DD6B55"
  1229. });
  1230. }
  1231. $scope.ldloading[style.replace('-', '_')] = false;
  1232. });
  1233. } else {
  1234. //新建
  1235. var type = 2;
  1236. api_sysinfo.getSerialnumber(type, templateitem.id).then(function(data) {
  1237. if (data && data.status == 200) {
  1238. cidata.uuid = data.uuid;
  1239. api_cmdb.create(cidata).then(function(response) {
  1240. if (response) {
  1241. var resData = Restangular.stripRestangular(response);
  1242. SweetAlert.swal({
  1243. title: "保存成功!",
  1244. text: "内部编号:" + cidata.uuid,
  1245. confirmButtonColor: "#007AFF",
  1246. type: "success"
  1247. }, function() {
  1248. $state.go("app.means.listd");
  1249. // $state.go("app.means.list");
  1250. });
  1251. // if(resData.status){
  1252. // resData
  1253. // }
  1254. } else {
  1255. SweetAlert.swal({
  1256. title: "系统错误",
  1257. text: "系统错误,请稍后重试!",
  1258. type: "error",
  1259. confirmButtonColor: "#DD6B55"
  1260. });
  1261. }
  1262. $scope.ldloading[style.replace('-', '_')] = false;
  1263. });
  1264. } else {
  1265. SweetAlert.swal({
  1266. title: "系统错误",
  1267. text: "内部编号生成出错!",
  1268. type: "error",
  1269. confirmButtonColor: "#DD6B55"
  1270. });
  1271. }
  1272. })
  1273. }
  1274. } else {
  1275. SweetAlert.swal({
  1276. title: "错误",
  1277. text: "错误,请选择资产分类!",
  1278. type: "error",
  1279. confirmButtonColor: "#DD6B55"
  1280. });
  1281. }
  1282. //alert(JSON.stringify(cidata), null, 2);
  1283. $scope.ldloading[style.replace('-', '_')] = true;
  1284. return;
  1285. var _ = window._;
  1286. vm.model = (function filter(obj) {
  1287. var filtered = _.pick(obj, function(v) { return angular.isDefined(v) && v !== null && (angular.isArray(v) ? v.length > 0 : true) && (_.isPlainObject(v) ? (!_.isEmpty(v)) : true); });
  1288. return _.cloneDeep(filtered, function(v) { return v !== filtered && _.isPlainObject(v) ? filter(v) : undefined; });
  1289. })(vm.model);
  1290. } else {
  1291. if (vm.form.$$parentForm.$error) {
  1292. SweetAlert.swal({
  1293. title: "校验错误",
  1294. text: "请填写必填项!",
  1295. type: "error",
  1296. confirmButtonColor: "#DD6B55"
  1297. });
  1298. angular.forEach(vm.form.$$parentForm.$error.required, function(item) {
  1299. angular.forEach(vm.tabs, function(tab) {
  1300. angular.forEach(tab.form.fields, function(f) {
  1301. if (f.name == item.$name) {
  1302. f.validation.show = true;
  1303. tab.active = true;
  1304. }
  1305. })
  1306. })
  1307. });
  1308. $scope.ldloading[style.replace('-', '_')] = false;
  1309. }
  1310. }
  1311. };
  1312. $scope.vm = vm;
  1313. //树形图
  1314. var apple_selected, tree, treedata_avm, treedata_geography;
  1315. $scope.my_tree_handler = function(branch) {
  1316. //var _ref;
  1317. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  1318. // api_cmdb.query({'sign':classify}).then(function(data){
  1319. // var myData = Restangular.stripRestangular(data);
  1320. // // console.log(myData.data.node);
  1321. // if(myData.data&&myData.status==200){
  1322. // var ret = myData.data;
  1323. // redrawSvg(myData);
  1324. // }
  1325. // });
  1326. // $scope.ciId = undefined;
  1327. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  1328. // api_configure_form.renderTabForm(classify).then(function(data){
  1329. // var myData = Restangular.stripRestangular(data);
  1330. // //angular.extend($scope.vm.fields,result.fields);
  1331. // //angular.extend($scope.vm.model,result.model);
  1332. // $scope.templateProps = myData;
  1333. // $scope.vm.tabs = myData;
  1334. // vm.model = {};
  1335. // decodeVMTabForm(vm.model, vm.tabs);
  1336. // //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  1337. // //console.log(myData);
  1338. // });
  1339. };
  1340. $scope.my_data = [];
  1341. function convertListToTree(data, treeMap) {
  1342. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  1343. var root = null; //Initially set our loop to null
  1344. var parentNode = null;
  1345. //loop over data
  1346. for (var i = 0; i < data.length; i++) {
  1347. var datum = data[i];
  1348. //each node will have children, so let's give it a "children" poperty
  1349. datum.children = [];
  1350. //add an entry for this node to the map so that any future children can
  1351. //lookup the parent
  1352. idToNodeMap[datum.id] = datum;
  1353. //Does this node have a parent?
  1354. if (typeof datum.parent === "undefined" || datum.parent == null) {
  1355. //Doesn't look like it, so this node is the root of the tree
  1356. root = datum;
  1357. treeMap[datum.id] = root;
  1358. } else {
  1359. //This node has a parent, so let's look it up using the id
  1360. parentNode = idToNodeMap[datum.parent.id];
  1361. //We don't need this property, so let's delete it.
  1362. delete datum.parent;
  1363. //Let's add the current node as a child of the parent node.
  1364. parentNode.children.push(datum);
  1365. }
  1366. }
  1367. return root;
  1368. }
  1369. function convertParentToChildList(data) {
  1370. var treeMap = {};
  1371. var list = [];
  1372. convertListToTree(data, treeMap);
  1373. angular.forEach(treeMap, function(item) {
  1374. list.push(item);
  1375. });
  1376. return list;
  1377. }
  1378. $scope.my_tree = tree = {};
  1379. $scope.try_async_load = function() {
  1380. $scope.my_data = [];
  1381. $scope.select_treedata = [];
  1382. $scope.doing_async = true;
  1383. api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  1384. //console.log(result['list']);
  1385. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  1386. $scope.doing_async = false;
  1387. // tree.expand_all();
  1388. //console.log(treelist);
  1389. });
  1390. };
  1391. $scope.select_treedata = [];
  1392. $scope.propTypeOptions = [];
  1393. $scope.try_async_load();
  1394. $scope.onFilterCallback = function(item) {
  1395. //console.log(item);
  1396. if (angular.isDefined(item.children) && item.children.length >= 1) {
  1397. //not valid
  1398. } else {
  1399. var tempclassify = item.prefix.toLowerCase() + item.sign;
  1400. $scope.cifilter_classic = tempclassify;
  1401. $scope.templateitem = item;
  1402. api_configure_form.renderTabForm(tempclassify).then(function(data) {
  1403. var myData = Restangular.stripRestangular(data);
  1404. $scope.propTypeOptions = myData;
  1405. $scope.templateProps = myData;
  1406. $scope.vm.tabs = myData;
  1407. vm.model = {};
  1408. decodeVMTabForm(vm.model, vm.tabs);
  1409. });
  1410. }
  1411. }
  1412. $scope.jry_shuxing = JSON.parse($stateParams.model);
  1413. // console.log($scope.jry_shuxing);
  1414. $scope.refreshform = function() {
  1415. if ($stateParams.model) {
  1416. var modeldata = JSON.parse($stateParams.model)
  1417. api_configure_form.renderTabForm(modeldata.model.label).then(function(data) {
  1418. var myData = Restangular.stripRestangular(data);
  1419. $scope.templateProps = myData;
  1420. $scope.vm.tabs = myData;
  1421. vm.model = {};
  1422. vm.model = $scope.vm.model = decodeCIModel(modeldata.model);
  1423. vm.model["loginUser"] = $rootScope.user.name;
  1424. // console.log(vm.model);
  1425. decodeVMTabForm(vm.model, vm.tabs);
  1426. // console.log(myData);
  1427. });
  1428. }
  1429. }
  1430. $scope.refreshform();
  1431. }
  1432. ]);