diff --git a/Inquirer.js b/Inquirer.js index 7394a18..4cb6bbd 100644 --- a/Inquirer.js +++ b/Inquirer.js @@ -185,7 +185,7 @@ for (k in obj) { r.push(d = document.createElement("div")); d.appendChild(formatter([ - { c: config.color.keyword, v: k }, + { c: config.color.keyword, v: k + " " }, inspectorLink(obj[k]), { c: config.color.normal, v: ": " }, objectRow(obj[k]) @@ -275,6 +275,40 @@ } } + function objectTable(obj) { + var i, cname, colmap = {}, tbl = document.createElement("table"), tr, td; + // Discover columns + tr = document.createElement("tr"); + td = document.createElement("th"); + td.innerText = "#"; + tr.appendChild(td); + for (i in obj) { + var row = obj[i]; + for (cname in row) + if (!colmap[cname]) { + var col = colmap[cname] = document.createElement("th"); + col.innerText = cname; + tr.appendChild(col); + } + } + tbl.appendChild(tr); + // Fill data + for (i in obj) { + var row = obj[i]; + tr = document.createElement("tr"); + for (cname in colmap) { + td = document.createElement("td"); + if (row[cname] !== undefined) { + td.innerText = row[cname]; + } + tr.appendChild(td); + } + tbl.appendChild(tr); + } + + return tbl; + } + // Methods /** * Error window handling @@ -371,6 +405,7 @@ anchor: "TRBL", style: { overflow: "scroll", + userSelect: "text" }, }), merger.ui.textbox("Tinput", { @@ -618,6 +653,7 @@ overflow: "scroll", fontFamily: "Lucida Console, Monospace", border: "0", + userSelect: "text" }, }), merger.ui.button("insp_close", { @@ -630,8 +666,32 @@ } }), ], - load: function () { - panel.appendChild(objectRow(object, true, true)); + frameTools: [ + merger.ui.toggleButton("isp_asObject", { + icon: "", + title: "Show as object", + width: 30, + selected: true, + group: "mode", + onClick: function () { + this.getWindow() && this.getWindow().load(false); + } + }), merger.ui.toggleButton("isp_asTable", { + icon: "", + title: "Show as table", + width: 30, + group: "mode", + onClick: function () { + this.getWindow().load(true); + } + }) + ], + load: function (asTable) { + panel.innerHTML = ""; + if (asTable) + panel.appendChild(objectTable(object)); + else + panel.appendChild(objectRow(object, true, true)); }, onClose: function () { this.hide();