Main.js 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652
  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. (function(){
  9. var removeOn = function(string){
  10. return string.replace(/^on([A-Z])/, function(full, first){
  11. return first.toLowerCase();
  12. });
  13. };
  14. Events.implement({
  15. "fireEvent": function(type, args, delay){
  16. if (this.options && this.options.name && MWF.xDesktop && MWF.xDesktop.$globalEvents){
  17. if (MWF.xDesktop.$globalEvents[this.options.name]){
  18. var evs = MWF.xDesktop.$globalEvents[this.options.name][type];
  19. if (evs){
  20. evs.each(function(fn){
  21. if (delay) fn.delay(delay, this, args);
  22. else fn.apply(this, args);
  23. }, this);
  24. }
  25. }
  26. }
  27. type = removeOn(type);
  28. var events = this.$events[type];
  29. if (!events) return this;
  30. args = Array.convert(args);
  31. events.each(function(fn){
  32. if (delay) fn.delay(delay, this, args);
  33. else fn.apply(this, args);
  34. }, this);
  35. return this;
  36. }
  37. });
  38. })();
  39. MWF.xApplication.Common.Main = new Class({
  40. Extends: MWF.widget.Common,
  41. Implements: [Options, Events],
  42. options: {
  43. "desktopReload": true,
  44. "style": "default",
  45. "name": "Common",
  46. "icon": "", //图标
  47. "title": "", //标题
  48. "event": null,
  49. "width": "800",
  50. "height": "600",
  51. "isResize": true,
  52. "isMax": true,
  53. "setCurrent": true,
  54. "isRefresh": false,
  55. "isWindowRefresh": true
  56. },
  57. initialize: function(desktop, options){
  58. this.setOptions(options);
  59. this.desktop = desktop;
  60. this.path = "/x_component_"+this.options.name.replace(/\./g, "_")+"/$Main/";
  61. this.options.icon = this.path+this.options.style+"/"+this.options.icon;
  62. this.cssPath =this.path+this.options.style+"/css.wcss";
  63. this._loadCss();
  64. },
  65. fireAppEvent: function(when){
  66. this.fireEvent(when);
  67. if (this[("on-"+when).camelCase()]) this[("on-"+when).camelCase()]();
  68. // if (this[("on-"+when).camelCase()+"Events"){
  69. // this[("on-"+when).camelCase()+"Events".each(function(event){
  70. // event.apply(this);
  71. // }.bind(this));
  72. // }
  73. },
  74. loadNoAnimation: function(isCurrent, max, hide){
  75. this.fireAppEvent("queryLoad");
  76. if (!this.inBrowser){
  77. this.loadWindow(isCurrent, false, max, hide);
  78. }else{
  79. this.loadInBrowser(isCurrent);
  80. }
  81. },
  82. load : function(isCurrent){
  83. this.fireAppEvent("queryLoad");
  84. if (!this.inBrowser){
  85. this.loadWindow(isCurrent);
  86. }else{
  87. this.loadInBrowser(isCurrent);
  88. }
  89. },
  90. loadApplication: function(callback){
  91. if (callback) callback();
  92. },
  93. loadWindow: function(isCurrent, animation, max, hide){
  94. this.fireAppEvent("queryLoadWindow");
  95. var options = {
  96. "style": "desktop_"+this.desktop.options.style,
  97. "title": this.options.title,
  98. "isResize": this.options.isResize,
  99. "isMax": this.options.isMax,
  100. "isRefresh": this.options.isWindowRefresh,
  101. "container": this.desktop.node,
  102. "onPostShow": function(){
  103. if (isCurrent) this.setCurrent();
  104. this.fireAppEvent("postLoadWindow");
  105. this.fireAppEvent("queryLoadApplication");
  106. this.setContentEvent();
  107. this.loadApplication(function(){
  108. this.fireAppEvent("postLoadApplication");
  109. }.bind(this));
  110. // var resize = false;
  111. // var size = this.window.node.getSize();
  112. // var position = this.window.node.getPosition();
  113. // var bodySize = $(document.body).getSize();
  114. // var height = size.y;
  115. // var width = size.x;
  116. // var y = (size.y+position.y)-bodySize.y;
  117. // if (y>-10){
  118. // height = size.y-y-10;
  119. // resize = true;
  120. // }
  121. // var x = (size.x+position.x)-bodySize.x;
  122. // if (x>-10){
  123. // width = size.x-x-10;
  124. // resize = true;
  125. // }
  126. // var y = (size.y+position.y)-bodySize.y;
  127. // if (y>0){
  128. // height = size.y-y;
  129. // resize = true;
  130. // }
  131. // var x = (size.x+position.x)-bodySize.x;
  132. // if (x>0){
  133. // width = size.x-x;
  134. // resize = true;
  135. // }
  136. // if (resize){
  137. // this.window.options.height = height;
  138. // this.window.options.width = width;
  139. // this.window.node.setStyles({
  140. // "width": ""+width+"px",
  141. // "height": ""+height+"px"
  142. // });
  143. // this.window.spacer.setStyles({
  144. // "width": ""+width+"px",
  145. // "height": ""+height+"px"
  146. // });
  147. // this.window.setContentSize();
  148. // }
  149. this.fireAppEvent("postLoad");
  150. }.bind(this),
  151. "onResize": function(){
  152. this.window.options.title = this.options.title;
  153. this.window.getTitle();
  154. this.fireAppEvent("resize");
  155. }.bind(this),
  156. "onResizeCompleted": function(){
  157. this.fireAppEvent("resizeCompleted");
  158. }.bind(this),
  159. "onMoveDrop": function(e){
  160. if (Browser.name=="firefox"){
  161. if (e.event.clientX<0 || e.event.clientY<0) this.openInNewBrowser();
  162. }else{
  163. if (e.event.x<0 || e.event.y<0) this.openInNewBrowser();
  164. }
  165. }.bind(this)
  166. // "onQueryMax": function(){
  167. // if (this.window.css.windowTitleMax) this.window.title.setStyles(this.window.css.windowTitleMax);
  168. // if (this.window.css.windowTitleRefreshMax) this.window.titleRefresh.setStyles(this.window.css.windowTitleRefreshMax);
  169. // if (this.window.css.windowTitleTextMax) this.window.titleText.setStyles(this.window.css.windowTitleTextMax);
  170. // if (this.window.css.windowTitleActionMax) this.window.titleAction.setStyles(this.window.css.windowTitleActionMax);
  171. // }.bind(this)
  172. };
  173. if (this.options.event){
  174. options.fromTop = this.options.event.page.y;
  175. options.fromLeft = this.options.event.page.x;
  176. }
  177. options.width = this.options.width || options.width;
  178. options.height = this.options.height || options.height;
  179. this.window = new MWF.xDesktop.Window(this, options);
  180. this.fireAppEvent("loadWindow");
  181. //this.maxSize();
  182. this.content = this.window.content;
  183. if (animation===false){
  184. this.window.showNoAnimation(max, hide);
  185. }else{
  186. this.window.show();
  187. }
  188. },
  189. loadInBrowser: function(){
  190. this.window = {
  191. "isHide": false,
  192. "isMax": true,
  193. "maxSize": function(){},
  194. "restore": function(){},
  195. "setCurrent": function(){},
  196. "hide": function(){},
  197. "maxOrRestoreSize": function(){},
  198. "restoreSize": function(){},
  199. "close": function(){}
  200. };
  201. this.window.titleText = $(document.head).getElement("title");
  202. try{
  203. this.window.titleText.set("text", this.options.title);
  204. }catch(e){}
  205. this.window.content = $("appContent") || $("layout");
  206. this.content = this.window.content;
  207. //this.content.setStyles({"height": "100%", "overflow": "hidden"});
  208. window.addEvent("resize", function(){
  209. this.fireAppEvent("resize");
  210. }.bind(this));
  211. // $(document.body).addEvent("resize", function(){
  212. // debugger;
  213. // this.fireAppEvent("resize");
  214. // }.bind(this));
  215. window.onbeforeunload = function(e){
  216. this.fireAppEvent("queryClose");
  217. }.bind(this);
  218. this.fireAppEvent("postLoadWindow");
  219. this.fireAppEvent("queryLoadApplication");
  220. this.setContentEvent();
  221. this.loadApplication(function(){
  222. this.fireAppEvent("postLoadApplication");
  223. }.bind(this));
  224. //this.content.setStyle("height", document.body.getSize().y);
  225. this.fireAppEvent("postLoad");
  226. },
  227. openInNewBrowser: function(){
  228. this.desktop.openBrowserApp = this.options.name;
  229. this.desktop.openBrowserStatus = (this.recordStatus) ? this.recordStatus() : null;
  230. window.open("app.html", "_blank");
  231. if (!this.inBrowser) this.close();
  232. },
  233. openInNewWindow: function(){
  234. this.desktop.openBrowserApp = this.options.name;
  235. this.desktop.openBrowserStatus = (this.recordStatus) ? this.recordStatus() : null;
  236. window.open("app.html", "_blank");
  237. if (!this.inBrowser) this.close();
  238. },
  239. setContentEvent: function(){
  240. // this.content.addEvents({
  241. // "resize": function(){
  242. // if (this.onResize) this.onResize();
  243. // }.bind(this)
  244. // });
  245. },
  246. setCurrent: function(){
  247. if (this.desktop.currentApp==this) return true;
  248. if (this.desktop.currentApp){
  249. this.desktop.currentApp.setUncurrent();
  250. }
  251. this.window.setCurrent();
  252. if (this.window.isHide){
  253. if (this.window.isMax){
  254. this.window.maxSize(function(){this.fireAppEvent("current");}.bind(this));
  255. }else{
  256. this.window.restore(function(){this.fireAppEvent("current");}.bind(this));
  257. }
  258. }else{
  259. this.fireAppEvent("current");
  260. }
  261. if (this.taskitem) this.taskitem.selected();
  262. this.desktop.currentApp = this;
  263. this.desktop.appCurrentList.erase(this);
  264. this.desktop.appCurrentList.push(this);
  265. },
  266. setUncurrent: function(){
  267. if (this.desktop.currentApp==this){
  268. this.window.setUncurrent();
  269. this.taskitem.unSelected();
  270. this.desktop.currentApp = null;
  271. this.fireAppEvent("uncurrent");
  272. }
  273. },
  274. minSize: function(){
  275. this.fireAppEvent("queryMinSize");
  276. var p = this.taskitem.node.getPosition();
  277. this.setUncurrent();
  278. this.window.hide(p.x, p.y, function(){
  279. this.fireAppEvent("postMinSize");
  280. }.bind(this));
  281. },
  282. _minSize: function(){
  283. var p = this.taskitem.node.getPosition();
  284. this.setUncurrent();
  285. this.window.hide(p.x, p.y);
  286. },
  287. maxOrRestoreSize: function(){
  288. var max = true;
  289. if (this.window.isMax) max = false;
  290. this.fireAppEvent((max) ? "queryMaxSize" : "queryRestoreSize");
  291. this.window.maxOrRestoreSize(function(){
  292. this.fireAppEvent((max) ? "postMaxSize" : "postRestoreSize");
  293. }.bind(this));
  294. },
  295. maxSize: function(callback){
  296. if (!this.window.isMax){
  297. this.fireAppEvent("queryMaxSize");
  298. this.window.maxSize(function(){
  299. this.fireAppEvent("postMaxSize");
  300. if (callback) callback();
  301. }.bind(this));
  302. }else{
  303. if (callback) callback();
  304. }
  305. },
  306. _maxSize: function(callback){
  307. this.window.maxSize();
  308. },
  309. restoreSize: function(callback){
  310. this.fireAppEvent("queryRestoreSize");
  311. this.window.restoreSize(function(){
  312. this.fireAppEvent("postRestoreSize");
  313. if (callback) callback();
  314. }.bind(this));
  315. },
  316. _restoreSize: function(callback){
  317. this.window.restoreSize();
  318. },
  319. refresh: function(){
  320. this.desktop.refreshApp(this);
  321. },
  322. close: function(){
  323. this.fireAppEvent("queryClose");
  324. this.setUncurrent();
  325. if (this.inBrowser){
  326. window.close();
  327. }else{
  328. this.window.close(function(){
  329. this.taskitem.destroy();
  330. delete this.window;
  331. delete this.taskitem;
  332. this.desktop.closeApp(this);
  333. this.fireAppEvent("postClose");
  334. //MWF.recycleCount = 0;
  335. //debugger;
  336. MWF.release(this);
  337. //
  338. //alert(MWF.recycleCount)
  339. //debugger;
  340. }.bind(this));
  341. }
  342. },
  343. setTitle: function(str){
  344. try{
  345. this.options.title = str;
  346. this.window.titleText.set("text", str);
  347. if (this.taskitem){
  348. this.taskitem.textNode.set("text", str);
  349. this.taskitem.node.set("title", str+((this.appId) ? "-"+this.appId : ""));
  350. this.taskitem.setTaskitemSize();
  351. }
  352. }catch(e){}
  353. },
  354. //application事件
  355. onQueryLoad: function(){},
  356. onQueryLoadWindow: function(){},
  357. onLoadWindow: function(){},
  358. onPostLoadWindow: function(){},
  359. onQueryLoadApplication: function(){},
  360. onPostLoadApplication: function(){},
  361. onPostLoad: function(){},
  362. onResize: function(){},
  363. onQueryClose: function(){},
  364. onPostClose: function(){},
  365. onQueryMinSize: function(){},
  366. onPostMinSize: function(){},
  367. onQueryMaxSize: function(){},
  368. onPostMaxSize: function(){},
  369. onQueryRestoreSize: function(){},
  370. onPostRestoreSize: function(){},
  371. dialog: function(options){
  372. MWF.require("MWF.xDesktop.Dialog", function(){
  373. options.markNode = this.content;
  374. var dlg = new MWF.xDesktop.Dialog(options);
  375. dlg.show();
  376. }.bind(this));
  377. },
  378. notice: function(content, type, target, where, offset){
  379. if (!where) where = {"x": "right", "y": "top"};
  380. if (!target) target = this.window.content;
  381. if (!type) type = "ok";
  382. var noticeTarget = target || layout.layout.contentNode;
  383. var off = offset;
  384. if (!off){
  385. off = {
  386. x: 10,
  387. y: where.y.toString().toLowerCase()=="bottom" ? 10 : 10
  388. };
  389. }
  390. new mBox.Notice({
  391. type: type,
  392. position: where,
  393. move: false,
  394. target: noticeTarget,
  395. delayClose: (type=="error") ? 10000 : 5000,
  396. offset: off,
  397. content: content
  398. });
  399. },
  400. confirm: function(type, e, title, text, width, height, ok, cancel, callback, mask, style){
  401. MWF.require("MWF.xDesktop.Dialog", function(){
  402. var size = this.content.getSize();
  403. var x = 0;
  404. var y = 0;
  405. if (typeOf(e)=="element"){
  406. var position = e.getPosition(this.content);
  407. x = position.x;
  408. y = position.y;
  409. }else{
  410. if (Browser.name=="firefox"){
  411. x = parseFloat(e.event.clientX || e.event.x);
  412. y = parseFloat(e.event.clientY || e.event.y);
  413. }else{
  414. x = parseFloat(e.event.x);
  415. y = parseFloat(e.event.y);
  416. }
  417. if (e.target){
  418. var position = e.target.getPosition(this.content);
  419. x = position.x;
  420. y = position.y;
  421. }
  422. // }
  423. }
  424. if (x+parseFloat(width)>size.x){
  425. x = x-parseFloat(width);
  426. }
  427. if (x<0) x = 0;
  428. if (y+parseFloat(height)>size.y){
  429. y = y-parseFloat(height);
  430. }
  431. if (y<0) y = 0;
  432. var ctext = "";
  433. var chtml = "";
  434. if (typeOf(text).toLowerCase()=="object"){
  435. ctext = text.text;
  436. chtml = text.html;
  437. }else{
  438. ctext = text;
  439. }
  440. // var tmp = new Element("div", {"overflow": "hidden","padding": "10px", "padding-left": "60px", "width": ""+width+"px"}).inject(document.body);
  441. // if (chtml) tmp.set("html", chtml);
  442. // if (ctext) tmp.set("text", ctext);
  443. // height = tmp.getSize().y;
  444. // tmp.destroy();
  445. var dlg = new MWF.xDesktop.Dialog({
  446. "title": title,
  447. "style": style || "o2",
  448. "top": y,
  449. "left": x-20,
  450. "fromTop":y,
  451. "fromLeft": x-20,
  452. "width": width,
  453. "height": height,
  454. "text": ctext,
  455. "html": chtml,
  456. "container": this.content,
  457. "mark": (mask) ? true : false,
  458. "maskNode": mask || this.content,
  459. "buttonList": [
  460. {
  461. "text": MWF.LP.process.button.ok,
  462. "action": ok
  463. },
  464. {
  465. "text": MWF.LP.process.button.cancel,
  466. "action": cancel
  467. }
  468. ]
  469. });
  470. switch (type.toLowerCase()){
  471. case "success":
  472. dlg.content.setStyle("background-image", "url()");
  473. break;
  474. case "error":
  475. dlg.content.setStyle("background-image", "url()");
  476. break;
  477. case "info":
  478. dlg.content.setStyle("background-image", "url()");
  479. break;
  480. case "warn":
  481. dlg.content.setStyle("background-image", "url()");
  482. break;
  483. default:
  484. //dlg.content.setStyle("background-image", "");
  485. }
  486. dlg.show();
  487. if (callback) callback(dlg);
  488. }.bind(this));
  489. },
  490. dlg: function(type, e, title, text, width, height, actions, mask, style){
  491. MWF.require("MWF.xDesktop.Dialog", function(){
  492. var size = this.content.getSize();
  493. var p = (e) ? MWF.getEPointer(e) : MWF.getCenter({"x":width, "y": height}, this.content, this.content);
  494. var x = p.x || 0;
  495. var y = p.y || 0;
  496. if (x+parseFloat(width)>size.x){
  497. x = x-parseFloat(width);
  498. }
  499. if (x<0) x = 0;
  500. if (y+parseFloat(height)>size.y){
  501. y = y-parseFloat(height);
  502. }
  503. if (y<0) y = 0;
  504. var ctext = "";
  505. var chtml = "";
  506. if (typeOf(text).toLowerCase()==="object"){
  507. ctext = text.text;
  508. chtml = text.html;
  509. }else{
  510. ctext = text;
  511. }
  512. var dlg = new MWF.xDesktop.Dialog({
  513. "title": title,
  514. "style": style || "o2",
  515. "top": y,
  516. "left": x-20,
  517. "fromTop":y,
  518. "fromLeft": x-20,
  519. "width": width,
  520. "height": height,
  521. "text": ctext,
  522. "html": chtml,
  523. "container": this.content,
  524. "mark": (mask) ? true : false,
  525. "maskNode": mask || this.content,
  526. "buttonList": actions
  527. });
  528. switch (type.toLowerCase()){
  529. case "success":
  530. dlg.content.setStyle("background-image", "url()");
  531. break;
  532. case "error":
  533. dlg.content.setStyle("background-image", "url()");
  534. break;
  535. case "info":
  536. dlg.content.setStyle("background-image", "url()");
  537. break;
  538. case "warn":
  539. dlg.content.setStyle("background-image", "url()");
  540. break;
  541. default:
  542. }
  543. dlg.show();
  544. }.bind(this));
  545. },
  546. alert: function(type, e, title, text, width, height){
  547. MWF.require("MWF.widget.Dialog", function(){
  548. var size = $(document.body).getSize();
  549. var x = parseFloat(e.event.x);
  550. var y = parseFloat(e.event.y);
  551. if (Browser.name=="firefox"){
  552. x = parseFloat(e.event.clientX);
  553. y = parseFloat(e.event.clientY);
  554. }
  555. x = x - parseFloat(width)/2;
  556. y = y - parseFloat(height)/2;
  557. if (x+parseFloat(width)>size.x){
  558. x = x-parseFloat(width);
  559. }
  560. var ctext = "";
  561. var chtml = "";
  562. if (typeOf(text).toLowerCase()=="object"){
  563. ctext = text.text;
  564. chtml = text.html;
  565. }else{
  566. ctext = text;
  567. }
  568. var dlg = new MWF.DL({
  569. "title": title,
  570. "style": "o2",
  571. "top": y,
  572. "left": x,
  573. "fromTop":y,
  574. "fromLeft": (Browser.name=="firefox") ? e.event.clientX : e.event.x,
  575. "width": width,
  576. "height": height,
  577. "text": ctext,
  578. "html": chtml,
  579. "buttonList": [
  580. {
  581. "text": MWF.LP.process.button.ok,
  582. "action": function(){
  583. this.close();
  584. }
  585. }
  586. ]
  587. });
  588. switch (type.toLowerCase()){
  589. case "success":
  590. dlg.content.setStyle("background-image", "url()");
  591. break;
  592. case "error":
  593. dlg.content.setStyle("background-image", "url()");
  594. break;
  595. case "info":
  596. dlg.content.setStyle("background-image", "url()");
  597. break;
  598. case "warn":
  599. dlg.content.setStyle("background-image", "url()");
  600. break;
  601. default:
  602. }
  603. dlg.show();
  604. }.bind(this));
  605. }
  606. });