FormExplorer.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  1. MWF.xDesktop.requireApp("process.ProcessManager", "Explorer", null, false);
  2. MWF.xApplication.process.ProcessManager.FormExplorer = new Class({
  3. Extends: MWF.xApplication.process.ProcessManager.Explorer,
  4. Implements: [Options, Events],
  5. options: {
  6. "create": MWF.APPPM.LP.form.create,
  7. "search": MWF.APPPM.LP.form.search,
  8. "searchText": MWF.APPPM.LP.form.searchText,
  9. "noElement": MWF.APPPM.LP.form.noFormNoticeText
  10. },
  11. //ev.dataTransfer.setData("text/plain", ev.target.id);
  12. keyCopy: function(e){
  13. if (this.selectMarkItems.length){
  14. var items = [];
  15. var i = 0;
  16. var checkItems = function(e){
  17. if (i>=this.selectMarkItems.length){
  18. if (items.length){
  19. var str = JSON.encode(items);
  20. if (e){
  21. e.clipboardData.setData('text/plain', str);
  22. }else {
  23. window.clipboardData.setData("Text", str);
  24. }
  25. this.app.notice(this.app.lp.copyed, "success");
  26. }
  27. }
  28. }.bind(this);
  29. this.selectMarkItems.each(function(item){
  30. this.app.restActions.getForm(item.data.id, function(json){
  31. this.app.restActions.listFormFieldWithForm(item.data.id, function(fieldJson){
  32. var fieldList = [];
  33. if (fieldJson.data.number) fieldJson.data.number.each(function(f){ fieldList.push({"dataType": "number", "name": f.name}) });
  34. if (fieldJson.data.person) fieldJson.data.person.each(function(f){ fieldList.push({"dataType": "person", "name": f.name}) });
  35. if (fieldJson.data.string) fieldJson.data.string.each(function(f){ fieldList.push({"dataType": "string", "name": f.name}) });
  36. json.data.fieldList = fieldList;
  37. }.bind(this), null, false);
  38. json.data.elementType = "form";
  39. items.push(json.data);
  40. i++;
  41. checkItems(e);
  42. }.bind(this), null, false)
  43. }.bind(this));
  44. if (e) e.preventDefault();
  45. }
  46. },
  47. keyPaste: function(e){
  48. var dataStr = "";
  49. if (e){
  50. dataStr = e.clipboardData.getData('text/plain');
  51. }else{
  52. dataStr = window.clipboardData.getData("Text");
  53. }
  54. var data = JSON.decode(dataStr);
  55. this.pasteItem(data, 0);
  56. },
  57. pasteItem: function(data, i){
  58. if (i<data.length){
  59. var item = data[i];
  60. if (item.elementType==="form"){
  61. this.saveItemAs(item, function(){
  62. i++;
  63. this.pasteItem(data, i);
  64. }.bind(this), function(){
  65. i++;
  66. this.pasteItem(data, i);
  67. }.bind(this), function(){
  68. this.reload();
  69. }.bind(this));
  70. }else{
  71. i++;
  72. this.pasteItem(data, i);
  73. }
  74. }else{
  75. this.reload();
  76. }
  77. },
  78. saveItemAs: function(data, success, failure, cancel){
  79. this.app.restActions.listForm(this.app.options.application.id, function(dJson){
  80. var i=1;
  81. var someItems = dJson.data.filter(function(d){ return d.id===data.id });
  82. if (someItems.length){
  83. var someItem = someItems[0];
  84. var lp = this.app.lp;
  85. var _self = this;
  86. var d1 = new Date().parse(data.lastUpdateTime);
  87. var d2 = new Date().parse(someItem.lastUpdateTime);
  88. var html = "<div>"+lp.copyConfirmInfor+"</div>";
  89. html += "<div style='overflow: hidden; margin: 10px 0px; padding: 5px 10px; background-color: #ffffff; border-radius: 6px;'><div style='font-weight: bold; font-size:14px;'>"+lp.copySource+" "+someItem.name+"</div>";
  90. html += "<div style='font-size:12px; color: #666666; float: left'>"+someItem.lastUpdateTime+"</div>" +
  91. "<div style='font-size:12px; color: #666666; float: left; margin-left: 20px;'>"+MWF.name.cn(someItem.lastUpdatePerson)+"</div>" +
  92. "<div style='color: red; float: right;'>"+((d1>=d2) ? "": lp.copynew)+"</div></div>";
  93. html += "<div style='overflow: hidden; margin: 10px 0px; padding: 5px 10px; background-color: #ffffff; border-radius: 6px;'><div style='clear: both;font-weight: bold; font-size:14px;'>"+lp.copyTarget+" "+data.name+"</div>";
  94. html += "<div style='font-size:12px; color: #666666; float: left;'>"+data.lastUpdateTime+"</div>" +
  95. "<div style='font-size:12px; color: #666666; float: left; margin-left: 20px;'>"+MWF.name.cn(data.lastUpdatePerson)+"</div>" +
  96. "<div style='color: red; float: right;'>"+((d1<=d2) ? "": lp.copynew)+"</div></div>";
  97. // html += "<>"
  98. this.app.dlg("inofr", null, this.app.lp.copyConfirmTitle, {"html": html}, 500, 290, [
  99. {
  100. "text": lp.copyConfirm_overwrite,
  101. "action": function(){_self.saveItemAsUpdate(someItem, data, success, failure);this.close();}
  102. },
  103. {
  104. "text": lp.copyConfirm_new,
  105. "action": function(){_self.saveItemAsNew(dJson, data, success, failure);this.close();}
  106. },
  107. {
  108. "text": lp.copyConfirm_skip,
  109. "action": function(){/*nothing*/ this.close(); if (success) success();}
  110. },
  111. {
  112. "text": lp.copyConfirm_cancel,
  113. "action": function(){this.close(); if (cancel) cancel();}
  114. }
  115. ]);
  116. }else{
  117. this.saveItemAsNew(dJson, data, success, failure)
  118. }
  119. }.bind(this), function(){if (failure) failure();}.bind(this));
  120. },
  121. saveItemAsUpdate: function(someItem, form, success, failure){
  122. var item = this.app.options.application;
  123. var pcdata = JSON.decode(MWF.decodeJsonString(form.data));
  124. var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData));
  125. pcdata.id = someItem.id;
  126. pcdata.isNewForm = false;
  127. pcdata.json.id = someItem.id;
  128. pcdata.json.application = item.id;
  129. pcdata.json.applicationName = item.name;
  130. pcdata.json.name = someItem.name;
  131. pcdata.json.alias = someItem.alias;
  132. mobiledata.json.id = someItem.id;
  133. mobiledata.json.application = item.id;
  134. mobiledata.applicationName = item.name;
  135. mobiledata.json.name = someItem.name;
  136. mobiledata.json.alias = someItem.alias;
  137. this.app.restActions.saveForm(pcdata, mobiledata, form.fieldList, function(){
  138. if (success) success();
  139. }.bind(this), function(){
  140. if (failure) failure();
  141. }.bind(this));
  142. },
  143. saveItemAsNew: function(formsJson, form, success, failure){
  144. var item = this.app.options.application;
  145. var id = item.id;
  146. var name = item.name;
  147. var pcdata = JSON.decode(MWF.decodeJsonString(form.data));
  148. var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData));
  149. var oldName = pcdata.json.name;
  150. var i=1;
  151. while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){
  152. pcdata.json.name = oldName+"_copy"+i;
  153. mobiledata.json.name = oldName+"_copy"+i;
  154. i++;
  155. }
  156. pcdata.id = "";
  157. pcdata.isNewForm = true;
  158. pcdata.json.id = "";
  159. pcdata.json.application = id;
  160. pcdata.json.applicationName = name;
  161. pcdata.json.alias = "";
  162. mobiledata.json.id = "";
  163. mobiledata.json.application = id;
  164. mobiledata.applicationName = name;
  165. mobiledata.json.alias = "";
  166. this.app.restActions.saveForm(pcdata, mobiledata, form.fieldList, function(){
  167. if (success) success();
  168. }.bind(this), function(){
  169. if (failure) failure();
  170. }.bind(this));
  171. },
  172. _createElement: function(e){
  173. this.formTemplateList = null;
  174. this.defalutFormTemplateList = null;
  175. var _self = this;
  176. var createDefaultForm = function(e, template){
  177. layout.desktop.getFormDesignerStyle(function(){
  178. var options = {
  179. "style": layout.desktop.formDesignerStyle,
  180. "template": template,
  181. "onQueryLoad": function(){
  182. this.actions = _self.app.restActions;
  183. this.application = _self.app.options.application;
  184. }
  185. };
  186. layout.desktop.openApplication(e, "process.FormDesigner", options);
  187. }.bind(this));
  188. };
  189. var createForm = function(e, template){
  190. layout.desktop.getFormDesignerStyle(function(){
  191. var options = {
  192. "style": layout.desktop.formDesignerStyle,
  193. "templateId": template,
  194. "onQueryLoad": function(){
  195. this.actions = _self.app.restActions;
  196. this.application = _self.app.options.application;
  197. }
  198. };
  199. layout.desktop.openApplication(e, "process.FormDesigner", options);
  200. }.bind(this));
  201. };
  202. var createTemplateMaskNode = new Element("div", {"styles": this.css.createTemplateMaskNode}).inject(this.app.content);
  203. var createTemplateAreaNode = new Element("div", {"styles": this.css.createFormTemplateAreaNode}).inject(this.app.content);
  204. createTemplateAreaNode.fade("in");
  205. var createTemplateTitleNode = new Element("div", {"styles": this.css.createTemplateFormTitleNode, "text": this.app.lp.createSelectTemplate}).inject(createTemplateAreaNode);
  206. var createTemplateCategoryNode = new Element("div", {"styles": this.css.createTemplateFormCategoryNode}).inject(createTemplateAreaNode);
  207. var createTemplateCategoryTitleNode = new Element("div", {"styles": this.css.createTemplateFormCategoryTitleNode, "text": this.app.lp.templateCategory}).inject(createTemplateCategoryNode);
  208. var createTemplateContentNode = new Element("div", {"styles": this.css.createTemplateFormContentNode}).inject(createTemplateAreaNode);
  209. var createTemplateCategoryAllNode = new Element("div", {"styles": this.css.createTemplateFormCategoryItemNode, "text": this.app.lp.all}).inject(createTemplateCategoryNode);
  210. createTemplateCategoryAllNode.addEvent("click", function(){
  211. loadAllTemplates();
  212. });
  213. this.app.restActions.listFormTemplateCategory(function(json){
  214. json.data.each(function(d){
  215. var createTemplateCategoryItemNode = new Element("div", {"styles": this.css.createTemplateFormCategoryItemNode, "text": d.name+"("+ d.count+")", "value": d.name}).inject(createTemplateCategoryNode);
  216. createTemplateCategoryItemNode.addEvent("click", function(){
  217. createTemplateContentNode.empty();
  218. createTemplateCategoryNode.getElements("div").each(function(node, i){
  219. if (i>0) node.setStyles(_self.css.createTemplateFormCategoryItemNode);
  220. });
  221. this.setStyles(_self.css.createTemplateFormCategoryItemNode_current);
  222. loadTemplates(this.get("value"));
  223. });
  224. }.bind(this));
  225. }.bind(this));
  226. var resize = function(){
  227. var size = this.app.content.getSize();
  228. var y = (size.y*0.1)/2;
  229. var x = (size.x*0.1)/2;
  230. if (y<0) y=0;
  231. if (x<0) x=0;
  232. createTemplateAreaNode.setStyles({
  233. "top": ""+y+"px",
  234. "left": ""+x+"px"
  235. });
  236. y = size.y*0.9-createTemplateCategoryNode.getSize().y-70;
  237. createTemplateContentNode.setStyle("height", ""+y+"px");
  238. }.bind(this);
  239. resize();
  240. this.app.addEvent("resize", resize);
  241. var getDefaultFormTemplateList = function(callback){
  242. if (this.defalutFormTemplateList){
  243. if (callback) callback();
  244. }else{
  245. var url = "/x_component_process_FormDesigner/Module/Form/template/templates.json";
  246. MWF.getJSON(url, function(json){
  247. this.defalutFormTemplateList = json;
  248. if (callback) callback();
  249. }.bind(this));
  250. }
  251. }.bind(this);
  252. var loadDefaultTemplate = function(){
  253. getDefaultFormTemplateList(function(){
  254. this.defalutFormTemplateList.each(function(template){
  255. var templateNode = new Element("div", {"styles": this.css.formTemplateNode}).inject(createTemplateContentNode);
  256. var templateIconNode = new Element("div", {"styles": this.css.formTemplateIconNode}).inject(templateNode);
  257. var templateTitleNode = new Element("div", {"styles": this.css.formTemplateTitleNode, "text": template.title}).inject(templateNode);
  258. templateNode.store("template", template.name);
  259. var templateIconImgNode = new Element("img", {"styles": this.css.formTemplateIconImgNode}).inject(templateIconNode);
  260. templateIconImgNode.set("src", "/x_component_process_FormDesigner/Module/Form/template/"+template.icon);
  261. templateNode.addEvents({
  262. "mouseover": function(){this.setStyles(_self.css.formTemplateNode_over)},
  263. "mouseout": function(){this.setStyles(_self.css.formTemplateNode)},
  264. "mousedown": function(){this.setStyles(_self.css.formTemplateNode_down)},
  265. "mouseup": function(){this.setStyles(_self.css.formTemplateNode_over)},
  266. "click": function(e){
  267. createDefaultForm(e, this.retrieve("template"));
  268. _self.app.removeEvent("resize", resize);
  269. createTemplateAreaNode.destroy();
  270. createTemplateMaskNode.destroy();
  271. }
  272. });
  273. }.bind(this))
  274. }.bind(this));
  275. }.bind(this);
  276. var getFormTemplateList = function(callback){
  277. if (this.formTemplateList){
  278. if (callback) callback();
  279. }else{
  280. this.app.restActions.listFormTemplate(function(json){
  281. this.formTemplateList = json.data;
  282. if (callback) callback();
  283. }.bind(this));
  284. }
  285. }.bind(this);
  286. var loadTemplates = function(category){
  287. getFormTemplateList(function(){
  288. Object.each(this.formTemplateList, function(v, k){
  289. var flag = (category) ? (k==category) : true;
  290. if (flag){
  291. v.each(function(template){
  292. var templateNode = new Element("div", {"styles": this.css.formTemplateNode}).inject(createTemplateContentNode);
  293. var templateIconNode = new Element("div", {"styles": this.css.formTemplatePreviewNode}).inject(templateNode);
  294. var templateTitleNode = new Element("div", {"styles": this.css.formTemplateTitleNode, "text": template.name}).inject(templateNode);
  295. templateNode.store("template", template.id);
  296. templateIconNode.set("html", template.outline);
  297. var templateActionNode = new Element("img", {"styles": this.css.formTemplateActionNode}).inject(templateIconNode);
  298. templateActionNode.addEvent("click", function(e){
  299. var thisNode = this.getParent().getParent();
  300. var id = thisNode.retrieve("template");
  301. _self.app.confirm("wram", e, _self.app.lp.form.deleteFormTemplateTitle, _self.app.lp.form.deleteFormTemplate, 300, 120, function(){
  302. _self.app.restActions.deleteFormTemplate(id, function(json){
  303. thisNode.destroy();
  304. }.bind(this));
  305. this.close();
  306. }, function(){
  307. this.close();
  308. });
  309. e.stopPropagation();
  310. });
  311. //templateIconImgNode.set("src", "/x_component_process_FormDesigner/Module/Form/template/"+template.icon);
  312. templateNode.addEvents({
  313. "mouseover": function(){
  314. this.setStyles(_self.css.formTemplateNode_over);
  315. if (templateActionNode) templateActionNode.setStyle("display", "block");
  316. },
  317. "mouseout": function(){
  318. this.setStyles(_self.css.formTemplateNode);
  319. if (templateActionNode) templateActionNode.setStyle("display", "none");
  320. },
  321. "mousedown": function(){this.setStyles(_self.css.formTemplateNode_down)},
  322. "mouseup": function(){this.setStyles(_self.css.formTemplateNode_over)},
  323. "click": function(e){
  324. createForm(e, this.retrieve("template"));
  325. _self.app.removeEvent("resize", resize);
  326. createTemplateAreaNode.destroy();
  327. createTemplateMaskNode.destroy();
  328. }
  329. });
  330. }.bind(this));
  331. }
  332. }.bind(this));
  333. }.bind(this));
  334. }.bind(this);
  335. var loadAllTemplates = function(){
  336. createTemplateContentNode.empty();
  337. createTemplateCategoryNode.getElements("div").each(function(node, i){
  338. if (i>0) node.setStyles(_self.css.createTemplateFormCategoryItemNode);
  339. });
  340. createTemplateCategoryAllNode.setStyles(_self.css.createTemplateFormCategoryItemNode_current);
  341. loadDefaultTemplate();
  342. loadTemplates();
  343. };
  344. loadAllTemplates();
  345. createTemplateMaskNode.addEvent("click", function(){
  346. this.app.removeEvent("resize", resize);
  347. createTemplateAreaNode.destroy();
  348. createTemplateMaskNode.destroy();
  349. }.bind(this));
  350. },
  351. _loadItemDataList: function(callback){
  352. this.app.restActions.listForm(this.app.options.application.id,callback);
  353. },
  354. _getItemObject: function(item){
  355. return new MWF.xApplication.process.ProcessManager.FormExplorer.Form(this, item)
  356. },
  357. setTooltip: function(){
  358. this.options.tooltip = {
  359. "create": MWF.APPPM.LP.form.create,
  360. "search": MWF.APPPM.LP.form.search,
  361. "searchText": MWF.APPPM.LP.form.searchText,
  362. "noElement": MWF.APPPM.LP.form.noFormNoticeText
  363. };
  364. },
  365. deleteItems: function(){
  366. this.hideDeleteAction();
  367. while (this.deleteMarkItems.length){
  368. var item = this.deleteMarkItems.shift();
  369. if (this.deleteMarkItems.length){
  370. item.deleteForm();
  371. }else{
  372. item.deleteForm(function(){
  373. // this.reloadItems();
  374. // this.hideDeleteAction();
  375. }.bind(this));
  376. }
  377. }
  378. }
  379. });
  380. MWF.xApplication.process.ProcessManager.FormExplorer.Form = new Class({
  381. Extends: MWF.xApplication.process.ProcessManager.Explorer.Item,
  382. _open: function(e){
  383. layout.desktop.getFormDesignerStyle(function(){
  384. var _self = this;
  385. var options = {
  386. "style": layout.desktop.formDesignerStyle,
  387. "onQueryLoad": function(){
  388. this.actions = _self.explorer.actions;
  389. this.category = _self;
  390. this.options.id = _self.data.id;
  391. this.application = _self.explorer.app.options.application;
  392. }
  393. };
  394. this.explorer.app.desktop.openApplication(e, "process.FormDesigner", options);
  395. }.bind(this));
  396. },
  397. _getIcon: function(){
  398. var x = (Math.random()*49).toInt();
  399. return "process_icon_"+x+".png";
  400. },
  401. _getLnkPar: function(){
  402. return {
  403. "icon": this.explorer.path+this.explorer.options.style+"/formIcon/lnk.png",
  404. "title": this.data.name,
  405. "par": "process.FormDesigner#{\"id\": \""+this.data.id+"\"}"
  406. };
  407. },
  408. // deleteItem: function(e){
  409. // var _self = this;
  410. // this.explorer.app.confirm("info", e, this.explorer.app.lp.form.deleteFormTitle, this.explorer.app.lp.form.deleteForm, 320, 110, function(){
  411. // _self.deleteForm();
  412. // this.close();
  413. // },function(){
  414. // this.close();
  415. // });
  416. // },
  417. deleteForm: function(callback){
  418. this.explorer.app.restActions.deleteForm(this.data.id, function(){
  419. this.node.destroy();
  420. if (callback) callback();
  421. }.bind(this));
  422. },
  423. saveItemAs: function(item){
  424. var id = item.id;
  425. var name = item.name;
  426. this.explorer.app.restActions.getForm(this.data.id, function(json){
  427. var pcdata = JSON.decode(MWF.decodeJsonString(json.data.data));
  428. var mobiledata = JSON.decode(MWF.decodeJsonString(json.data.mobileData));
  429. pcdata.json.alias = "";
  430. mobiledata.json.alias = "";
  431. var oldName = pcdata.json.name;
  432. this.explorer.app.restActions.listForm(id, function(formsJson){
  433. var i=1;
  434. while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){
  435. pcdata.json.name = oldName+"_copy"+i;
  436. mobiledata.json.name = oldName+"_copy"+i;
  437. i++;
  438. }
  439. pcdata.id = "";
  440. pcdata.isNewForm = true;
  441. pcdata.json.id = "";
  442. pcdata.json.application = id;
  443. pcdata.json.applicationName = name;
  444. mobiledata.json.id = "";
  445. mobiledata.json.application = id;
  446. mobiledata.applicationName = name;
  447. this.explorer.app.restActions.listFormFieldWithForm(this.data.id, function(fieldJson){
  448. var fieldList = [];
  449. if (fieldJson.data.number) fieldJson.data.number.each(function(f){ fieldList.push({"dataType": "number", "name": f.name}) });
  450. if (fieldJson.data.person) fieldJson.data.person.each(function(f){ fieldList.push({"dataType": "person", "name": f.name}) });
  451. if (fieldJson.data.string) fieldJson.data.string.each(function(f){ fieldList.push({"dataType": "string", "name": f.name}) });
  452. this.explorer.app.restActions.saveForm(pcdata, mobiledata, fieldList, function(){
  453. if (id == this.explorer.app.options.application.id) this.explorer.reload();
  454. }.bind(this));
  455. }.bind(this));
  456. }.bind(this));
  457. }.bind(this));
  458. }
  459. });