gdzc_meansformCtrl.js 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077
  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. var vm = this;
  14. vm.options = {};
  15. vm.exampleTitle = ['expressionProperties', 'model property'];
  16. vm.fields = [];
  17. vm.model = {};
  18. vm.model["loginUser"] = $rootScope.user;
  19. var that = $injector;
  20. var parse = $parse;
  21. var formKey = "";
  22. var pdKey = "";
  23. if (angular.isDefined($state.current.pdKey) && $state.current.pdKey != "") {
  24. pdKey = $state.current.pdKey;
  25. //console.log("pdKey::"+$state.current.pdKey);
  26. }
  27. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  28. formKey = $stateParams.formKey;
  29. // console.log(formKey);
  30. //console.log("formKey::"+$stateParams.formKey);
  31. }
  32. //关系图
  33. var dom = document.getElementById("meansmap");
  34. var myChart = echarts.init(dom);
  35. var app = {};
  36. var option = null;
  37. myChart.showLoading();
  38. var data2 = [{
  39. name: "治安管理工作",
  40. label: {
  41. normal: {
  42. backgroundColor: '#725bb8'
  43. }
  44. },
  45. children: [{
  46. name: "娱乐场所治安管理",
  47. children: [{
  48. name: "娱乐场所治安管理工作"
  49. }]
  50. }, {
  51. name: "安保工作",
  52. children: [{
  53. name: "输油气管道安保工作"
  54. }, {
  55. name: "校园安保工作"
  56. }, {
  57. name: "节假日、重大活动、大型群众性活动安保和敏感期社会面管控工作"
  58. }]
  59. }, {
  60. name: "精神病人管控工作",
  61. children: [{
  62. name: "精神病人肇事肇祸案事件"
  63. }]
  64. }, {
  65. name: "物流寄递业",
  66. children: [{
  67. name: "物流寄递业治安管理工作"
  68. }]
  69. }, {
  70. name: "推进基层基础工作创新",
  71. children: [{
  72. name: "加强派出所建设"
  73. }]
  74. }, {
  75. name: "地网建设工作",
  76. children: [{
  77. name: "加强二轮电动车防盗登记备案装置安装工作"
  78. }]
  79. }, {
  80. name: "无人机管理",
  81. children: [{
  82. name: "加强无人机管理"
  83. }]
  84. }, {
  85. name: "加强社会面巡逻防控",
  86. children: [{
  87. name: "武装联勤巡逻"
  88. }]
  89. }]
  90. }];
  91. myChart.hideLoading();
  92. // echarts.util.each(data2.children, function(datum, index) {
  93. // index % 2 === 0 && (datum.collapsed = true);
  94. // });
  95. option = {
  96. backgroundColor: '#02246d',
  97. tooltip: {
  98. trigger: 'item',
  99. triggerOn: 'mousemove'
  100. },
  101. legend: {
  102. top: '2%',
  103. left: '3%',
  104. orient: 'vertical',
  105. data: [{
  106. name: 'tree1',
  107. icon: 'rectangle'
  108. }],
  109. borderColor: '#c23531'
  110. },
  111. series: [{
  112. type: 'tree',
  113. name: '治安管理工作',
  114. data: data2,
  115. top: '5%',
  116. left: '7%',
  117. bottom: '2%',
  118. right: '60%',
  119. symbolSize: 7,
  120. // label: {
  121. // normal: {
  122. // position: 'left',
  123. // verticalAlign: 'middle',
  124. // align: 'right'
  125. // }
  126. // },
  127. label: {
  128. normal: {
  129. position: 'center',
  130. verticalAlign: 'middle',
  131. align: 'left',
  132. backgroundColor: '#7049f0',
  133. color: '#fff',
  134. padding: 3,
  135. formatter: [
  136. '{box|{b}}'
  137. ].join('\n'),
  138. rich: {
  139. box: {
  140. top: 5,
  141. height: 30,
  142. color: '#fff',
  143. padding: [0, 5],
  144. align: 'center'
  145. }
  146. }
  147. }
  148. },
  149. leaves: {
  150. label: {
  151. normal: {
  152. position: 'center',
  153. verticalAlign: 'middle',
  154. align: 'left',
  155. backgroundColor: '#c44eff',
  156. formatter: [
  157. '{box|{b}}'
  158. ].join('\n'),
  159. rich: {
  160. box: {
  161. height: 18,
  162. color: '#fff',
  163. padding: [0, 5],
  164. align: 'center'
  165. }
  166. }
  167. }
  168. }
  169. },
  170. expandAndCollapse: true,
  171. animationDuration: 550,
  172. animationDurationUpdate: 750
  173. }]
  174. };
  175. myChart.on('legendselectchanged', function(params) {
  176. // 获取点击图例的选中状态
  177. var isSelected = params.selected[params.name];
  178. // 在控制台中打印
  179. console.log((isSelected ? '选中了' : '取消选中了') + '图例' + params.name);
  180. // 打印所有图例的状态
  181. console.log(params.selected);
  182. })
  183. if (option && typeof option === "object") {
  184. myChart.setOption(option, true);
  185. }
  186. function getinternetAlarm() {
  187. api_bpm_data.fetchDataList('applicationForm', { "idx": 0, "sum": 100 }).then(function(data) {
  188. // if (data.status == 200) {
  189. option.series[0].data[0] = {
  190. name: "治安管理工作",
  191. label: {
  192. normal: {
  193. backgroundColor: '#725bb8'
  194. }
  195. },
  196. children: [{
  197. name: "娱乐场所治安管理",
  198. children: [{
  199. name: "娱乐场所治安管理工作"
  200. }]
  201. }, {
  202. name: "加强社会面巡逻防控",
  203. children: [{
  204. name: "武装联勤巡逻"
  205. }]
  206. }]
  207. }
  208. myChart.setOption(option);
  209. myChart.hideLoading();
  210. // }
  211. })
  212. }
  213. // getinternetAlarm();
  214. setInterval(function() {
  215. getinternetAlarm();
  216. }, 10000);
  217. //关系图end
  218. //用户测试数据,后续从header的auth中获取
  219. var userId = 2;
  220. userId = $rootScope.user.id;
  221. //==============处理表单设计数据 开始====================
  222. //处理组件加载后台数据选项的方法
  223. function refreshSelectOptions(searchVal, field) {
  224. if (field.templateOptions.optionsUrl) {
  225. var process = BpmRestangular.all("");
  226. if (field.templateOptions.ApiService) {
  227. process = UserRestangular.all("");
  228. }
  229. process.customPOST({ "idx": 0, "sum": 1000 }, field.templateOptions.optionsUrl).then(function(result) {
  230. if (!field.templateOptions.options) {
  231. field.templateOptions.options = [];
  232. }
  233. if (field.templateOptions.optionsDataKey) {
  234. field.templateOptions.options = result[field.templateOptions.optionsDataKey];
  235. } else {
  236. field.templateOptions.options = result;
  237. }
  238. });
  239. }
  240. }
  241. function decodeVMTabForm(model, tabs) {
  242. var result = { model: {}, tabs: [] };
  243. var mdata = angular.fromJson(model);
  244. angular.extend(result.model, mdata);
  245. angular.forEach(tabs, function(tab) {
  246. tab.form.model = vm.model;
  247. angular.forEach(tab.form.fields, function(field) {
  248. if (field.key == "") {
  249. delete field.key;
  250. }
  251. if (angular.isDefined(field.extjson) && field.extjson != "") {
  252. var extObj = angular.fromJson(field.extjson);
  253. angular.extend(field.templateOptions, extObj.templateOptions);
  254. delete extObj.templateOptions;
  255. for (var prop in extObj) {
  256. if (new RegExp("Expression").test(prop)) {
  257. //var obj = $scope.$eval(extObj[prop]);
  258. //extObj[prop] = $scope.$eval(extObj[prop]);
  259. if (extObj[prop] != null) {
  260. if (new RegExp("function").test(extObj[prop])) {
  261. var propValue = eval(extObj[prop]);
  262. extObj[prop] = propValue;
  263. } else {
  264. //console.log(extObj[prop]);
  265. var obj = $scope.$eval(extObj[prop]);
  266. extObj[prop] = obj;
  267. //console.log(obj);
  268. }
  269. }
  270. } else if (new RegExp("expressionProperties").test(prop)) {
  271. for (var p in extObj[prop]) {
  272. if (new RegExp("function").test(extObj[prop][p])) {
  273. var propValue = eval(extObj[prop][p]);
  274. extObj[prop][p] = propValue;
  275. } else {
  276. //if(p.indexOf("'")>=0){
  277. // var obj = $scope.$eval(extObj[prop][p]);
  278. // extObj[prop][$scope.$eval(p)]=obj;
  279. //}
  280. }
  281. }
  282. } else if ("watcher" == prop) {
  283. if (angular.isArray(extObj[prop])) {
  284. angular.forEach(extObj[prop], function(item, index) {
  285. for (var p in item) {
  286. if (new RegExp("function").test(item[p])) {
  287. var propValue = eval(item[p]);
  288. extObj[prop][index][p] = propValue;
  289. }
  290. }
  291. });
  292. } else if (angular.isObject(extObj[prop])) {
  293. for (var p in extObj[prop]) {
  294. if (new RegExp("function").test(extObj[prop][p])) {
  295. var propValue = eval(extObj[prop][p]);
  296. extObj[prop][p] = propValue;
  297. }
  298. }
  299. }
  300. }
  301. }
  302. angular.extend(field, extObj);
  303. delete field.extjson;
  304. }
  305. if (field.extjson == "") {
  306. delete field.extjson;
  307. }
  308. if (angular.isDefined(field.templateOptions)) {
  309. var templateOs = field.templateOptions;
  310. for (var property in templateOs) {
  311. //console.log(property);
  312. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  313. if (new RegExp("function").test(templateOs[property])) {
  314. var propValue = eval(templateOs[property]);
  315. field.templateOptions[property] = propValue;
  316. } else {
  317. if (that.has(templateOs[property])) {
  318. field.templateOptions[property] = that.get(templateOs[property]);
  319. } else {
  320. field.templateOptions[property] = templateOs[property];
  321. }
  322. }
  323. } else if (templateOs[property] == null) {
  324. //delete field.templateOptions[property];
  325. } else {}
  326. }
  327. }
  328. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  329. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  330. angular.extend(field.templateOptions, extObj);
  331. delete field.templateOptions.extjson;
  332. }
  333. //...
  334. if (field.templateOptions) {
  335. //处理远程获取数据控件方法调用
  336. if (field.templateOptions.optionsUrl) {
  337. field.templateOptions.refresh = refreshSelectOptions;
  338. }
  339. //处理嵌套属性数据绑定/
  340. if (field.templateOptions.pkey) {
  341. var pmodel, i = 0;
  342. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  343. if (i == 0) {
  344. if (result.model[p] == null) {
  345. result.model[p] = {};
  346. }
  347. pmodel = result.model[p];
  348. i++;
  349. } else {
  350. if (pmodel[p] == null) {
  351. pmodel[p] = {};
  352. }
  353. pmodel = pmodel[p];
  354. }
  355. });
  356. if (pmodel != null) {
  357. field.model = pmodel;
  358. if (pmodel[field.key] == null) {
  359. pmodel[field.key] = null;
  360. }
  361. }
  362. } else {
  363. if (result.model[field.key] == null) {
  364. result.model[field.key] = null;
  365. }
  366. }
  367. //处理弹出框组件初始化
  368. if (field.type == "ui-input-selectmodal") {
  369. field.templateOptions.modal = $modal;
  370. //field.templateOptions.Restangular = Restangular;
  371. } else if (field.type == "ui-userselect") {
  372. field.templateOptions.modal = $modal;
  373. //field.templateOptions.Restangular = Restangular;
  374. } else if (field.type == "ui-multiuserselect") {
  375. field.templateOptions.modal = $modal;
  376. } else if (field.type == "ui-modelselect") {
  377. field.templateOptions.modal = $modal;
  378. //field.templateOptions.Restangular = Restangular;
  379. } else if (field.type == "ui-dropfile") {
  380. field.templateOptions.fileUploader = new FileUploader({
  381. url: '/uploader'
  382. });
  383. field.templateOptions.taskId = $stateParams.taskId;
  384. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  385. field.templateOptions.userId = $rootScope.user.id;
  386. //field.ApiService=api_bpm_domain;
  387. } else if (field.type == "ui-dropfiletable") {
  388. if (field.templateOptions.processInstanceId) {
  389. } else {
  390. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  391. }
  392. } else if (field.type == "ui-repeatSection") {
  393. var repeatForm = {
  394. model: {
  395. },
  396. fields: field.templateOptions.fields
  397. };
  398. repeatForm.model[field.key] = [];
  399. decodeVMTabForm(repeatForm);
  400. }
  401. }
  402. // console.log(field);
  403. //field
  404. //result.fields.push(field);
  405. })
  406. });
  407. vm.originalTabs = angular.copy(vm.form);
  408. }
  409. //解析自定义表单设计数据
  410. function decodeVMForm(vmForm) {
  411. var result = { model: {}, tabs: [] };
  412. //设置模型实体数据 begin
  413. // var mdata = vmForm.model;
  414. //解析数据实体
  415. var mdata = angular.fromJson(vmForm.model); //JSON.parse(field.extjson);
  416. angular.extend(result.model, mdata);
  417. //设置模型实体数据 end
  418. //解析设计数据生成表单项 begin
  419. var fields = [];
  420. //处理修改设计数据中展示设置
  421. angular.forEach(vmForm.tabs, function(field) {
  422. if (field.key == "") {
  423. delete field.key;
  424. }
  425. if (angular.isDefined(field.extjson)) {
  426. var extObj = angular.fromJson(field.extjson); //JSON.parse(field.extjson);
  427. angular.extend(field.templateOptions, extObj.templateOptions);
  428. delete extObj.templateOptions;
  429. for (var prop in extObj) {
  430. if (new RegExp("Expression").test(prop)) {
  431. //var obj = $scope.$eval(extObj[prop]);
  432. //extObj[prop] = $scope.$eval(extObj[prop]);
  433. if (extObj[prop] != null) {
  434. if (new RegExp("function").test(extObj[prop])) {
  435. var propValue = eval(extObj[prop]);
  436. extObj[prop] = propValue;
  437. } else {
  438. //console.log(extObj[prop]);
  439. var obj = $scope.$eval(extObj[prop]);
  440. extObj[prop] = obj;
  441. //console.log(obj);
  442. }
  443. }
  444. } else if (new RegExp("expressionProperties").test(prop)) {
  445. for (var p in extObj[prop]) {
  446. if (new RegExp("function").test(extObj[prop][p])) {
  447. var propValue = eval(extObj[prop][p]);
  448. extObj[prop][p] = propValue;
  449. } else {
  450. //if(p.indexOf("'")>=0){
  451. // var obj = $scope.$eval(extObj[prop][p]);
  452. // extObj[prop][$scope.$eval(p)]=obj;
  453. //}
  454. }
  455. }
  456. } else if ("watcher" == prop) {
  457. if (angular.isArray(extObj[prop])) {
  458. angular.forEach(extObj[prop], function(item, index) {
  459. for (var p in item) {
  460. if (new RegExp("function").test(item[p])) {
  461. var propValue = eval(item[p]);
  462. extObj[prop][index][p] = propValue;
  463. }
  464. }
  465. });
  466. } else if (angular.isObject(extObj[prop])) {
  467. for (var p in extObj[prop]) {
  468. if (new RegExp("function").test(extObj[prop][p])) {
  469. var propValue = eval(extObj[prop][p]);
  470. extObj[prop][p] = propValue;
  471. }
  472. }
  473. }
  474. }
  475. }
  476. angular.extend(field, extObj);
  477. delete field.extjson;
  478. }
  479. if (angular.isDefined(field.templateOptions)) {
  480. var templateOs = field.templateOptions;
  481. for (var property in templateOs) {
  482. //console.log(property);
  483. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  484. if (new RegExp("function").test(templateOs[property])) {
  485. var propValue = eval(templateOs[property]);
  486. field.templateOptions[property] = propValue;
  487. } else {
  488. if (that.has(templateOs[property])) {
  489. field.templateOptions[property] = that.get(templateOs[property]);
  490. } else {
  491. field.templateOptions[property] = templateOs[property];
  492. }
  493. }
  494. } else if (templateOs[property] == null) {
  495. //delete field.templateOptions[property];
  496. } else {}
  497. }
  498. }
  499. console.log(field);
  500. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  501. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  502. angular.extend(field.templateOptions, extObj);
  503. delete field.templateOptions.extjson;
  504. }
  505. //...
  506. if (field.templateOptions) {
  507. //处理远程获取数据控件方法调用
  508. if (field.templateOptions.optionsUrl) {
  509. field.templateOptions.refresh = refreshSelectOptions;
  510. }
  511. //处理嵌套属性数据绑定/
  512. if (field.templateOptions.pkey) {
  513. var pmodel, i = 0;
  514. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  515. if (i == 0) {
  516. if (result.model[p] == null) {
  517. result.model[p] = {};
  518. }
  519. pmodel = result.model[p];
  520. i++;
  521. } else {
  522. if (pmodel[p] == null) {
  523. pmodel[p] = {};
  524. }
  525. pmodel = pmodel[p];
  526. }
  527. });
  528. if (pmodel != null) {
  529. field.model = pmodel;
  530. if (pmodel[field.key] == null) {
  531. pmodel[field.key] = null;
  532. }
  533. }
  534. } else {
  535. if (result.model[field.key] == null) {
  536. result.model[field.key] = null;
  537. }
  538. }
  539. //处理弹出框组件初始化
  540. if (field.type == "ui-input-selectmodal") {
  541. field.templateOptions.modal = $modal;
  542. //field.templateOptions.Restangular = Restangular;
  543. } else if (field.type == "ui-userselect") {
  544. field.templateOptions.modal = $modal;
  545. //field.templateOptions.Restangular = Restangular;
  546. } else if (field.type == "ui-multiuserselect") {
  547. field.templateOptions.modal = $modal;
  548. } else if (field.type == "ui-modelselect") {
  549. field.templateOptions.modal = $modal;
  550. //field.templateOptions.Restangular = Restangular;
  551. } else if (field.type == "ui-dropfile") {
  552. field.templateOptions.fileUploader = new FileUploader({
  553. url: '/uploader'
  554. });
  555. field.templateOptions.taskId = $stateParams.taskId;
  556. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  557. field.templateOptions.userId = $rootScope.user.id;
  558. //field.ApiService=api_bpm_domain;
  559. } else if (field.type == "ui-dropfiletable") {
  560. if (field.templateOptions.processInstanceId) {
  561. } else {
  562. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  563. }
  564. } else if (field.type == "ui-repeatSection") {
  565. var repeatForm = {
  566. model: {
  567. },
  568. fields: field.templateOptions.fields
  569. };
  570. repeatForm.model[field.key] = [];
  571. decodeVMForm(repeatForm);
  572. }
  573. }
  574. // console.log(field);
  575. result.fields.push(field);
  576. });
  577. angular.extend($scope.vm.fields, result.fields);
  578. angular.extend($scope.vm.model, result.model);
  579. $scope.formData = vmForm;
  580. //console.log($scope.vm);
  581. //解析设计数据生成表单项 end
  582. return result;
  583. }
  584. //======================处理表单设计数据 结束========================
  585. $scope.ldloading = {};
  586. function filter(obj) {
  587. angular.forEach(obj, function(key, value) {
  588. if (value === "" || value === null) {
  589. delete obj[key];
  590. } else if (Object.prototype.toString.call(value) === '[object Object]') {
  591. filter(value);
  592. } else if (angular.isArray(value)) {
  593. angular.forEach(value, function(item) {
  594. filter(item);
  595. });
  596. }
  597. });
  598. }
  599. function invokeOnAllFormOptions(fn) {
  600. angular.forEach(vm.tabs, function(tab) {
  601. if (tab.form.options && tab.form.options[fn]) {
  602. tab.form.options[fn]();
  603. }
  604. });
  605. }
  606. function encodeCIData(data, ciId) {
  607. /*
  608. create/update state:未审核
  609. create createtime:系统时间
  610. create/update lastupdatetime : 系统时间
  611. label:ci分类
  612. */
  613. if (ciId) {
  614. var baseprop = ['uuid', 'name', 'type', 'label', 'status', 'createtime', 'lastupdatetime', 'props']; //state|audittime//createtime//removeflag|removetime//configperson//lastupdateperson//manager//useradmin
  615. var extraprop = 'props';
  616. data[extraprop] = {};
  617. for (var key in data) {
  618. // console.log(data[key]);
  619. if (_.indexOf(baseprop, key) >= 0) {
  620. continue;
  621. } else {
  622. data[extraprop][key] = data[key];
  623. delete data[key];
  624. }
  625. }
  626. if ($rootScope.user) {
  627. data[extraprop]['lastupdateperson'] = $rootScope.user.name;
  628. data[extraprop]['configperson'] = $rootScope.user.name;
  629. var isCMAdminFlag = false;
  630. angular.forEach($rootScope.user.role, function(roleItem) {
  631. if (roleItem.rolecode == "cmdb charge") {
  632. isCMAdminFlag = true;
  633. }
  634. })
  635. if (!isCMAdminFlag) {
  636. data[extraprop]['state'] = '1';
  637. }
  638. }
  639. if (data.props.id) {
  640. } else {
  641. data.label = ciId;
  642. }
  643. return data;
  644. }
  645. return undefined;
  646. }
  647. function decodeCIModel(data) {
  648. var extraprop = 'props';
  649. if (data[extraprop]) {
  650. for (var key in data[extraprop]) {
  651. data[key] = data[extraprop][key];
  652. }
  653. delete data[extraprop];
  654. }
  655. data['iscmadmin'] = false;
  656. angular.forEach($rootScope.user.role, function(roleItem) {
  657. if (roleItem.rolecode == "cmdb charge") {
  658. data['iscmadmin'] = true;
  659. }
  660. })
  661. return data;
  662. };
  663. vm.remove = function(data, style) {
  664. $scope.ldloading[style.replace('-', '_')] = true;
  665. // var cidata = {
  666. // label: data.label,
  667. // id: data.id,
  668. // uuid: data.uuid,
  669. // name: data.name,
  670. // props: {}
  671. // };
  672. // if (cidata.id) {
  673. // cidata.props['removeflag'] = true;
  674. // cidata.props['lastupdateperson'] = vm.model.loginUser;
  675. //cidata.props['removetime']=new Date();
  676. var modalInstance = $modal.open({
  677. templateUrl: 'assets/views/delete.html',
  678. controller: function($scope, scope, $modalInstance, api_bpm_data) {
  679. var cidata = {
  680. label: data.label,
  681. id: data.id,
  682. uuid: data.uuid,
  683. name: data.name,
  684. props: {}
  685. };
  686. if (cidata.id) {
  687. cidata.props['removeflag'] = true;
  688. cidata.props['lastupdateperson'] = vm.model.loginUser;
  689. $scope.ok = function() {
  690. $modalInstance.close(cidata);
  691. };
  692. $scope.cancel = function() {
  693. $modalInstance.dismiss('cancel');
  694. };
  695. }
  696. },
  697. size: 'sm',
  698. resolve: {
  699. scope: function() {
  700. return $scope;
  701. }
  702. }
  703. });
  704. modalInstance.result.then(function(selectedItem) {
  705. if (selectedItem) {
  706. // if (selectedItem.length > 0) {
  707. api_cmdb.put(selectedItem, selectedItem.id).then(function(response) {
  708. if (response) {
  709. var resData = Restangular.stripRestangular(response);
  710. SweetAlert.swal({
  711. title: "删除成功!",
  712. confirmButtonColor: "#007AFF"
  713. }, function() {
  714. $state.go("app.means.listd");
  715. // $state.go("app.means.list");
  716. // $scope.refreshform();
  717. // reinitTabForm($scope.classify);
  718. });
  719. } else {
  720. SweetAlert.swal({
  721. title: "系统错误",
  722. text: "系统错误,请稍后重试!",
  723. type: "error",
  724. confirmButtonColor: "#DD6B55"
  725. });
  726. }
  727. $scope.ldloading[style.replace('-', '_')] = false;
  728. });
  729. // } else {
  730. // SweetAlert.swal({
  731. // title: "操作异常!",
  732. // text: "系统异常,请稍后重试,或者联系管理员!",
  733. // type: "error"
  734. // });
  735. // }
  736. }
  737. })
  738. }
  739. // })
  740. // api_cmdb.put(cidata,data.id).then(function(response){
  741. // if(response){
  742. // var resData = Restangular.stripRestangular(response);
  743. // SweetAlert.swal({
  744. // title: "删除成功!",
  745. // confirmButtonColor: "#007AFF"
  746. // },function(){
  747. // $state.go("app.means.list");
  748. // // $scope.refreshform();
  749. // // reinitTabForm($scope.classify);
  750. // });
  751. // }else{
  752. // SweetAlert.swal({
  753. // title: "系统错误",
  754. // text: "系统错误,请稍后重试!",
  755. // type: "error",
  756. // confirmButtonColor: "#DD6B55"
  757. // });
  758. // }
  759. // $scope.ldloading[style.replace('-', '_')] = false;
  760. // });
  761. // } else {
  762. // $timeout(function() {
  763. // $scope.ldloading[style.replace('-', '_')] = false;
  764. // }, 2000);
  765. // }
  766. // }
  767. function formValid() {
  768. angular.forEach(vm.tabs, function(item) {
  769. //item.
  770. })
  771. }
  772. // 显示对应索引
  773. $scope.xianshi = 0;
  774. $scope.toindex = function(res) {
  775. $scope.xianshi = res;
  776. }
  777. $scope.closeModel = function() {
  778. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  779. if ($stateParams.formKey == "means_editor" || $stateParams.formKey == "means_edit") {
  780. $state.go('app.means.listd', {});
  781. // $state.go('app.means.list', {});
  782. }
  783. event.preventDefault();
  784. }
  785. }
  786. vm.submit = function(data, ciId, templateitem, style) {
  787. // $scope.ldloading[style.replace('-', '_')] = true;
  788. // console.log(vm.form.$$parentForm.$valid);
  789. if (vm.form.$$parentForm.$valid) {
  790. invokeOnAllFormOptions('updateInitialValue');
  791. //alert(JSON.stringify(vm.model), null, 2);
  792. //vm.options.updateInitialValue();
  793. //console.log(vm.model);
  794. var cidata = encodeCIData(vm.model, ciId);
  795. if (cidata) {
  796. //var cidata = ;
  797. if (cidata.props.id) {
  798. //修改
  799. api_cmdb.put(cidata, ciId).then(function(response) {
  800. if (response) {
  801. var resData = Restangular.stripRestangular(response);
  802. SweetAlert.swal({
  803. title: "保存成功!",
  804. confirmButtonColor: "#007AFF",
  805. type: "success"
  806. }, function() {
  807. $scope.ldloading[style.replace('-', '_')] = false;
  808. // $scope.refreshform();
  809. $state.go("app.means.listd");
  810. // $state.go("app.means.list");
  811. });
  812. } else {
  813. SweetAlert.swal({
  814. title: "系统错误",
  815. text: "系统错误,请稍后重试!",
  816. type: "error",
  817. confirmButtonColor: "#DD6B55"
  818. });
  819. }
  820. $scope.ldloading[style.replace('-', '_')] = false;
  821. });
  822. } else {
  823. //新建
  824. var type = 2;
  825. api_sysinfo.getSerialnumber(type, templateitem.id).then(function(data) {
  826. if (data && data.status == 200) {
  827. cidata.uuid = data.uuid;
  828. api_cmdb.create(cidata).then(function(response) {
  829. if (response) {
  830. var resData = Restangular.stripRestangular(response);
  831. SweetAlert.swal({
  832. title: "保存成功!",
  833. text: "内部编号:" + cidata.uuid,
  834. confirmButtonColor: "#007AFF",
  835. type: "success"
  836. }, function() {
  837. $state.go("app.means.listd");
  838. // $state.go("app.means.list");
  839. });
  840. // if(resData.status){
  841. // resData
  842. // }
  843. } else {
  844. SweetAlert.swal({
  845. title: "系统错误",
  846. text: "系统错误,请稍后重试!",
  847. type: "error",
  848. confirmButtonColor: "#DD6B55"
  849. });
  850. }
  851. $scope.ldloading[style.replace('-', '_')] = false;
  852. });
  853. } else {
  854. SweetAlert.swal({
  855. title: "系统错误",
  856. text: "内部编号生成出错!",
  857. type: "error",
  858. confirmButtonColor: "#DD6B55"
  859. });
  860. }
  861. })
  862. }
  863. } else {
  864. SweetAlert.swal({
  865. title: "错误",
  866. text: "错误,请选择资产分类!",
  867. type: "error",
  868. confirmButtonColor: "#DD6B55"
  869. });
  870. }
  871. //alert(JSON.stringify(cidata), null, 2);
  872. $scope.ldloading[style.replace('-', '_')] = true;
  873. return;
  874. var _ = window._;
  875. vm.model = (function filter(obj) {
  876. var filtered = _.pick(obj, function(v) { return angular.isDefined(v) && v !== null && (angular.isArray(v) ? v.length > 0 : true) && (_.isPlainObject(v) ? (!_.isEmpty(v)) : true); });
  877. return _.cloneDeep(filtered, function(v) { return v !== filtered && _.isPlainObject(v) ? filter(v) : undefined; });
  878. })(vm.model);
  879. } else {
  880. if (vm.form.$$parentForm.$error) {
  881. SweetAlert.swal({
  882. title: "校验错误",
  883. text: "请填写必填项!",
  884. type: "error",
  885. confirmButtonColor: "#DD6B55"
  886. });
  887. angular.forEach(vm.form.$$parentForm.$error.required, function(item) {
  888. angular.forEach(vm.tabs, function(tab) {
  889. angular.forEach(tab.form.fields, function(f) {
  890. if (f.name == item.$name) {
  891. f.validation.show = true;
  892. tab.active = true;
  893. }
  894. })
  895. })
  896. });
  897. $scope.ldloading[style.replace('-', '_')] = false;
  898. }
  899. }
  900. };
  901. $scope.vm = vm;
  902. //树形图
  903. var apple_selected, tree, treedata_avm, treedata_geography;
  904. $scope.my_tree_handler = function(branch) {
  905. //var _ref;
  906. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  907. // api_cmdb.query({'sign':classify}).then(function(data){
  908. // var myData = Restangular.stripRestangular(data);
  909. // // console.log(myData.data.node);
  910. // if(myData.data&&myData.status==200){
  911. // var ret = myData.data;
  912. // redrawSvg(myData);
  913. // }
  914. // });
  915. // $scope.ciId = undefined;
  916. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  917. // api_configure_form.renderTabForm(classify).then(function(data){
  918. // var myData = Restangular.stripRestangular(data);
  919. // //angular.extend($scope.vm.fields,result.fields);
  920. // //angular.extend($scope.vm.model,result.model);
  921. // $scope.templateProps = myData;
  922. // $scope.vm.tabs = myData;
  923. // vm.model = {};
  924. // decodeVMTabForm(vm.model, vm.tabs);
  925. // //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  926. // //console.log(myData);
  927. // });
  928. };
  929. $scope.my_data = [];
  930. function convertListToTree(data, treeMap) {
  931. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  932. var root = null; //Initially set our loop to null
  933. var parentNode = null;
  934. //loop over data
  935. for (var i = 0; i < data.length; i++) {
  936. var datum = data[i];
  937. //each node will have children, so let's give it a "children" poperty
  938. datum.children = [];
  939. //add an entry for this node to the map so that any future children can
  940. //lookup the parent
  941. idToNodeMap[datum.id] = datum;
  942. //Does this node have a parent?
  943. if (typeof datum.parent === "undefined" || datum.parent == null) {
  944. //Doesn't look like it, so this node is the root of the tree
  945. root = datum;
  946. treeMap[datum.id] = root;
  947. } else {
  948. //This node has a parent, so let's look it up using the id
  949. parentNode = idToNodeMap[datum.parent.id];
  950. //We don't need this property, so let's delete it.
  951. delete datum.parent;
  952. //Let's add the current node as a child of the parent node.
  953. parentNode.children.push(datum);
  954. }
  955. }
  956. return root;
  957. }
  958. function convertParentToChildList(data) {
  959. var treeMap = {};
  960. var list = [];
  961. convertListToTree(data, treeMap);
  962. angular.forEach(treeMap, function(item) {
  963. list.push(item);
  964. });
  965. return list;
  966. }
  967. $scope.my_tree = tree = {};
  968. $scope.try_async_load = function() {
  969. $scope.my_data = [];
  970. $scope.select_treedata = [];
  971. $scope.doing_async = true;
  972. api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  973. //console.log(result['list']);
  974. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  975. $scope.doing_async = false;
  976. // tree.expand_all();
  977. //console.log(treelist);
  978. });
  979. };
  980. $scope.select_treedata = [];
  981. $scope.propTypeOptions = [];
  982. $scope.try_async_load();
  983. $scope.onFilterCallback = function(item) {
  984. //console.log(item);
  985. if (angular.isDefined(item.children) && item.children.length >= 1) {
  986. //not valid
  987. } else {
  988. var tempclassify = item.prefix.toLowerCase() + item.sign;
  989. $scope.cifilter_classic = tempclassify;
  990. $scope.templateitem = item;
  991. api_configure_form.renderTabForm(tempclassify).then(function(data) {
  992. var myData = Restangular.stripRestangular(data);
  993. $scope.propTypeOptions = myData;
  994. $scope.templateProps = myData;
  995. $scope.vm.tabs = myData;
  996. vm.model = {};
  997. decodeVMTabForm(vm.model, vm.tabs);
  998. });
  999. }
  1000. }
  1001. $scope.jry_shuxing = JSON.parse($stateParams.model);
  1002. // console.log($scope.jry_shuxing);
  1003. $scope.refreshform = function() {
  1004. if ($stateParams.model) {
  1005. var modeldata = JSON.parse($stateParams.model)
  1006. api_configure_form.renderTabForm(modeldata.model.label).then(function(data) {
  1007. var myData = Restangular.stripRestangular(data);
  1008. $scope.templateProps = myData;
  1009. $scope.vm.tabs = myData;
  1010. vm.model = {};
  1011. vm.model = $scope.vm.model = decodeCIModel(modeldata.model);
  1012. vm.model["loginUser"] = $rootScope.user.name;
  1013. // console.log(vm.model);
  1014. decodeVMTabForm(vm.model, vm.tabs);
  1015. // console.log(myData);
  1016. });
  1017. }
  1018. }
  1019. $scope.refreshform();
  1020. }
  1021. ]);