Main.js 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763
  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. if (this.options.mvcStyle) this.stylePath = this.path + this.options.style + "/" + this.options.mvcStyle;
  64. if (!this.options.mvcStyle) this._loadCss();
  65. },
  66. fireAppEvent: function (when) {
  67. this.fireEvent(when);
  68. if (this[("on-" + when).camelCase()]) this[("on-" + when).camelCase()]();
  69. // if (this[("on-"+when).camelCase()+"Events"){
  70. // this[("on-"+when).camelCase()+"Events".each(function(event){
  71. // event.apply(this);
  72. // }.bind(this));
  73. // }
  74. },
  75. loadNoAnimation: function (isCurrent, max, hide) {
  76. this.fireAppEvent("queryLoad");
  77. if (!this.inBrowser) {
  78. if (layout.viewMode==="Homepage"){
  79. this.loadWindowFlat(isCurrent);
  80. }else{
  81. this.loadWindow(isCurrent, false, max, hide);
  82. }
  83. } else {
  84. this.loadInBrowser(isCurrent);
  85. }
  86. },
  87. load: function (isCurrent, content) {
  88. this.fireAppEvent("queryLoad");
  89. if (!this.inBrowser) {
  90. if (layout.viewMode==="Default"){
  91. this.loadWindowFlat(isCurrent);
  92. }else{
  93. this.loadWindow(isCurrent);
  94. }
  95. } else {
  96. this.loadInBrowser(content);
  97. }
  98. },
  99. loadApplication: function (callback) {
  100. if (callback) callback();
  101. },
  102. loadWindow: function (isCurrent, animation, max, hide) {
  103. this.fireAppEvent("queryLoadWindow");
  104. var options = {
  105. "style": "desktop_" + this.desktop.options.style,
  106. "title": this.options.title,
  107. "isResize": this.options.isResize,
  108. "isMax": this.options.isMax,
  109. "isRefresh": this.options.isWindowRefresh,
  110. "container": this.desktop.node,
  111. "onPostShow": function () {
  112. if (isCurrent) this.setCurrent();
  113. this.fireAppEvent("postLoadWindow");
  114. this.fireAppEvent("queryLoadApplication");
  115. //load css
  116. if (this.stylePath) {
  117. this.content.loadCss(this.stylePath, this.loadWindowApplication.bind(this));
  118. }else{
  119. this.loadWindowApplication();
  120. }
  121. }.bind(this),
  122. "onResize": function () {
  123. this.window.options.title = this.options.title;
  124. this.window.getTitle();
  125. this.fireAppEvent("resize");
  126. }.bind(this),
  127. "onResizeCompleted": function () {
  128. this.fireAppEvent("resizeCompleted");
  129. }.bind(this),
  130. "onMoveDrop": function (e) {
  131. if (Browser.name == "firefox") {
  132. if (e.event.clientX < 0 || e.event.clientY < 0) this.openInNewBrowser();
  133. } else {
  134. if (e.event.x < 0 || e.event.y < 0) this.openInNewBrowser();
  135. }
  136. }.bind(this)
  137. };
  138. if (this.options.event) {
  139. options.fromTop = this.options.event.page.y;
  140. options.fromLeft = this.options.event.page.x;
  141. }
  142. options.width = this.options.width || options.width;
  143. options.height = this.options.height || options.height;
  144. this.window = new MWF.xDesktop.Window(this, options);
  145. this.fireAppEvent("loadWindow");
  146. //this.maxSize();
  147. this.content = this.window.content;
  148. if (animation === false) {
  149. this.window.showNoAnimation(max, hide);
  150. } else {
  151. this.window.show();
  152. }
  153. },
  154. loadWindowApplication: function(){
  155. this.setContentEvent();
  156. this.loadApplication(function () {
  157. this.fireAppEvent("postLoadApplication");
  158. }.bind(this));
  159. this.fireAppEvent("postLoad");
  160. },
  161. loadWindowFlat: function (isCurrent) {
  162. this.window = {
  163. "app": this,
  164. "isHide": false,
  165. "isMax": true,
  166. "maxSize": function () { },
  167. "restore": function () { },
  168. "setCurrent": function () {
  169. //this.content.show();
  170. this.window.node.removeClass("layout_component_node_hide");
  171. this.window.node.addClass("layout_component_node_show");
  172. //this.window.node.fade("in");
  173. }.bind(this),
  174. "setUncurrent": function () {
  175. //this.content.hide();
  176. this.window.node.addClass("layout_component_node_hide");
  177. this.window.node.removeClass("layout_component_node_show");
  178. //this.window.node.fade("out");
  179. }.bind(this),
  180. "hide": function () { },
  181. "maxOrRestoreSize": function () { },
  182. "restoreSize": function () { },
  183. "close": function (callback) {
  184. this.content.destroy();
  185. if (callback) callback();
  186. }.bind(this)
  187. };
  188. this.window.node = new Element("div.layout_component_node").inject(layout.desktop.contentNode);
  189. this.window.content = new Element("div.layout_component_content").inject(this.window.node);
  190. this.content = this.window.content;
  191. //this.window.setUncurrent();
  192. this.resizeFun = function(){
  193. this.fireAppEvent("resize");
  194. }.bind(this);
  195. layout.desktop.addEvent("resize", this.resizeFun);
  196. // window.addEventListener("beforeunload", function (e) {
  197. // this.fireAppEvent("queryClose");
  198. // }.bind(this));
  199. // window.addEventListener("pagehide", function (e) {
  200. // this.fireAppEvent("queryClose");
  201. // }.bind(this));
  202. if (isCurrent){
  203. this.setCurrent();
  204. }else{
  205. this.setUncurrent();
  206. }
  207. this.fireAppEvent("postLoadWindow");
  208. this.fireAppEvent("queryLoadApplication");
  209. //load css
  210. if (this.stylePath) {
  211. this.content.loadCss(this.stylePath, this.loadWindowApplication.bind(this));
  212. }else{
  213. this.loadWindowApplication();
  214. }
  215. },
  216. loadInBrowser: function (content) {
  217. this.window = {
  218. "isHide": false,
  219. "isMax": true,
  220. "maxSize": function () { },
  221. "restore": function () { },
  222. "setCurrent": function () {},
  223. "setUncurrent": function () {},
  224. "hide": function () { },
  225. "maxOrRestoreSize": function () { },
  226. "restoreSize": function () { },
  227. "close": function () { }
  228. };
  229. this.window.titleText = $(document.head).getElement("title");
  230. try {
  231. this.window.titleText.set("text", this.options.title);
  232. } catch (e) { }
  233. this.window.content = content;
  234. if (!this.window.content) this.window.content = $("appContent") || $("layout");
  235. if (!this.window.content) {
  236. this.window.content = new Element("div", {"styles": {"width": 0, "height": 0}}).inject(document.body);
  237. }
  238. this.content = this.window.content;
  239. //this.content.setStyles({"height": "100%", "overflow": "hidden"});
  240. window.addEvent("resize", function () {
  241. this.fireAppEvent("resize");
  242. }.bind(this));
  243. // $(document.body).addEvent("resize", function(){
  244. // debugger;
  245. // this.fireAppEvent("resize");
  246. // }.bind(this));
  247. window.addEventListener("beforeunload", function (e) {
  248. this.fireAppEvent("queryClose");
  249. }.bind(this));
  250. window.addEventListener("pagehide", function (e) {
  251. this.fireAppEvent("queryClose");
  252. }.bind(this));
  253. // window.onbeforeunload = function(e){
  254. // this.fireAppEvent("queryClose");
  255. // }.bind(this);
  256. this.fireAppEvent("postLoadWindow");
  257. this.fireAppEvent("queryLoadApplication");
  258. this.setContentEvent();
  259. if (this.stylePath) o2.loadCss(this.stylePath);
  260. this.loadApplication(function () {
  261. this.fireAppEvent("postLoadApplication");
  262. }.bind(this));
  263. //this.content.setStyle("height", document.body.getSize().y);
  264. this.fireAppEvent("postLoad");
  265. },
  266. openInNewBrowser: function (noClose) {
  267. this.desktop.openBrowserApp = this.options.name;
  268. this.desktop.openBrowserStatus = (this.recordStatus) ? this.recordStatus() : null;
  269. var status = (this.desktop.openBrowserStatus) ? JSON.encode(this.desktop.openBrowserStatus) : "";
  270. var url = "app.html?app=" + this.options.name + "&status=" + status;
  271. window.open(url, "_blank");
  272. if (!this.inBrowser) if (!noClose) this.close();
  273. },
  274. openInNewWindow: function () {
  275. this.desktop.openBrowserApp = this.options.name;
  276. this.desktop.openBrowserStatus = (this.recordStatus) ? this.recordStatus() : null;
  277. window.open("app.html", "_blank");
  278. if (!this.inBrowser) this.close();
  279. },
  280. setContentEvent: function () {
  281. // this.content.addEvents({
  282. // "resize": function(){
  283. // if (this.onResize) this.onResize();
  284. // }.bind(this)
  285. // });
  286. },
  287. setCurrent: function () {
  288. if (this.desktop.currentApp == this) return true;
  289. if (this.desktop.currentApp) {
  290. this.desktop.currentApp.setUncurrent();
  291. }
  292. // if (layout.viewMode=="Default" && !this.isLoadApplication){
  293. // this.isLoadApplication = true;
  294. // this.load(true);
  295. // } else {
  296. this.window.setCurrent();
  297. if (this.window.isHide) {
  298. if (this.window.isMax) {
  299. this.window.maxSize(function () { this.fireAppEvent("current"); }.bind(this));
  300. } else {
  301. this.window.restore(function () { this.fireAppEvent("current"); }.bind(this));
  302. }
  303. } else {
  304. this.fireAppEvent("current");
  305. }
  306. if (this.taskitem) this.taskitem.selected();
  307. this.desktop.currentApp = this;
  308. this.desktop.appCurrentList.erase(this);
  309. this.desktop.appCurrentList.push(this);
  310. //}
  311. },
  312. setUncurrent: function () {
  313. if (this.desktop.currentApp == this) {
  314. this.window.setUncurrent();
  315. this.taskitem.unSelected();
  316. this.desktop.currentApp = null;
  317. this.fireAppEvent("uncurrent");
  318. }else{
  319. this.window.setUncurrent();
  320. this.taskitem.unSelected();
  321. }
  322. },
  323. minSize: function () {
  324. this.fireAppEvent("queryMinSize");
  325. var p = this.taskitem.node.getPosition();
  326. this.setUncurrent();
  327. this.window.hide(p.x, p.y, function () {
  328. this.fireAppEvent("postMinSize");
  329. }.bind(this));
  330. },
  331. _minSize: function () {
  332. var p = this.taskitem.node.getPosition();
  333. this.setUncurrent();
  334. this.window.hide(p.x, p.y);
  335. },
  336. maxOrRestoreSize: function () {
  337. var max = true;
  338. if (this.window.isMax) max = false;
  339. this.fireAppEvent((max) ? "queryMaxSize" : "queryRestoreSize");
  340. this.window.maxOrRestoreSize(function () {
  341. this.fireAppEvent((max) ? "postMaxSize" : "postRestoreSize");
  342. }.bind(this));
  343. },
  344. maxSize: function (callback) {
  345. if (!this.window.isMax) {
  346. this.fireAppEvent("queryMaxSize");
  347. this.window.maxSize(function () {
  348. this.fireAppEvent("postMaxSize");
  349. if (callback) callback();
  350. }.bind(this));
  351. } else {
  352. if (callback) callback();
  353. }
  354. },
  355. _maxSize: function (callback) {
  356. this.window.maxSize();
  357. },
  358. restoreSize: function (callback) {
  359. this.fireAppEvent("queryRestoreSize");
  360. this.window.restoreSize(function () {
  361. this.fireAppEvent("postRestoreSize");
  362. if (callback) callback();
  363. }.bind(this));
  364. },
  365. _restoreSize: function (callback) {
  366. this.window.restoreSize();
  367. },
  368. refresh: function () {
  369. this.desktop.refreshApp(this);
  370. },
  371. close: function (hasTaskitem) {
  372. if (this.inBrowser) {
  373. window.close();
  374. } else {
  375. this.fireAppEvent("queryClose");
  376. this.setUncurrent();
  377. this.window.close(function () {
  378. if (!hasTaskitem) this.taskitem.destroy();
  379. this.window = null;
  380. this.taskitem = null;
  381. if (this.resizeFun) layout.desktop.removeEvent("resize", this.resizeFun);
  382. this.desktop.closeApp(this, hasTaskitem);
  383. this.fireAppEvent("postClose");
  384. o2.release(this);
  385. }.bind(this));
  386. }
  387. },
  388. setTitle: function (str) {
  389. try {
  390. if (this.taskitem) {
  391. this.taskitem.textNode.set("text", str);
  392. this.taskitem.node.set("title", str + ((this.appId) ? "-" + this.appId : ""));
  393. this.taskitem.setTaskitemSize();
  394. }
  395. this.options.title = str;
  396. this.window.titleText.set("text", str);
  397. } catch (e) { }
  398. },
  399. loading: function(){
  400. // if (this.taskitem){
  401. // if (this.taskitem.refreshNode) this.taskitem.refreshNode.addClass("icon_taskLoading");
  402. // }
  403. // this.loadingNode = new Element("div", {
  404. // "styles": {
  405. // "height": "100%",
  406. // "width": "100%",
  407. // "overflow": "auto",
  408. // "position": "absolute",
  409. // "top": "0px",
  410. // "left": "0px",
  411. // "background-repeat": "no-repeat",
  412. // "background-position": "center"
  413. // }
  414. // }).inject(this.content);
  415. // this.loadingNode.addClass("icon_loading");
  416. },
  417. unLoading: function(){
  418. // if (this.taskitem){
  419. // if (this.taskitem.refreshNode) this.taskitem.refreshNode.removeClass("icon_taskLoading");
  420. // }
  421. // if (this.loadingNode) this.loadingNode.destroy();
  422. },
  423. //application事件
  424. onQueryLoad: function () { },
  425. onQueryLoadWindow: function () { },
  426. onLoadWindow: function () { },
  427. onPostLoadWindow: function () { },
  428. onQueryLoadApplication: function () { },
  429. onPostLoadApplication: function () { },
  430. onPostLoad: function () { },
  431. onResize: function () { },
  432. onQueryClose: function () { },
  433. onPostClose: function () { },
  434. onQueryMinSize: function () { },
  435. onPostMinSize: function () { },
  436. onQueryMaxSize: function () { },
  437. onPostMaxSize: function () { },
  438. onQueryRestoreSize: function () { },
  439. onPostRestoreSize: function () { },
  440. dialog: function (options) {
  441. MWF.require("MWF.xDesktop.Dialog", function () {
  442. options.markNode = this.content;
  443. var dlg = new MWF.xDesktop.Dialog(options);
  444. dlg.show();
  445. }.bind(this));
  446. },
  447. notice: function (content, type, target, where, offset) {
  448. if (window.mBox){
  449. if (!where) where = { "x": "right", "y": "top" };
  450. if (!target) target = this.content;
  451. if (!target) target = this.window.content;
  452. if (!type) type = "ok";
  453. var noticeTarget = target || layout.layout.contentNode;
  454. var off = offset;
  455. if (!off) {
  456. off = {
  457. x: 10,
  458. y: where.y.toString().toLowerCase() == "bottom" ? 10 : 10
  459. };
  460. }
  461. new mBox.Notice({
  462. type: type,
  463. position: where,
  464. move: false,
  465. target: noticeTarget,
  466. delayClose: (type == "error") ? 10000 : 5000,
  467. offset: off,
  468. content: content
  469. });
  470. }
  471. },
  472. confirm: function (type, e, title, text, width, height, ok, cancel, callback, mask, style) {
  473. MWF.require("MWF.xDesktop.Dialog", function () {
  474. var content = layout.mobile ? $(document.body) : this.content;
  475. var size = content.getSize();
  476. var x = 0;
  477. var y = 0;
  478. if (layout.mobile) {
  479. if (parseFloat(width) > size.x) {
  480. width = size.x - 40;
  481. x = 40;
  482. } else {
  483. x = (size.x - parseFloat(width)) / 2;
  484. }
  485. if (parseFloat(height) > size.y) {
  486. y = 0;
  487. } else {
  488. y = (size.y - parseFloat(height)) / 2;
  489. }
  490. } else {
  491. if (typeOf(e) == "element") {
  492. var position = e.getPosition(content);
  493. x = position.x;
  494. y = position.y;
  495. } else {
  496. if (Browser.name == "firefox") {
  497. x = parseFloat(e.event.clientX || e.event.x);
  498. y = parseFloat(e.event.clientY || e.event.y);
  499. } else {
  500. x = parseFloat(e.event.x);
  501. y = parseFloat(e.event.y);
  502. }
  503. if (e.target) {
  504. var position = e.target.getPosition(content);
  505. x = position.x;
  506. y = position.y;
  507. }
  508. }
  509. if (x + parseFloat(width) > size.x) {
  510. x = x - parseFloat(width);
  511. }
  512. if (x < 0) x = 0;
  513. if (y + parseFloat(height) > size.y) {
  514. y = y - parseFloat(height);
  515. }
  516. if (y < 0) y = 0;
  517. }
  518. var ctext = "";
  519. var chtml = "";
  520. if (typeOf(text).toLowerCase() == "object") {
  521. ctext = text.text;
  522. chtml = text.html;
  523. } else {
  524. ctext = text;
  525. }
  526. // var tmp = new Element("div", {"overflow": "hidden","padding": "10px", "padding-left": "60px", "width": ""+width+"px"}).inject(document.body);
  527. // if (chtml) tmp.set("html", chtml);
  528. // if (ctext) tmp.set("text", ctext);
  529. // height = tmp.getSize().y;
  530. // tmp.destroy();
  531. var dlg = new MWF.xDesktop.Dialog({
  532. "title": title,
  533. "style": style || "o2",
  534. "top": y,
  535. "left": x - 20,
  536. "fromTop": y,
  537. "fromLeft": x - 20,
  538. "width": width,
  539. "height": height,
  540. "text": ctext,
  541. "html": chtml,
  542. "container": content,
  543. "mark": (mask) ? true : false,
  544. "maskNode": mask || content,
  545. "buttonList": [
  546. {
  547. "type": "ok",
  548. "text": MWF.LP.process.button.ok,
  549. "action": ok
  550. },
  551. {
  552. "type": "cancel",
  553. "text": MWF.LP.process.button.cancel,
  554. "action": cancel
  555. }
  556. ]
  557. });
  558. switch (type.toLowerCase()) {
  559. case "success":
  560. dlg.content.setStyle("background-image", "url()");
  561. break;
  562. case "error":
  563. dlg.content.setStyle("background-image", "url()");
  564. break;
  565. case "info":
  566. dlg.content.setStyle("background-image", "url()");
  567. break;
  568. case "warn":
  569. dlg.content.setStyle("background-image", "url()");
  570. break;
  571. default:
  572. //dlg.content.setStyle("background-image", "");
  573. }
  574. dlg.show();
  575. if (callback) callback(dlg);
  576. }.bind(this));
  577. },
  578. dlg: function (type, e, title, text, width, height, actions, mask, style) {
  579. MWF.require("MWF.xDesktop.Dialog", function () {
  580. var size = this.content.getSize();
  581. var p = (e) ? MWF.getEPointer(e) : MWF.getCenter({ "x": width, "y": height }, this.content, this.content);
  582. var x = p.x || 0;
  583. var y = p.y || 0;
  584. if (x + parseFloat(width) > size.x) {
  585. x = x - parseFloat(width);
  586. }
  587. if (x < 0) x = 0;
  588. if (y + parseFloat(height) > size.y) {
  589. y = y - parseFloat(height);
  590. }
  591. if (y < 0) y = 0;
  592. var ctext = "";
  593. var chtml = "";
  594. if (typeOf(text).toLowerCase() === "object") {
  595. ctext = text.text;
  596. chtml = text.html;
  597. } else {
  598. ctext = text;
  599. }
  600. var dlg = new MWF.xDesktop.Dialog({
  601. "title": title,
  602. "style": style || "o2",
  603. "top": y,
  604. "left": x - 20,
  605. "fromTop": y,
  606. "fromLeft": x - 20,
  607. "width": width,
  608. "height": height,
  609. "text": ctext,
  610. "html": chtml,
  611. "container": this.content,
  612. "mark": (mask) ? true : false,
  613. "maskNode": mask || this.content,
  614. "buttonList": actions
  615. });
  616. switch (type.toLowerCase()) {
  617. case "success":
  618. dlg.content.setStyle("background-image", "url()");
  619. break;
  620. case "error":
  621. dlg.content.setStyle("background-image", "url()");
  622. break;
  623. case "info":
  624. dlg.content.setStyle("background-image", "url()");
  625. break;
  626. case "warn":
  627. dlg.content.setStyle("background-image", "url()");
  628. break;
  629. default:
  630. }
  631. dlg.show();
  632. }.bind(this));
  633. },
  634. alert: function (type, e, title, text, width, height) {
  635. MWF.require("MWF.widget.Dialog", function () {
  636. var size = $(document.body).getSize();
  637. debugger;
  638. var x = 0, y = 0;
  639. if (e === "center") {
  640. var p = o2.getCenterPosition(this.content, width, height);
  641. x = p.x;
  642. y = p.y;
  643. } else {
  644. x = parseFloat(e.event.x);
  645. y = parseFloat(e.event.y);
  646. if (Browser.name == "firefox") {
  647. x = parseFloat(e.event.clientX);
  648. y = parseFloat(e.event.clientY);
  649. }
  650. x = x - parseFloat(width) / 2;
  651. y = y - parseFloat(height) / 2;
  652. }
  653. if (x + parseFloat(width) > size.x) {
  654. x = x - parseFloat(width);
  655. }
  656. if (x < 0) x = 0;
  657. if (y + parseFloat(height) > size.y) {
  658. y = y - parseFloat(height);
  659. }
  660. if (y < 0) y = 0;
  661. var ctext = "";
  662. var chtml = "";
  663. if (typeOf(text).toLowerCase() == "object") {
  664. ctext = text.text;
  665. chtml = text.html;
  666. } else {
  667. ctext = text;
  668. }
  669. var dlg = new MWF.DL({
  670. "title": title,
  671. "style": "o2",
  672. "top": y,
  673. "left": x,
  674. "fromTop": y,
  675. "fromLeft": x,
  676. "width": width,
  677. "height": height,
  678. "text": ctext,
  679. "html": chtml,
  680. "maskNode": this.content,
  681. "container": this.content,
  682. "buttonList": [
  683. {
  684. "text": MWF.LP.process.button.ok,
  685. "action": function () {
  686. this.close();
  687. }
  688. }
  689. ]
  690. });
  691. switch (type.toLowerCase()) {
  692. case "success":
  693. dlg.content.setStyle("background-image", "url()");
  694. break;
  695. case "error":
  696. dlg.content.setStyle("background-image", "url()");
  697. break;
  698. case "info":
  699. dlg.content.setStyle("background-image", "url()");
  700. break;
  701. case "warn":
  702. dlg.content.setStyle("background-image", "url()");
  703. break;
  704. default:
  705. }
  706. dlg.show();
  707. }.bind(this));
  708. }
  709. });