newpape.js 94 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064
  1. app.controller('newtreemap', ["$scope", "$rootScope", "$sce", "$http", "$modal", '$parse', '$injector', "$aside", '$state', "$stateParams", "toaster", "SweetAlert", 'Restangular', "api_cmdb", "api_configure_form", "api_bpm_data", "api_configure_data", function($scope, $rootScope, $sce, $http, $modal, $parse, $injector, $aside, $state, $stateParams, toaster, SweetAlert, Restangular, api_cmdb, api_configure_form, api_bpm_data, api_configure_data) {
  2. var container = document.getElementById('mynetwork');
  3. var network = null;
  4. var newNodeArr = [];
  5. var options;
  6. var nodesArr = [];
  7. var edgesArr = [];
  8. var nodes_data;
  9. var edges_data;
  10. var thisnode = {};
  11. $scope.cmdbtype = {};
  12. var open = false;
  13. $scope.guanxi = {};
  14. $scope.openedge = {};
  15. $scope.textheight = {}
  16. $scope.opennode = {};
  17. $scope.cmdbisopen = false;
  18. var connectedNum = '子节点数:';
  19. // window.onload = function() {  changeDivHeight();   }     
  20. changeDivHeight();         
  21. window.onresize = function() {  changeDivHeight(); }              
  22. function  changeDivHeight() {                               
  23. var  h  =  document.documentElement.clientHeight; //获取页面可见高度  
  24. $scope.textheight = { "height": h - 46 + "px" };  
  25. }
  26. //属性弹框
  27. $rootScope.toggle('off-sidebar');
  28. //新增关系弹框
  29. function showModal(action, event) {
  30. var modalInstance = $aside.open({
  31. templateUrl: 'cmdbmapEvent.html',
  32. placement: 'right',
  33. size: 'sm',
  34. backdrop: false,
  35. controller: function($scope, $modalInstance) {
  36. $scope.$modalInstance = $modalInstance;
  37. $scope.action = action;
  38. $scope.event = event;
  39. $scope.cancel = function() {
  40. $modalInstance.dismiss('cancel');
  41. };
  42. $scope.deleteEvent = function() {
  43. $modalInstance.close($scope.event, $scope.event);
  44. };
  45. }
  46. });
  47. modalInstance.result.then(function(selectedEvent, action) {
  48. $scope.eventDeleted(selectedEvent);
  49. });
  50. }
  51. $scope.eventClicked = function(event) {
  52. showModal('Clicked', event);
  53. };
  54. // $scope.eventClicked();
  55. $scope.addEvent = function() {
  56. $scope.events.push({
  57. title: 'New Event',
  58. starts_at: new Date(y, m, d, 10, 0),
  59. ends_at: new Date(y, m, d, 11, 0),
  60. type: 'job'
  61. });
  62. $scope.eventEdited($scope.events[$scope.events.length - 1]);
  63. };
  64. $scope.eventEdited = function(event) {
  65. showModal('Edited', event);
  66. };
  67. //修改关系
  68. $scope.editId = -1;
  69. $scope.setEditId = function(pid) {
  70. $scope.editId = pid;
  71. };
  72. //新增关系
  73. $scope.key = {};
  74. // $scope.linktypeOptions = scope.linktypeOptions;
  75. $scope.guanxidata = [
  76. { id: 0, name: '连接', value: 'link' },
  77. { id: 1, name: '安装部署', value: 'installon' },
  78. { id: 2, name: '归属', value: 'blong' },
  79. { id: 3, name: '使用', value: 'use' },
  80. { id: 4, name: '互备', value: 'backupbetw' },
  81. { id: 5, name: '主备', value: 'backupown' }
  82. ];
  83. $scope.ok = function(key) {
  84. $modalInstance.close(key);
  85. $scope.guanxi = {};
  86. };
  87. $scope.openModal = function(size, modal) {
  88. var modalInstance = $modal.open({
  89. templateUrl: 'assets/views/customform/tpl/cmdb/add_cmdb.html',
  90. controller: function($scope, i18nService, $modalInstance, api_configure_data, api_configure_form, api_cmdb) {
  91. $scope.langs = i18nService.getAllLangs();
  92. $scope.lang = 'zh-cn';
  93. i18nService.setCurrentLang($scope.lang);
  94. $scope.title = "资产列表";
  95. $scope.gridOptions = {};
  96. $scope.gridOptions.data = 'myDatatwo';
  97. $scope.gridOptions.enableColumnResizing = true;
  98. $scope.gridOptions.enableFiltering = false;
  99. $scope.gridOptions.enableGridMenu = false;
  100. $scope.gridOptions.showGridFooter = true;
  101. $scope.gridOptions.showColumnFooter = false;
  102. $scope.gridOptions.fastWatch = true;
  103. $scope.gridOptions.useExternalFiltering = true;
  104. $scope.gridOptions.useExternalPagination = true;
  105. $scope.gridOptions.paginationPageSizes = [10, 20, 50, 100];
  106. $scope.gridOptions.paginationPageSize = 10;
  107. $scope.gridOptions.multiSelect = false;
  108. $scope.gridOptions.rowIdentity = function(row) {
  109. return row.id;
  110. };
  111. $scope.gridOptions.getRowIdentity = function(row) {
  112. return row.id;
  113. };
  114. // $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>";
  115. $scope.gridOptions.columnDefs = [
  116. { name: 'item', displayName: '序号', width: 80, enableFiltering: false },
  117. { name: 'uuid', displayName: '内部编号', width: 170 },
  118. { name: 'props.hw_mingcheng', displayName: '资产名称', width: 110 },
  119. // { name: 'props.hw_cifilterClassic', displayName: '资产类型', width: 130, enableFiltering: false },
  120. // { name: 'type', displayName: '资产型号', width: 100, enableFiltering: false },
  121. { name: 'props.hw_state', displayName: '资产状态', width: 130, enableFiltering: false },
  122. { name: 'props.hwnw_area', displayName: '资产地点', width: 130, enableFiltering: false },
  123. { name: 'createtime', displayName: '申请时间', enableFiltering: false ,
  124. cellTemplate: '<div><div class="ui-grid-cell-contents">{{grid.appScope.transferTime(row.entity.createtime)}}</div></div>'
  125. }
  126. ];
  127. // $scope.selectButtonClick
  128. var defaultFilterData = {
  129. // "assignee":2,
  130. // "sign":"basehwitndl",
  131. // "applicationForm": { "hw_state": "在线" },
  132. "idx": 0,
  133. "sum": 10
  134. };
  135. $scope.transferTime = function(time) {
  136. return moment(time).format('YYYY-MM-DD HH:mm');
  137. }
  138. $scope.memoryfilterData = {
  139. // "assignee":2,
  140. // "sign":"basehwitndl",
  141. // "applicationForm": { "hw_state": "在线" },
  142. "idx": 0,
  143. "sum": 10
  144. }
  145. $scope.refreshData = function(style, filterData) {
  146. if (angular.isUndefined(filterData)) {
  147. filterData = defaultFilterData;
  148. }
  149. $scope.myDatatwo = [];
  150. // $scope.gridOptions['sum']=filterData.sum;
  151. api_cmdb.query(filterData).then(function(data) {
  152. // $scope.callsPending--;
  153. var filterData = $scope.memoryfilterData;
  154. var myDatatwo = Restangular.stripRestangular(data);
  155. $scope.gridOptions['totalItems'] = data.total;
  156. for (var i = 0; i < myDatatwo.data.node.length; i++) {
  157. myDatatwo.data.node[i].createtime = moment(myDatatwo.data.node[i].createtime).format('YYYY-MM-DD');
  158. if (modal.id == myDatatwo.data.node[i].id) {
  159. myDatatwo.data.node.splice(i, 1);
  160. }
  161. }
  162. $scope.myDatatwo = myDatatwo.data.node;
  163. for (var i = 0; i < $scope.myDatatwo.length; i++) {
  164. $scope.myDatatwo[i]['item'] = i + 1 + filterData.idx * filterData.sum
  165. }
  166. }, function() {});
  167. };
  168. $scope.refreshData('expand-right', defaultFilterData);
  169. $scope.gridOptions.onRegisterApi = function(gridApi) {
  170. $scope.gridApi = gridApi;
  171. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  172. var filtersData = $scope.memoryfilterData;
  173. filtersData.idx = newPage - 1;
  174. filtersData.sum = pageSize;
  175. // $scope.loadData(filtersData);
  176. $scope.refreshData('expand-right', filtersData);
  177. //console.log(pageSize);
  178. // $scope.loadData({"idx":newPage-1,"sum":pageSize});
  179. });
  180. // gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  181. // $scope.selected.items.push(data.entity);
  182. //console.log(data);
  183. gridApi.selection.on.rowSelectionChanged($scope, function(scope, ect) {
  184. if (scope.isSelected) {
  185. scope.grid.appScope.selected.items.push(scope.entity)
  186. } else {
  187. for (var i = 0; i <= scope.grid.appScope.selected.items.length; i++) {
  188. if (scope.grid.appScope.selected.items[i].id == scope.entity.id) {
  189. scope.grid.appScope.selected.items.splice(i, 1);
  190. break;
  191. }
  192. }
  193. }
  194. $scope.mySelectedRows = $scope.gridApi.selection.getSelectedRows();
  195. });
  196. // });
  197. gridApi.selection.on.rowSelectionChangedBatch($scope, function(rows) {
  198. // $scope.selected.items = data.entity;
  199. //console.log(data);
  200. var selectitem = [];
  201. selectitem = angular.copy($scope.selected.items);
  202. for (var j = 0; j < rows.length; j++) {
  203. if (rows[j].isSelected == true) {
  204. selectitem.push(rows[j].entity);
  205. } else {
  206. delete selectitem[j];
  207. // rows.splice(j, 1);
  208. }
  209. }
  210. $scope.selected.items = [];
  211. for (var i = 0; i < selectitem.length; i++) {
  212. if (selectitem[i]) {
  213. $scope.selected.items.push(selectitem[i]);
  214. }
  215. }
  216. });
  217. // gridApi.selection.on.selectAllRows = function(row) { //GridRow
  218. // // if (row.entity.age > 45) {
  219. // row.grid.api.selection.selectRow(row.entity); // 选中行
  220. // // }
  221. // };
  222. gridApi.core.on.filterChanged($scope, function() {
  223. var grid = this.grid;
  224. var filtersData = {
  225. idx: 0,
  226. sum: 10,
  227. "user": { "roledata": { "rolecode": "roleset" }, "selectType": "1" }
  228. };
  229. angular.forEach(grid.columns, function(item) {
  230. if (item.enableFiltering) {
  231. // console.log("item.filters[0]=" + JSON.stringify(item.filters));
  232. if (angular.isDefined(item.filters[0].term) && item.filters[0].term != '') {
  233. if (angular.isUndefined(filtersData['user'])) {
  234. filtersData['user'] = {};
  235. }
  236. filtersData['user'][item.field] = item.filters[0].term;
  237. }
  238. }
  239. });
  240. $scope.memoryfilterData = filtersData;
  241. // $scope.loadData(filtersData);
  242. });
  243. };
  244. $scope.onDblClick = function(data, event) {
  245. // $scope.selected.items = data.entity;
  246. $scope.selectButtonClick(data, event);
  247. };
  248. // $scope.loadData = function(filterData) {
  249. // // console.log("filtersData=111" + JSON.stringify(filterData))
  250. // items.fetchItems(filterData, APIService).then(function(data) {
  251. // var myDatatwo = Restangular.stripRestangular(data);
  252. // $scope.gridOptions.totalItems = myDatatwo.totalNum;
  253. // $scope.myDatatwo = myDatatwo.list;
  254. // });
  255. // };
  256. //树形图
  257. var apple_selected, tree, treedata_avm, treedata_geography;
  258. $scope.my_tree_handler = function(branch) {
  259. //var _ref;
  260. var classify = $scope.classify = branch.prefix.toLowerCase() + branch.sign;
  261. api_cmdb.query({ 'sign': classify }).then(function(data) {
  262. var myDatalingbei = Restangular.stripRestangular(data);
  263. // console.log(myData.data.node);
  264. if (myDatalingbei.data && myDatalingbei.status == 200) {
  265. var ret = myDatalingbei.data;
  266. redrawSvg(myDatalingbei);
  267. }
  268. });
  269. };
  270. $scope.my_data = [];
  271. function convertListToTree(data, treeMap) {
  272. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  273. var root = null; //Initially set our loop to null
  274. var parentNode = null;
  275. //loop over data
  276. for (var i = 0; i < data.length; i++) {
  277. var datum = data[i];
  278. //each node will have children, so let's give it a "children" poperty
  279. datum.children = [];
  280. //add an entry for this node to the map so that any future children can
  281. //lookup the parent
  282. idToNodeMap[datum.id] = datum;
  283. //Does this node have a parent?
  284. if (typeof datum.parent === "undefined" || datum.parent == null) {
  285. //Doesn't look like it, so this node is the root of the tree
  286. root = datum;
  287. treeMap[datum.id] = root;
  288. } else {
  289. //This node has a parent, so let's look it up using the id
  290. parentNode = idToNodeMap[datum.parent.id];
  291. //We don't need this property, so let's delete it.
  292. delete datum.parent;
  293. //Let's add the current node as a child of the parent node.
  294. parentNode.children.push(datum);
  295. }
  296. }
  297. return root;
  298. }
  299. function convertParentToChildList(data) {
  300. var treeMap = {};
  301. var list = [];
  302. convertListToTree(data, treeMap);
  303. angular.forEach(treeMap, function(item) {
  304. list.push(item);
  305. });
  306. return list;
  307. }
  308. $scope.my_tree = tree = {};
  309. $scope.try_async_load = function() {
  310. $scope.my_data = [];
  311. $scope.select_treedata = [];
  312. $scope.doing_async = true;
  313. api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  314. //console.log(result['list']);
  315. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  316. $scope.doing_async = false;
  317. // tree.expand_all();
  318. //console.log(treelist);
  319. });
  320. };
  321. $scope.select_treedata = [];
  322. $scope.propTypeOptions = [];
  323. $scope.try_async_load();
  324. $scope.onFilterremove = function(item) {
  325. console.log(item)
  326. }
  327. $scope.searchdata = {};
  328. $scope.clear = function() {
  329. $scope.searchdata = {};
  330. $scope.cifilter_classic = {};
  331. $scope.try_async_load();
  332. var fildata = {
  333. idx: 0,
  334. sum: 10,
  335. }
  336. $scope.memoryfilterData = fildata;
  337. $scope.refreshData('expand-right', fildata);
  338. }
  339. $scope.cifilter_classic = {};
  340. $scope.chiceIncident = function(item) {
  341. var fildata = defaultFilterData;
  342. // fildata.applicationForm = {};
  343. // sign: basehwnwswt
  344. if (item && item.id) {
  345. var classify = item.prefix.toLowerCase() + item.sign;
  346. fildata.sign = classify
  347. }else{
  348. delete fildata.sign
  349. }
  350. $scope.gridOptions.paginationCurrentPage = 1;
  351. var transitiondata = angular.copy(item);
  352. $scope.refreshData('expand-right', fildata);
  353. }
  354. $scope.applicadata = [];
  355. $scope.onFilterCallback = function(item) {
  356. var tempclassify = item.prefix.toLowerCase() + item.sign;
  357. api_configure_form.renderTabForm(tempclassify).then(function(data) {
  358. var myData = Restangular.stripRestangular(data);
  359. $scope.applicadata = myData[0].form.fields;
  360. });
  361. // }
  362. }
  363. // $scope.loadData({
  364. // idx: 0,
  365. // sum: 10,
  366. // "user": { "roledata": { "rolecode": "roleset" }, "selectType": "1" }
  367. // });
  368. $scope.selected = {
  369. items: []
  370. };
  371. $scope.ok = function() {
  372. // if(onDataCallback&&angular.isFunction(onDataCallback)){
  373. // onDataCallback($scope.selected.item, parentScope);
  374. // }
  375. $modalInstance.close($scope.selected.items);
  376. };
  377. $scope.cancel = function() {
  378. $modalInstance.dismiss('cancel');
  379. };
  380. },
  381. size: 'lg'
  382. });
  383. modalInstance.result.then(function(selectedItem) {
  384. $scope.guanxi.cmdbname = selectedItem[0];
  385. }, function() {});
  386. }
  387. $scope.changeedge = function(data) {
  388. SweetAlert.swal({
  389. title: "确认修改资产关系-" + data.label + "?",
  390. type: "warning",
  391. showCancelButton: true,
  392. confirmButtonColor: "#DD6B55",
  393. confirmButtonText: "确认修改",
  394. cancelButtonText: "取消"
  395. }, function(isConfirm) {
  396. if (isConfirm) {
  397. //{"id":-1,"name":"link","source":6741,"target":6749,"left":true,"right":false,"props":{}}
  398. $scope.changeedges = true;
  399. $scope.guanxi.cmdbname = data.tolabelname.data;
  400. $scope.guanxi.name = data;
  401. $scope.guanxi.name.value = data.namelink;
  402. $scope.guanxi.name.name = data.label;
  403. $scope.guanxi.edgesid = data.id;
  404. } else {
  405. $scope.changeedges = false;
  406. }
  407. });
  408. }
  409. function getmapdata() {
  410. _mydata.nodes = [];
  411. _mydata.edges = [];
  412. api_cmdb.findRefById($scope.opennode[0]).then(function(result) {
  413. var obj = {};
  414. var oaj = {};
  415. angular.forEach(result.data.node, function(item, index) {
  416. if (!obj[item]) {
  417. obj[item] = 1;
  418. angular.forEach($scope.select_treelist, function(itemca) {
  419. var regstring = itemca.prefix + itemca.sign;
  420. if (item.label == regstring.toLocaleLowerCase()) {
  421. _mydata.nodes.push({
  422. "id": item.id,
  423. "assistId": item.id,
  424. "label": item.props.hw_mingcheng,
  425. "image": itemca.iconname ? itemca.iconname : "assets/images/cmdb/other.png",
  426. // "image":"assets/images/cmdb/other.png",
  427. "shape": "image",
  428. "name": item.props.hw_mingcheng,
  429. "ngcord": item.label,
  430. "data": item,
  431. "pid": item.id,
  432. "hostType": "1",
  433. "hostStatus": "1",
  434. "size": 15,
  435. "isOurDraw": "false",
  436. "hidden": false
  437. })
  438. }
  439. })
  440. }
  441. })
  442. angular.forEach(result.data.edge, function(itemedge, indexone) {
  443. if (!oaj[itemedge]) {
  444. oaj[itemedge] = 1;
  445. _mydata.edges.push({
  446. "id": itemedge.id,
  447. "from": itemedge.source,
  448. "to": itemedge.target,
  449. "namelink": itemedge.name,
  450. "label": strangelink(itemedge.name),
  451. "color": {
  452. "color": "#ccc"
  453. }
  454. })
  455. }
  456. })
  457. // angular.forEach(_mydata.edges, function(itemedge) {
  458. // if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  459. // angular.forEach(_mydata.nodes, function(item) {
  460. // if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  461. // var datas = itemedge;
  462. // datas.tolabelname = item
  463. // $scope.openedge.push(datas); 
  464. // }
  465. // })
  466. // }
  467. // })
  468. draw(_mydata);
  469. })
  470. }
  471. $scope.ok = function(key, cmdbtype, type) {
  472. if (key.cmdbname.id||key.cmdbname.id==0) {
  473. if (type) {
  474. var fildata = { "id": $scope.guanxi.edgesid, "name": key.name.value, "source": key.cmdbname.id, "target": $scope.opennode[0], "left": true, "right": false, "props": {} }
  475. // $scope.cmdbisopen = false;
  476. api_cmdb.putRef(fildata, $scope.guanxi.edgesid).then(function(response) {
  477. if (response) {
  478. var resData = Restangular.stripRestangular(response);
  479. SweetAlert.swal({
  480. title: "修改成功!",
  481. confirmButtonColor: "#007AFF",
  482. type: "success"
  483. }, function() {
  484. $scope.guanxi = {};
  485. // angular.forEach(_mydata.edges, function(itemedge, index) {
  486. // if (itemedge.id == $scope.guanxi.edgesid) {
  487. // _mydata.edges[index] = response.data.edge[0];
  488. // if () {
  489. // }
  490. // }
  491. // if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  492. // angular.forEach(_mydata.nodes, function(item) {
  493. // if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  494. // var datas = itemedge;
  495. // datas.tolabelname = item
  496. // $scope.openedge.push(datas); 
  497. // }
  498. // })
  499. // }
  500. // })
  501. $scope.edgedatag = angular.copy(_mydata.edges);
  502. api_cmdb.findRefById($scope.opennode[0]).then(function(result) {
  503. _mydata.edges = [];
  504. $scope.openedge = [];
  505. angular.forEach(result.data.edge, function(itemedge, indexone) {
  506. var someone = true;
  507. // angular.forEach($scope.edgedatag, function(chil) {
  508. // if (chil.id == itemedge.id) {
  509. // someone = false;
  510. // }
  511. // })
  512. // if (someone) {
  513. _mydata.edges.push({
  514. "id": itemedge.id,
  515. "from": itemedge.source,
  516. "to": itemedge.target,
  517. // "label": itemedge.name,
  518. "namelink": itemedge.name,
  519. "label": strangelink(itemedge.name),
  520. "color": {
  521. "color": "#ccc"
  522. }
  523. })
  524. // }
  525. })
  526. angular.forEach(_mydata.edges, function(itemedge) {
  527. if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  528. angular.forEach(_mydata.nodes, function(item) {
  529. if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  530. var datas = itemedge;
  531. datas.tolabelname = item
  532. $scope.openedge.push(datas); 
  533. }
  534. })
  535. }
  536. })
  537. draw(_mydata);
  538. $scope.changeedges = false;
  539. })
  540. })
  541. // getmapdata();
  542. // angular.forEach(_mydata.edges, function(itemedge) {
  543. // if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  544. // angular.forEach(_mydata.nodes, function(item) {
  545. // if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  546. // var datas = itemedge;
  547. // datas.tolabelname = item
  548. // $scope.openedge.push(datas); 
  549. // }
  550. // })
  551. // }
  552. // })
  553. // draw(_mydata);
  554. // });
  555. } else {
  556. SweetAlert.swal({
  557. title: "修改失败",
  558. text: "修改失败,请稍后重试!",
  559. type: "error",
  560. confirmButtonColor: "#DD6B55"
  561. });
  562. }
  563. // $scope.ldloading[style.replace('-', '_')] = false;
  564. });
  565. } else {
  566. var fildata = { "id": -1, "name": key.name.value, "source": key.cmdbname.id, "target": $scope.opennode[0], "left": true, "right": false, "props": {} }
  567. $scope.cmdbisopen = false;
  568. api_cmdb.createRef(fildata).then(function(response) {
  569. if (response && response.status == 200) {
  570. // SweetAlert.swal("title": "新增成功",
  571. // "text": "新增关系成功!",
  572. // "type": "success")
  573. SweetAlert.swal({
  574. title: "新增成功",
  575. text: "新增关系成功!",
  576. type: "success"
  577. }, function(isConfirm) {
  578. $scope.guanxi = {};
  579. api_cmdb.findRefById($scope.opennode[0]).then(function(result) {
  580. angular.forEach(result.data.node, function(item, index) {
  581. var someone = true;
  582. angular.forEach(_mydata.nodes, function(chil) {
  583. if (chil.id == item.id) {
  584. someone = false;
  585. }
  586. })
  587. if (someone) {
  588. angular.forEach($scope.select_treelist, function(itemca) {
  589. var regstring = itemca.prefix + itemca.sign;
  590. if (item.label == regstring.toLocaleLowerCase()) {
  591. _mydata.nodes.push({
  592. "id": item.id,
  593. "assistId": item.id,
  594. "label": item.props.hw_mingcheng,
  595. "image": itemca.iconname ? itemca.iconname : "assets/images/cmdb/other.png",
  596. // "image":"assets/images/cmdb/other.png",
  597. "shape": "image",
  598. "name": item.props.hw_mingcheng,
  599. "ngcord": item.label,
  600. "data": item,
  601. "pid": item.id,
  602. "hostType": "1",
  603. "hostStatus": "1",
  604. "size": 15,
  605. "isOurDraw": "false",
  606. "hidden": false
  607. })
  608. }
  609. })
  610. }
  611. // }
  612. })
  613. angular.forEach(result.data.edge, function(itemedge, indexone) {
  614. var someone = true;
  615. angular.forEach(_mydata.edges, function(chil) {
  616. if (chil.id == itemedge.id) {
  617. someone = false;
  618. }
  619. })
  620. if (someone) {
  621. _mydata.edges.push({
  622. "id": itemedge.id,
  623. "from": itemedge.source,
  624. "to": itemedge.target,
  625. // "label": itemedge.name,
  626. "namelink": itemedge.name,
  627. "label": strangelink(itemedge.name),
  628. "color": {
  629. "color": "#ccc"
  630. }
  631. })
  632. }
  633. })
  634. draw(_mydata);
  635. })
  636. })
  637. } else {
  638. SweetAlert.swal("新增失败!", "新增关系失败", "error")
  639. }
  640. });
  641. }
  642. // }else{
  643. // SweetAlert.swal({
  644. // title: "新增失败",
  645. // text: "请选择!",
  646. // type: "success"
  647. // })
  648. }
  649. };
  650. $scope.cancel = function() {
  651. $modalInstance.dismiss('cancel');
  652. };
  653. $scope.statement = JSON.parse(localStorage.cmdbmap).model;
  654. $scope.select_treelist = JSON.parse(localStorage.ciclassify);
  655. // var _mydata = {
  656. // nodes: [{
  657. // "id": $scope.statement.id,
  658. // "assistId": $scope.statement.id,
  659. // "label": $scope.statement.props.hw_mingcheng,
  660. // "image": "assets/images/cmdb/Server.png",
  661. // "shape": "image",
  662. // "name": $scope.statement.props.hw_mingcheng,
  663. // "ngcord": $scope.statement.label,
  664. // "pid": $scope.statement.id,
  665. // "data": $scope.statement,
  666. // "hostType": "1",
  667. // "hostStatus": "1",
  668. // "size": 15,
  669. // "isOurDraw": "false",
  670. // "hidden": false
  671. // }],
  672. // edges: []
  673. // }
  674. var _mydata = { nodes: [], edges: [] };
  675. angular.forEach($scope.select_treelist, function(item) {
  676. var regstring = item.prefix + item.sign;
  677. if ($scope.statement.label == regstring.toLocaleLowerCase()) {
  678. _mydata = {
  679. nodes: [{
  680. "id": $scope.statement.id,
  681. "assistId": $scope.statement.id,
  682. "label": $scope.statement.props.hw_mingcheng,
  683. "image": item.iconname ? item.iconname : "assets/images/cmdb/other.png",
  684. // "image": "assets/images/cmdb/other.png",
  685. "shape": "image",
  686. "name": $scope.statement.props.hw_mingcheng,
  687. "ngcord": $scope.statement.label,
  688. "pid": $scope.statement.id,
  689. "data": $scope.statement,
  690. "hostType": "1",
  691. "hostStatus": "1",
  692. "size": 15,
  693. "isOurDraw": "false",
  694. "hidden": false
  695. }],
  696. edges: []
  697. }
  698. }
  699. })
  700. // $scope.select_treedata = [];
  701. // api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  702. // $scope.select_treelist = result['list'];
  703. // angular.forEach($scope.select_treelist, function(item) {
  704. // var regstring = item.prefix + item.sign;
  705. // if ($scope.statement.label == regstring.toLocaleLowerCase()) {
  706. // var _mydata = {
  707. // nodes: [{
  708. // "id": $scope.statement.id,
  709. // "assistId": $scope.statement.id,
  710. // "label": $scope.statement.props.hw_mingcheng,
  711. // "image": itemca.iconname ? itemca.iconname : "assets/images/cmdb/Server.png",
  712. // "shape": "image",
  713. // "name": $scope.statement.props.hw_mingcheng,
  714. // "ngcord": $scope.statement.label,
  715. // "pid": $scope.statement.id,
  716. // "data": $scope.statement,
  717. // "hostType": "1",
  718. // "hostStatus": "1",
  719. // "size": 15,
  720. // "isOurDraw": "false",
  721. // "hidden": false
  722. // }],
  723. // edges: []
  724. // }
  725. // }
  726. // })
  727. // draw(_mydata);
  728. // })
  729. // var _mydata = {
  730. // nodes: [{
  731. // "id": $scope.statement.id,
  732. // "assistId": $scope.statement.id,
  733. // "label": $scope.statement.props.hw_mingcheng,
  734. // "image": "assets/images/cmdb/Server.png",
  735. // "shape": "image",
  736. // "name": $scope.statement.props.hw_mingcheng,
  737. // "ngcord": $scope.statement.label,
  738. // "pid": $scope.statement.id,
  739. // "data": $scope.statement,
  740. // "hostType": "1",
  741. // "hostStatus": "1",
  742. // "size": 15,
  743. // "isOurDraw": "false",
  744. // "hidden": false
  745. // }],
  746. // edges: []
  747. // }
  748. //资产属性列表
  749. var vm = this;
  750. vm.options = {};
  751. vm.exampleTitle = ['expressionProperties', 'model property'];
  752. vm.fields = [];
  753. vm.models = {};
  754. // vm.models["loginUser"] = $rootScope.user;
  755. var that = $injector;
  756. var parse = $parse;
  757. var formKey = "";
  758. var pdKey = "";
  759. if (angular.isDefined($state.current.pdKey) && $state.current.pdKey != "") {
  760. pdKey = $state.current.pdKey;
  761. //console.log("pdKey::"+$state.current.pdKey);
  762. }
  763. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  764. formKey = $stateParams.formKey;
  765. //console.log("formKey::"+$stateParams.formKey);
  766. }
  767. //用户测试数据,后续从header的auth中获取
  768. var userId = 2;
  769. userId = $rootScope.user.id;
  770. //==============处理表单设计数据 开始====================
  771. //处理组件加载后台数据选项的方法
  772. function refreshSelectOptions(searchVal, field) {
  773. if (field.templateOptions.optionsUrl) {
  774. var process = BpmRestangular.all("");
  775. if (field.templateOptions.ApiService) {
  776. process = UserRestangular.all("");
  777. }
  778. process.customPOST({ "idx": 0, "sum": 1000 }, field.templateOptions.optionsUrl).then(function(result) {
  779. if (!field.templateOptions.options) {
  780. field.templateOptions.options = [];
  781. }
  782. if (field.templateOptions.optionsDataKey) {
  783. field.templateOptions.options = result[field.templateOptions.optionsDataKey];
  784. } else {
  785. field.templateOptions.options = result;
  786. }
  787. });
  788. }
  789. }
  790. function decodeVMTabForm(model, tabs) {
  791. var result = { model: {}, tabs: [] };
  792. var mdata = angular.fromJson(model);
  793. angular.extend(result.model, mdata);
  794. angular.forEach(tabs, function(tab) {
  795. tab.form.model = vm.models;
  796. angular.forEach(tab.form.fields, function(field) {
  797. if (field.key == "") {
  798. delete field.key;
  799. }
  800. field.type = "ui-otherlisttab";
  801. if (angular.isDefined(field.extjson) && field.extjson != "") {
  802. var extObj = angular.fromJson(field.extjson);
  803. angular.extend(field.templateOptions, extObj.templateOptions);
  804. delete extObj.templateOptions;
  805. for (var prop in extObj) {
  806. if (new RegExp("Expression").test(prop)) {
  807. //var obj = $scope.$eval(extObj[prop]);
  808. //extObj[prop] = $scope.$eval(extObj[prop]);
  809. if (extObj[prop] != null) {
  810. if (new RegExp("function").test(extObj[prop])) {
  811. var propValue = eval(extObj[prop]);
  812. extObj[prop] = propValue;
  813. } else {
  814. //console.log(extObj[prop]);
  815. var obj = $scope.$eval(extObj[prop]);
  816. extObj[prop] = obj;
  817. //console.log(obj);
  818. }
  819. }
  820. } else if (new RegExp("expressionProperties").test(prop)) {
  821. for (var p in extObj[prop]) {
  822. if (new RegExp("function").test(extObj[prop][p])) {
  823. var propValue = eval(extObj[prop][p]);
  824. extObj[prop][p] = propValue;
  825. } else {
  826. //if(p.indexOf("'")>=0){
  827. // var obj = $scope.$eval(extObj[prop][p]);
  828. // extObj[prop][$scope.$eval(p)]=obj;
  829. //}
  830. }
  831. }
  832. } else if ("watcher" == prop) {
  833. if (angular.isArray(extObj[prop])) {
  834. angular.forEach(extObj[prop], function(item, index) {
  835. for (var p in item) {
  836. if (new RegExp("function").test(item[p])) {
  837. var propValue = eval(item[p]);
  838. extObj[prop][index][p] = propValue;
  839. }
  840. }
  841. });
  842. } else if (angular.isObject(extObj[prop])) {
  843. for (var p in extObj[prop]) {
  844. if (new RegExp("function").test(extObj[prop][p])) {
  845. var propValue = eval(extObj[prop][p]);
  846. extObj[prop][p] = propValue;
  847. }
  848. }
  849. }
  850. }
  851. }
  852. angular.extend(field, extObj);
  853. delete field.extjson;
  854. }
  855. if (field.extjson == "") {
  856. delete field.extjson;
  857. }
  858. if (angular.isDefined(field.templateOptions)) {
  859. var templateOs = field.templateOptions;
  860. for (var property in templateOs) {
  861. //console.log(property);
  862. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  863. if (new RegExp("function").test(templateOs[property])) {
  864. var propValue = eval(templateOs[property]);
  865. field.templateOptions[property] = propValue;
  866. } else {
  867. if (that.has(templateOs[property])) {
  868. field.templateOptions[property] = that.get(templateOs[property]);
  869. } else {
  870. field.templateOptions[property] = templateOs[property];
  871. }
  872. }
  873. } else if (templateOs[property] == null) {
  874. //delete field.templateOptions[property];
  875. } else {}
  876. }
  877. }
  878. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  879. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  880. angular.extend(field.templateOptions, extObj);
  881. delete field.templateOptions.extjson;
  882. }
  883. //...
  884. if (field.templateOptions) {
  885. //处理远程获取数据控件方法调用
  886. if (field.templateOptions.optionsUrl) {
  887. field.templateOptions.refresh = refreshSelectOptions;
  888. }
  889. //处理嵌套属性数据绑定/
  890. if (field.templateOptions.pkey) {
  891. var pmodel, i = 0;
  892. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  893. if (i == 0) {
  894. if (result.model[p] == null) {
  895. result.model[p] = {};
  896. }
  897. pmodel = result.model[p];
  898. i++;
  899. } else {
  900. if (pmodel[p] == null) {
  901. pmodel[p] = {};
  902. }
  903. pmodel = pmodel[p];
  904. }
  905. });
  906. if (pmodel != null) {
  907. field.model = pmodel;
  908. if (pmodel[field.key] == null) {
  909. pmodel[field.key] = null;
  910. }
  911. }
  912. } else {
  913. if (result.model[field.key] == null) {
  914. result.model[field.key] = null;
  915. }
  916. }
  917. //处理弹出框组件初始化
  918. if (field.type == "ui-input-selectmodal") {
  919. field.templateOptions.modal = $modal;
  920. //field.templateOptions.Restangular = Restangular;
  921. } else if (field.type == "ui-userselect") {
  922. field.templateOptions.modal = $modal;
  923. //field.templateOptions.Restangular = Restangular;
  924. } else if (field.type == "ui-multiuserselect") {
  925. field.templateOptions.modal = $modal;
  926. } else if (field.type == "ui-modelselect") {
  927. field.templateOptions.modal = $modal;
  928. //field.templateOptions.Restangular = Restangular;
  929. }
  930. }
  931. // console.log(field);
  932. //field
  933. //result.fields.push(field);
  934. })
  935. });
  936. vm.originalTabs = angular.copy(vm.form);
  937. }
  938. //======================处理表单设计数据 结束========================
  939. $scope.ldloading = {};
  940. function filter(obj) {
  941. angular.forEach(obj, function(key, value) {
  942. if (value === "" || value === null) {
  943. delete obj[key];
  944. } else if (Object.prototype.toString.call(value) === '[object Object]') {
  945. filter(value);
  946. } else if (angular.isArray(value)) {
  947. angular.forEach(value, function(item) {
  948. filter(item);
  949. });
  950. }
  951. });
  952. }
  953. function invokeOnAllFormOptions(fn) {
  954. angular.forEach(vm.tabs, function(tab) {
  955. if (tab.form.options && tab.form.options[fn]) {
  956. tab.form.options[fn]();
  957. }
  958. });
  959. }
  960. function encodeCIData(data, ciId) {
  961. if (ciId) {
  962. var baseprop = ['uuid', 'name', 'type', 'label', 'status', 'createtime', 'lastupdatetime', 'props'];
  963. var extraprop = 'props';
  964. data[extraprop] = {};
  965. for (var key in data) {
  966. console.log(data[key]);
  967. if (_.indexOf(baseprop, key) >= 0) {
  968. continue;
  969. } else {
  970. data[extraprop][key] = data[key];
  971. delete data[key];
  972. }
  973. }
  974. if ($rootScope.user) {
  975. data[extraprop]['lastupdateperson'] = $rootScope.user.name;
  976. data[extraprop]['configperson'] = $rootScope.user.name;
  977. var isCMAdminFlag = false;
  978. angular.forEach($rootScope.user.role, function(roleItem) {
  979. if (roleItem.rolecode == "cmdb charge") {
  980. isCMAdminFlag = true;
  981. }
  982. })
  983. if (!isCMAdminFlag) {
  984. data[extraprop]['state'] = '1';
  985. }
  986. }
  987. if (data.props.id) {
  988. } else {
  989. data.label = ciId;
  990. }
  991. return data;
  992. }
  993. return undefined;
  994. }
  995. function decodeCIModel(data) {
  996. var extraprop = 'props';
  997. if (data[extraprop]) {
  998. for (var key in data[extraprop]) {
  999. data[key] = data[extraprop][key];
  1000. }
  1001. delete data[extraprop];
  1002. }
  1003. data['iscmadmin'] = false;
  1004. angular.forEach($rootScope.user.role, function(roleItem) {
  1005. if (roleItem.rolecode == "cmdb charge") {
  1006. data['iscmadmin'] = true;
  1007. }
  1008. })
  1009. return data;
  1010. }
  1011. function formValid() {
  1012. angular.forEach(vm.tabs, function(item) {
  1013. //item.
  1014. })
  1015. }
  1016. $scope.vm = vm;
  1017. $scope.refreshcmdbform = function(item, itemdata) {
  1018. // var tempclassify = item.prefix.toLowerCase() + item.sign;
  1019. api_configure_form.renderTabForm(item).then(function(data) {
  1020. var myData = Restangular.stripRestangular(data);
  1021. $scope.propTypeOptions = myData;
  1022. $scope.templateProps = myData;
  1023. $scope.vm.tabs = myData;
  1024. vm.models = itemdata.data;
  1025. if (angular.isDefined(vm.models.vtvmvtm_kaiji)) {
  1026. if (vm.models.vtvmvtm_kaiji) {
  1027. vm.models.vtvmvtm_kaiji = "是";
  1028. } else {
  1029. vm.models.vtvmvtm_kaiji = "否";
  1030. }
  1031. }
  1032. decodeVMTabForm(vm.models, vm.tabs);
  1033. });
  1034. // }
  1035. }
  1036. var cifilterClassic = {};
  1037. function strangelink(name) {
  1038. if (name == 'link') {
  1039. return "连接"
  1040. } else if (name == 'installon') {
  1041. return "安装部署"
  1042. } else if (name == 'blong') {
  1043. return "归属"
  1044. } else if (name == 'use') {
  1045. return "使用"
  1046. } else if (name == 'backupbetw') {
  1047. return "互备"
  1048. } else if (name == "backupown") {
  1049. return "主备"
  1050. }
  1051. }
  1052. //网状图
  1053. $(function() {
  1054. // 高度响应式
  1055. clientHeight = document.documentElement.clientHeight;
  1056. clientWidth = document.documentElement.clientWidth;
  1057. $('#mynetwork').css('height', clientHeight);
  1058. $('#mynetwork').css('width', clientWidth);
  1059. function strangelink(name) {
  1060. if (name == 'link') {
  1061. return "连接"
  1062. } else if (name == 'installon') {
  1063. return "安装部署"
  1064. } else if (name == 'blong') {
  1065. return "归属"
  1066. } else if (name == 'use') {
  1067. return "使用"
  1068. } else if (name == 'backupbetw') {
  1069. return "互备"
  1070. } else if (name == "backupown") {
  1071. return "主备"
  1072. }
  1073. }
  1074. function getinternetAlarm(getmodel) {
  1075. api_cmdb.findRefById(getmodel.id).then(function(result) {
  1076. var obj = {};
  1077. var oaj = {};
  1078. angular.forEach(result.data.node, function(item, index) {
  1079. // if (!obj[item]) {
  1080. obj[item] = 1;
  1081. angular.forEach($scope.select_treelist, function(itemca) {
  1082. var regstring = itemca.prefix + itemca.sign;
  1083. if (item.label == regstring.toLocaleLowerCase()) {
  1084. _mydata.nodes.push({
  1085. "id": item.id,
  1086. "assistId": item.id,
  1087. "label": item.props.hw_mingcheng,
  1088. "image": itemca.iconname ? itemca.iconname : "assets/images/cmdb/other.png",
  1089. // "image":"assets/images/cmdb/other.png",
  1090. "shape": "image",
  1091. "name": item.props.hw_mingcheng,
  1092. "ngcord": item.label,
  1093. "data": item,
  1094. "pid": item.id,
  1095. "hostType": "1",
  1096. "hostStatus": "1",
  1097. "size": 15,
  1098. "isOurDraw": "false",
  1099. "hidden": false
  1100. })
  1101. }
  1102. })
  1103. // }
  1104. })
  1105. angular.forEach(result.data.edge, function(itemedge, indexone) {
  1106. // if (!oaj[itemedge]) {
  1107. oaj[itemedge] = 1;
  1108. _mydata.edges.push({
  1109. "id": itemedge.id,
  1110. "from": itemedge.source,
  1111. "to": itemedge.target,
  1112. "namelink": itemedge.name,
  1113. "label": strangelink(itemedge.name),
  1114. "color": {
  1115. "color": "#ccc"
  1116. }
  1117. })
  1118. // }
  1119. })
  1120. draw(_mydata);
  1121. })
  1122. }
  1123. getinternetAlarm($scope.statement)
  1124. });
  1125. function draw(data) {
  1126. var options = {
  1127. nodes: {
  1128. font: {
  1129. color: "#888",
  1130. size: 10
  1131. }
  1132. },
  1133. edges: {
  1134. smooth: false, //是否显示方向箭头
  1135. color: "#333" // 线条颜色
  1136. },
  1137. layout: {
  1138. improvedLayout: false,
  1139. // direction: 'LR', // UD, DU, LR, RL
  1140. },
  1141. interaction: {
  1142. hover: true,
  1143. navigationButtons: false, // 如果为真,则在网络画布上绘制导航按钮。这些是HTML按钮,可以使用CSS完全自定义。
  1144. keyboard: {
  1145. enabled: true,
  1146. speed: {
  1147. x: -1,
  1148. y: -1,
  1149. zoom: 0.02
  1150. },
  1151. bindToWindow: true
  1152. } // 启用键盘快捷键
  1153. },
  1154. physics: {
  1155. stabilization: false,
  1156. barnesHut: {
  1157. centralGravity: 8, // 中心重力吸引器将整个网络拉回中心
  1158. springLength: 80, // 边缘被建模为弹簧。这个弹簧长度是弹簧的剩余长度
  1159. gravitationalConstant: -80000, // 重力吸引。我们喜欢排斥 所以价值是负数。如果你想要排斥力更强,减小值(所以-10000,-50000)。
  1160. avoidOverlap: 0.2, // 接受范围:[0 .. 1]。当大于0时,会考虑节点的大小。该距离将由重力模型的节点的包围圆的半径计算。值1是最大重叠避免。
  1161. damping: 0.3,
  1162. springConstant: 0.5
  1163. },
  1164. minVelocity: 16 // 一旦达到所有节点的最小速度,我们假设网络已经稳定,仿真停止。
  1165. },
  1166. // selection: {
  1167. // enabled: true, // 打开或关闭配置界面。
  1168. // getEdgeAt: function(data) {
  1169. // // if (isDo) {
  1170. // // callback(data); // 操作成功
  1171. // // } else {
  1172. // // callback(null); // 操作失败
  1173. // // }
  1174. // },
  1175. // },
  1176. };
  1177. network = new vis.Network(container, data, options);
  1178. nodes_data = network.body.data.nodes;
  1179. edges_data = network.body.data.edges;
  1180. //动画稳定后的处理事件
  1181. var stabilizedTimer;
  1182. network.on("stabilized", function(params) { // 会调用两次?
  1183. window.clearTimeout(stabilizedTimer);
  1184. stabilizedTimer = setTimeout(function() {
  1185. exportNetworkPosition(network);
  1186. options.physics.enabled = false; // 关闭物理系统
  1187. network.setOptions(options);
  1188. }, 200);
  1189. });
  1190. // 右键
  1191. // network.on("oncontext", function(params) {
  1192. // if (params.edges.length == 1) {
  1193. // var menuNode = document.getElementById('epMenu');
  1194. // document.oncontextmenu = hideSysMenu; //屏蔽鼠标右键
  1195. // var evt = window.event || arguments[0];
  1196. // var rightedge = evt.clientX;
  1197. // var bottomedge = evt.clientY;
  1198. // // epMenu.create({ left: rightedge, top: bottomedge }, [{ name: '删除关系', 'action': sayremove }, { name: '新增关系', 'action': sayadd }]);
  1199. // epMenu.create({ left: rightedge, top: bottomedge }, [{ name: '删除关系', 'action': sayremove(params) }, { name: '删除关系2', 'action': hideSysMenu(params) }]);
  1200. // }
  1201. // });
  1202. // 右键2
  1203. network.on("getNodeAt", function(params) {
  1204. console.log(params)
  1205. });
  1206. // 右键3
  1207. network.on("editNode", function(params) {
  1208. console.log(params)
  1209. });
  1210. //选中节点
  1211. network.on("selectNode", function(params) {
  1212. // console.log(params)
  1213. });
  1214. //单击节点
  1215. network.on("click", function(params) {
  1216. $scope.openedge = [];
  1217. if (params.nodes.length != 0) { // 双击的是节点
  1218. $scope.opennode = params.nodes;
  1219. var _node = params.nodes[0];
  1220. var _nodeName = nodes_data._data[_node].name;
  1221. var _allChild = getAllChilds(network, _node, []);
  1222. angular.forEach(_mydata.nodes, function(item) {
  1223. if (item.id == params.nodes[0]) {
  1224. $scope.cmdbtype = item
  1225. $scope.refreshcmdbform(item.ngcord, item); 
  1226. }
  1227. })
  1228. angular.forEach(_mydata.edges, function(itemedge) {
  1229. if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  1230. angular.forEach(_mydata.nodes, function(item) {
  1231. if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  1232. var datas = itemedge;
  1233. datas.tolabelname = item
  1234. $scope.openedge.push(datas); 
  1235. }
  1236. })
  1237. }
  1238. })
  1239. // angular.forEach(_mydata.nodes, function(item) {
  1240. // angular.forEach(_mydata.edges, function(itemedge) {
  1241. // if (itemedge.to == item.id) {
  1242. // var datas = itemedge;
  1243. // datas.tolabelname = item
  1244. // $scope.openedge.push(datas); 
  1245. // }
  1246. // })
  1247. // })
  1248. if ($scope.cmdbisopen) {
  1249. } else {
  1250. $scope.cmdbisopen = true;
  1251. open = true;
  1252. }
  1253. // angular.forEach(_mydata.edges, function(item) {
  1254. // if (item.id == $scope.statement.id) {
  1255. // $scope.openedge.push(item);
  1256. // }
  1257. // })
  1258. } else if (params.edges.length == 1) {
  1259. // $scope.cmdbisopen = true;
  1260. // var menuNode = document.getElementById('epMenu');
  1261. // var evt = window.event || arguments[0];
  1262. // var rightedge = evt.clientX;
  1263. // var bottomedge = evt.clientY;
  1264. // epMenu.create({ left: rightedge, top: bottomedge }, [{ name: '删除关系', 'action': sayremove(params) }, { name: '删除关系2', 'action': hideSysMenu(params) }]);
  1265. } else {
  1266. epMenu.destory();
  1267. $scope.cmdbisopen = false;
  1268. }
  1269. // epMenu.destory();
  1270. });
  1271. //双击节点 隐藏或者显示子节点
  1272. network.on("doubleClick", function(params) {
  1273. event.preventDefault();
  1274. // if (params.nodes.length != 0) { // 双击的是节点
  1275. // if (open) {
  1276. // } else {
  1277. // $scope.cmdbisopen = true;
  1278. // open = true;
  1279. // }
  1280. // } else {
  1281. // }
  1282. if (params.nodes.length != 0) { // 双击的是节点
  1283. var _node = params.nodes[0];
  1284. var _nodeName = nodes_data._data[_node].name;
  1285. var _allChild = getAllChilds(network, _node, []);
  1286. angular.forEach(_mydata.nodes, function(item) {
  1287. if (item.id == params.nodes[0]) {
  1288. $scope.refreshcmdbform(item.ngcord, item); 
  1289. }
  1290. })
  1291. if (_allChild.length > 0) { // 存在子节点
  1292. if (nodes_data._data[_allChild[_allChild.length - 1]].hidden == false) {
  1293. nodes_data.update([{
  1294. id: _node,
  1295. label: _nodeName + " " + connectedNum + _allChild.length
  1296. }]);
  1297. for (var i = 0; i < _allChild.length; i++) {
  1298. nodes_data.update([{
  1299. id: _allChild[i],
  1300. hidden: true
  1301. }]);
  1302. edges_data.update([{
  1303. id: _allChild[i],
  1304. hidden: true
  1305. }]);
  1306. }
  1307. } else {
  1308. nodes_data.update([{
  1309. id: _node,
  1310. label: _nodeName
  1311. }]);
  1312. for (var j = 0; j < _allChild.length; j++) {
  1313. nodes_data.update([{
  1314. id: _allChild[j],
  1315. hidden: false
  1316. }]);
  1317. edges_data.update([{
  1318. id: _allChild[j],
  1319. hidden: false
  1320. }]);
  1321. }
  1322. }
  1323. } else {
  1324. $scope.openedge = [];
  1325. api_cmdb.findRefById(params.nodes[0]).then(function(result) {
  1326. angular.forEach(result.data.node, function(item, index) {
  1327. var someone = true;
  1328. angular.forEach(_mydata.nodes, function(chil) {
  1329. if (chil.id == item.id) {
  1330. someone = false;
  1331. }
  1332. })
  1333. if (someone) {
  1334. angular.forEach($scope.select_treelist, function(itemca) {
  1335. var regstring = itemca.prefix + itemca.sign;
  1336. if (item.label == regstring.toLocaleLowerCase()) {
  1337. _mydata.nodes.push({
  1338. "id": item.id,
  1339. "assistId": item.id,
  1340. "label": item.props.hw_mingcheng,
  1341. "image": itemca.iconname ? itemca.iconname : "assets/images/cmdb/other.png",
  1342. // "image":"assets/images/cmdb/other.png",
  1343. "shape": "image",
  1344. "name": item.props.hw_mingcheng,
  1345. "ngcord": item.label,
  1346. "data": item,
  1347. "pid": item.id,
  1348. "hostType": "1",
  1349. "hostStatus": "1",
  1350. "size": 15,
  1351. "isOurDraw": "false",
  1352. "hidden": false
  1353. })
  1354. }
  1355. })
  1356. }
  1357. // }
  1358. })
  1359. angular.forEach(result.data.edge, function(itemedge, indexone) {
  1360. var someone = true;
  1361. angular.forEach(_mydata.edges, function(chil) {
  1362. if (chil.id == itemedge.id) {
  1363. someone = false;
  1364. }
  1365. })
  1366. if (someone) {
  1367. _mydata.edges.push({
  1368. "id": itemedge.id,
  1369. "from": itemedge.source,
  1370. "to": itemedge.target,
  1371. // "label": itemedge.name,
  1372. "namelink": itemedge.name,
  1373. "label": strangelink(itemedge.name),
  1374. "color": {
  1375. "color": "#ccc"
  1376. }
  1377. })
  1378. }
  1379. })
  1380. angular.forEach(_mydata.edges, function(itemedge) {
  1381. if (itemedge.to == $scope.cmdbtype.id || itemedge.from == $scope.cmdbtype.id) {
  1382. angular.forEach(_mydata.nodes, function(item) {
  1383. if ((itemedge.to == item.id && itemedge.from == $scope.cmdbtype.id) || (itemedge.from == item.id && itemedge.to == $scope.cmdbtype.id)) {
  1384. var datas = itemedge;
  1385. datas.tolabelname = item
  1386. $scope.openedge.push(datas); 
  1387. }
  1388. })
  1389. }
  1390. })
  1391. // })
  1392. // angular.forEach(_mydata.edges, function(item) {
  1393. // if (item.from == $scope.cmdbtype.id || item.to == $scope.cmdbtype.id) {
  1394. // var datas = itemedge;
  1395. // datas.tolabelname = item
  1396. // $scope.openedge.push(item);
  1397. // }
  1398. // })
  1399. draw(_mydata);
  1400. })
  1401. }
  1402. }
  1403. });
  1404. //拖动节点
  1405. network.on("dragging", function(params) { //拖动进行中事件
  1406. if (params.nodes.length != 0) {
  1407. nodeMoveFun(params);
  1408. }
  1409. });
  1410. //拖动结束后
  1411. network.on("dragEnd", function(params) {
  1412. if (params.nodes.length != 0) {
  1413. var arr = nodeMoveFun(params);
  1414. exportNetworkPosition(network, arr);
  1415. }
  1416. });
  1417. //浮动
  1418. network.on('hoverNode', function(param) {
  1419. thisnode = param;
  1420. });
  1421. // 缩放
  1422. network.on("zoom", function(params) {});
  1423. }
  1424. // clientHeight = document.documentElement.clientHeight;
  1425. // clientWidth = document.documentElement.clientWidth;
  1426. function centerNode(source) {
  1427. source.event.center = { x: (document.documentElement.clientWidth - 20) / 2, y: (document.documentElement.clientHeight - 40) / 2 };
  1428. source.event.changedPointers[0].clientX = (document.documentElement.clientWidth - 20) / 2;
  1429. source.event.changedPointers[0].clientY = (document.documentElement.clientHeight - 40) / 2;
  1430. nodeMoveFun(source);
  1431. // var arr = nodeMoveFun(source);
  1432. // exportNetworkPosition(network, arr);
  1433. }
  1434. /*
  1435. *获取所有子节点
  1436. * network :图形对象
  1437. * _thisNode :单击的节点(父节点)
  1438. * _Allnodes :用来装子节点ID的数组
  1439. * */
  1440. function getAllChilds(network, _thisNode, _Allnodes) {
  1441. var _nodes = network.getConnectedNodes(_thisNode, "to");
  1442. if (_nodes.length > 0) {
  1443. for (var i = 0; i < _nodes.length; i++) {
  1444. getAllChilds(network, _nodes[i], _Allnodes);
  1445. _Allnodes.push(_nodes[i]);
  1446. }
  1447. }
  1448. return _Allnodes
  1449. };
  1450. // 节点移动
  1451. function nodeMoveFun(params) {
  1452. var click_node_id = params.nodes[0];
  1453. var allsubidsarr = getAllChilds(network, click_node_id, []); // 获取所有的子节点
  1454. if (allsubidsarr) { // 如果存在子节点
  1455. var positionThis = network.getPositions(click_node_id);
  1456. var clickNodePosition = positionThis[click_node_id]; // 记录拖动后,被拖动节点的位置
  1457. var position = JSON.parse(localStorage.getItem("position"));
  1458. var startNodeX, startNodeY; // 记录被拖动节点的子节点,拖动前的位置
  1459. var numNetx, numNety; // 记录被拖动节点移动的相对距离
  1460. var positionObj = {}; // 记录移动的节点位置信息, 用于返回
  1461. positionObj[click_node_id] = {
  1462. x: clickNodePosition.x,
  1463. y: clickNodePosition.y
  1464. }; // 记录被拖动节点位置信息
  1465. numNetx = clickNodePosition.x - position[click_node_id].x; // 拖动的距离
  1466. numNety = clickNodePosition.y - position[click_node_id].y;
  1467. for (var j = 0; j < allsubidsarr.length; j++) {
  1468. if (position[allsubidsarr[j]]) {
  1469. startNodeX = position[allsubidsarr[j]].x; // 子节点开始的位置
  1470. startNodeY = position[allsubidsarr[j]].y;
  1471. network.moveNode(allsubidsarr[j], (startNodeX + numNetx), (startNodeY + numNety)); // 在视图上移动子节点
  1472. positionObj[allsubidsarr[j]] = {
  1473. x: (startNodeX + numNetx),
  1474. y: (startNodeY + numNety)
  1475. }; // 记录子节点位置信息
  1476. }
  1477. }
  1478. }
  1479. return positionObj;
  1480. };
  1481. //处理本地存储,这里仅仅只能作为高级浏览器使用,ie9以下不能处理
  1482. function setLocal(position) {
  1483. localStorage.removeItem("position");
  1484. localStorage.setItem("position", JSON.stringify(position));
  1485. }
  1486. var epMenu = {
  1487. create: function(point, option) {
  1488. var menuNode = document.getElementById('epMenu');
  1489. if (!menuNode) {
  1490. //没有菜单节点的时候创建一个
  1491. menuNode = document.createElement("div");
  1492. menuNode.setAttribute('class', 'epMenu');
  1493. menuNode.setAttribute('id', 'epMenu');
  1494. } else $(menuNode).html(''); //清空里面的内容
  1495. $(menuNode).css({ left: point.left + 'px', top: point.top + 'px' });
  1496. for (var x in option) {
  1497. var tempNode = document.createElement("a");
  1498. $(tempNode).text(option[x]['name']).on('click', option[x].action);
  1499. menuNode.appendChild(tempNode);
  1500. }
  1501. $("body").append(menuNode);
  1502. },
  1503. destory: function() {
  1504. $(".epMenu").remove();
  1505. }
  1506. };
  1507. function sayadd() {
  1508. alert("hellokity");
  1509. epMenu.destory();
  1510. }
  1511. $scope.sayremove = function(data) {
  1512. SweetAlert.swal({
  1513. title: "确认删除资产关系-" + data.label + "?",
  1514. // text: "删除资产关系-" + data.label + "以后,你将不能恢复该数据!",
  1515. type: "warning",
  1516. showCancelButton: true,
  1517. confirmButtonColor: "#DD6B55",
  1518. confirmButtonText: "确认删除!",
  1519. cancelButtonText: "取消"
  1520. }, function(isConfirm) {
  1521. if (isConfirm) {
  1522. if (data.id == 0) {
  1523. data.id = "0"
  1524. }
  1525. api_cmdb.removeRef(data.id).then(function(response) {
  1526. if (response && response.status == 200) {
  1527. angular.forEach(_mydata.edges, function(item, index) {
  1528. if (data.id == item.id) {
  1529. _mydata.edges.splice(index, 1);
  1530. }
  1531. })
  1532. draw(_mydata);
  1533. angular.forEach($scope.openedge, function(item, index) {
  1534. if (data.id == item.id) {
  1535. $scope.openedge.splice(index, 1);
  1536. }
  1537. })
  1538. SweetAlert.swal({
  1539. title: "删除成功",
  1540. text: "关系删除成功!",
  1541. type: "success"
  1542. });
  1543. } else {
  1544. SweetAlert.swal({
  1545. title: "系统错误!",
  1546. text: "系统错误,请稍候重试或者联系管理员!",
  1547. type: "error"
  1548. });
  1549. }
  1550. });
  1551. }
  1552. });
  1553. }
  1554. // function sayremove(data) {
  1555. // // api_cmdb.put(cidata, $scope.ciId).then(function(response) {
  1556. // // if (response) {
  1557. // // var resData = Restangular.stripRestangular(response);
  1558. // // SweetAlert.swal({
  1559. // // title: "保存成功!",
  1560. // // confirmButtonColor: "#007AFF"
  1561. // // }, function() {
  1562. // // refreshData($scope.classify);
  1563. // // reinitTabForm($scope.classify);
  1564. // // });
  1565. // // } else {
  1566. // // SweetAlert.swal({
  1567. // // title: "系统错误",
  1568. // // text: "系统错误,请稍后重试!",
  1569. // // type: "error",
  1570. // // confirmButtonColor: "#DD6B55"
  1571. // // });
  1572. // // }
  1573. // // $scope.ldloading[style.replace('-', '_')] = false;
  1574. // // });
  1575. // SweetAlert.swal({
  1576. // title: "确认删除资产关系?",
  1577. // text: "删除资产关系以后,你将不能恢复该数据!",
  1578. // type: "warning",
  1579. // cancelButtonText: "取消",
  1580. // showCancelButton: true,
  1581. // confirmButtonColor: "#DD6B55",
  1582. // confirmButtonText: "确认删除!"
  1583. // }, function(isConfirm) {
  1584. // if (isConfirm) {
  1585. // api_cmdb.removeRef(id).then(function(response) {
  1586. // if (response && response.status == 200) {
  1587. // angular.forEach(_mydata.edges, function(item) {
  1588. // if (id == item.id) {
  1589. // _mydata.edges.splice(index, 1)
  1590. // }
  1591. // })
  1592. // draw(_mydata);
  1593. // // links.splice(links.indexOf($scope.selected_link), 1);
  1594. // // restart();
  1595. // } else {
  1596. // SweetAlert.swal({
  1597. // title: "系统错误!",
  1598. // text: "系统错误,请稍候重试或者联系管理员!",
  1599. // type: "error"
  1600. // });
  1601. // }
  1602. // });
  1603. // }
  1604. // });
  1605. // epMenu.destory();
  1606. // }
  1607. function hideSysMenu() {
  1608. return false;
  1609. }
  1610. // //删除下级所有节点
  1611. // function remove_all_sub_nodes(node_id) {
  1612. // var sub_nodes = get_directly_sub_nodes(node_id);
  1613. // if (sub_nodes.length == 0) { //当前点击的为叶子节点
  1614. // //判断是否有下级节点
  1615. // if (typeof(allnodes[node_id - 1]['subids']) != 'undefined') {
  1616. // $.each(allnodes[node_id - 1]['subids'], function(index, item) {
  1617. // nodes.add(allnodes[item - 1]);
  1618. // edges.add({ id: node_id + '_' + item, from: node_id, to: item });
  1619. // });
  1620. // } else {
  1621. // alert('当前为叶子节点');
  1622. // }
  1623. // } else {
  1624. // $.each(sub_nodes, function(index, item) {
  1625. // var sub_sub_nodes = get_directly_sub_nodes(item);
  1626. // if (sub_sub_nodes.length == 0) {
  1627. // nodes.remove({ id: item });
  1628. // edges.remove({ id: node_id + '_' + item });
  1629. // } else {
  1630. // remove_all_sub_nodes(item);
  1631. // }
  1632. // nodes.remove({ id: item });
  1633. // edges.remove({ id: node_id + '_' + item });
  1634. // });
  1635. // }
  1636. // }
  1637. /*
  1638. *节点位置设置
  1639. * network :图形对象
  1640. * arr :本次移动的节点位置信息
  1641. * */
  1642. function exportNetworkPosition(network, arr) {
  1643. if (arr) { // 折叠过后 getPositions() 获取的位置信息里不包含隐藏的节点位置信息,这时候调用上次存储的全部节点位置,并修改这次移动的节点位置,最后保存
  1644. var localtionPosition = JSON.parse(localStorage.getItem("position"));
  1645. for (let index in arr) {
  1646. localtionPosition[index] = {
  1647. x: arr[index].x,
  1648. y: arr[index].y
  1649. }
  1650. }
  1651. setLocal(localtionPosition);
  1652. } else {
  1653. var position = network.getPositions();
  1654. setLocal(position);
  1655. }
  1656. };
  1657. // //选中节点
  1658. // // network.on("selectNode", function(params) {
  1659. // // console.log(params)
  1660. // // });
  1661. // //单击节点
  1662. // network.on("click", function(params) {});
  1663. // // 右键
  1664. // // network.on("hoverNode", function(params) {
  1665. // // console.log(network);
  1666. // // if (params.node) {
  1667. // // var menuNode = document.getElementById('epMenu');
  1668. // // document.oncontextmenu = hideSysMenu; //屏蔽鼠标右键
  1669. // // var evt = window.event || arguments[0];
  1670. // // var rightedge = evt.clientX;
  1671. // // var bottomedge = evt.clientY;
  1672. // // epMenu.create({ left: rightedge, top: bottomedge }, [{ name: '删除关系', 'action': sayremove }, { name: '新增关系', 'action': sayadd }]);
  1673. // // }
  1674. // // });
  1675. // network.on("oncontext", function(params) {
  1676. // // console.log(network);
  1677. // // var nodeid = network.selectionHandler.hoverObj.nodes.id
  1678. // // console.log(nodeid)
  1679. // if (thisnode.node) {
  1680. // var menuNode = document.getElementById('epMenu');
  1681. // document.oncontextmenu = hideSysMenu; //屏蔽鼠标右键
  1682. // var evt = window.event || arguments[0];
  1683. // var rightedge = evt.clientX;
  1684. // var bottomedge = evt.clientY;
  1685. // epMenu.create({ left: rightedge, top: bottomedge }, [{ name: '删除关系', 'action': sayremove }, { name: '新增关系', 'action': sayadd }]);
  1686. // }
  1687. // });
  1688. // // var networkCanvas = document.getElementById("mynetwork").getElementsByTagName("canvas")[0]
  1689. // // function changeCursor(newCursorStyle) {
  1690. // // networkCanvas.style.cursor = newCursorStyle;
  1691. // // }
  1692. // // function changeEventCursor(eventName, cursorType) {
  1693. // // network.on(eventName, function() {
  1694. // // changeCursor(cursorType);
  1695. // // });
  1696. // // }
  1697. // network.on('hoverNode', function(param) {
  1698. // changeCursor('grab');
  1699. // thisnode = param;
  1700. // });
  1701. var options = {
  1702. autoResize: true, // Default:true 如果为true,则网络将自动检测其容器何时调整大小,并相应地重新绘制自己。如果为false,则可以在使用函数redraw()和setSize()调整容器的容器大小后强制重新绘制网络。
  1703. clickToUse: true, // Default:false 将网络配置clickToUse为时,只有在激活时才会对鼠标和触摸事件做出反应。激活时,网络周围会显示蓝色阴影边框。通过点击该网络将网络设置为活动状态,然后通过点击网络外部或按ESC键将其更改为非活动状态。
  1704. width: "100%", // 画布的宽度。可以百分比或像素
  1705. height: "100%",
  1706. locale: "cn", // 选择区域设置。默认情况下,该语言是英语。
  1707. nodes: {
  1708. borderWidth: 1,
  1709. borderWidthSelected: 2,
  1710. brokenImage: undefined,
  1711. chosen: true,
  1712. color: {
  1713. border: '#2B7CE9',
  1714. background: '#97C2FC',
  1715. highlight: {
  1716. border: '#2B7CE9',
  1717. background: '#D2E5FF'
  1718. },
  1719. hover: {
  1720. border: '#2B7CE9',
  1721. background: '#D2E5FF'
  1722. }
  1723. },
  1724. fixed: {
  1725. x: false,
  1726. y: false
  1727. },
  1728. font: {
  1729. color: '#343434',
  1730. size: 14, // px
  1731. face: 'arial',
  1732. background: 'none',
  1733. strokeWidth: 0, // px
  1734. strokeColor: '#ffffff',
  1735. align: 'center',
  1736. multi: false,
  1737. vadjust: 0,
  1738. bold: {
  1739. color: '#343434',
  1740. size: 14, // px
  1741. face: 'arial',
  1742. vadjust: 0,
  1743. mod: 'bold'
  1744. },
  1745. ital: {
  1746. color: '#343434',
  1747. size: 14, // px
  1748. face: 'arial',
  1749. vadjust: 0,
  1750. mod: 'italic',
  1751. },
  1752. boldital: {
  1753. color: '#343434',
  1754. size: 14, // px
  1755. face: 'arial',
  1756. vadjust: 0,
  1757. mod: 'bold italic'
  1758. },
  1759. mono: {
  1760. color: '#343434',
  1761. size: 15, // px
  1762. face: 'courier new',
  1763. vadjust: 2,
  1764. mod: ''
  1765. }
  1766. },
  1767. group: undefined,
  1768. heightConstraint: false,
  1769. hidden: false,
  1770. icon: {
  1771. face: 'FontAwesome',
  1772. code: undefined,
  1773. size: 50, //50,
  1774. color: '#2B7CE9'
  1775. },
  1776. image: undefined,
  1777. label: undefined,
  1778. labelHighlightBold: true,
  1779. level: undefined,
  1780. mass: 1,
  1781. physics: true,
  1782. scaling: {
  1783. min: 10,
  1784. max: 30,
  1785. label: {
  1786. enabled: false,
  1787. min: 14,
  1788. max: 30,
  1789. maxVisible: 30,
  1790. drawThreshold: 5
  1791. },
  1792. customScalingFunction: function(min, max, total, value) {
  1793. if (max === min) {
  1794. return 0.5;
  1795. } else {
  1796. let scale = 1 / (max - min);
  1797. return Math.max(0, (value - min) * scale);
  1798. }
  1799. }
  1800. },
  1801. shadow: {
  1802. enabled: false,
  1803. color: 'rgba(0,0,0,0.5)',
  1804. size: 10,
  1805. x: 5,
  1806. y: 5
  1807. },
  1808. shape: 'ellipse',
  1809. shapeProperties: {
  1810. borderDashes: false, // only for borders
  1811. borderRadius: 6, // only for box shape
  1812. interpolation: false, // only for image and circularImage shapes
  1813. useImageSize: false, // only for image and circularImage shapes
  1814. useBorderWithImage: false // only for image shape
  1815. },
  1816. size: 25,
  1817. title: undefined,
  1818. value: undefined,
  1819. widthConstraint: false,
  1820. x: undefined,
  1821. y: undefined
  1822. },
  1823. locales: {
  1824. cn: {
  1825. edit: '编辑',
  1826. del: '删除选定',
  1827. back: '返回',
  1828. addNode: '添加节点',
  1829. addEdge: '添加关联',
  1830. editNode: '编辑节点',
  1831. editEdge: '编辑关联',
  1832. addDescription: '单击空白处来放置一个新节点。',
  1833. edgeDescription: '单击一个节点并拖动到另一个节点以连接它们。',
  1834. editEdgeDescription: '单击控制点并将其拖动到节点以连接到它。',
  1835. createEdgeError: '无法将边缘链接到集群。',
  1836. deleteClusterError: '不能删除集群。',
  1837. editClusterError: '不能编辑集群。'
  1838. }
  1839. },
  1840. configure: {
  1841. enabled: true, // 打开或关闭配置界面。
  1842. filter: function(option, path) {
  1843. return path.indexOf('physics') !== -1
  1844. }, // 如果布尔值为true,则给出所有选项,false将不显示任何值。 如果提供了字符串,则允许以下任意组合:节点,边,布局,交互,操纵,物理,选择,渲染器。随意想出一个有趣的分开的字符。最后,当提供一个字符串数组时,任何前面提到的字段都被接​​受。当提供一个函数时,你会收到两个参数。选项对象中的选项和选项的路径。如果它返回true,则选项将显示在配置程序中。
  1845. // container: undefined,
  1846. showButton: true // 在配置器底部显示生成选项按钮。
  1847. },
  1848. nodes: {
  1849. font: {
  1850. color: "#eee",
  1851. size: 10
  1852. }
  1853. },
  1854. edges: {
  1855. smooth: {
  1856. enabled: true,
  1857. type: 'cubicBezier', // 'dynamic', 'continuous', 'discrete','diagonalCross', 'horizontal', 'vertical', 'curvedCW', 'curvedCCW', 'cubicBezier'
  1858. forceDirection: 'vertical', //'horizontal', 'vertical', 'none' 该选项仅用于cubicBezier曲线。
  1859. roundness: 0.7 // 0 .. 1.0,
  1860. },
  1861. // lable: "dkfjaksdj",
  1862. color: "#737373" // 线条颜色
  1863. },
  1864. enableEditMode: true,
  1865. layout: { // 自动层级布局
  1866. improvedLayout: true,
  1867. randomSeed: 1, //配置每次生成的节点位置都一样,参数为数字1、2等
  1868. hierarchical: {
  1869. enabled: true, //切换分层布局系统
  1870. levelSeparation: 260, //不同级别之间的距离。
  1871. nodeSpacing: 260, // 自由轴上节点之间的最小距离,这仅适用于初始布局。如果启用物理,则节点距离将存在有效的节点距离。
  1872. treeSpacing: 260, //不同树木之间的距离(独立网络)
  1873. blockShifting: false, // 每个节点都会检查空白,并尽可能地将它的分支与它一起移动,并在任何级别上考虑nodeSpacing
  1874. edgeMinimization: false, // 每个节点将尝试沿其自由轴移动以减少其边缘的总长度
  1875. parentCentralization: false, // 如果为true,则布局算法完成后,父节点将再次居中。
  1876. // direction: 'LR', // UD, DU, LR, RL
  1877. // sortMethod: 'directed' // directed hubsize
  1878. }
  1879. },
  1880. manipulation: {
  1881. enabled: true,
  1882. addNode: function(data, callback) {
  1883. document.getElementById('node-type').value = "1";
  1884. document.getElementById('node-label').value = "";
  1885. document.getElementById('saveButton').onclick = saveData.bind(this, data, callback);
  1886. document.getElementById('cancelButton').onclick = clearPopUp.bind();
  1887. document.getElementById('network-popUp').style.display = 'block';
  1888. },
  1889. editNode: function(data, callback) {
  1890. document.getElementById('node-label').value = deviceName;
  1891. document.getElementById('saveButton').onclick = saveEditData.bind(this, data, callback);
  1892. document.getElementById('cancelButton').onclick = cancelEdit.bind(this, callback);
  1893. document.getElementById('network-popUp').style.display = 'block';
  1894. }
  1895. },
  1896. selection: {
  1897. enabled: true, // 打开或关闭配置界面。
  1898. getEdgeAt: function(data) {
  1899. // if (isDo) {
  1900. // callback(data); // 操作成功
  1901. // } else {
  1902. // callback(null); // 操作失败
  1903. // }
  1904. },
  1905. },
  1906. deleteNode: function(data, callback) {
  1907. // do something
  1908. if (isDo) {
  1909. callback(data); // 操作成功
  1910. } else {
  1911. callback(null); // 操作失败
  1912. }
  1913. },
  1914. addEdge: function(data, callback) {
  1915. // do something
  1916. if (isDo) {
  1917. callback(data); // 操作成功
  1918. } else {
  1919. callback(null); // 操作失败
  1920. }
  1921. },
  1922. editEdge: true, // 关系不可编辑
  1923. deleteEdge: function(data, callback) {
  1924. // do something
  1925. if (isDo) {
  1926. callback(data); // 操作成功
  1927. } else {
  1928. callback(null); // 操作失败
  1929. }
  1930. },
  1931. // }
  1932. interaction: {
  1933. hover: true,
  1934. navigationButtons: true, // 如果为真,则在网络画布上绘制导航按钮。这些是HTML按钮,可以使用CSS完全自定义。
  1935. keyboard: {
  1936. enabled: true,
  1937. speed: {
  1938. x: -1,
  1939. y: -1,
  1940. zoom: 0.02
  1941. },
  1942. bindToWindow: false
  1943. } // 启用键盘快捷键
  1944. },
  1945. physics: { // 采用分层布局系统,关闭物理布局
  1946. enabled: true,
  1947. stabilization: false,
  1948. barnesHut: {
  1949. centralGravity: 8, // 中心重力吸引器将整个网络拉回中心
  1950. springLength: 80, // 边缘被建模为弹簧。这个弹簧长度是弹簧的剩余长度
  1951. gravitationalConstant: -80000, // 重力吸引。我们喜欢排斥 所以价值是负数。如果你想要排斥力更强,减小值(所以-10000,-50000)。
  1952. avoidOverlap: 0.2, // 接受范围:[0 .. 1]。当大于0时,会考虑节点的大小。该距离将由重力模型的节点的包围圆的半径计算。值1是最大重叠避免。
  1953. damping: 0.3,
  1954. springConstant: 0.5
  1955. },
  1956. minVelocity: 16 // 一旦达到所有节点的最小速度,我们假设网络已经稳定,仿真停止。
  1957. // stabilization: {//如果开启,下面注释掉的监听图形绘制过程的函数才会生效
  1958. // enabled:true,
  1959. // iterations:2000,
  1960. // updateInterval:25
  1961. // }
  1962. }
  1963. };
  1964. /**
  1965. * 查找设备
  1966. * @param name 设备名称/SN/MAC
  1967. */
  1968. function findDevice(name) {
  1969. var nodes = network.body.data.nodes._data;
  1970. for (var i in nodes) {
  1971. if (nodes[i].label == name || nodes[i].hostSn == name || nodes[i].hostMac == name) { // 具体需要可在此配置
  1972. network.focus(nodes[i].id, {
  1973. scale: 2
  1974. });
  1975. return
  1976. }
  1977. }
  1978. layer.msg("查找的设备不存在!", {
  1979. icon: 5
  1980. });
  1981. }
  1982. }]);