PageExplorer.js 23 KB

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