cmdbListCtrl.js 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221
  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('cmdbListCtrl', ['$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',
  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) {
  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){
  420. /*
  421. create/update state:未审核
  422. create createtime:系统时间
  423. create/update lastupdatetime : 系统时间
  424. label:ci分类
  425. */
  426. if($scope.classify){
  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. data.label=$scope.classify;
  453. return data;
  454. }
  455. return undefined;
  456. }
  457. function decodeCIModel(data){
  458. var extraprop = 'props';
  459. if(data[extraprop]){
  460. for(var key in data[extraprop]){
  461. data[key] = data[extraprop][key];
  462. }
  463. delete data[extraprop];
  464. }
  465. data['iscmadmin']=false;
  466. angular.forEach($rootScope.user.role,function(roleItem){
  467. if(roleItem.rolecode == "cmdb charge"){
  468. data['iscmadmin'] = true;
  469. }
  470. })
  471. return data;
  472. }
  473. vm.remove = function(data, style){
  474. $scope.ldloading[style.replace('-', '_')] = true;
  475. var cidata = {
  476. label:data.label,
  477. id:$scope.ciId,
  478. uuid:data.uuid,
  479. name:data.name,
  480. props:{}
  481. };
  482. if($scope.ciId){
  483. cidata.props['removeflag']=true;
  484. //cidata.props['removetime']=new Date();
  485. api_cmdb.put(cidata,$scope.ciId).then(function(response){
  486. if(response){
  487. var resData = Restangular.stripRestangular(response);
  488. SweetAlert.swal({
  489. title: "保存成功!",
  490. confirmButtonColor: "#007AFF"
  491. },function(){
  492. refreshData($scope.classify);
  493. reinitTabForm($scope.classify);
  494. });
  495. }else{
  496. SweetAlert.swal({
  497. title: "系统错误",
  498. text: "系统错误,请稍后重试!",
  499. type: "error",
  500. confirmButtonColor: "#DD6B55"
  501. });
  502. }
  503. $scope.ldloading[style.replace('-', '_')] = false;
  504. });
  505. }else{
  506. $timeout(function () {
  507. $scope.ldloading[style.replace('-', '_')] = false;
  508. }, 2000);
  509. }
  510. }
  511. function formValid(){
  512. angular.forEach(vm.tabs,function(item){
  513. //item.
  514. })
  515. }
  516. vm.submit = function(data, style){
  517. $scope.ldloading[style.replace('-', '_')] = true;
  518. console.log(vm.form.$$parentForm.$valid);
  519. if (vm.form.$$parentForm.$valid) {
  520. invokeOnAllFormOptions('updateInitialValue');
  521. //alert(JSON.stringify(vm.model), null, 2);
  522. //vm.options.updateInitialValue();
  523. //console.log(vm.model);
  524. var cidata = encodeCIData(vm.model);
  525. if(cidata){
  526. //var cidata = ;
  527. if($scope.ciId){
  528. api_cmdb.put(cidata,$scope.ciId).then(function(response){
  529. if(response){
  530. var resData = Restangular.stripRestangular(response);
  531. SweetAlert.swal({
  532. title: "保存成功!",
  533. confirmButtonColor: "#007AFF"
  534. },function(){
  535. refreshData($scope.classify);
  536. reinitTabForm($scope.classify);
  537. });
  538. }else{
  539. SweetAlert.swal({
  540. title: "系统错误",
  541. text: "系统错误,请稍后重试!",
  542. type: "error",
  543. confirmButtonColor: "#DD6B55"
  544. });
  545. }
  546. $scope.ldloading[style.replace('-', '_')] = false;
  547. });
  548. }else{
  549. api_cmdb.create(cidata).then(function(response){
  550. if(response){
  551. var resData = Restangular.stripRestangular(response);
  552. SweetAlert.swal({
  553. title: "保存成功!",
  554. confirmButtonColor: "#007AFF"
  555. },function(){
  556. refreshData($scope.classify);
  557. reinitTabForm($scope.classify);
  558. });
  559. // if(resData.status){
  560. // resData
  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. }
  573. }else{
  574. SweetAlert.swal({
  575. title: "错误",
  576. text: "错误,请选择资产分类!",
  577. type: "error",
  578. confirmButtonColor: "#DD6B55"
  579. });
  580. }
  581. //alert(JSON.stringify(cidata), null, 2);
  582. $scope.ldloading[style.replace('-', '_')] = true;
  583. return;
  584. var _ = window._;
  585. vm.model = (function filter(obj) {
  586. var filtered = _.pick(obj, function (v) { return angular.isDefined(v) && v !== null && (angular.isArray(v)?v.length>0:true) && (_.isPlainObject(v)?(!_.isEmpty(v)):true); });
  587. return _.cloneDeep(filtered, function (v) { return v !== filtered && _.isPlainObject(v) ? filter(v) : undefined; });
  588. })(vm.model);
  589. if(pdKey!=""){
  590. if($scope.oprcode=="save"){//保存
  591. api_bpm_domain.save(taskId, vm.model).then(function(response){
  592. if(response){
  593. var resData = Restangular.stripRestangular(response);
  594. SweetAlert.swal({
  595. title: "保存成功!",
  596. confirmButtonColor: "#007AFF"
  597. },function(){
  598. $state.go($scope.formData.cancelUri);
  599. });
  600. // if(resData.status){
  601. // resData
  602. // }
  603. }else{
  604. SweetAlert.swal({
  605. title: "系统错误",
  606. text: "系统错误,请稍后重试!",
  607. type: "error",
  608. confirmButtonColor: "#DD6B55"
  609. });
  610. }
  611. $scope.ldloading[style.replace('-', '_')] = false;
  612. });
  613. }else{
  614. switch($scope.formData.url){
  615. case "start" :
  616. vm.model["initUser"]=$rootScope.user.id;
  617. if(vm.model["assignee"]||vm.model["candidateGroups"]){
  618. }else{
  619. vm.model["assignee"]=$rootScope.user.id;
  620. }
  621. api_bpm_domain.start(pdKey,vm.model).then(function(response){
  622. if(response){
  623. var resData = Restangular.stripRestangular(response);
  624. SweetAlert.swal({
  625. title: "提交成功!",
  626. confirmButtonColor: "#007AFF"
  627. },function(){
  628. $state.go($scope.formData.cancelUrl);
  629. });
  630. }else{
  631. SweetAlert.swal({
  632. title: "系统错误",
  633. text: "系统错误,请稍后重试!",
  634. type: "error",
  635. confirmButtonColor: "#DD6B55"
  636. });
  637. }
  638. $scope.ldloading[style.replace('-', '_')] = false;
  639. });
  640. break;
  641. case "complete" :
  642. // api_bpm_domain.complete(pdKey, userId, vm.model).then(function(response){
  643. console.log("complete taskId::"+$stateParams.taskId);
  644. api_bpm_domain.complete($stateParams.taskId, userId, vm.model).then(function(response){
  645. if(response){
  646. var resData = Restangular.stripRestangular(response);
  647. SweetAlert.swal({
  648. title: "提交成功!",
  649. confirmButtonColor: "#007AFF"
  650. },function(){
  651. // if($scope.uploader.getNotUploadedItems().length>0&&response.data.processInstanceId){
  652. // // $scope.uploader.options.url();
  653. // $scope.uploader.onBeforeUploadItem = function(item) {
  654. // item.url = api_bpm_domain.saveAttachments($stateParams.processInstanceId,$stateParams.taskId,$scope.user.id).getRequestedUrl();
  655. // console.info('onBeforeUploadItem', item);
  656. // };
  657. // $scope.uploader.uploadAll();
  658. // }
  659. $state.go($scope.formData.cancelUrl);
  660. });
  661. }else{
  662. SweetAlert.swal({
  663. title: "系统错误",
  664. text: "系统错误,请稍后重试!",
  665. type: "error",
  666. confirmButtonColor: "#DD6B55"
  667. });
  668. }
  669. $scope.ldloading[style.replace('-', '_')] = false;
  670. });
  671. break;
  672. default:
  673. $scope.ldloading[style.replace('-', '_')] = false;
  674. break;
  675. }
  676. }
  677. // var submitFunc = api_bpm_domain[$scope.formData.url]
  678. // if(anuglar.isFunction(submitFunc)){
  679. // submitFunc.apply(null, pdKey)
  680. // }
  681. }
  682. }else{
  683. if(vm.form.$$parentForm.$error){
  684. SweetAlert.swal({
  685. title: "校验错误",
  686. text: "请填写必填项!",
  687. type: "error",
  688. confirmButtonColor: "#DD6B55"
  689. });
  690. angular.forEach(vm.form.$$parentForm.$error.required, function(item){
  691. angular.forEach(vm.tabs,function(tab){
  692. angular.forEach(tab.form.fields,function(f){
  693. if(f.name == item.$name){
  694. f.validation.show = true;
  695. tab.active=true;
  696. }
  697. })
  698. })
  699. });
  700. $scope.ldloading[style.replace('-', '_')] = false;
  701. }
  702. }
  703. };
  704. $scope.vm = vm;
  705. //cmdb list
  706. $scope.gridOptions = {};
  707. $scope.gridOptions.data = 'myData';
  708. $scope.gridOptions.enableColumnResizing = true;
  709. $scope.gridOptions.enableFiltering = true;
  710. $scope.gridOptions.enableGridMenu = true;
  711. $scope.gridOptions.enableRowSelection = true;
  712. $scope.gridOptions.enableRowHeaderSelection=false;
  713. $scope.gridOptions.showGridFooter = true;
  714. $scope.gridOptions.showColumnFooter = true;
  715. $scope.gridOptions.fastWatch = true;
  716. $scope.gridOptions.useExternalPagination = false;
  717. $scope.gridOptions.paginationPageSizes = [10];
  718. $scope.gridOptions.paginationPageSize = 10;
  719. $scope.gridOptions.multiSelect = false;
  720. $scope.gridOptions.modifierKeysToMultiSelect = false;
  721. //$scope.gridOptions.noUnselect = true;
  722. //$scope.gridOptions.rowTemplate = "<div ng-dblclick=\"grid.appScope.pdList.onDblClick(row)\" ng-repeat=\"(colRenderIndex, col) in colContainer.renderedColumns track by col.uid\" ui-grid-one-bind-id-grid=\"rowRenderIndex + '-' + col.uid + '-cell'\" class=\"ui-grid-cell\" ng-class=\"{ 'ui-grid-row-header-cell': col.isRowHeader }\" role=\"{{col.isRowHeader ? 'rowheader' : 'gridcell'}}\" ui-grid-cell></div>";
  723. //
  724. $scope.gridOptions.rowIdentity = function(row) {
  725. return row.id;
  726. };
  727. $scope.gridOptions.getRowIdentity = function(row) {
  728. return row.id;
  729. };
  730. $scope.transferstate = function(state){
  731. if(state=="1"){return state="未审核"}
  732. else if(state=="2"){return state="已审核"}
  733. else if(state=="3"){return state="不匹配"}
  734. else if(state=="4"){return state="丢失"}
  735. }
  736. $scope.transferremoveflag = function(removeflag){
  737. if(removeflag==true){return removeflag="已删除"}
  738. else if(removeflag==false){return removeflag="正常"}
  739. }
  740. $scope.gridOptions.columnDefs = [
  741. {
  742. name: 'uuid',
  743. displayName: '搜索代码',
  744. width: 100
  745. }, {
  746. name: 'name',
  747. displayName: '资产名称',
  748. width: 100
  749. },{
  750. name: 'status',
  751. displayName: '资产状态',
  752. width: 140
  753. }, {
  754. name: 'props.state',
  755. displayName: '资产审批状态',
  756. width: 100,
  757. cellTemplate:'<div class="ui-grid-cell-contents">{{grid.appScope.transferstate(row.entity.props.state)}}</div>'
  758. }, {
  759. name: 'props.configperson',
  760. displayName: '资产管理员',
  761. width: 100
  762. }, {
  763. name: 'props.removeflag',
  764. displayName: '是否删除',
  765. width: 140,
  766. cellTemplate:'<div class="ui-grid-cell-contents">{{grid.appScope.transferremoveflag(row.entity.props.removeflag)}}</div>'
  767. }];
  768. $scope.gridOptions.onRegisterApi = function(gridApi) {
  769. $scope.gridApi = gridApi;
  770. /*
  771. // gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  772. // console.log(newPage);
  773. // console.log(pageSize);
  774. // refreshData({
  775. // "idx": newPage - 1,
  776. // "sum": pageSize
  777. // });
  778. // });
  779. */
  780. gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  781. //$scope.selected.item = data.entity;
  782. $scope.entity = angular.copy(data.entity);
  783. $scope.ciId = data.entity.id;
  784. //TODO
  785. vm.model=$scope.vm.model=decodeCIModel($scope.entity);
  786. angular.forEach($scope.vm.tabs, function(tab){
  787. tab.form.model = vm.model;
  788. });
  789. //decodeVMTabForm($scope.entity, vm.tabs);
  790. //console.log(data);
  791. });
  792. };
  793. // $scope.gridOptions.appScopeProvider = {
  794. // onDblClick : function(row) {
  795. // $state.go('app.form.detail',{data:row, formKey:'changeDetail', pdKey:'change'});
  796. // //var url = '//google.com';
  797. // //$window.open(url, "_blank", "height=600,width=800,toolbar=no,location=no,menubar=no,titlebar=no");
  798. // }
  799. // };
  800. this.selectRowFunction = function(data) {
  801. $scope.ciId = data.id;
  802. console.log(data);
  803. // $state.go('app.process.modeler',{modelId:data.id});
  804. // $state.go('app.change.editor', {
  805. // taskId: data.taskId,
  806. // processInstanceId: data.processInstanceId
  807. // });
  808. };
  809. var reinitTabForm = function(classify){
  810. $scope.ciId = undefined;
  811. api_configure_form.renderTabForm(classify).then(function(data){
  812. var myData = Restangular.stripRestangular(data);
  813. //angular.extend($scope.vm.fields,result.fields);
  814. //angular.extend($scope.vm.model,result.model);
  815. $scope.templateProps = myData;
  816. $scope.vm.tabs = myData;
  817. vm.model = {};
  818. decodeVMTabForm(vm.model, vm.tabs);
  819. //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  820. //console.log(myData);
  821. });
  822. }
  823. var refreshData = function(filterData){
  824. if(angular.isUndefined(filterData)){
  825. return;
  826. }
  827. $scope.myData = [];
  828. api_cmdb.query({'sign':filterData}).then(function(data){
  829. var myData = Restangular.stripRestangular(data);
  830. console.log(myData.data);
  831. if(myData.data&&myData.status==200){
  832. var ret = myData.data.node;
  833. // for(var i=0;i<ret.length;i++){
  834. // if(ret[i].status){
  835. // if(ret[i].status=="1"){ ret[i].statu="已部署"}
  836. // else if(ret[i].status=="2"){ ret[i].statu="测试中"}
  837. // else if(ret[i].status=="3"){ ret[i].statu="使用中"}
  838. // else if(ret[i].status=="4"){ ret[i].statu="维护中"}
  839. // else if(ret[i].status=="5"){ ret[i].statu="报废"}
  840. // else if(ret[i].status=="6"){ ret[i].statu="备用"}
  841. // }
  842. // }
  843. $scope.gridOptions.totalItems = ret.length;
  844. $scope.myData = ret;
  845. }
  846. });
  847. };
  848. var apple_selected, tree, treedata_avm, treedata_geography;
  849. $scope.my_tree_handler = function (branch) {
  850. //var _ref;
  851. $scope.ciclassify=branch;
  852. $scope.classify=branch.prefix.toLowerCase()+branch.sign;
  853. refreshData($scope.classify);
  854. $scope.ciId = undefined;
  855. api_configure_form.renderTabForm($scope.classify).then(function(data){
  856. var myData = Restangular.stripRestangular(data);
  857. //angular.extend($scope.vm.fields,result.fields);
  858. //angular.extend($scope.vm.model,result.model);
  859. $scope.templateProps = myData;
  860. $scope.vm.tabs = myData;
  861. vm.model = {};
  862. vm.model["loginUser"]= $rootScope.user.name;
  863. console.log(vm.model);
  864. decodeVMTabForm(vm.model, vm.tabs);
  865. //$scope.vm.originalTabs = angular.copy($scope.vm.form);
  866. console.log(myData);
  867. });
  868. console.log(branch);
  869. };
  870. $scope.my_data = [];
  871. function convertListToTree(data, treeMap){
  872. var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
  873. var root = null; //Initially set our loop to null
  874. var parentNode = null;
  875. //loop over data
  876. for(var i = 0; i < data.length; i++) {
  877. var datum = data[i];
  878. //each node will have children, so let's give it a "children" poperty
  879. datum.children = [];
  880. //add an entry for this node to the map so that any future children can
  881. //lookup the parent
  882. idToNodeMap[datum.id] = datum;
  883. //Does this node have a parent?
  884. if(typeof datum.parent === "undefined" || datum.parent == null) {
  885. //Doesn't look like it, so this node is the root of the tree
  886. root = datum;
  887. treeMap[datum.id] = root;
  888. } else {
  889. //This node has a parent, so let's look it up using the id
  890. parentNode = idToNodeMap[datum.parent.id];
  891. //We don't need this property, so let's delete it.
  892. delete datum.parent;
  893. //Let's add the current node as a child of the parent node.
  894. parentNode.children.push(datum);
  895. }
  896. }
  897. return root;
  898. }
  899. function convertParentToChildList(data){
  900. var treeMap = {};
  901. var list=[];
  902. convertListToTree(data, treeMap);
  903. angular.forEach(treeMap,function(item){
  904. list.push(item);
  905. });
  906. return list;
  907. }
  908. $scope.my_tree = tree = {};
  909. $scope.try_async_load = function () {
  910. $scope.my_data = [];
  911. $scope.doing_async = true;
  912. api_configure_data.fetchDataList('ciclassify',{'idx':0,'sum':100}).then(function(result){
  913. console.log(result['list']);
  914. $scope.my_data = convertParentToChildList(result['list']);
  915. $scope.doing_async = false;
  916. tree.expand_all();
  917. //console.log(treelist);
  918. });
  919. };
  920. $scope.try_async_load();
  921. var importUploader = $scope.importUploader = new FileUploader({
  922. url:api_cmdb.import().getRequestedUrl()
  923. });
  924. importUploader.filters.push({
  925. name: 'customFilter',
  926. fn: function(item /*{File|FileLikeObject}*/ , options) {
  927. var type = item.name.slice(item.name.lastIndexOf('.') + 1);
  928. //var type = '|' + item.type.slice(item.type.lastIndexOf('/') + 1) + '|';
  929. return (type == 'csv');
  930. }
  931. });
  932. importUploader.onWhenAddingFileFailed = function(item /*{File|FileLikeObject}*/ , filter, options) {
  933. console.info('onWhenAddingFileFailed', item, filter, options);
  934. };
  935. importUploader.onAfterAddingFile = function(fileItem) {
  936. console.info('onAfterAddingFile', fileItem);
  937. };
  938. importUploader.onAfterAddingAll = function(addedFileItems) {
  939. console.info('onAfterAddingAll', addedFileItems);
  940. };
  941. importUploader.onProgressItem = function(fileItem, progress) {
  942. console.info('onProgressItem', fileItem, progress);
  943. };
  944. importUploader.onProgressAll = function(progress) {
  945. console.info('onProgressAll', progress);
  946. };
  947. importUploader.onSuccessItem = function(fileItem, response, status, headers) {
  948. SweetAlert.swal({
  949. title: "导入成功!",
  950. confirmButtonColor: "#007AFF",
  951. type: "success"
  952. },function(){
  953. refreshData($scope.classify);
  954. });
  955. console.info('onSuccessItem', fileItem, response, status, headers);
  956. };
  957. importUploader.onErrorItem = function(fileItem, response, status, headers) {
  958. console.info('onErrorItem', fileItem, response, status, headers);
  959. SweetAlert.swal({
  960. title: "系统错误!",
  961. text: "系统错误,请稍候重试!",
  962. type: "error"
  963. });
  964. };
  965. importUploader.onCancelItem = function(fileItem, response, status, headers) {
  966. console.info('onCancelItem', fileItem, response, status, headers);
  967. };
  968. importUploader.onCompleteItem = function(fileItem, response, status, headers) {
  969. console.info('onCompleteItem', fileItem, response, status, headers);
  970. };
  971. importUploader.onCompleteAll = function() {
  972. console.info('onCompleteAll');
  973. };
  974. $scope.ldloading = {};
  975. $scope.import = function(){
  976. $scope.ldloading.expand = true;
  977. if(angular.isDefined($scope.ciclassify)&&$scope.ciclassify!=null){
  978. if(angular.isUndefined($scope.ciclassify.children)||$scope.ciclassify.children.length==0){
  979. importUploader.onBeforeUploadItem = function(item) {
  980. item.formData.push({'fileName':$scope.classify});
  981. item.formData.push({'uid':$rootScope.user.name});
  982. console.info('onBeforeUploadItem', item);
  983. };
  984. importUploader.uploadAll();
  985. $scope.ldloading.expand = false;
  986. }else{
  987. SweetAlert.swal({
  988. title: "参数不合法!",
  989. text: "参数不合法,请选择没有子类的资产导入!",
  990. type: "error"
  991. });
  992. }
  993. }else{
  994. SweetAlert.swal({
  995. title: "参数不合法!",
  996. text: "参数不合法,请选择需要导入资产分类!",
  997. type: "error"
  998. });
  999. }
  1000. }
  1001. $scope.ldloading = {};
  1002. $scope.export = function(){
  1003. $scope.ldloading.expand_right = true;
  1004. if(angular.isDefined($scope.ciclassify)&&$scope.ciclassify!=null){
  1005. if(angular.isUndefined($scope.ciclassify.children)||$scope.ciclassify.children.length==0){
  1006. api_cmdb.export($scope.classify).then(function(response){
  1007. var dataList = Restangular.stripRestangular(response);
  1008. if(dataList&&(dataList.length>=1)){
  1009. var headers = [];
  1010. var fieldHeaders = [];
  1011. var fields = [];
  1012. var rowData = [];
  1013. if($scope.templateProps.length>0){
  1014. angular.forEach($scope.templateProps, function(prop){
  1015. headers.push(prop.title);
  1016. angular.forEach(prop.form.fields, function(field, index){
  1017. fieldHeaders.push(field.templateOptions.label);
  1018. fields.push(field.key);
  1019. if(index!=0){
  1020. headers.push("");
  1021. }
  1022. });
  1023. })
  1024. }
  1025. var rowLine = [];
  1026. angular.forEach(dataList, function(data){
  1027. rowLine = [];
  1028. angular.forEach(fields,function(keyfield){
  1029. if(data[keyfield]){
  1030. if(keyfield=="state"){
  1031. if(data[keyfield]=="1"){data[keyfield]="未审核"}
  1032. else if(data[keyfield]=="2"){data[keyfield]="已审核"}
  1033. else if(data[keyfield]=="3"){data[keyfield]="不匹配"}
  1034. else if(data[keyfield]=="4"){data[keyfield]="丢失"}
  1035. rowLine.push(data[keyfield]);
  1036. }else if(keyfield=="removeflag"){
  1037. if(data[keyfield]){data[keyfield]="已删除"}
  1038. else{data[keyfield]="正常"}
  1039. rowLine.push(data[keyfield]);
  1040. }else if(keyfield=="ownershipType"||keyfield=="bladeownershipType"||keyfield=="miniwnershipType"||keyfield=="bdcOwnershipType"){
  1041. if(data[keyfield]=="1"){data[keyfield]="独立采购"}
  1042. else if(data[keyfield]=="2"){data[keyfield]="项目采购"}
  1043. else if(data[keyfield]=="3"){data[keyfield]="借用"}
  1044. else if(data[keyfield]=="4"){data[keyfield]="赠送"}
  1045. rowLine.push(data[keyfield]);
  1046. }else if(keyfield=="createtime"||keyfield=="audittime"||keyfield=="lastupdatetime"||keyfield=="removetime"){
  1047. data[keyfield]=moment(data[keyfield]).format('YYYY-MM-DD HH:mm:ss')
  1048. rowLine.push(data[keyfield]);
  1049. }else{
  1050. if(data[keyfield]==true){data[keyfield]="是"}
  1051. else if(data[keyfield]==false){data[keyfield]="否"}
  1052. rowLine.push(data[keyfield]);
  1053. // data[keyfield]=moment(data[keyfield]).format('YYYY-MM-DD HH:mm:ss')
  1054. }
  1055. }else{
  1056. rowLine.push("");
  1057. }
  1058. })
  1059. rowData.push(rowLine);
  1060. })
  1061. var csvdata = headers.join(',') + '\r\n';
  1062. csvdata = csvdata + fieldHeaders.join(',') + '\r\n';
  1063. csvdata = csvdata + fields.join(',') + '\r\n';
  1064. angular.forEach(rowData, function(line){
  1065. csvdata = csvdata + line.join(',') + '\r\n';
  1066. })
  1067. csvdata = "\ufeff" + csvdata;
  1068. var file = new Blob([ csvdata ], {
  1069. type : 'application/csv;charset=utf-8'
  1070. });
  1071. var filename = $scope.ciclassify.label;
  1072. var fileURL = URL.createObjectURL(file);
  1073. var a = document.createElement('a');
  1074. a.href = fileURL;
  1075. a.target = '_blank';
  1076. a.download = filename +'.csv';
  1077. document.body.appendChild(a);
  1078. a.click();
  1079. $scope.ldloading.expand_right = false;
  1080. }
  1081. })
  1082. }else{
  1083. SweetAlert.swal({
  1084. title: "参数不合法!",
  1085. text: "参数不合法,请选择没有子类的资产导出!",
  1086. type: "error"
  1087. });
  1088. }
  1089. }else{
  1090. SweetAlert.swal({
  1091. title: "参数不合法!",
  1092. text: "参数不合法,请选择需要导出的资产分类!",
  1093. type: "error"
  1094. });
  1095. }
  1096. }
  1097. $scope.download = function(){
  1098. if(angular.isDefined($scope.ciclassify)&&$scope.ciclassify!=null){
  1099. //api_cmdb.download($scope.sign).getRequestedUrl();
  1100. if(angular.isUndefined($scope.ciclassify.children)||$scope.ciclassify.children.length==0){
  1101. var filename = $scope.ciclassify.label;
  1102. //$scope.ciclassify.
  1103. var headers = [];
  1104. var fieldHeaders = [];
  1105. var fields = [];
  1106. if($scope.templateProps.length>0){
  1107. angular.forEach($scope.templateProps, function(prop){
  1108. headers.push(prop.title);
  1109. angular.forEach(prop.form.fields, function(field, index){
  1110. fieldHeaders.push(field.templateOptions.label);
  1111. fields.push(field.key);
  1112. if(index!=0){
  1113. headers.push("");
  1114. }
  1115. });
  1116. })
  1117. }
  1118. if(headers.length>1){
  1119. var csvdata = headers.join(',') + '\r\n';
  1120. csvdata = csvdata + fieldHeaders.join(',') + '\r\n';
  1121. csvdata = csvdata + fields.join(',') + '\r\n';
  1122. csvdata = "\ufeff" + csvdata;
  1123. var file = new Blob([ csvdata ], {
  1124. type : 'application/csv;charset=utf-8'
  1125. //type : 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8'
  1126. });
  1127. //trick to download store a file having its URL
  1128. var fileURL = URL.createObjectURL(file);
  1129. var a = document.createElement('a');
  1130. a.href = fileURL;
  1131. a.target = '_blank';
  1132. a.download = filename +'.csv';
  1133. document.body.appendChild(a);
  1134. a.click();
  1135. }
  1136. }else{
  1137. SweetAlert.swal({
  1138. title: "参数不合法!",
  1139. text: "参数不合法,请选择没有子类的资产进行模版下载!",
  1140. type: "error"
  1141. });
  1142. }
  1143. }else{
  1144. SweetAlert.swal({
  1145. title: "参数不合法!",
  1146. text: "参数不合法,请选择需要下载模版的资产分类!",
  1147. type: "error"
  1148. });
  1149. }
  1150. }
  1151. }]);