Main.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506
  1. MWF.xApplication.Common = MWF.xApplication.Common || {
  2. options: {
  3. "multitask": false, //允许多窗口运行
  4. "executable": true //可执行
  5. }
  6. };
  7. MWF.require("MWF.xDesktop.Window", null, false);
  8. MWF.xApplication.Common.Main = new Class({
  9. Extends: MWF.widget.Common,
  10. Implements: [Options, Events],
  11. options: {
  12. "desktopReload": true,
  13. "style": "default",
  14. "name": "Common",
  15. "icon": "", //图标
  16. "title": "", //标题
  17. "event": null,
  18. "width": "800",
  19. "height": "600",
  20. "isResize": true,
  21. "isMax": true,
  22. "setCurrent": true,
  23. "isRefresh": false,
  24. "isWindowRefresh": true
  25. },
  26. initialize: function(desktop, options){
  27. this.setOptions(options);
  28. this.desktop = desktop;
  29. this.path = "/x_component_"+this.options.name.replace(/\./g, "_")+"/$Main/";
  30. this.options.icon = this.path+this.options.style+"/"+this.options.icon;
  31. this.cssPath =this.path+this.options.style+"/css.wcss";
  32. this._loadCss();
  33. },
  34. fireAppEvent: function(when){
  35. this.fireEvent(when);
  36. if (this[("on-"+when).camelCase()]) this[("on-"+when).camelCase()]();
  37. // if (this[("on-"+when).camelCase()+"Events"){
  38. // this[("on-"+when).camelCase()+"Events".each(function(event){
  39. // event.apply(this);
  40. // }.bind(this));
  41. // }
  42. },
  43. loadNoAnimation: function(isCurrent, max, hide){
  44. this.fireAppEvent("queryLoad");
  45. if (!this.inBrowser){
  46. this.loadWindow(isCurrent, false, max, hide);
  47. }else{
  48. this.loadInBrowser(isCurrent);
  49. }
  50. },
  51. load : function(isCurrent){
  52. this.fireAppEvent("queryLoad");
  53. if (!this.inBrowser){
  54. this.loadWindow(isCurrent);
  55. }else{
  56. this.loadInBrowser(isCurrent);
  57. }
  58. },
  59. loadApplication: function(callback){
  60. if (callback) callback();
  61. },
  62. loadWindow: function(isCurrent, animation, max, hide){
  63. this.fireAppEvent("queryLoadWindow");
  64. var options = {
  65. "style": "desktop_"+this.desktop.options.style,
  66. "title": this.options.title,
  67. "isResize": this.options.isResize,
  68. "isMax": this.options.isMax,
  69. "isRefresh": this.options.isWindowRefresh,
  70. "container": this.desktop.node,
  71. "onPostShow": function(){
  72. if (isCurrent) this.setCurrent();
  73. this.fireAppEvent("postLoadWindow");
  74. this.fireAppEvent("queryLoadApplication");
  75. this.setContentEvent();
  76. this.loadApplication(function(){
  77. this.fireAppEvent("postLoadApplication");
  78. }.bind(this));
  79. var resize = false;
  80. var size = this.window.node.getSize();
  81. var position = this.window.node.getPosition();
  82. var bodySize = $(document.body).getSize();
  83. var height = size.y;
  84. var width = size.x;
  85. var y = (size.y+position.y)-bodySize.y;
  86. if (y>-10){
  87. height = size.y-y-10;
  88. resize = true;
  89. }
  90. var x = (size.x+position.x)-bodySize.x;
  91. if (x>-10){
  92. width = size.x-x-10;
  93. resize = true;
  94. }
  95. if (resize){
  96. this.window.options.height = height;
  97. this.window.options.width = width;
  98. this.window.node.setStyles({
  99. "width": ""+width+"px",
  100. "height": ""+height+"px"
  101. });
  102. this.window.spacer.setStyles({
  103. "width": ""+width+"px",
  104. "height": ""+height+"px"
  105. });
  106. this.window.setContentSize();
  107. }
  108. this.fireAppEvent("postLoad");
  109. }.bind(this),
  110. "onResize": function(){
  111. this.window.options.title = this.options.title;
  112. this.window.getTitle();
  113. this.fireAppEvent("resize");
  114. }.bind(this),
  115. "onResizeCompleted": function(){
  116. this.fireAppEvent("resizeCompleted");
  117. }.bind(this),
  118. "onMoveDrop": function(e){
  119. if (Browser.name=="firefox"){
  120. if (e.event.clientX<0 || e.event.clientY<0) this.openInNewBrowser();
  121. }else{
  122. if (e.event.x<0 || e.event.y<0) this.openInNewBrowser();
  123. }
  124. }.bind(this)
  125. };
  126. if (this.options.event){
  127. options.fromTop = this.options.event.page.y;
  128. options.fromLeft = this.options.event.page.x;
  129. }
  130. options.width = this.options.width || options.width;
  131. options.height = this.options.height || options.height;
  132. this.window = new MWF.xDesktop.Window(this, options);
  133. this.fireAppEvent("loadWindow");
  134. //this.maxSize();
  135. this.content = this.window.content;
  136. if (animation===false){
  137. this.window.showNoAnimation(max, hide);
  138. }else{
  139. this.window.show();
  140. }
  141. },
  142. loadInBrowser: function(){
  143. this.window = {
  144. "isHide": false,
  145. "isMax": true,
  146. "maxSize": function(){},
  147. "restore": function(){},
  148. "setCurrent": function(){},
  149. "hide": function(){},
  150. "maxOrRestoreSize": function(){},
  151. "restoreSize": function(){},
  152. "close": function(){}
  153. };
  154. this.window.titleText = $(document.head).getElement("title");
  155. this.window.titleText.set("text", this.options.title);
  156. this.window.content = $("appContent");
  157. this.content = this.window.content;
  158. //this.content.setStyles({"height": "100%", "overflow": "hidden"});
  159. $(document.body).addEvent("resize", function(){
  160. this.fireAppEvent("resize");
  161. }.bind(this));
  162. window.onbeforeunload = function(e){
  163. this.fireAppEvent("queryClose");
  164. }.bind(this);
  165. this.fireAppEvent("postLoadWindow");
  166. this.fireAppEvent("queryLoadApplication");
  167. this.setContentEvent();
  168. this.loadApplication(function(){
  169. this.fireAppEvent("postLoadApplication");
  170. }.bind(this));
  171. this.content.setStyle("height", document.body.getSize().y);
  172. this.fireAppEvent("postLoad");
  173. },
  174. openInNewBrowser: function(){
  175. this.desktop.openBrowserApp = this.options.name;
  176. this.desktop.openBrowserStatus = (this.recordStatus) ? this.recordStatus() : null;
  177. window.open("app.html", "_blank");
  178. this.close();
  179. },
  180. setContentEvent: function(){
  181. // this.content.addEvents({
  182. // "resize": function(){
  183. // if (this.onResize) this.onResize();
  184. // }.bind(this)
  185. // });
  186. },
  187. setCurrent: function(){
  188. if (this.desktop.currentApp==this) return true;
  189. if (this.desktop.currentApp){
  190. this.desktop.currentApp.setUncurrent();
  191. }
  192. this.window.setCurrent();
  193. if (this.window.isHide){
  194. if (this.window.isMax){
  195. this.window.maxSize(function(){this.fireAppEvent("current");}.bind(this));
  196. }else{
  197. this.window.restore(function(){this.fireAppEvent("current");}.bind(this));
  198. }
  199. }else{
  200. this.fireAppEvent("current");
  201. }
  202. if (this.taskitem) this.taskitem.selected();
  203. this.desktop.currentApp = this;
  204. this.desktop.appCurrentList.erase(this);
  205. this.desktop.appCurrentList.push(this);
  206. },
  207. setUncurrent: function(){
  208. if (this.desktop.currentApp==this){
  209. this.window.setUncurrent();
  210. this.taskitem.unSelected();
  211. this.desktop.currentApp = null;
  212. this.fireAppEvent("uncurrent");
  213. }
  214. },
  215. minSize: function(){
  216. this.fireAppEvent("queryMinSize");
  217. var p = this.taskitem.node.getPosition();
  218. this.setUncurrent();
  219. this.window.hide(p.x, p.y, function(){
  220. this.fireAppEvent("postMinSize");
  221. }.bind(this));
  222. },
  223. _minSize: function(){
  224. var p = this.taskitem.node.getPosition();
  225. this.setUncurrent();
  226. this.window.hide(p.x, p.y);
  227. },
  228. maxOrRestoreSize: function(){
  229. var max = true;
  230. if (this.window.isMax) max = false;
  231. this.fireAppEvent((max) ? "queryMaxSize" : "queryRestoreSize");
  232. this.window.maxOrRestoreSize(function(){
  233. this.fireAppEvent((max) ? "postMaxSize" : "postRestoreSize");
  234. }.bind(this));
  235. },
  236. maxSize: function(callback){
  237. if (!this.window.isMax){
  238. this.fireAppEvent("queryMaxSize");
  239. this.window.maxSize(function(){
  240. this.fireAppEvent("postMaxSize");
  241. if (callback) callback();
  242. }.bind(this));
  243. }else{
  244. if (callback) callback();
  245. }
  246. },
  247. _maxSize: function(callback){
  248. this.window.maxSize();
  249. },
  250. restoreSize: function(callback){
  251. this.fireAppEvent("queryRestoreSize");
  252. this.window.restoreSize(function(){
  253. this.fireAppEvent("postRestoreSize");
  254. if (callback) callback();
  255. }.bind(this));
  256. },
  257. _restoreSize: function(callback){
  258. this.window.restoreSize();
  259. },
  260. refresh: function(){
  261. this.desktop.refreshApp(this);
  262. },
  263. close: function(){
  264. this.fireAppEvent("queryClose");
  265. this.setUncurrent();
  266. if (this.inBrowser){
  267. window.close();
  268. }else{
  269. this.window.close(function(){
  270. this.taskitem.destroy();
  271. delete this.window;
  272. delete this.taskitem;
  273. this.desktop.closeApp(this);
  274. this.fireAppEvent("postClose");
  275. //MWF.recycleCount = 0;
  276. //debugger;
  277. MWF.release(this);
  278. //
  279. //alert(MWF.recycleCount)
  280. //debugger;
  281. }.bind(this));
  282. }
  283. },
  284. setTitle: function(str){
  285. this.options.title = str;
  286. this.window.titleText.set("text", str);
  287. if (this.taskitem){
  288. this.taskitem.textNode.set("text", str);
  289. this.taskitem.node.set("title", str+"-"+this.appId);
  290. }
  291. },
  292. //application事件
  293. onQueryLoad: function(){},
  294. onQueryLoadWindow: function(){},
  295. onLoadWindow: function(){},
  296. onPostLoadWindow: function(){},
  297. onQueryLoadApplication: function(){},
  298. onPostLoadApplication: function(){},
  299. onPostLoad: function(){},
  300. onResize: function(){},
  301. onQueryClose: function(){},
  302. onPostClose: function(){},
  303. onQueryMinSize: function(){},
  304. onPostMinSize: function(){},
  305. onQueryMaxSize: function(){},
  306. onPostMaxSize: function(){},
  307. onQueryRestoreSize: function(){},
  308. onPostRestoreSize: function(){},
  309. dialog: function(options){
  310. MWF.require("MWF.xDesktop.Dialog", function(){
  311. options.markNode = this.content;
  312. var dlg = new MWF.xDesktop.Dialog(options);
  313. dlg.show();
  314. }.bind(this));
  315. },
  316. notice: function(content, type, target, where, offset){
  317. if (!where) where = {"x": "right", "y": "top"};
  318. if (!target) target = this.window.content;
  319. if (!type) type = "ok";
  320. var noticeTarget = target || layout.layout.contentNode;
  321. var off = offset;
  322. if (!off){
  323. off = {
  324. x: 10,
  325. y: where.y.toString().toLowerCase()=="bottom" ? 10 : 10
  326. };
  327. }
  328. new mBox.Notice({
  329. type: type,
  330. position: where,
  331. move: false,
  332. target: noticeTarget,
  333. delayClose: (type=="error") ? 10000 : 5000,
  334. offset: off,
  335. content: content
  336. });
  337. },
  338. confirm: function(type, e, title, text, width, height, ok, cancel, callback, mask, style){
  339. MWF.require("MWF.xDesktop.Dialog", function(){
  340. var size = this.content.getSize();
  341. var x = 0;
  342. var y = 0;
  343. debugger;
  344. if (typeOf(e)=="element"){
  345. var position = e.getPosition(this.content);
  346. x = position.x;
  347. y = position.y;
  348. }else{
  349. if (Browser.name=="firefox"){
  350. x = parseFloat(e.event.clientX);
  351. y = parseFloat(e.event.clientY);
  352. }else{
  353. x = parseFloat(e.event.x);
  354. y = parseFloat(e.event.y);
  355. }
  356. if (e.target){
  357. var position = e.target.getPosition(this.content);
  358. x = position.x;
  359. y = position.y;
  360. }
  361. // }
  362. }
  363. if (x+parseFloat(width)>size.x){
  364. x = x-parseFloat(width);
  365. }
  366. if (x<0) x = 0;
  367. if (y+parseFloat(height)>size.y){
  368. y = y-parseFloat(height);
  369. }
  370. if (y<0) y = 0;
  371. var ctext = "";
  372. var chtml = "";
  373. if (typeOf(text).toLowerCase()=="object"){
  374. ctext = text.text;
  375. chtml = text.html;
  376. }else{
  377. ctext = text;
  378. }
  379. var dlg = new MWF.xDesktop.Dialog({
  380. "title": title,
  381. "style": style || "flat",
  382. "top": y,
  383. "left": x-20,
  384. "fromTop":y,
  385. "fromLeft": x-20,
  386. "width": width,
  387. "height": height,
  388. "text": ctext,
  389. "html": chtml,
  390. "container": this.content,
  391. "maskNode": mask,
  392. "buttonList": [
  393. {
  394. "text": MWF.LP.process.button.ok,
  395. "action": ok
  396. },
  397. {
  398. "text": MWF.LP.process.button.cancel,
  399. "action": cancel
  400. }
  401. ]
  402. });
  403. switch (type.toLowerCase()){
  404. case "success":
  405. dlg.content.setStyle("background-image", "url()");
  406. break;
  407. case "error":
  408. dlg.content.setStyle("background-image", "url()");
  409. break;
  410. case "info":
  411. dlg.content.setStyle("background-image", "url()");
  412. break;
  413. case "warn":
  414. dlg.content.setStyle("background-image", "url()");
  415. break;
  416. default:
  417. //dlg.content.setStyle("background-image", "");
  418. }
  419. dlg.show();
  420. if (callback) callback(dlg);
  421. }.bind(this));
  422. },
  423. alert: function(type, e, title, text, width, height){
  424. MWF.require("MWF.widget.Dialog", function(){
  425. var size = $(document.body).getSize();
  426. var x = parseFloat(e.event.x);
  427. var y = parseFloat(e.event.y);
  428. if (Browser.name=="firefox"){
  429. x = parseFloat(e.event.clientX);
  430. y = parseFloat(e.event.clientY);
  431. }
  432. x = x - parseFloat(width)/2;
  433. y = y - parseFloat(height)/2;
  434. if (x+parseFloat(width)>size.x){
  435. x = x-parseFloat(width);
  436. }
  437. var dlg = new MWF.DL({
  438. "title": title,
  439. "style": "chart",
  440. "top": y,
  441. "left": x,
  442. "fromTop":y,
  443. "fromLeft": (Browser.name=="firefox") ? e.event.clientX : e.event.x,
  444. "width": width,
  445. "height": height,
  446. "text": text,
  447. "buttonList": [
  448. {
  449. "text": MWF.LP.process.button.ok,
  450. "action": function(){
  451. this.close();
  452. }
  453. }
  454. ]
  455. });
  456. switch (type.toLowerCase()){
  457. case "success":
  458. dlg.content.setStyle("background-image", "url()");
  459. break;
  460. case "error":
  461. dlg.content.setStyle("background-image", "url()");
  462. break;
  463. case "info":
  464. dlg.content.setStyle("background-image", "url()");
  465. break;
  466. case "warn":
  467. dlg.content.setStyle("background-image", "url()");
  468. break;
  469. default:
  470. }
  471. dlg.show();
  472. }.bind(this));
  473. }
  474. });