meansformCtrl.js 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  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('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.langs = i18nService.getAllLangs();
  10. $scope.lang = 'zh-cn';
  11. i18nService.setCurrentLang($scope.lang);
  12. var vm = this;
  13. vm.options = {};
  14. vm.exampleTitle = ['expressionProperties', 'model property'];
  15. vm.fields = [];
  16. vm.model = {};
  17. vm.model["loginUser"] = $rootScope.user;
  18. var that = $injector;
  19. var parse = $parse;
  20. var formKey = "";
  21. var pdKey = "";
  22. if (angular.isDefined($state.current.pdKey) && $state.current.pdKey != "") {
  23. pdKey = $state.current.pdKey;
  24. //console.log("pdKey::"+$state.current.pdKey);
  25. }
  26. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  27. formKey = $stateParams.formKey;
  28. //console.log("formKey::"+$stateParams.formKey);
  29. }
  30. //用户测试数据,后续从header的auth中获取
  31. var userId = 2;
  32. userId = $rootScope.user.id;
  33. //==============处理表单设计数据 开始====================
  34. //处理组件加载后台数据选项的方法
  35. function refreshSelectOptions(searchVal, field) {
  36. if (field.templateOptions.optionsUrl) {
  37. var process = BpmRestangular.all("");
  38. if (field.templateOptions.ApiService) {
  39. process = UserRestangular.all("");
  40. }
  41. process.customPOST({ "idx": 0, "sum": 1000 }, field.templateOptions.optionsUrl).then(function(result) {
  42. if (!field.templateOptions.options) {
  43. field.templateOptions.options = [];
  44. }
  45. if (field.templateOptions.optionsDataKey) {
  46. field.templateOptions.options = result[field.templateOptions.optionsDataKey];
  47. } else {
  48. field.templateOptions.options = result;
  49. }
  50. });
  51. }
  52. }
  53. function decodeVMTabForm(model, tabs) {
  54. var result = { model: {}, tabs: [] };
  55. var mdata = angular.fromJson(model);
  56. angular.extend(result.model, mdata);
  57. angular.forEach(tabs, function(tab) {
  58. tab.form.model = vm.model;
  59. angular.forEach(tab.form.fields, function(field) {
  60. if (field.key == "") {
  61. delete field.key;
  62. }
  63. if (angular.isDefined(field.extjson) && field.extjson != "") {
  64. var extObj = angular.fromJson(field.extjson);
  65. angular.extend(field.templateOptions, extObj.templateOptions);
  66. delete extObj.templateOptions;
  67. for (var prop in extObj) {
  68. if (new RegExp("Expression").test(prop)) {
  69. //var obj = $scope.$eval(extObj[prop]);
  70. //extObj[prop] = $scope.$eval(extObj[prop]);
  71. if (extObj[prop] != null) {
  72. if (new RegExp("function").test(extObj[prop])) {
  73. var propValue = eval(extObj[prop]);
  74. extObj[prop] = propValue;
  75. } else {
  76. //console.log(extObj[prop]);
  77. var obj = $scope.$eval(extObj[prop]);
  78. extObj[prop] = obj;
  79. //console.log(obj);
  80. }
  81. }
  82. } else if (new RegExp("expressionProperties").test(prop)) {
  83. for (var p in extObj[prop]) {
  84. if (new RegExp("function").test(extObj[prop][p])) {
  85. var propValue = eval(extObj[prop][p]);
  86. extObj[prop][p] = propValue;
  87. } else {
  88. //if(p.indexOf("'")>=0){
  89. // var obj = $scope.$eval(extObj[prop][p]);
  90. // extObj[prop][$scope.$eval(p)]=obj;
  91. //}
  92. }
  93. }
  94. } else if ("watcher" == prop) {
  95. if (angular.isArray(extObj[prop])) {
  96. angular.forEach(extObj[prop], function(item, index) {
  97. for (var p in item) {
  98. if (new RegExp("function").test(item[p])) {
  99. var propValue = eval(item[p]);
  100. extObj[prop][index][p] = propValue;
  101. }
  102. }
  103. });
  104. } else if (angular.isObject(extObj[prop])) {
  105. for (var p in extObj[prop]) {
  106. if (new RegExp("function").test(extObj[prop][p])) {
  107. var propValue = eval(extObj[prop][p]);
  108. extObj[prop][p] = propValue;
  109. }
  110. }
  111. }
  112. }
  113. }
  114. angular.extend(field, extObj);
  115. delete field.extjson;
  116. }
  117. if (field.extjson == "") {
  118. delete field.extjson;
  119. }
  120. if (angular.isDefined(field.templateOptions)) {
  121. var templateOs = field.templateOptions;
  122. for (var property in templateOs) {
  123. //console.log(property);
  124. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  125. if (new RegExp("function").test(templateOs[property])) {
  126. var propValue = eval(templateOs[property]);
  127. field.templateOptions[property] = propValue;
  128. } else {
  129. if (that.has(templateOs[property])) {
  130. field.templateOptions[property] = that.get(templateOs[property]);
  131. } else {
  132. field.templateOptions[property] = templateOs[property];
  133. }
  134. }
  135. } else if (templateOs[property] == null) {
  136. //delete field.templateOptions[property];
  137. } else {}
  138. }
  139. }
  140. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  141. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  142. angular.extend(field.templateOptions, extObj);
  143. delete field.templateOptions.extjson;
  144. }
  145. //...
  146. if (field.templateOptions) {
  147. //处理远程获取数据控件方法调用
  148. if (field.templateOptions.optionsUrl) {
  149. field.templateOptions.refresh = refreshSelectOptions;
  150. }
  151. //处理嵌套属性数据绑定/
  152. if (field.templateOptions.pkey) {
  153. var pmodel, i = 0;
  154. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  155. if (i == 0) {
  156. if (result.model[p] == null) {
  157. result.model[p] = {};
  158. }
  159. pmodel = result.model[p];
  160. i++;
  161. } else {
  162. if (pmodel[p] == null) {
  163. pmodel[p] = {};
  164. }
  165. pmodel = pmodel[p];
  166. }
  167. });
  168. if (pmodel != null) {
  169. field.model = pmodel;
  170. if (pmodel[field.key] == null) {
  171. pmodel[field.key] = null;
  172. }
  173. }
  174. } else {
  175. if (result.model[field.key] == null) {
  176. result.model[field.key] = null;
  177. }
  178. }
  179. //处理弹出框组件初始化
  180. if (field.type == "ui-input-selectmodal") {
  181. field.templateOptions.modal = $modal;
  182. //field.templateOptions.Restangular = Restangular;
  183. } else if (field.type == "ui-userselect") {
  184. field.templateOptions.modal = $modal;
  185. //field.templateOptions.Restangular = Restangular;
  186. } else if (field.type == "ui-multiuserselect") {
  187. field.templateOptions.modal = $modal;
  188. } else if (field.type == "ui-modelselect") {
  189. field.templateOptions.modal = $modal;
  190. //field.templateOptions.Restangular = Restangular;
  191. } else if (field.type == "ui-dropfile") {
  192. field.templateOptions.fileUploader = new FileUploader({
  193. url: '/uploader'
  194. });
  195. field.templateOptions.taskId = $stateParams.taskId;
  196. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  197. field.templateOptions.userId = $rootScope.user.id;
  198. //field.ApiService=api_bpm_domain;
  199. } else if (field.type == "ui-dropfiletable") {
  200. if (field.templateOptions.processInstanceId) {
  201. } else {
  202. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  203. }
  204. } else if (field.type == "ui-repeatSection") {
  205. var repeatForm = {
  206. model: {
  207. },
  208. fields: field.templateOptions.fields
  209. };
  210. repeatForm.model[field.key] = [];
  211. decodeVMTabForm(repeatForm);
  212. }
  213. }
  214. // console.log(field);
  215. //field
  216. //result.fields.push(field);
  217. })
  218. });
  219. vm.originalTabs = angular.copy(vm.form);
  220. }
  221. //解析自定义表单设计数据
  222. function decodeVMForm(vmForm) {
  223. var result = { model: {}, tabs: [] };
  224. //设置模型实体数据 begin
  225. // var mdata = vmForm.model;
  226. //解析数据实体
  227. var mdata = angular.fromJson(vmForm.model); //JSON.parse(field.extjson);
  228. angular.extend(result.model, mdata);
  229. //设置模型实体数据 end
  230. //解析设计数据生成表单项 begin
  231. var fields = [];
  232. //处理修改设计数据中展示设置
  233. angular.forEach(vmForm.tabs, function(field) {
  234. if (field.key == "") {
  235. delete field.key;
  236. }
  237. if (angular.isDefined(field.extjson)) {
  238. var extObj = angular.fromJson(field.extjson); //JSON.parse(field.extjson);
  239. angular.extend(field.templateOptions, extObj.templateOptions);
  240. delete extObj.templateOptions;
  241. for (var prop in extObj) {
  242. if (new RegExp("Expression").test(prop)) {
  243. //var obj = $scope.$eval(extObj[prop]);
  244. //extObj[prop] = $scope.$eval(extObj[prop]);
  245. if (extObj[prop] != null) {
  246. if (new RegExp("function").test(extObj[prop])) {
  247. var propValue = eval(extObj[prop]);
  248. extObj[prop] = propValue;
  249. } else {
  250. //console.log(extObj[prop]);
  251. var obj = $scope.$eval(extObj[prop]);
  252. extObj[prop] = obj;
  253. //console.log(obj);
  254. }
  255. }
  256. } else if (new RegExp("expressionProperties").test(prop)) {
  257. for (var p in extObj[prop]) {
  258. if (new RegExp("function").test(extObj[prop][p])) {
  259. var propValue = eval(extObj[prop][p]);
  260. extObj[prop][p] = propValue;
  261. } else {
  262. //if(p.indexOf("'")>=0){
  263. // var obj = $scope.$eval(extObj[prop][p]);
  264. // extObj[prop][$scope.$eval(p)]=obj;
  265. //}
  266. }
  267. }
  268. } else if ("watcher" == prop) {
  269. if (angular.isArray(extObj[prop])) {
  270. angular.forEach(extObj[prop], function(item, index) {
  271. for (var p in item) {
  272. if (new RegExp("function").test(item[p])) {
  273. var propValue = eval(item[p]);
  274. extObj[prop][index][p] = propValue;
  275. }
  276. }
  277. });
  278. } else if (angular.isObject(extObj[prop])) {
  279. for (var p in extObj[prop]) {
  280. if (new RegExp("function").test(extObj[prop][p])) {
  281. var propValue = eval(extObj[prop][p]);
  282. extObj[prop][p] = propValue;
  283. }
  284. }
  285. }
  286. }
  287. }
  288. angular.extend(field, extObj);
  289. delete field.extjson;
  290. }
  291. if (angular.isDefined(field.templateOptions)) {
  292. var templateOs = field.templateOptions;
  293. for (var property in templateOs) {
  294. //console.log(property);
  295. if (angular.isString(templateOs[property]) && !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))) {
  296. if (new RegExp("function").test(templateOs[property])) {
  297. var propValue = eval(templateOs[property]);
  298. field.templateOptions[property] = propValue;
  299. } else {
  300. if (that.has(templateOs[property])) {
  301. field.templateOptions[property] = that.get(templateOs[property]);
  302. } else {
  303. field.templateOptions[property] = templateOs[property];
  304. }
  305. }
  306. } else if (templateOs[property] == null) {
  307. //delete field.templateOptions[property];
  308. } else {}
  309. }
  310. }
  311. console.log(field);
  312. if (angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)) {
  313. var extObj = angular.fromJson(field.templateOptions.extjson); //JSON.parse(field.extjson);
  314. angular.extend(field.templateOptions, extObj);
  315. delete field.templateOptions.extjson;
  316. }
  317. //...
  318. if (field.templateOptions) {
  319. //处理远程获取数据控件方法调用
  320. if (field.templateOptions.optionsUrl) {
  321. field.templateOptions.refresh = refreshSelectOptions;
  322. }
  323. //处理嵌套属性数据绑定/
  324. if (field.templateOptions.pkey) {
  325. var pmodel, i = 0;
  326. angular.forEach(field.templateOptions.pkey.split("."), function(p) {
  327. if (i == 0) {
  328. if (result.model[p] == null) {
  329. result.model[p] = {};
  330. }
  331. pmodel = result.model[p];
  332. i++;
  333. } else {
  334. if (pmodel[p] == null) {
  335. pmodel[p] = {};
  336. }
  337. pmodel = pmodel[p];
  338. }
  339. });
  340. if (pmodel != null) {
  341. field.model = pmodel;
  342. if (pmodel[field.key] == null) {
  343. pmodel[field.key] = null;
  344. }
  345. }
  346. } else {
  347. if (result.model[field.key] == null) {
  348. result.model[field.key] = null;
  349. }
  350. }
  351. //处理弹出框组件初始化
  352. if (field.type == "ui-input-selectmodal") {
  353. field.templateOptions.modal = $modal;
  354. //field.templateOptions.Restangular = Restangular;
  355. } else if (field.type == "ui-userselect") {
  356. field.templateOptions.modal = $modal;
  357. //field.templateOptions.Restangular = Restangular;
  358. } else if (field.type == "ui-multiuserselect") {
  359. field.templateOptions.modal = $modal;
  360. } else if (field.type == "ui-modelselect") {
  361. field.templateOptions.modal = $modal;
  362. //field.templateOptions.Restangular = Restangular;
  363. } else if (field.type == "ui-dropfile") {
  364. field.templateOptions.fileUploader = new FileUploader({
  365. url: '/uploader'
  366. });
  367. field.templateOptions.taskId = $stateParams.taskId;
  368. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  369. field.templateOptions.userId = $rootScope.user.id;
  370. //field.ApiService=api_bpm_domain;
  371. } else if (field.type == "ui-dropfiletable") {
  372. if (field.templateOptions.processInstanceId) {
  373. } else {
  374. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  375. }
  376. } else if (field.type == "ui-repeatSection") {
  377. var repeatForm = {
  378. model: {
  379. },
  380. fields: field.templateOptions.fields
  381. };
  382. repeatForm.model[field.key] = [];
  383. decodeVMForm(repeatForm);
  384. }
  385. }
  386. // console.log(field);
  387. result.fields.push(field);
  388. });
  389. angular.extend($scope.vm.fields, result.fields);
  390. angular.extend($scope.vm.model, result.model);
  391. $scope.formData = vmForm;
  392. //console.log($scope.vm);
  393. //解析设计数据生成表单项 end
  394. return result;
  395. }
  396. //======================处理表单设计数据 结束========================
  397. $scope.ldloading = {};
  398. function filter(obj) {
  399. angular.forEach(obj, function(key, value) {
  400. if (value === "" || value === null) {
  401. delete obj[key];
  402. } else if (Object.prototype.toString.call(value) === '[object Object]') {
  403. filter(value);
  404. } else if (angular.isArray(value)) {
  405. angular.forEach(value, function(item) {
  406. filter(item);
  407. });
  408. }
  409. });
  410. }
  411. function invokeOnAllFormOptions(fn) {
  412. angular.forEach(vm.tabs, function(tab) {
  413. if (tab.form.options && tab.form.options[fn]) {
  414. tab.form.options[fn]();
  415. }
  416. });
  417. }
  418. function encodeCIData(data, ciId) {
  419. /*
  420. create/update state:未审核
  421. create createtime:系统时间
  422. create/update lastupdatetime : 系统时间
  423. label:ci分类
  424. */
  425. if (ciId) {
  426. var baseprop = ['uuid', 'name', 'type', 'label', 'status', 'createtime', 'lastupdatetime', 'props']; //state|audittime//createtime//removeflag|removetime//configperson//lastupdateperson//manager//useradmin
  427. var extraprop = 'props';
  428. data[extraprop] = {};
  429. for (var key in data) {
  430. console.log(data[key]);
  431. if (_.indexOf(baseprop, key) >= 0) {
  432. continue;
  433. } else {
  434. data[extraprop][key] = data[key];
  435. delete data[key];
  436. }
  437. }
  438. if ($rootScope.user) {
  439. data[extraprop]['lastupdateperson'] = $rootScope.user.name;
  440. data[extraprop]['configperson'] = $rootScope.user.name;
  441. var isCMAdminFlag = false;
  442. angular.forEach($rootScope.user.role, function(roleItem) {
  443. if (roleItem.rolecode == "cmdb charge") {
  444. isCMAdminFlag = true;
  445. }
  446. })
  447. if (!isCMAdminFlag) {
  448. data[extraprop]['state'] = '1';
  449. }
  450. }
  451. if (data.props.id) {
  452. } else {
  453. data.label = ciId;
  454. }
  455. return data;
  456. }
  457. return undefined;
  458. }
  459. function decodeCIModel(data) {
  460. var extraprop = 'props';
  461. if (data[extraprop]) {
  462. for (var key in data[extraprop]) {
  463. data[key] = data[extraprop][key];
  464. }
  465. delete data[extraprop];
  466. }
  467. data['iscmadmin'] = false;
  468. angular.forEach($rootScope.user.role, function(roleItem) {
  469. if (roleItem.rolecode == "cmdb charge") {
  470. data['iscmadmin'] = true;
  471. }
  472. })
  473. return data;
  474. }
  475. vm.remove = function(data, style) {
  476. $scope.ldloading[style.replace('-', '_')] = true;
  477. // var cidata = {
  478. // label: data.label,
  479. // id: data.id,
  480. // uuid: data.uuid,
  481. // name: data.name,
  482. // props: {}
  483. // };
  484. // if (cidata.id) {
  485. // cidata.props['removeflag'] = true;
  486. // cidata.props['lastupdateperson'] = vm.model.loginUser;
  487. //cidata.props['removetime']=new Date();
  488. var modalInstance = $modal.open({
  489. templateUrl: 'assets/views/delete.html',
  490. controller: function($scope, scope, $modalInstance, api_bpm_data) {
  491. var cidata = {
  492. label: data.label,
  493. id: data.id,
  494. uuid: data.uuid,
  495. name: data.name,
  496. props: {}
  497. };
  498. if (cidata.id) {
  499. cidata.props['removeflag'] = true;
  500. cidata.props['lastupdateperson'] = vm.model.loginUser;
  501. $scope.ok = function() {
  502. $modalInstance.close(cidata);
  503. };
  504. $scope.cancel = function() {
  505. $modalInstance.dismiss('cancel');
  506. };
  507. }
  508. },
  509. size: 'sm',
  510. resolve: {
  511. scope: function() {
  512. return $scope;
  513. }
  514. }
  515. });
  516. modalInstance.result.then(function(selectedItem) {
  517. if (selectedItem) {
  518. // if (selectedItem.length > 0) {
  519. api_cmdb.put(selectedItem, selectedItem.id).then(function(response) {
  520. if (response) {
  521. var resData = Restangular.stripRestangular(response);
  522. SweetAlert.swal({
  523. title: "删除成功!",
  524. confirmButtonColor: "#007AFF"
  525. }, function() {
  526. $state.go("app.means.list");
  527. // $scope.refreshform();
  528. // reinitTabForm($scope.classify);
  529. });
  530. } else {
  531. SweetAlert.swal({
  532. title: "系统错误",
  533. text: "系统错误,请稍后重试!",
  534. type: "error",
  535. confirmButtonColor: "#DD6B55"
  536. });
  537. }
  538. $scope.ldloading[style.replace('-', '_')] = false;
  539. });
  540. // } else {
  541. // SweetAlert.swal({
  542. // title: "操作异常!",
  543. // text: "系统异常,请稍后重试,或者联系管理员!",
  544. // type: "error"
  545. // });
  546. // }
  547. }
  548. })
  549. }
  550. // })
  551. // api_cmdb.put(cidata,data.id).then(function(response){
  552. // if(response){
  553. // var resData = Restangular.stripRestangular(response);
  554. // SweetAlert.swal({
  555. // title: "删除成功!",
  556. // confirmButtonColor: "#007AFF"
  557. // },function(){
  558. // $state.go("app.means.list");
  559. // // $scope.refreshform();
  560. // // reinitTabForm($scope.classify);
  561. // });
  562. // }else{
  563. // SweetAlert.swal({
  564. // title: "系统错误",
  565. // text: "系统错误,请稍后重试!",
  566. // type: "error",
  567. // confirmButtonColor: "#DD6B55"
  568. // });
  569. // }
  570. // $scope.ldloading[style.replace('-', '_')] = false;
  571. // });
  572. // } else {
  573. // $timeout(function() {
  574. // $scope.ldloading[style.replace('-', '_')] = false;
  575. // }, 2000);
  576. // }
  577. // }
  578. function formValid() {
  579. angular.forEach(vm.tabs, function(item) {
  580. //item.
  581. })
  582. }
  583. $scope.closeModel = function() {
  584. if (angular.isDefined($stateParams.formKey) && $stateParams.formKey != "") {
  585. if ($stateParams.formKey == "means_editor" || $stateParams.formKey == "means_edit") {
  586. $state.go('app.means.list', {});
  587. }
  588. event.preventDefault();
  589. }
  590. }
  591. vm.submit = function(data, ciId, templateitem, style) {
  592. // $scope.ldloading[style.replace('-', '_')] = true;
  593. console.log(vm.form.$$parentForm.$valid);
  594. if (vm.form.$$parentForm.$valid) {
  595. invokeOnAllFormOptions('updateInitialValue');
  596. //alert(JSON.stringify(vm.model), null, 2);
  597. //vm.options.updateInitialValue();
  598. //console.log(vm.model);
  599. var cidata = encodeCIData(vm.model, ciId);
  600. if (cidata) {
  601. //var cidata = ;
  602. if (cidata.props.id) {
  603. //修改
  604. api_cmdb.put(cidata, ciId).then(function(response) {
  605. if (response) {
  606. var resData = Restangular.stripRestangular(response);
  607. SweetAlert.swal({
  608. title: "保存成功!",
  609. confirmButtonColor: "#007AFF"
  610. }, function() {
  611. $scope.ldloading[style.replace('-', '_')] = false;
  612. // $scope.refreshform();
  613. $state.go("app.means.list");
  614. });
  615. } else {
  616. SweetAlert.swal({
  617. title: "系统错误",
  618. text: "系统错误,请稍后重试!",
  619. type: "error",
  620. confirmButtonColor: "#DD6B55"
  621. });
  622. }
  623. $scope.ldloading[style.replace('-', '_')] = false;
  624. });
  625. } else {
  626. //新建
  627. var type = 2;
  628. api_sysinfo.getSerialnumber(type, templateitem.id).then(function(data) {
  629. if (data && data.status == 200) {
  630. cidata.uuid = data.uuid;
  631. api_cmdb.create(cidata).then(function(response) {
  632. if (response) {
  633. var resData = Restangular.stripRestangular(response);
  634. SweetAlert.swal({
  635. title: "保存成功!",
  636. text: "内部编号:" + cidata.uuid,
  637. confirmButtonColor: "#007AFF"
  638. }, function() {
  639. $state.go("app.means.list");
  640. });
  641. // if(resData.status){
  642. // resData
  643. // }
  644. } else {
  645. SweetAlert.swal({
  646. title: "系统错误",
  647. text: "系统错误,请稍后重试!",
  648. type: "error",
  649. confirmButtonColor: "#DD6B55"
  650. });
  651. }
  652. $scope.ldloading[style.replace('-', '_')] = false;
  653. });
  654. } else {
  655. SweetAlert.swal({
  656. title: "系统错误",
  657. text: "内部编号生成出错!",
  658. type: "error",
  659. confirmButtonColor: "#DD6B55"
  660. });
  661. }
  662. })
  663. }
  664. } else {
  665. SweetAlert.swal({
  666. title: "错误",
  667. text: "错误,请选择资产分类!",
  668. type: "error",
  669. confirmButtonColor: "#DD6B55"
  670. });
  671. }
  672. //alert(JSON.stringify(cidata), null, 2);
  673. $scope.ldloading[style.replace('-', '_')] = true;
  674. return;
  675. var _ = window._;
  676. vm.model = (function filter(obj) {
  677. var filtered = _.pick(obj, function(v) { return angular.isDefined(v) && v !== null && (angular.isArray(v) ? v.length > 0 : true) && (_.isPlainObject(v) ? (!_.isEmpty(v)) : true); });
  678. return _.cloneDeep(filtered, function(v) { return v !== filtered && _.isPlainObject(v) ? filter(v) : undefined; });
  679. })(vm.model);
  680. } else {
  681. if (vm.form.$$parentForm.$error) {
  682. SweetAlert.swal({
  683. title: "校验错误",
  684. text: "请填写必填项!",
  685. type: "error",
  686. confirmButtonColor: "#DD6B55"
  687. });
  688. angular.forEach(vm.form.$$parentForm.$error.required, function(item) {
  689. angular.forEach(vm.tabs, function(tab) {
  690. angular.forEach(tab.form.fields, function(f) {
  691. if (f.name == item.$name) {
  692. f.validation.show = true;
  693. tab.active = true;
  694. }
  695. })
  696. })
  697. });
  698. $scope.ldloading[style.replace('-', '_')] = false;
  699. }
  700. }
  701. };
  702. $scope.vm = vm;
  703. //树形图
  704. var apple_selected, tree, treedata_avm, treedata_geography;
  705. $scope.my_tree_handler = function(branch) {
  706. //var _ref;
  707. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  708. // api_cmdb.query({'sign':classify}).then(function(data){
  709. // var myData = Restangular.stripRestangular(data);
  710. // // console.log(myData.data.node);
  711. // if(myData.data&&myData.status==200){
  712. // var ret = myData.data;
  713. // redrawSvg(myData);
  714. // }
  715. // });
  716. // $scope.ciId = undefined;
  717. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  718. // api_configure_form.renderTabForm(classify).then(function(data){
  719. // var myData = Restangular.stripRestangular(data);
  720. // //angular.extend($scope.vm.fields,result.fields);
  721. // //angular.extend($scope.vm.model,result.model);
  722. // $scope.templateProps = myData;
  723. // $scope.vm.tabs = myData;
  724. // vm.model = {};
  725. // decodeVMTabForm(vm.model, vm.tabs);
  726. // //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  727. // //console.log(myData);
  728. // });
  729. };
  730. $scope.my_data = [];
  731. function convertListToTree(data, treeMap) {
  732. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  733. var root = null; //Initially set our loop to null
  734. var parentNode = null;
  735. //loop over data
  736. for (var i = 0; i < data.length; i++) {
  737. var datum = data[i];
  738. //each node will have children, so let's give it a "children" poperty
  739. datum.children = [];
  740. //add an entry for this node to the map so that any future children can
  741. //lookup the parent
  742. idToNodeMap[datum.id] = datum;
  743. //Does this node have a parent?
  744. if (typeof datum.parent === "undefined" || datum.parent == null) {
  745. //Doesn't look like it, so this node is the root of the tree
  746. root = datum;
  747. treeMap[datum.id] = root;
  748. } else {
  749. //This node has a parent, so let's look it up using the id
  750. parentNode = idToNodeMap[datum.parent.id];
  751. //We don't need this property, so let's delete it.
  752. delete datum.parent;
  753. //Let's add the current node as a child of the parent node.
  754. parentNode.children.push(datum);
  755. }
  756. }
  757. return root;
  758. }
  759. function convertParentToChildList(data) {
  760. var treeMap = {};
  761. var list = [];
  762. // convertListToTree(data, treeMap);
  763. angular.forEach(treeMap, function(item) {
  764. list.push(item);
  765. });
  766. return list;
  767. }
  768. $scope.my_tree = tree = {};
  769. $scope.try_async_load = function() {
  770. $scope.my_data = [];
  771. $scope.select_treedata = [];
  772. $scope.doing_async = true;
  773. api_configure_data.fetchDataList('ciclassify', { 'idx': 0, 'sum': 100 }).then(function(result) {
  774. //console.log(result['list']);
  775. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  776. $scope.doing_async = false;
  777. // tree.expand_all();
  778. //console.log(treelist);
  779. });
  780. };
  781. $scope.select_treedata = [];
  782. $scope.propTypeOptions = [];
  783. $scope.try_async_load();
  784. $scope.onFilterCallback = function(item) {
  785. //console.log(item);
  786. if (angular.isDefined(item.children) && item.children.length >= 1) {
  787. //not valid
  788. } else {
  789. var tempclassify = item.prefix.toLowerCase() + item.sign;
  790. $scope.cifilter_classic = tempclassify;
  791. $scope.templateitem = item;
  792. api_configure_form.renderTabForm(tempclassify).then(function(data) {
  793. var myData = Restangular.stripRestangular(data);
  794. $scope.propTypeOptions = myData;
  795. $scope.templateProps = myData;
  796. $scope.vm.tabs = myData;
  797. vm.model = {};
  798. decodeVMTabForm(vm.model, vm.tabs);
  799. });
  800. }
  801. }
  802. $scope.refreshform = function() {
  803. if ($stateParams.model) {
  804. var modeldata = JSON.parse($stateParams.model)
  805. api_configure_form.renderTabForm(modeldata.model.label).then(function(data) {
  806. var myData = Restangular.stripRestangular(data);
  807. $scope.templateProps = myData;
  808. $scope.vm.tabs = myData;
  809. vm.model = {};
  810. vm.model = $scope.vm.model = decodeCIModel(modeldata.model);
  811. vm.model["loginUser"] = $rootScope.user.name;
  812. console.log(vm.model);
  813. decodeVMTabForm(vm.model, vm.tabs);
  814. console.log(myData);
  815. });
  816. }
  817. }
  818. $scope.refreshform();
  819. }
  820. ]);