diff --git a/Inquirer.js b/Inquirer.js index 66fefe2..6604683 100644 --- a/Inquirer.js +++ b/Inquirer.js @@ -24,7 +24,7 @@ var icon = "", // bugico = "", // - VERSION = "0.7c",// + VERSION = "0.7d",// alertIcon ; // @@ -63,7 +63,7 @@ r += "{\n"; for (k in obj) { r += k + ":" + objectResume(obj[k]) + ",\n"; - if (r.length > 500) { + if (r.length > 400) { r += " ..."; break; } @@ -123,7 +123,6 @@ title: "Error", width: wwidth, height: wheight, - visible: false, content: [merger.ui.picture("Iico", { src: bugico, top: 0, @@ -184,30 +183,33 @@ * Get the console window */ function getConsole() { - var wid, win, wwidth = 500, wheight = 350; + var wid, win, wwidth = 300, wheight = 250, inputHeight = 20; wid = "console"; win = getApp().windows[wid]; + if (document.body.scrollWidth) + wwidth = Math.max(wwidth, document.body.scrollWidth - 200); + if (document.body.scrollHeight) + wheight = Math.max(wheight, document.body.scrollHeight - 150); if (!win) { win = merger.ui.window(wid, { title: "Console", width: wwidth, height: wheight, - visible: false, content: [ merger.ui.html("Hconsole", { top: 0, left: 0, width: wwidth, - height: wheight - 20, + height: wheight - (inputHeight - 5), style: { overflow: "scroll", }, }), merger.ui.textbox("Tinput", { - top: wheight - 20, + top: wheight - (inputHeight - 5), left: -5, width: wwidth + 10, - height: 25, + height: inputHeight, placeholder: "javascript code here", //multiple: true, style: { @@ -216,7 +218,7 @@ border: "0", overflow: "scroll", background: "#EEE", - padding: "5px", + padding: "3px", }, onkeydown: function (e) { var t, stop; @@ -379,7 +381,6 @@ title: "Preferences", width: wwidth, height: wheight, - visible: false, content: [ merger.ui.checkbox("pref_autoshow", { top: 0, @@ -421,8 +422,35 @@ return win; } - function openInspector(){ - + /** + * Open inspector window + * @param {*} object Any object to inspect + */ + function openInspector(object) { + var wid, win, wwidth = 250, wheight = 300; + wid = "inspector_" + uuid(); + win = merger.ui.window(wid, { + title: "Inspector", + width: wwidth, + height: wheight, + content: [ + merger.ui.button("pref_save", { + top: wheight - 20, + left: wwidth - 25, + text: "Ok", + onClick: function () { + this.getWindow().close(); + } + }), + ], + onClose: function () { + this.hide(); + getApp().removeWindow(win); + } + }); + getApp().addWindow(win); + win.show(); + return win; } /** @@ -438,8 +466,7 @@ text: "Preferences...", icon: merger.media.createIcon('#EEE', '⚒'), onClick: function () { - this.getApp().windows.wPref.show(); - //openProperties(); + openProperties(); } }), ], @@ -484,7 +511,7 @@ }, onFocus: function () { removeIcon(); - if (!inq.autoShow) + if (!getApp().getFocusedWindow()) openConsole(); }, showError: function (err) { @@ -614,7 +641,8 @@ } function inspect(object) { - + openInspector(object); + show(); } function console() { diff --git a/Merger.js b/Merger.js index cf23591..82dd5c6 100644 --- a/Merger.js +++ b/Merger.js @@ -467,6 +467,27 @@ core.getDesktop().removeChild(win); } + /** Count windows on application */ + MergerApplication.prototype.listWindows = function () { + var k, r = []; + for (k in this.windows) + r.push(k); + return r; + } + + /** Return the currently focused window on application */ + MergerApplication.prototype.getFocusedWindow = function () { + var k, w, s, l; + for (k in this.windows) { + w = this.windows[k]; + if (w.getVisible() && (!s || Number(w.style.zIndex) > l)) { + s = w; + l = Number(w.style.zIndex); + } + } + return s; + } + //=== Tools //============================================================================================= @@ -728,6 +749,7 @@ border: "1px solid " + sys.color.frame, fontFamily: "Arial", fontSize: "14px", + zIndex: 9999, }, _zLayer: 9, });