WidgetExplorer.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  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. "categoryEnable": true,
  14. "itemStyle": "card",
  15. "name": 'portal.WidgetExplorer'
  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.getWidget(item.data.id, function(json){
  46. json.data.elementType = "widget";
  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==="widget"){
  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.listWidget(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.saveWidget(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.saveWidget(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. var _self = this;
  182. var options = {
  183. "style": layout.desktop.pageDesignerStyle || "default",
  184. //"templateId": "page.json",
  185. "application":{
  186. "name": _self.app.options.application.name,
  187. "id": _self.app.options.application.id
  188. },
  189. "onQueryLoad": function(){
  190. this.actions = _self.app.restActions;
  191. this.application = _self.app.options.application;
  192. }
  193. };
  194. this.app.desktop.openApplication(e, "portal.WidgetDesigner", options);
  195. },
  196. _loadItemDataList: function(callback){
  197. this.app.restActions.listWidget(this.app.options.application.id,callback);
  198. },
  199. _getItemObject: function(item){
  200. return new MWF.xApplication.portal.PortalManager.WidgetExplorer.Widget(this, item)
  201. },
  202. deleteItems: function(){
  203. this.hideDeleteAction();
  204. while (this.deleteMarkItems.length){
  205. var item = this.deleteMarkItems.shift();
  206. if (this.deleteMarkItems.length){
  207. item.deleteWidget();
  208. }else{
  209. item.deleteWidget(function(){
  210. // this.reloadItems();
  211. //this.hideDeleteAction();
  212. }.bind(this));
  213. }
  214. }
  215. }
  216. });
  217. MWF.xApplication.portal.PortalManager.WidgetExplorer.Widget= new Class({
  218. Extends: MWF.xApplication.process.ProcessManager.Explorer.Item,
  219. _open: function(e){
  220. var _self = this;
  221. var options = {
  222. "appId": "portal.WidgetDesigner"+_self.data.id,
  223. "id": _self.data.id,
  224. // "application": _self.explorer.app.options.application.id,
  225. "application":{
  226. "name": _self.explorer.app.options.application.name,
  227. "id": _self.explorer.app.options.application.id
  228. },
  229. "onQueryLoad": function(){
  230. this.actions = _self.explorer.actions;
  231. this.category = _self;
  232. this.options.id = _self.data.id;
  233. this.application = _self.explorer.app.options.application;
  234. }
  235. };
  236. this.explorer.app.desktop.openApplication(e, "portal.WidgetDesigner", options);
  237. },
  238. _getIcon: function(){
  239. var x = (Math.random()*49).toInt();
  240. return "process_icon_"+x+".png";
  241. },
  242. _getLnkPar: function(){
  243. return {
  244. "icon": this.explorer.path+this.explorer.options.style+"/processIcon/lnk.png",
  245. "title": this.data.name,
  246. "par": "portal.WidgetDesigner#{\"id\": \""+this.data.id+"\"}"
  247. };
  248. },
  249. // deleteItem: function(e){
  250. // var _self = this;
  251. // this.explorer.app.confirm("info", e, this.explorer.app.lp.process.deleteProcessTitle, this.explorer.app.lp.process.deleteProcess, 320, 110, function(){
  252. // _self.deleteProcess();
  253. // this.close();
  254. // },function(){
  255. // this.close();
  256. // });
  257. // },
  258. deleteWidget: function(callback){
  259. this.explorer.actions.deleteWidget(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.getWidget(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.listWidget(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.saveWidget(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. });