WidgetExplorer.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. MWF.xDesktop.requireApp("process.ProcessManager", "Explorer", null, false);
  2. MWF.xApplication.portal.PortalManager.WidgetExplorer = 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.widget.create,
  9. "search": MWF.xApplication.portal.PortalManager.LP.widget.search,
  10. "searchText": MWF.xApplication.portal.PortalManager.LP.widget.searchText,
  11. "noElement": MWF.xApplication.portal.PortalManager.LP.widget.noNoticeText
  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.getWidget(item.data.id, function(json){
  33. json.data.elementType = "widget";
  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==="widget"){
  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.listWidget(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.saveWidget(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.saveWidget(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. var _self = this;
  169. var options = {
  170. "style": layout.desktop.pageDesignerStyle || "default",
  171. //"templateId": "page.json",
  172. "onQueryLoad": function(){
  173. this.actions = _self.app.restActions;
  174. this.application = _self.app.options.application;
  175. }
  176. };
  177. this.app.desktop.openApplication(e, "portal.WidgetDesigner", options);
  178. },
  179. _loadItemDataList: function(callback){
  180. this.app.restActions.listWidget(this.app.options.application.id,callback);
  181. },
  182. _getItemObject: function(item){
  183. return new MWF.xApplication.portal.PortalManager.WidgetExplorer.Widget(this, item)
  184. },
  185. deleteItems: function(){
  186. this.hideDeleteAction();
  187. while (this.deleteMarkItems.length){
  188. var item = this.deleteMarkItems.shift();
  189. if (this.deleteMarkItems.length){
  190. item.deleteWidget();
  191. }else{
  192. item.deleteWidget(function(){
  193. // this.reloadItems();
  194. //this.hideDeleteAction();
  195. }.bind(this));
  196. }
  197. }
  198. }
  199. });
  200. MWF.xApplication.portal.PortalManager.WidgetExplorer.Widget= new Class({
  201. Extends: MWF.xApplication.process.ProcessManager.Explorer.Item,
  202. _open: function(e){
  203. var _self = this;
  204. var options = {
  205. "onQueryLoad": function(){
  206. this.actions = _self.explorer.actions;
  207. this.category = _self;
  208. this.options.id = _self.data.id;
  209. this.application = _self.explorer.app.options.application;
  210. }
  211. };
  212. this.explorer.app.desktop.openApplication(e, "portal.WidgetDesigner", options);
  213. },
  214. _getIcon: function(){
  215. var x = (Math.random()*49).toInt();
  216. return "process_icon_"+x+".png";
  217. },
  218. _getLnkPar: function(){
  219. return {
  220. "icon": this.explorer.path+this.explorer.options.style+"/processIcon/lnk.png",
  221. "title": this.data.name,
  222. "par": "portal.WidgetDesigner#{\"id\": \""+this.data.id+"\"}"
  223. };
  224. },
  225. // deleteItem: function(e){
  226. // var _self = this;
  227. // this.explorer.app.confirm("info", e, this.explorer.app.lp.process.deleteProcessTitle, this.explorer.app.lp.process.deleteProcess, 320, 110, function(){
  228. // _self.deleteProcess();
  229. // this.close();
  230. // },function(){
  231. // this.close();
  232. // });
  233. // },
  234. deleteWidget: function(callback){
  235. this.explorer.actions.deleteWidget(this.data.id, function(){
  236. this.node.destroy();
  237. if (callback) callback();
  238. }.bind(this));
  239. }
  240. });