PageExplorer.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  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. "categoryEnable": true,
  14. "itemStyle": "card",
  15. "name": 'portal.PageExplorer'
  16. },
  17. openFindDesigner: function(){
  18. this.app.options.application.moduleType = "portal";
  19. var options = {
  20. "filter": {
  21. "moduleList": ["portal"],
  22. "appList": [this.app.options.application]
  23. }
  24. };
  25. layout.openApplication(null, "FindDesigner", options);
  26. },
  27. keyCopy: function(e){
  28. if (this.selectMarkItems.length){
  29. var items = [];
  30. var i = 0;
  31. var checkItems = function(e){
  32. if (i>=this.selectMarkItems.length){
  33. if (items.length){
  34. var str = JSON.encode(items);
  35. if (e){
  36. e.clipboardData.setData('text/plain', str);
  37. }else {
  38. window.clipboardData.setData("Text", str);
  39. }
  40. this.app.notice(this.app.lp.copyed, "success");
  41. }
  42. }
  43. }.bind(this);
  44. this.selectMarkItems.each(function(item){
  45. this.app.restActions.getPage(item.data.id, function(json){
  46. json.data.elementType = "page";
  47. items.push(json.data);
  48. i++;
  49. checkItems(e);
  50. }.bind(this), null, false)
  51. }.bind(this));
  52. if (e) e.preventDefault();
  53. }
  54. },
  55. keyPaste: function(e){
  56. var dataStr = "";
  57. if (e){
  58. dataStr = e.clipboardData.getData('text/plain');
  59. }else{
  60. dataStr = window.clipboardData.getData("Text");
  61. }
  62. var data = JSON.decode(dataStr);
  63. this.pasteItem(data, 0);
  64. },
  65. pasteItem: function(data, i){
  66. if (i<data.length){
  67. var item = data[i];
  68. if (item.elementType==="page"){
  69. this.saveItemAs(item, function(){
  70. i++;
  71. this.pasteItem(data, i);
  72. }.bind(this), function(){
  73. i++;
  74. this.pasteItem(data, i);
  75. }.bind(this), function(){
  76. this.reload();
  77. }.bind(this));
  78. }else{
  79. i++;
  80. this.pasteItem(data, i);
  81. }
  82. }else{
  83. this.reload();
  84. }
  85. },
  86. saveItemAs: function(data, success, failure, cancel){
  87. this.app.restActions.listPage(this.app.options.application.id, function(dJson){
  88. var i=1;
  89. var someItems = dJson.data.filter(function(d){ return d.id===data.id });
  90. if (someItems.length){
  91. var someItem = someItems[0];
  92. var lp = this.app.lp;
  93. var _self = this;
  94. var d1 = new Date().parse(data.lastUpdateTime || data.updateTime);
  95. var d2 = new Date().parse(someItem.lastUpdateTime || someItem.updateTime);
  96. var html = "<div>"+lp.copyConfirmInfor+"</div>";
  97. 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>";
  98. html += "<div style='font-size:12px; color: #666666; float: left'>"+(someItem.lastUpdateTime || someItem.updateTime)+"</div>" +
  99. "<div style='font-size:12px; color: #666666; float: left; margin-left: 20px;'>"+MWF.name.cn(someItem.lastUpdatePerson || "")+"</div>" +
  100. "<div style='color: red; float: right;'>"+((d1>=d2) ? "": lp.copynew)+"</div></div>";
  101. 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>";
  102. html += "<div style='font-size:12px; color: #666666; float: left;'>"+(data.lastUpdateTime || data.updateTime)+"</div>" +
  103. "<div style='font-size:12px; color: #666666; float: left; margin-left: 20px;'>"+MWF.name.cn(data.lastUpdatePerson || "")+"</div>" +
  104. "<div style='color: red; float: right;'>"+((d1<=d2) ? "": lp.copynew)+"</div></div>";
  105. // html += "<>"
  106. this.app.dlg("inofr", null, this.app.lp.copyConfirmTitle, {"html": html}, 500, 290, [
  107. {
  108. "text": lp.copyConfirm_overwrite,
  109. "action": function(){_self.saveItemAsUpdate(someItem, data, success, failure);this.close();}
  110. },
  111. {
  112. "text": lp.copyConfirm_new,
  113. "action": function(){_self.saveItemAsNew(dJson, data, success, failure);this.close();}
  114. },
  115. {
  116. "text": lp.copyConfirm_skip,
  117. "action": function(){/*nothing*/ this.close(); if (success) success();}
  118. },
  119. {
  120. "text": lp.copyConfirm_cancel,
  121. "action": function(){this.close(); if (cancel) cancel();}
  122. }
  123. ]);
  124. }else{
  125. this.saveItemAsNew(dJson, data, success, failure)
  126. }
  127. }.bind(this), function(){if (failure) failure();}.bind(this));
  128. },
  129. saveItemAsUpdate: function(someItem, form, success, failure){
  130. var item = this.app.options.application;
  131. var pcdata = JSON.decode(MWF.decodeJsonString(form.data));
  132. var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData));
  133. pcdata.id = someItem.id;
  134. pcdata.isNewPage = false;
  135. pcdata.json.id = someItem.id;
  136. pcdata.json.application = item.id;
  137. pcdata.json.applicationName = item.name;
  138. pcdata.json.name = someItem.name;
  139. pcdata.json.alias = someItem.alias;
  140. mobiledata.json.id = someItem.id;
  141. mobiledata.json.application = item.id;
  142. mobiledata.applicationName = item.name;
  143. mobiledata.json.name = someItem.name;
  144. mobiledata.json.alias = someItem.alias;
  145. this.app.restActions.savePage(pcdata, mobiledata, null, function(){
  146. if (success) success();
  147. }.bind(this), function(){
  148. if (failure) failure();
  149. }.bind(this));
  150. },
  151. saveItemAsNew: function(formsJson, form, success, failure){
  152. var item = this.app.options.application;
  153. var id = item.id;
  154. var name = item.name;
  155. var pcdata = JSON.decode(MWF.decodeJsonString(form.data));
  156. var mobiledata = JSON.decode(MWF.decodeJsonString(form.mobileData));
  157. var oldName = pcdata.json.name;
  158. var i=1;
  159. while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){
  160. pcdata.json.name = oldName+"_copy"+i;
  161. mobiledata.json.name = oldName+"_copy"+i;
  162. i++;
  163. }
  164. pcdata.id = "";
  165. pcdata.isNewPage = true;
  166. pcdata.json.id = "";
  167. pcdata.json.application = id;
  168. pcdata.json.applicationName = name;
  169. pcdata.json.alias = "";
  170. mobiledata.json.id = "";
  171. mobiledata.json.application = id;
  172. mobiledata.applicationName = name;
  173. mobiledata.json.alias = "";
  174. this.app.restActions.savePage(pcdata, mobiledata, null, function(){
  175. if (success) success();
  176. }.bind(this), function(){
  177. if (failure) failure();
  178. }.bind(this));
  179. },
  180. _createElement: function(e){
  181. if( layout.desktop && layout.desktop.getPageDesignerStyle ){
  182. layout.desktop.getPageDesignerStyle(function(){
  183. this.__createElement(e, layout.desktop.pageDesignerStyle )
  184. }.bind(this));
  185. }else{
  186. this.__createElement( e,"default" );
  187. }
  188. },
  189. __createElement: function( e, style ){
  190. var _self = this;
  191. var options = {
  192. "style": style,
  193. "template": "page.json",
  194. "application":{
  195. "name": _self.app.options.application.name,
  196. "id": _self.app.options.application.id
  197. },
  198. "onQueryLoad": function(){
  199. this.actions = _self.app.restActions;
  200. this.application = _self.app.options.application;
  201. }
  202. };
  203. layout.desktop.openApplication(e, "portal.PageDesigner", options);
  204. },
  205. _loadItemDataList: function(callback){
  206. this.app.restActions.listPage(this.app.options.application.id,callback);
  207. },
  208. _getItemObject: function(item){
  209. return new MWF.xApplication.portal.PortalManager.PageExplorer.Page(this, item)
  210. },
  211. deleteItems: function(){
  212. this.hideDeleteAction();
  213. while (this.deleteMarkItems.length){
  214. var item = this.deleteMarkItems.shift();
  215. if (this.deleteMarkItems.length){
  216. item.deletePage();
  217. }else{
  218. item.deletePage(function(){
  219. // this.reloadItems();
  220. //this.hideDeleteAction();
  221. }.bind(this));
  222. }
  223. }
  224. }
  225. });
  226. MWF.xApplication.portal.PortalManager.PageExplorer.Page= new Class({
  227. Extends: MWF.xApplication.process.ProcessManager.Explorer.Item,
  228. _open: function(e){
  229. var _self = this;
  230. var options = {
  231. "appId": "portal.PageDesigner"+_self.data.id,
  232. "id": _self.data.id,
  233. // "application": _self.explorer.app.options.application.id,
  234. "application":{
  235. "name": _self.explorer.app.options.application.name,
  236. "id": _self.explorer.app.options.application.id
  237. },
  238. "onQueryLoad": function(){
  239. this.actions = _self.explorer.actions;
  240. this.category = _self;
  241. this.options.id = _self.data.id;
  242. this.application = _self.explorer.app.options.application;
  243. }
  244. };
  245. this.explorer.app.desktop.openApplication(e, "portal.PageDesigner", options);
  246. },
  247. _getIcon: function(){
  248. var x = (Math.random()*49).toInt();
  249. return "process_icon_"+x+".png";
  250. },
  251. _getLnkPar: function(){
  252. return {
  253. "icon": this.explorer.path+this.explorer.options.style+"/formIcon/lnk.png",
  254. "title": this.data.name,
  255. "par": "portal.PageDesigner#{\"id\": \""+this.data.id+"\"}"
  256. };
  257. },
  258. deletePage: function(callback){
  259. this.explorer.actions.deletePage(this.data.id, function(){
  260. this.node.destroy();
  261. if (callback) callback();
  262. }.bind(this));
  263. },
  264. saveas: function(){
  265. MWF.xDesktop.requireApp("Selector", "package", function(){
  266. var selector = new MWF.O2Selector(this.explorer.app.content, {
  267. "title": this.explorer.app.lp.copyto,
  268. "type": "Portal",
  269. "values": [this.explorer.app.options.application],
  270. "onComplete": function(items){
  271. items.each(function(item){
  272. this.saveItemAs(item.data);
  273. }.bind(this));
  274. }.bind(this),
  275. });
  276. }.bind(this));
  277. },
  278. saveItemAs: function(item){
  279. var id = item.id;
  280. var name = item.name;
  281. this.explorer.app.restActions.getPage(this.data.id, function(json){
  282. var pcdata = JSON.decode(MWF.decodeJsonString(json.data.data));
  283. var mobiledata = JSON.decode(MWF.decodeJsonString(json.data.mobileData));
  284. pcdata.json.alias = "";
  285. mobiledata.json.alias = "";
  286. var oldName = pcdata.json.name;
  287. this.explorer.app.restActions.listPage(id, function(formsJson){
  288. var i=1;
  289. while (formsJson.data.some(function(d){ return d.name==pcdata.json.name })){
  290. pcdata.json.name = oldName+"_copy"+i;
  291. mobiledata.json.name = oldName+"_copy"+i;
  292. i++;
  293. }
  294. pcdata.id = "";
  295. pcdata.isNewPage = true;
  296. pcdata.json.id = "";
  297. pcdata.json.application = id;
  298. pcdata.json.applicationName = name;
  299. mobiledata.json.id = "";
  300. mobiledata.json.application = id;
  301. mobiledata.applicationName = name;
  302. this.explorer.app.restActions.savePage(pcdata, mobiledata, null, function(){
  303. if (id == this.explorer.app.options.application.id) this.explorer.reload();
  304. }.bind(this));
  305. }.bind(this));
  306. }.bind(this));
  307. }
  308. });