diff --git a/Inquirer.js b/Inquirer.js index b2b0971..5646d36 100644 --- a/Inquirer.js +++ b/Inquirer.js @@ -24,7 +24,7 @@ var icon = "", // bugico = "", // - VERSION = "0.7d",// + VERSION = "0.7e",// alertIcon, config = { color: { @@ -50,42 +50,6 @@ return v.toString(16); }); } - function objectResumeText(obj) { - var r, k, v; - if (obj === null) - return ""; - if (obj === undefined) - return ""; - switch (typeof obj) { - case "string": - if (obj.length < 200) - return '"' + obj + '"'; - else - return '"' + obj.substr(0, 200) + "..."; - case "function": - return "function"; - case "object": - r = ""; - if (obj instanceof HTMLElement) - r += "<" + obj.tagName + ">:: "; - else if (obj instanceof HTMLDocument) - r += "DOCUMENT:: "; - else if (obj instanceof Window) - r += "WINDOW:: "; - r += "{\n"; - for (k in obj) { - r += k + ":" + objectResumeText(obj[k]) + ",\n"; - if (r.length > 400) { - r += " ..."; - break; - } - } - r += "}"; - return r; - default: - return "" + obj; - } - } function objectResumeLink(obj) { var a = document.createElement("a"), isError; @@ -121,36 +85,44 @@ rtp = rtd[i]; if (!rtp) continue; - p = document.createElement("span"); - p.data = rtp; - if (rtp.c) - p.style.color = rtp.c; - p.innerText = rtp.v; - r.appendChild(p); + if (rtp instanceof Node) + r.appendChild(rtp); + else { + p = document.createElement("span"); + p.data = rtp; + if (rtp.c) + p.style.color = rtp.c; + p.innerText = rtp.v; + r.appendChild(p); + } } return r; } /** expandable object resume */ - function compactObject(co) { - var r, f, m, d; + function compactObject(m, d) { + var r, f, mn, dn; r = document.createElement("span"); f = document.createElement("span"); - m = formatter(co.m); - d = formatter(co.d); + mn = formatter(m); function open() { f.innerText = "▼ "; - if (r.contains(m)) - r.removeChild(m); - r.appendChild(d); + if (r.contains(mn)) + r.removeChild(mn); + if (dn == null) { + if (typeof d === "function") + d = d(); + dn = formatter(d); + } + r.appendChild(dn); f.onclick = close; return r; } function close() { f.innerText = "▶︎ "; - if (r.contains(d)) - r.removeChild(d); - r.appendChild(m); + if (r.contains(dn)) + r.removeChild(dn); + r.appendChild(mn); f.onclick = open; return r; } @@ -176,13 +148,53 @@ } /** formatice object resume */ - function objectResume(o) { - return []; + function objectResume(obj) { + var r = [], k, max = 10, first = true; + if (Array.isArray(obj)) + r.push({ c: config.color.normal, v: "Array (" + obj.length + ")" }); + else { + if (obj.constructor) + r.push({ c: config.color.normal, v: functionName(obj.constructor) + " " }); + r.push({ c: config.color.normal, v: "{" }); + for (k in obj) { + if (max-- <= 0) { + r.push({ c: config.color.normal, v: "..." }); + break; + } + if (first) + first = false; + else + r.push({ c: config.color.normal, v: ", " }); + r.push({ c: config.color.keyword, v: k }); + } + r.push({ c: config.color.normal, v: "}" }); + } + return r; } /** foramtice object details */ - function objectDetails(o) { - return []; + function objectDetails(obj) { + return function () { + var r = [], k, d; + if (Array.isArray(obj)) + r.push({ c: config.color.normal, v: "Array (" + obj.length + ") [" }); + else { + if (obj.constructor) + r.push({ c: config.color.normal, v: functionName(obj.constructor) + " " }); + r.push({ c: config.color.normal, v: "{" }); + } + for (k in obj) { + r.push(d = document.createElement("div")); + d.appendChild(formatter([ + { c: config.color.keyword, v: k }, + { c: config.color.normal, v: ": " }, + objectRow(obj[k]) + ])) + d.style.paddingLeft = "8px"; + } + r.push({ c: config.color.normal, v: Array.isArray(obj) ? "]" : "}" }); + return r; + }; } /** return the function name */ @@ -200,7 +212,7 @@ /** Advanced way to show object on screen */ function objectRow(obj, full, expanded) { var row, robj; - row = document.createElement("div"); + row = document.createElement("span"); if (obj === null) row.innerText = ""; else if (obj === undefined) @@ -226,23 +238,16 @@ ])); break; case "function": - row.appendChild(robj = compactObject({ - m: [ - { c: config.color.keyword, v: "function" }, - obj.name ? { c: config.color.normal, v: " " + functionName(obj) } : null, - { c: config.color.normal, v: "() {...}" }, - ], - d: functionDetails(obj) - })); + row.appendChild(robj = compactObject([ + { c: config.color.keyword, v: "function" }, + obj.name ? { c: config.color.normal, v: " " + functionName(obj) } : null, + { c: config.color.normal, v: "() {...}" }, + ], + functionDetails(obj) + )); break; case "object": - row.appendChild(robj = compactObject({ - m: [ - obj.constructor ? { c: config.color.normal, v: functionName(obj.constructor) + " " } : null, - { c: config.color.normal, v: "{...}" }, - ], - d: objectDetails(obj) - })); + row.appendChild(robj = compactObject(objectResume(obj), objectDetails(obj))); break; default: row.innerText = obj; @@ -451,13 +456,13 @@ d.style.paddingBottom = "3px"; break; case 'o': - d.appendChild(objectResumeLink(object)); + d.appendChild(objectRow(object)); d.style.borderBottom = "1px solid #EEE"; head.appendChild(document.createTextNode("<")); head.style.color = "#DDD"; break; case 'e': - d.appendChild(objectResumeLink(object)); + d.appendChild(objectRow(object)); head.appendChild(document.createTextNode("!")); head.style.color = "#F88"; d.style.background = "#FEE"; @@ -572,7 +577,7 @@ * @param {*} object Any object to inspect */ function openInspector(object) { - var wid, win, wwidth = 250, wheight = 300, panel; + var wid, win, wwidth = 450, wheight = 400, panel; wid = "inspector_" + uuid(); win = merger.ui.window(wid, { title: "Inspector",