WidgetExplorer.js 11 KB

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