meansformCtrl.js 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809
  1. 'use strict';
  2. var cmdbFormly = angular.module('formlyCMDB', [
  3. 'formly', 'formlyBootstrap', 'ui.bootstrap',
  4. 'ngSanitize','ui.select','ui.grid']);
  5. app.requires.push('formlyCMDB');
  6. 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',
  7. 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) {
  8. $scope.langs=i18nService.getAllLangs();
  9. $scope.lang = 'zh-cn';
  10. i18nService.setCurrentLang($scope.lang);
  11. var vm = this;
  12. vm.options = {};
  13. vm.exampleTitle = ['expressionProperties','model property'];
  14. vm.fields=[];
  15. vm.model={};
  16. vm.model["loginUser"] = $rootScope.user;
  17. var that=$injector;
  18. var parse=$parse;
  19. var formKey = "";
  20. var pdKey = "";
  21. if(angular.isDefined($state.current.pdKey)&&$state.current.pdKey!=""){
  22. pdKey = $state.current.pdKey;
  23. //console.log("pdKey::"+$state.current.pdKey);
  24. }
  25. if(angular.isDefined($stateParams.formKey)&&$stateParams.formKey!=""){
  26. formKey = $stateParams.formKey;
  27. //console.log("formKey::"+$stateParams.formKey);
  28. }
  29. //用户测试数据,后续从header的auth中获取
  30. var userId = 2;
  31. userId = $rootScope.user.id;
  32. //==============处理表单设计数据 开始====================
  33. //处理组件加载后台数据选项的方法
  34. function refreshSelectOptions(searchVal, field) {
  35. if(field.templateOptions.optionsUrl){
  36. var process = BpmRestangular.all("");
  37. if(field.templateOptions.ApiService){
  38. process = UserRestangular.all("");
  39. }
  40. process.customPOST({"idx":0,"sum":1000},field.templateOptions.optionsUrl).then(function(result){
  41. if(!field.templateOptions.options){
  42. field.templateOptions.options=[];
  43. }
  44. if(field.templateOptions.optionsDataKey){
  45. field.templateOptions.options =result[field.templateOptions.optionsDataKey];
  46. }else{
  47. field.templateOptions.options =result;
  48. }
  49. });
  50. }
  51. }
  52. function decodeVMTabForm(model, tabs){
  53. var result = {model:{},tabs:[]};
  54. var mdata = angular.fromJson(model);
  55. angular.extend(result.model,mdata);
  56. angular.forEach(tabs, function(tab){
  57. tab.form.model = vm.model;
  58. angular.forEach(tab.form.fields,function(field){
  59. if(field.key==""){
  60. delete field.key;
  61. }
  62. if(angular.isDefined(field.extjson)&&field.extjson!=""){
  63. var extObj = angular.fromJson(field.extjson);
  64. angular.extend(field.templateOptions, extObj.templateOptions);
  65. delete extObj.templateOptions;
  66. for(var prop in extObj){
  67. if(new RegExp("Expression").test(prop)){
  68. //var obj = $scope.$eval(extObj[prop]);
  69. //extObj[prop] = $scope.$eval(extObj[prop]);
  70. if(extObj[prop]!=null){
  71. if(new RegExp("function").test(extObj[prop])){
  72. var propValue = eval(extObj[prop]);
  73. extObj[prop] = propValue;
  74. }else{
  75. //console.log(extObj[prop]);
  76. var obj = $scope.$eval(extObj[prop]);
  77. extObj[prop] = obj;
  78. //console.log(obj);
  79. }
  80. }
  81. }else if(new RegExp("expressionProperties").test(prop)){
  82. for(var p in extObj[prop]){
  83. if(new RegExp("function").test(extObj[prop][p])){
  84. var propValue = eval(extObj[prop][p]);
  85. extObj[prop][p] = propValue;
  86. }else{
  87. //if(p.indexOf("'")>=0){
  88. // var obj = $scope.$eval(extObj[prop][p]);
  89. // extObj[prop][$scope.$eval(p)]=obj;
  90. //}
  91. }
  92. }
  93. }else if("watcher"==prop){
  94. if(angular.isArray(extObj[prop])){
  95. angular.forEach(extObj[prop],function(item,index){
  96. for(var p in item){
  97. if(new RegExp("function").test(item[p])){
  98. var propValue = eval(item[p]);
  99. extObj[prop][index][p] = propValue;
  100. }
  101. }
  102. });
  103. }else if(angular.isObject(extObj[prop])){
  104. for(var p in extObj[prop]){
  105. if(new RegExp("function").test(extObj[prop][p])){
  106. var propValue = eval(extObj[prop][p]);
  107. extObj[prop][p] = propValue;
  108. }
  109. }
  110. }
  111. }
  112. }
  113. angular.extend(field,extObj);
  114. delete field.extjson;
  115. }
  116. if(field.extjson==""){
  117. delete field.extjson;
  118. }
  119. if(angular.isDefined(field.templateOptions)){
  120. var templateOs = field.templateOptions;
  121. for(var property in templateOs){
  122. //console.log(property);
  123. if(angular.isString(templateOs[property])&& !(new RegExp("[\u4e00-\u9fa5]").test(templateOs[property]))){
  124. if(new RegExp("function").test(templateOs[property])){
  125. var propValue = eval(templateOs[property]);
  126. field.templateOptions[property] = propValue;
  127. }else{
  128. if(that.has(templateOs[property])){
  129. field.templateOptions[property] = that.get(templateOs[property]);
  130. }else{
  131. field.templateOptions[property] = templateOs[property];
  132. }
  133. }
  134. }else if(templateOs[property]==null){
  135. //delete field.templateOptions[property];
  136. }else{
  137. }
  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. }
  312. console.log(field);
  313. if(angular.isDefined(field.templateOptions) && angular.isDefined(field.templateOptions.extjson)){
  314. var extObj = angular.fromJson(field.templateOptions.extjson);//JSON.parse(field.extjson);
  315. angular.extend(field.templateOptions,extObj);
  316. delete field.templateOptions.extjson;
  317. }
  318. //...
  319. if(field.templateOptions){
  320. //处理远程获取数据控件方法调用
  321. if(field.templateOptions.optionsUrl){
  322. field.templateOptions.refresh = refreshSelectOptions;
  323. }
  324. //处理嵌套属性数据绑定/
  325. if(field.templateOptions.pkey){
  326. var pmodel,i= 0;
  327. angular.forEach(field.templateOptions.pkey.split("."),function(p){
  328. if(i==0){
  329. if(result.model[p]==null){
  330. result.model[p] = {};
  331. }
  332. pmodel = result.model[p];
  333. i++;
  334. }else{
  335. if(pmodel[p]==null){
  336. pmodel[p] = {};
  337. }
  338. pmodel = pmodel[p];
  339. }
  340. });
  341. if(pmodel!=null){
  342. field.model = pmodel;
  343. if(pmodel[field.key]==null){
  344. pmodel[field.key] = null;
  345. }
  346. }
  347. }else{
  348. if(result.model[field.key]==null){
  349. result.model[field.key] = null;
  350. }
  351. }
  352. //处理弹出框组件初始化
  353. if(field.type=="ui-input-selectmodal"){
  354. field.templateOptions.modal = $modal;
  355. //field.templateOptions.Restangular = Restangular;
  356. }else if(field.type=="ui-userselect"){
  357. field.templateOptions.modal = $modal;
  358. //field.templateOptions.Restangular = Restangular;
  359. }else if(field.type=="ui-multiuserselect"){
  360. field.templateOptions.modal = $modal;
  361. }else if(field.type=="ui-modelselect"){
  362. field.templateOptions.modal = $modal;
  363. //field.templateOptions.Restangular = Restangular;
  364. }else if(field.type=="ui-dropfile"){
  365. field.templateOptions.fileUploader = new FileUploader({
  366. url:'/uploader'
  367. });
  368. field.templateOptions.taskId = $stateParams.taskId;
  369. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  370. field.templateOptions.userId = $rootScope.user.id;
  371. //field.ApiService=api_bpm_domain;
  372. }else if(field.type=="ui-dropfiletable"){
  373. if(field.templateOptions.processInstanceId){
  374. }else{
  375. field.templateOptions.processInstanceId = $stateParams.processInstanceId;
  376. }
  377. }else if(field.type=="ui-repeatSection"){
  378. var repeatForm = {
  379. model:{
  380. },
  381. fields:field.templateOptions.fields
  382. };
  383. repeatForm.model[field.key]=[];
  384. decodeVMForm(repeatForm);
  385. }
  386. }
  387. // console.log(field);
  388. result.fields.push(field);
  389. });
  390. angular.extend($scope.vm.fields,result.fields);
  391. angular.extend($scope.vm.model,result.model);
  392. $scope.formData = vmForm;
  393. //console.log($scope.vm);
  394. //解析设计数据生成表单项 end
  395. return result;
  396. }
  397. //======================处理表单设计数据 结束========================
  398. $scope.ldloading = {};
  399. function filter(obj) {
  400. angular.forEach(obj, function(key, value){
  401. if (value === "" || value === null){
  402. delete obj[key];
  403. } else if (Object.prototype.toString.call(value) === '[object Object]') {
  404. filter(value);
  405. } else if (angular.isArray(value)) {
  406. angular.forEach(value,function(item){
  407. filter(item);
  408. });
  409. }
  410. });
  411. }
  412. function invokeOnAllFormOptions(fn) {
  413. angular.forEach(vm.tabs, function(tab) {
  414. if (tab.form.options && tab.form.options[fn]) {
  415. tab.form.options[fn]();
  416. }
  417. });
  418. }
  419. function encodeCIData(data,ciId){
  420. /*
  421. create/update state:未审核
  422. create createtime:系统时间
  423. create/update lastupdatetime : 系统时间
  424. label:ci分类
  425. */
  426. if(ciId){
  427. var baseprop = ['uuid','name','type','label','status','createtime','lastupdatetime','props'];//state|audittime//createtime//removeflag|removetime//configperson//lastupdateperson//manager//useradmin
  428. var extraprop = 'props';
  429. data[extraprop] = {};
  430. for(var key in data){
  431. console.log(data[key]);
  432. if(_.indexOf(baseprop, key)>=0){
  433. continue;
  434. }else{
  435. data[extraprop][key] = data[key];
  436. delete data[key];
  437. }
  438. }
  439. if($rootScope.user){
  440. data[extraprop]['lastupdateperson']=$rootScope.user.name;
  441. data[extraprop]['configperson']=$rootScope.user.name;
  442. var isCMAdminFlag = false;
  443. angular.forEach($rootScope.user.role,function(roleItem){
  444. if(roleItem.rolecode == "cmdb charge"){
  445. isCMAdminFlag = true;
  446. }
  447. })
  448. if(!isCMAdminFlag){
  449. data[extraprop]['state']='1';
  450. }
  451. }
  452. if(data.props.id){
  453. }else{
  454. data.label=ciId;
  455. }
  456. return data;
  457. }
  458. return undefined;
  459. }
  460. function decodeCIModel(data){
  461. var extraprop = 'props';
  462. if(data[extraprop]){
  463. for(var key in data[extraprop]){
  464. data[key] = data[extraprop][key];
  465. }
  466. delete data[extraprop];
  467. }
  468. data['iscmadmin']=false;
  469. angular.forEach($rootScope.user.role,function(roleItem){
  470. if(roleItem.rolecode == "cmdb charge"){
  471. data['iscmadmin'] = true;
  472. }
  473. })
  474. return data;
  475. }
  476. vm.remove = function(data, style){
  477. $scope.ldloading[style.replace('-', '_')] = true;
  478. var cidata = {
  479. label:data.label,
  480. id:data.id,
  481. uuid:data.uuid,
  482. name:data.name,
  483. props:{}
  484. };
  485. if(cidata.id){
  486. cidata.props['removeflag']=true;
  487. cidata.props['lastupdateperson']=vm.model.loginUser;
  488. //cidata.props['removetime']=new Date();
  489. api_cmdb.put(cidata,data.id).then(function(response){
  490. if(response){
  491. var resData = Restangular.stripRestangular(response);
  492. SweetAlert.swal({
  493. title: "删除成功!",
  494. confirmButtonColor: "#007AFF"
  495. },function(){
  496. $state.go("app.means.list");
  497. // $scope.refreshform();
  498. // reinitTabForm($scope.classify);
  499. });
  500. }else{
  501. SweetAlert.swal({
  502. title: "系统错误",
  503. text: "系统错误,请稍后重试!",
  504. type: "error",
  505. confirmButtonColor: "#DD6B55"
  506. });
  507. }
  508. $scope.ldloading[style.replace('-', '_')] = false;
  509. });
  510. }else{
  511. $timeout(function () {
  512. $scope.ldloading[style.replace('-', '_')] = false;
  513. }, 2000);
  514. }
  515. }
  516. function formValid(){
  517. angular.forEach(vm.tabs,function(item){
  518. //item.
  519. })
  520. }
  521. $scope.closeModel = function(){
  522. if(angular.isDefined($stateParams.formKey)&&$stateParams.formKey!=""){
  523. if($stateParams.formKey=="means_editor"||$stateParams.formKey=="means_edit") {
  524. $state.go('app.means.list',{});
  525. }
  526. event.preventDefault();
  527. }
  528. }
  529. vm.submit = function(data,ciId,templateitem,style){
  530. // $scope.ldloading[style.replace('-', '_')] = true;
  531. console.log(vm.form.$$parentForm.$valid);
  532. if (vm.form.$$parentForm.$valid) {
  533. invokeOnAllFormOptions('updateInitialValue');
  534. //alert(JSON.stringify(vm.model), null, 2);
  535. //vm.options.updateInitialValue();
  536. //console.log(vm.model);
  537. var cidata = encodeCIData(vm.model,ciId);
  538. if(cidata){
  539. //var cidata = ;
  540. if(cidata.props.id){
  541. //修改
  542. api_cmdb.put(cidata,ciId).then(function(response){
  543. if(response){
  544. var resData = Restangular.stripRestangular(response);
  545. SweetAlert.swal({
  546. title: "保存成功!",
  547. confirmButtonColor: "#007AFF"
  548. },function(){
  549. $scope.ldloading[style.replace('-', '_')] = false;
  550. // $scope.refreshform();
  551. $state.go("app.means.list");
  552. });
  553. }else{
  554. SweetAlert.swal({
  555. title: "系统错误",
  556. text: "系统错误,请稍后重试!",
  557. type: "error",
  558. confirmButtonColor: "#DD6B55"
  559. });
  560. }
  561. $scope.ldloading[style.replace('-', '_')] = false;
  562. });
  563. }else{
  564. //新建
  565. var type=2;
  566. api_sysinfo.getSerialnumber(type,templateitem.id).then(function(data){
  567. if(data&&data.status==200){
  568. cidata.uuid=data.uuid;
  569. api_cmdb.create(cidata).then(function(response){
  570. if(response){
  571. var resData = Restangular.stripRestangular(response);
  572. SweetAlert.swal({
  573. title: "保存成功!",
  574. text: "内部编号:"+cidata.uuid,
  575. confirmButtonColor: "#007AFF"
  576. },function(){
  577. $state.go("app.means.list");
  578. });
  579. // if(resData.status){
  580. // resData
  581. // }
  582. }else{
  583. SweetAlert.swal({
  584. title: "系统错误",
  585. text: "系统错误,请稍后重试!",
  586. type: "error",
  587. confirmButtonColor: "#DD6B55"
  588. });
  589. }
  590. $scope.ldloading[style.replace('-', '_')] = false;
  591. });
  592. }else{
  593. SweetAlert.swal({
  594. title: "系统错误",
  595. text: "内部编号生成出错!",
  596. type: "error",
  597. confirmButtonColor: "#DD6B55"
  598. });
  599. }
  600. })
  601. }
  602. }else{
  603. SweetAlert.swal({
  604. title: "错误",
  605. text: "错误,请选择资产分类!",
  606. type: "error",
  607. confirmButtonColor: "#DD6B55"
  608. });
  609. }
  610. //alert(JSON.stringify(cidata), null, 2);
  611. $scope.ldloading[style.replace('-', '_')] = true;
  612. return;
  613. var _ = window._;
  614. vm.model = (function filter(obj) {
  615. var filtered = _.pick(obj, function (v) { return angular.isDefined(v) && v !== null && (angular.isArray(v)?v.length>0:true) && (_.isPlainObject(v)?(!_.isEmpty(v)):true); });
  616. return _.cloneDeep(filtered, function (v) { return v !== filtered && _.isPlainObject(v) ? filter(v) : undefined; });
  617. })(vm.model);
  618. }else{
  619. if(vm.form.$$parentForm.$error){
  620. SweetAlert.swal({
  621. title: "校验错误",
  622. text: "请填写必填项!",
  623. type: "error",
  624. confirmButtonColor: "#DD6B55"
  625. });
  626. angular.forEach(vm.form.$$parentForm.$error.required, function(item){
  627. angular.forEach(vm.tabs,function(tab){
  628. angular.forEach(tab.form.fields,function(f){
  629. if(f.name == item.$name){
  630. f.validation.show = true;
  631. tab.active=true;
  632. }
  633. })
  634. })
  635. });
  636. $scope.ldloading[style.replace('-', '_')] = false;
  637. }
  638. }
  639. };
  640. $scope.vm = vm;
  641. //树形图
  642. var apple_selected, tree, treedata_avm, treedata_geography;
  643. $scope.my_tree_handler = function (branch) {
  644. //var _ref;
  645. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  646. // api_cmdb.query({'sign':classify}).then(function(data){
  647. // var myData = Restangular.stripRestangular(data);
  648. // // console.log(myData.data.node);
  649. // if(myData.data&&myData.status==200){
  650. // var ret = myData.data;
  651. // redrawSvg(myData);
  652. // }
  653. // });
  654. // $scope.ciId = undefined;
  655. // var classify=$scope.classify=branch.prefix.toLowerCase()+branch.sign;
  656. // api_configure_form.renderTabForm(classify).then(function(data){
  657. // var myData = Restangular.stripRestangular(data);
  658. // //angular.extend($scope.vm.fields,result.fields);
  659. // //angular.extend($scope.vm.model,result.model);
  660. // $scope.templateProps = myData;
  661. // $scope.vm.tabs = myData;
  662. // vm.model = {};
  663. // decodeVMTabForm(vm.model, vm.tabs);
  664. // //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  665. // //console.log(myData);
  666. // });
  667. };
  668. $scope.my_data = [];
  669. function convertListToTree(data, treeMap){
  670. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  671. var root = null; //Initially set our loop to null
  672. var parentNode = null;
  673. //loop over data
  674. for(var i = 0; i < data.length; i++) {
  675. var datum = data[i];
  676. //each node will have children, so let's give it a "children" poperty
  677. datum.children = [];
  678. //add an entry for this node to the map so that any future children can
  679. //lookup the parent
  680. idToNodeMap[datum.id] = datum;
  681. //Does this node have a parent?
  682. if(typeof datum.parent === "undefined" || datum.parent == null) {
  683. //Doesn't look like it, so this node is the root of the tree
  684. root = datum;
  685. treeMap[datum.id] = root;
  686. } else {
  687. //This node has a parent, so let's look it up using the id
  688. parentNode = idToNodeMap[datum.parent.id];
  689. //We don't need this property, so let's delete it.
  690. delete datum.parent;
  691. //Let's add the current node as a child of the parent node.
  692. parentNode.children.push(datum);
  693. }
  694. }
  695. return root;
  696. }
  697. function convertParentToChildList(data){
  698. var treeMap = {};
  699. var list=[];
  700. convertListToTree(data, treeMap);
  701. angular.forEach(treeMap,function(item){
  702. list.push(item);
  703. });
  704. return list;
  705. }
  706. $scope.my_tree = tree = {};
  707. $scope.try_async_load = function () {
  708. $scope.my_data = [];
  709. $scope.select_treedata = [];
  710. $scope.doing_async = true;
  711. api_configure_data.fetchDataList('ciclassify',{'idx':0,'sum':100}).then(function(result){
  712. //console.log(result['list']);
  713. $scope.select_treedata = $scope.my_data = convertParentToChildList(result['list']);
  714. $scope.doing_async = false;
  715. // tree.expand_all();
  716. //console.log(treelist);
  717. });
  718. };
  719. $scope.select_treedata = [];
  720. $scope.propTypeOptions = [];
  721. $scope.try_async_load();
  722. $scope.onFilterCallback = function(item){
  723. //console.log(item);
  724. if(angular.isDefined(item.children)&&item.children.length>=1){
  725. //not valid
  726. }else{
  727. var tempclassify=item.prefix.toLowerCase()+item.sign;
  728. $scope.cifilter_classic=tempclassify;
  729. $scope.templateitem=item;
  730. api_configure_form.renderTabForm(tempclassify).then(function(data){
  731. var myData = Restangular.stripRestangular(data);
  732. $scope.propTypeOptions = myData;
  733. $scope.templateProps = myData;
  734. $scope.vm.tabs = myData;
  735. vm.model = {};
  736. decodeVMTabForm(vm.model, vm.tabs);
  737. });
  738. }
  739. }
  740. $scope.refreshform = function(){
  741. if($stateParams.model){
  742. var modeldata=JSON.parse($stateParams.model)
  743. api_configure_form.renderTabForm(modeldata.model.label).then(function(data){
  744. var myData = Restangular.stripRestangular(data);
  745. $scope.templateProps = myData;
  746. $scope.vm.tabs = myData;
  747. vm.model = {};
  748. vm.model=$scope.vm.model=decodeCIModel(modeldata.model);
  749. vm.model["loginUser"]= $rootScope.user.name;
  750. console.log(vm.model);
  751. decodeVMTabForm(vm.model, vm.tabs);
  752. console.log(myData);
  753. });
  754. }
  755. }
  756. $scope.refreshform();
  757. }]);