diff --git a/WebInquirer.html b/WebInquirer.html index f4163dd..0e3dc1f 100644 --- a/WebInquirer.html +++ b/WebInquirer.html @@ -2,16 +2,17 @@ inquirer Tester + +
-
-
-

+
+
+


-
- -

- +
+ +

+ \ No newline at end of file diff --git a/inquirer.js b/inquirer.js index b6bcdfa..2191cfa 100644 --- a/inquirer.js +++ b/inquirer.js @@ -23,14 +23,43 @@ top: 10, left: 10, text: "---" - })], + }), + merger.ui.button("Bok", { + top: 200, + left: 355, + text: "Ok", + onClick: function (e) { + this.getWindow().close(); + } + }), + merger.ui.textbox("Tinfo", { + top: 25, + left: 10, + width: 340, + height: 190, + multiple: true, + style: { + whiteSpace: "pre", + } + }) + ], onClose: function () { merger.leave(); + }, + setError: function (message, data) { + this.client.Lerror.setText(message); + this.client.Tinfo.setText(JSON.stringify(data, null, 2)); } })], mainWindow: "Wmain", onLoad: function () { + }, + showError: function (message, data) { + this.windows.Wmain.setError(message, data); + }, + log: function (info) { + } }); return inqapp; @@ -38,36 +67,10 @@ function show() { getApp().focus(); - var w = jsTK.get("Werror"); - if (!w) { - w = jsTK.window("Werror", { - title: "Error", - width: 400, - height: 200, - content: [jsTK.label("Lerror", { - top: 30, - left: 10, - text: "---" - }), jsTK.list("Lerrors", { - top: 80, - left: 10, - width: 320, - height: 100, - }), jsTK.button("Bok", { - top: 80, - left: 10, - width: 320, - height: 100, - text: "Ok", - onClick: function () { - } - })] - }); - } } function hide() { - jsTK.close(); + getApp().windows.Wmain.close(); } function hook() { @@ -101,8 +104,11 @@ } function error(message, data) { - if (this.autoShow) + getApp().log({ error: true, data: { message: message, data: data } }); + if (this.autoShow) { + getApp().showError(message, data); show(); + } } function inspect() { diff --git a/merger/core.js b/merger/core.js index af68939..112a170 100644 --- a/merger/core.js +++ b/merger/core.js @@ -1,8 +1,16 @@ var merger = new function () { + + /** + * merger system variables + */ var sys = { icon: "", - ver: "0.1d", + ver: "0.2", }; + + /** + * merge method the root of all merger framework + */ if (!Object.prototype.merge) Object.defineProperty(Object.prototype, "merge", { writable: true, value: function (src) { @@ -18,6 +26,9 @@ w: {} }; + /** + * Toolbar clock logic + */ function clockTick() { var now = new Date(); var h = now.getHours(); @@ -29,14 +40,24 @@ // ---- Tools + /** + * Tool for trigger creation + * USE: insist() + * + * controller.when: function to check triggering. + * The first time the when returns true the "do"" method will be executed + * controller.do: function with logic to execute when "when" method returns true + * controller.each: (optional) integer with milliseconds to wait between checks. + * If not set, a continious check will be done. WARNING: this can consume a lot of CPU. + */ function insist(ctrl) { var controller = { when: function () { return true; }, - each: undefined, do: function () { - } + }, + each: undefined }.merge(ctrl); controller.check = function () { if (!this.when()) @@ -50,10 +71,16 @@ // ---- UI implementation // ---------------------- + /** + * Tool for creating tags + */ function mkTag(tag) { return document.createElement(tag); } + /** + * Tool for injecting CSS rules + */ function mkCSS(css) { style = mkTag('style'); if (style.styleSheet) @@ -63,6 +90,10 @@ document.getElementsByTagName('head')[0].appendChild(style); } + /** + * Open merger desktop. + * The first time finish the basic layout creation + */ function openDesktop() { if (!ui.dsk.merger_init) { ui.dsk.merger_init = true; @@ -106,17 +137,20 @@ clockTick(); setInterval(clockTick, 60000); } - //ui.dsk.style.display = ""; document.body.appendChild(ui.dsk); } - function control(id, def, c) { + /** + * Base control creation + */ + function control(type, id, def, c) { if (!c) c = mkTag("div"); + c.setAttribute("merger_type", type); c.setAttribute("id", id); c.setAttribute("name", id); c.style.position = "absolute"; - c.controls = {}; + c._type = type; c.getId = function () { return id; } @@ -157,7 +191,7 @@ } c.append = function (control) { this.appendChild(control); - this.controls[control.getId()] = control; + this[control.getId()] = control; control.parent = this; } c.setContent = function (ctt) { @@ -167,6 +201,15 @@ c.setStyle = function (style) { this.style.merge(style); } + c.getWindow = function () { + var win = this; + while (win && win._type != "window") + win = win.parent; + return win; + } + c.getApp = function () { + return this.getWindow().parent; + } var settings = {}; for (var key in def) { var mdata = def[key]; @@ -184,15 +227,23 @@ var o = settings[key]; o.f(o.d); } + if (c.onControlCreate) + c.onControlCreate(); return c; } + /** + * Menú Item control creation + */ function menuItem(id, def) { var m = mkTag("div").merge({ }); } + /** + * Window control creation + */ function window(id, def) { if (typeof (def) != "object") def = {}; @@ -208,7 +259,7 @@ def.content = []; var w; // Window Title - var wt = control("title", { + var wt = control("windowtitle", "windowtitle", { visible: !def.hideTitle, style: { borderBottom: "1px solid black", @@ -224,7 +275,7 @@ paddingTop: "1px", }, content: [ - control("closeButton", { + control("windowclosebutton", "closeButton", { visible: !def.hideCloseButton, style: { top: "2px", @@ -250,13 +301,13 @@ } }); // Window client - var wc = control("client", { + var wc = control("windowclient", "client", { content: def.content, style: { position: "relative" } }); def.content = [wt, wc]; // Window root - w = control(id, { + w = control("window", id, { setTitle: function (title) { wt.setTitle(title); }, @@ -279,29 +330,68 @@ return w; } - function icon(id, def) { + /** + * Picture control creation + */ + function picture(id, def) { } + /** + * Label control creation + */ function label(id, def) { - var c = control(id, def); + var c = control("label", id, { + setText: function (text) { + this.innerText = text; + } + }.merge(def)); + if (def.text !== undefined) + c.setText(def.text); + return c; + } + + /** + * TextBox control creation + */ + function textbox(id, def) { + def.style = { + fontSize: "10px", + fontFamily: "Lucida Console, Monospace" + }.merge(def.style); + var c = control("textbox", id, { + setText: function (value) { + this.value = value; + } + }.merge(def), mkTag(def.multiple ? "textarea" : "input")); + return c; + } + + /** + * Button control creation + */ + function button(id, def) { + var c = control("button", id, def, mkTag("button")); c.setText = function (text) { this.innerText = text; } c.setText(def.text); + c.addEventListener("click", function () { if (this.onClick) this.onClick.apply(this, arguments) }, false); return c; } - function button(id, def) { - - } - + /** + * List control creation + */ function list(id, def) { - var c = control(id, def); + var c = control("list", id, def); c.style.border = "1px solid red"; return c; } + /** + * Component path getter + */ function get(id) { return ui.w[id]; } @@ -313,12 +403,16 @@ ui.menu.sysMenu.src = app.icon ? app.icon : sys.icon; } + /** + * Application creation + */ function app(id, def) { if (ui.app[id]) throw new Error("Application '" + id + "' already exists"); var a = {}, windows = def.windows, i; ui.app[id] = a; a.merge({ + _type: "app", getId: function () { return id; }, @@ -367,6 +461,9 @@ document.body.removeChild(ui.dsk); } + /** + * merger API + */ // -- Kernel this.merge({ app: app, @@ -379,10 +476,14 @@ get: get, list: list, label: label, + textbox: textbox, button: button, } }); + /** + * Initializes merger subsystem + */ function kInit() { ui.dsk = mkTag("div"); ui.dsk.style.merge({ @@ -395,7 +496,6 @@ fontFamily: "Verdana", fontSize: "10px", overflow: "hidden", - //display: "none", backgroundColor: "rgba(128,128,128,0.3)", }); ui.menu = mkTag("div"); @@ -406,6 +506,9 @@ kInit(); } +/** + * Test app + */ merger.app("merger", { });