gdzc_old.js 82 KB

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