diff --git a/Inquirer.js b/Inquirer.js index cfc426d..0fa2b65 100644 --- a/Inquirer.js +++ b/Inquirer.js @@ -24,7 +24,9 @@ var icon = "", // bugico = "", // - VERSION = "0.7c"; // + VERSION = "0.7c",// + alertIcon + ; // // Locals var inq = this, inqapp; @@ -109,15 +111,15 @@ inqapp = merger.app("inquirer", { title: "Inquirer", icon: icon, - // appMenu: [ - // merger.ui.menuItem("app_close", { - // text: "Close", - // icon: merger.media.closeIcon(), - // onClick: function () { - // merger.leave(); - // } - // }), - // ], + appMenu: [ + merger.ui.menuItem("app_preferences", { + text: "Preferences...", + icon: merger.media.createIcon('#EEE', '⚒'), + onClick: function () { + this.getApp().windows.wPref.show(); + } + }), + ], menu: [ merger.ui.menuItem("app_tools", { text: "Tools", @@ -362,12 +364,58 @@ for (k in arguments) this.log('e', arguments[k]); } - })], + }), + merger.ui.window("wPref", { + title: "Preferences", + width: 175, + height: 100, + visible: false, + content: [ + merger.ui.checkbox("pref_autoshow", { + top: 0, + left: 3, + }), + merger.ui.label("pref_autoshow_lbl", { + top: 0, + left: 20, + text: "Open Inquirer on error" + }), + merger.ui.checkbox("pref_erricon", { + top: 15, + left: 3, + }), + merger.ui.label("pref_erricon_lbl", { + top: 15, + left: 20, + text: "Show small error indicator" + }), + merger.ui.button("pref_save", { + top: 80, + left: 150, + text: "Ok", + onClick: function () { + inq.autoShow = this.getWindow().content.pref_autoshow.checked; + inq.alertIcon = this.getWindow().content.pref_erricon.checked; + this.getWindow().close(); + } + }), + ], + onShow: function () { + this.getWindow().content.pref_autoshow.checked = inq.autoShow; + this.getWindow().content.pref_erricon.checked = inq.alertIcon; + } + }), + ], onLoad: function () { }, onAbout: function () { merger.dialogs.messageBox(this, "Inquirer v" + VERSION + " ©2016-2017 XWolf Override.
Debugger application layer for web pages. Useful for embedded browser debugging", "About Inquirer", null, this.icon, 100); }, + onFocus: function () { + removeIcon(); + if (!inq.autoShow) + this.windows.Wconsole.show(); + }, showError: function (err) { if (err instanceof Error) { this.windows.Wmain.setError(err.message, err.stack); @@ -383,6 +431,37 @@ return inqapp; } + /** + * Show a small yellow mark to indicate some error has been happend + */ + function showIcon() { + if (!alertIcon) { + alertIcon = document.createElement("DIV"); + alertIcon.style.merge({ + position: "absolute", + top: "0px", + right: "3px", + width: "2px", + height: "1px", + background: "gold", + borderBottom: "goldenRod", + }); + document.body.appendChild(alertIcon); + } + alertIcon.style.display = ""; + } + + /** + * Hides a small yellow mark to indicate some error has been happend + */ + function removeIcon() { + if (!alertIcon) + return; + alertIcon.style.display = "none"; + } + + // === Public members + function show() { getApp().show(); } @@ -458,6 +537,9 @@ getApp().showError(error); show(); } + if (this.alertIcon) { + showIcon(); + } } function inspect(object) { @@ -476,7 +558,8 @@ // Publish this.merge({ version: VERSION, - autoShow: true, // Open Inquirer environment when a new unhandled error happen + autoShow: false, // Open Inquirer environment when a new unhandled error happen + alertIcon: true, // Small icon on screen to indicate if there is any new error show: show, // Enters environment hide: hide, // Exit environent hook: hook, // Hook the webpage to control errors (Automatically hooked) diff --git a/Merger.js b/Merger.js index 302c855..7c65b34 100644 --- a/Merger.js +++ b/Merger.js @@ -28,7 +28,7 @@ sys = { // Configuration _type: "system", icon: "", - ver: "0.3c", + ver: "0.3d", color: { frame: "teal", //"orange" client: "white", @@ -182,15 +182,22 @@ function enterDesktop() { if (!selectedApp) { switchApplication(); + } else { + if (!insideDesktop() && selectedApp.onFocus) + selectedApp.onFocus(); } document.body.appendChild(getDesktop()); } /** Close desktop */ function leaveDesktop() { - var desktop = getDesktop(); - if (document.body.contains(desktop)) - document.body.removeChild(desktop); + if (insideDesktop()) + document.body.removeChild(getDesktop()); + } + + /** Return true if the desktop is present */ + function insideDesktop() { + return document.body.contains(getDesktop()); } /** Create application */ @@ -213,6 +220,11 @@ m.style.display = "inline-block"; m._root = true; } + if (a.appMenu) + for (i = 0; i < a.appMenu.length; i++) { + var m = a.appMenu[i]; + m.application = m.parentControl = a; + } if (a.onLoad) a.onLoad(); return a; @@ -238,8 +250,11 @@ for (i in selectedApp.windows) core.getDesktop().removeChild(selectedApp.windows[i]); selectedApp = a; + if (a.onFocus) + a.onFocus(); menu.sysMenu.setIcon(a.icon ? a.icon : sys.icon); menu.sysMenu.setText(a.title ? a.title : a.id); + menu.sysMenu.application = a; menu.sysMenu.items = []; menu.sysMenu.items.push( m = merger.ui.menuItem("sys_about", { @@ -271,9 +286,9 @@ m.parentControl = menu.sysMenu; } } + menu.sysMenu.items.push(m = menuSeparator("sys_applications_separator2")); // Application appMenu if (a.appMenu && a.appMenu.length > 0) { - menu.sysMenu.items.push(m = menuSeparator("sys_applications_separator2")); m.parentControl = menu.sysMenu; for (i in a.appMenu) { menu.sysMenu.items.push(m = a.appMenu[i]); @@ -407,8 +422,6 @@ MergerApplication.prototype.show = function () { core.enterDesktop(); core.app.focus(this.getId()); - if (this.onEnter) - this.onEnter(); } /** Add window to application */ @@ -576,7 +589,7 @@ if (w) return w.application; while (a && a._type != "app") - a = win.parentControl; + a = a.parentControl; return a; } c.merge = function (def) {