Guillermo
10 years ago
28 changed files with 21873 additions and 1316 deletions
@ -0,0 +1,72 @@
@@ -0,0 +1,72 @@
|
||||
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
||||
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||
|
||||
(function(mod) { |
||||
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
||||
mod(require("../../lib/codemirror")); |
||||
else if (typeof define == "function" && define.amd) // AMD
|
||||
define(["../../lib/codemirror"], mod); |
||||
else // Plain browser env
|
||||
mod(CodeMirror); |
||||
})(function(CodeMirror) { |
||||
"use strict"; |
||||
|
||||
CodeMirror.runMode = function(string, modespec, callback, options) { |
||||
var mode = CodeMirror.getMode(CodeMirror.defaults, modespec); |
||||
var ie = /MSIE \d/.test(navigator.userAgent); |
||||
var ie_lt9 = ie && (document.documentMode == null || document.documentMode < 9); |
||||
|
||||
if (callback.nodeType == 1) { |
||||
var tabSize = (options && options.tabSize) || CodeMirror.defaults.tabSize; |
||||
var node = callback, col = 0; |
||||
node.innerHTML = ""; |
||||
callback = function(text, style) { |
||||
if (text == "\n") { |
||||
// Emitting LF or CRLF on IE8 or earlier results in an incorrect display.
|
||||
// Emitting a carriage return makes everything ok.
|
||||
node.appendChild(document.createTextNode(ie_lt9 ? '\r' : text)); |
||||
col = 0; |
||||
return; |
||||
} |
||||
var content = ""; |
||||
// replace tabs
|
||||
for (var pos = 0;;) { |
||||
var idx = text.indexOf("\t", pos); |
||||
if (idx == -1) { |
||||
content += text.slice(pos); |
||||
col += text.length - pos; |
||||
break; |
||||
} else { |
||||
col += idx - pos; |
||||
content += text.slice(pos, idx); |
||||
var size = tabSize - col % tabSize; |
||||
col += size; |
||||
for (var i = 0; i < size; ++i) content += " "; |
||||
pos = idx + 1; |
||||
} |
||||
} |
||||
|
||||
if (style) { |
||||
var sp = node.appendChild(document.createElement("span")); |
||||
sp.className = "cm-" + style.replace(/ +/g, " cm-"); |
||||
sp.appendChild(document.createTextNode(content)); |
||||
} else { |
||||
node.appendChild(document.createTextNode(content)); |
||||
} |
||||
}; |
||||
} |
||||
|
||||
var lines = CodeMirror.splitLines(string), state = (options && options.state) || CodeMirror.startState(mode); |
||||
for (var i = 0, e = lines.length; i < e; ++i) { |
||||
if (i) callback("\n"); |
||||
var stream = new CodeMirror.StringStream(lines[i]); |
||||
if (!stream.string && mode.blankLine) mode.blankLine(state); |
||||
while (!stream.eol()) { |
||||
var style = mode.token(stream, state); |
||||
callback(stream.current(), style, i, stream.start, state); |
||||
stream.start = stream.pos; |
||||
} |
||||
} |
||||
}; |
||||
|
||||
}); |
@ -0,0 +1,384 @@
@@ -0,0 +1,384 @@
|
||||
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
||||
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||
|
||||
(function(mod) { |
||||
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
||||
mod(require("../../lib/codemirror")); |
||||
else if (typeof define == "function" && define.amd) // AMD
|
||||
define(["../../lib/codemirror"], mod); |
||||
else // Plain browser env
|
||||
mod(CodeMirror); |
||||
})(function(CodeMirror) { |
||||
"use strict"; |
||||
|
||||
CodeMirror.defineMode("xml", function(config, parserConfig) { |
||||
var indentUnit = config.indentUnit; |
||||
var multilineTagIndentFactor = parserConfig.multilineTagIndentFactor || 1; |
||||
var multilineTagIndentPastTag = parserConfig.multilineTagIndentPastTag; |
||||
if (multilineTagIndentPastTag == null) multilineTagIndentPastTag = true; |
||||
|
||||
var Kludges = parserConfig.htmlMode ? { |
||||
autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true, |
||||
'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true, |
||||
'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true, |
||||
'track': true, 'wbr': true, 'menuitem': true}, |
||||
implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true, |
||||
'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true, |
||||
'th': true, 'tr': true}, |
||||
contextGrabbers: { |
||||
'dd': {'dd': true, 'dt': true}, |
||||
'dt': {'dd': true, 'dt': true}, |
||||
'li': {'li': true}, |
||||
'option': {'option': true, 'optgroup': true}, |
||||
'optgroup': {'optgroup': true}, |
||||
'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true, |
||||
'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true, |
||||
'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true, |
||||
'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true, |
||||
'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true}, |
||||
'rp': {'rp': true, 'rt': true}, |
||||
'rt': {'rp': true, 'rt': true}, |
||||
'tbody': {'tbody': true, 'tfoot': true}, |
||||
'td': {'td': true, 'th': true}, |
||||
'tfoot': {'tbody': true}, |
||||
'th': {'td': true, 'th': true}, |
||||
'thead': {'tbody': true, 'tfoot': true}, |
||||
'tr': {'tr': true} |
||||
}, |
||||
doNotIndent: {"pre": true}, |
||||
allowUnquoted: true, |
||||
allowMissing: true, |
||||
caseFold: true |
||||
} : { |
||||
autoSelfClosers: {}, |
||||
implicitlyClosed: {}, |
||||
contextGrabbers: {}, |
||||
doNotIndent: {}, |
||||
allowUnquoted: false, |
||||
allowMissing: false, |
||||
caseFold: false |
||||
}; |
||||
var alignCDATA = parserConfig.alignCDATA; |
||||
|
||||
// Return variables for tokenizers
|
||||
var type, setStyle; |
||||
|
||||
function inText(stream, state) { |
||||
function chain(parser) { |
||||
state.tokenize = parser; |
||||
return parser(stream, state); |
||||
} |
||||
|
||||
var ch = stream.next(); |
||||
if (ch == "<") { |
||||
if (stream.eat("!")) { |
||||
if (stream.eat("[")) { |
||||
if (stream.match("CDATA[")) return chain(inBlock("atom", "]]>")); |
||||
else return null; |
||||
} else if (stream.match("--")) { |
||||
return chain(inBlock("comment", "-->")); |
||||
} else if (stream.match("DOCTYPE", true, true)) { |
||||
stream.eatWhile(/[\w\._\-]/); |
||||
return chain(doctype(1)); |
||||
} else { |
||||
return null; |
||||
} |
||||
} else if (stream.eat("?")) { |
||||
stream.eatWhile(/[\w\._\-]/); |
||||
state.tokenize = inBlock("meta", "?>"); |
||||
return "meta"; |
||||
} else { |
||||
type = stream.eat("/") ? "closeTag" : "openTag"; |
||||
state.tokenize = inTag; |
||||
return "tag bracket"; |
||||
} |
||||
} else if (ch == "&") { |
||||
var ok; |
||||
if (stream.eat("#")) { |
||||
if (stream.eat("x")) { |
||||
ok = stream.eatWhile(/[a-fA-F\d]/) && stream.eat(";"); |
||||
} else { |
||||
ok = stream.eatWhile(/[\d]/) && stream.eat(";"); |
||||
} |
||||
} else { |
||||
ok = stream.eatWhile(/[\w\.\-:]/) && stream.eat(";"); |
||||
} |
||||
return ok ? "atom" : "error"; |
||||
} else { |
||||
stream.eatWhile(/[^&<]/); |
||||
return null; |
||||
} |
||||
} |
||||
|
||||
function inTag(stream, state) { |
||||
var ch = stream.next(); |
||||
if (ch == ">" || (ch == "/" && stream.eat(">"))) { |
||||
state.tokenize = inText; |
||||
type = ch == ">" ? "endTag" : "selfcloseTag"; |
||||
return "tag bracket"; |
||||
} else if (ch == "=") { |
||||
type = "equals"; |
||||
return null; |
||||
} else if (ch == "<") { |
||||
state.tokenize = inText; |
||||
state.state = baseState; |
||||
state.tagName = state.tagStart = null; |
||||
var next = state.tokenize(stream, state); |
||||
return next ? next + " tag error" : "tag error"; |
||||
} else if (/[\'\"]/.test(ch)) { |
||||
state.tokenize = inAttribute(ch); |
||||
state.stringStartCol = stream.column(); |
||||
return state.tokenize(stream, state); |
||||
} else { |
||||
stream.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/); |
||||
return "word"; |
||||
} |
||||
} |
||||
|
||||
function inAttribute(quote) { |
||||
var closure = function(stream, state) { |
||||
while (!stream.eol()) { |
||||
if (stream.next() == quote) { |
||||
state.tokenize = inTag; |
||||
break; |
||||
} |
||||
} |
||||
return "string"; |
||||
}; |
||||
closure.isInAttribute = true; |
||||
return closure; |
||||
} |
||||
|
||||
function inBlock(style, terminator) { |
||||
return function(stream, state) { |
||||
while (!stream.eol()) { |
||||
if (stream.match(terminator)) { |
||||
state.tokenize = inText; |
||||
break; |
||||
} |
||||
stream.next(); |
||||
} |
||||
return style; |
||||
}; |
||||
} |
||||
function doctype(depth) { |
||||
return function(stream, state) { |
||||
var ch; |
||||
while ((ch = stream.next()) != null) { |
||||
if (ch == "<") { |
||||
state.tokenize = doctype(depth + 1); |
||||
return state.tokenize(stream, state); |
||||
} else if (ch == ">") { |
||||
if (depth == 1) { |
||||
state.tokenize = inText; |
||||
break; |
||||
} else { |
||||
state.tokenize = doctype(depth - 1); |
||||
return state.tokenize(stream, state); |
||||
} |
||||
} |
||||
} |
||||
return "meta"; |
||||
}; |
||||
} |
||||
|
||||
function Context(state, tagName, startOfLine) { |
||||
this.prev = state.context; |
||||
this.tagName = tagName; |
||||
this.indent = state.indented; |
||||
this.startOfLine = startOfLine; |
||||
if (Kludges.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent)) |
||||
this.noIndent = true; |
||||
} |
||||
function popContext(state) { |
||||
if (state.context) state.context = state.context.prev; |
||||
} |
||||
function maybePopContext(state, nextTagName) { |
||||
var parentTagName; |
||||
while (true) { |
||||
if (!state.context) { |
||||
return; |
||||
} |
||||
parentTagName = state.context.tagName; |
||||
if (!Kludges.contextGrabbers.hasOwnProperty(parentTagName) || |
||||
!Kludges.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) { |
||||
return; |
||||
} |
||||
popContext(state); |
||||
} |
||||
} |
||||
|
||||
function baseState(type, stream, state) { |
||||
if (type == "openTag") { |
||||
state.tagStart = stream.column(); |
||||
return tagNameState; |
||||
} else if (type == "closeTag") { |
||||
return closeTagNameState; |
||||
} else { |
||||
return baseState; |
||||
} |
||||
} |
||||
function tagNameState(type, stream, state) { |
||||
if (type == "word") { |
||||
state.tagName = stream.current(); |
||||
setStyle = "tag"; |
||||
return attrState; |
||||
} else { |
||||
setStyle = "error"; |
||||
return tagNameState; |
||||
} |
||||
} |
||||
function closeTagNameState(type, stream, state) { |
||||
if (type == "word") { |
||||
var tagName = stream.current(); |
||||
if (state.context && state.context.tagName != tagName && |
||||
Kludges.implicitlyClosed.hasOwnProperty(state.context.tagName)) |
||||
popContext(state); |
||||
if (state.context && state.context.tagName == tagName) { |
||||
setStyle = "tag"; |
||||
return closeState; |
||||
} else { |
||||
setStyle = "tag error"; |
||||
return closeStateErr; |
||||
} |
||||
} else { |
||||
setStyle = "error"; |
||||
return closeStateErr; |
||||
} |
||||
} |
||||
|
||||
function closeState(type, _stream, state) { |
||||
if (type != "endTag") { |
||||
setStyle = "error"; |
||||
return closeState; |
||||
} |
||||
popContext(state); |
||||
return baseState; |
||||
} |
||||
function closeStateErr(type, stream, state) { |
||||
setStyle = "error"; |
||||
return closeState(type, stream, state); |
||||
} |
||||
|
||||
function attrState(type, _stream, state) { |
||||
if (type == "word") { |
||||
setStyle = "attribute"; |
||||
return attrEqState; |
||||
} else if (type == "endTag" || type == "selfcloseTag") { |
||||
var tagName = state.tagName, tagStart = state.tagStart; |
||||
state.tagName = state.tagStart = null; |
||||
if (type == "selfcloseTag" || |
||||
Kludges.autoSelfClosers.hasOwnProperty(tagName)) { |
||||
maybePopContext(state, tagName); |
||||
} else { |
||||
maybePopContext(state, tagName); |
||||
state.context = new Context(state, tagName, tagStart == state.indented); |
||||
} |
||||
return baseState; |
||||
} |
||||
setStyle = "error"; |
||||
return attrState; |
||||
} |
||||
function attrEqState(type, stream, state) { |
||||
if (type == "equals") return attrValueState; |
||||
if (!Kludges.allowMissing) setStyle = "error"; |
||||
return attrState(type, stream, state); |
||||
} |
||||
function attrValueState(type, stream, state) { |
||||
if (type == "string") return attrContinuedState; |
||||
if (type == "word" && Kludges.allowUnquoted) {setStyle = "string"; return attrState;} |
||||
setStyle = "error"; |
||||
return attrState(type, stream, state); |
||||
} |
||||
function attrContinuedState(type, stream, state) { |
||||
if (type == "string") return attrContinuedState; |
||||
return attrState(type, stream, state); |
||||
} |
||||
|
||||
return { |
||||
startState: function() { |
||||
return {tokenize: inText, |
||||
state: baseState, |
||||
indented: 0, |
||||
tagName: null, tagStart: null, |
||||
context: null}; |
||||
}, |
||||
|
||||
token: function(stream, state) { |
||||
if (!state.tagName && stream.sol()) |
||||
state.indented = stream.indentation(); |
||||
|
||||
if (stream.eatSpace()) return null; |
||||
type = null; |
||||
var style = state.tokenize(stream, state); |
||||
if ((style || type) && style != "comment") { |
||||
setStyle = null; |
||||
state.state = state.state(type || style, stream, state); |
||||
if (setStyle) |
||||
style = setStyle == "error" ? style + " error" : setStyle; |
||||
} |
||||
return style; |
||||
}, |
||||
|
||||
indent: function(state, textAfter, fullLine) { |
||||
var context = state.context; |
||||
// Indent multi-line strings (e.g. css).
|
||||
if (state.tokenize.isInAttribute) { |
||||
if (state.tagStart == state.indented) |
||||
return state.stringStartCol + 1; |
||||
else |
||||
return state.indented + indentUnit; |
||||
} |
||||
if (context && context.noIndent) return CodeMirror.Pass; |
||||
if (state.tokenize != inTag && state.tokenize != inText) |
||||
return fullLine ? fullLine.match(/^(\s*)/)[0].length : 0; |
||||
// Indent the starts of attribute names.
|
||||
if (state.tagName) { |
||||
if (multilineTagIndentPastTag) |
||||
return state.tagStart + state.tagName.length + 2; |
||||
else |
||||
return state.tagStart + indentUnit * multilineTagIndentFactor; |
||||
} |
||||
if (alignCDATA && /<!\[CDATA\[/.test(textAfter)) return 0; |
||||
var tagAfter = textAfter && /^<(\/)?([\w_:\.-]*)/.exec(textAfter); |
||||
if (tagAfter && tagAfter[1]) { // Closing tag spotted
|
||||
while (context) { |
||||
if (context.tagName == tagAfter[2]) { |
||||
context = context.prev; |
||||
break; |
||||
} else if (Kludges.implicitlyClosed.hasOwnProperty(context.tagName)) { |
||||
context = context.prev; |
||||
} else { |
||||
break; |
||||
} |
||||
} |
||||
} else if (tagAfter) { // Opening tag spotted
|
||||
while (context) { |
||||
var grabbers = Kludges.contextGrabbers[context.tagName]; |
||||
if (grabbers && grabbers.hasOwnProperty(tagAfter[2])) |
||||
context = context.prev; |
||||
else |
||||
break; |
||||
} |
||||
} |
||||
while (context && !context.startOfLine) |
||||
context = context.prev; |
||||
if (context) return context.indent + indentUnit; |
||||
else return 0; |
||||
}, |
||||
|
||||
electricInput: /<\/[\s\w:]+>$/, |
||||
blockCommentStart: "<!--", |
||||
blockCommentEnd: "-->", |
||||
|
||||
configuration: parserConfig.htmlMode ? "html" : "xml", |
||||
helperType: parserConfig.htmlMode ? "html" : "xml" |
||||
}; |
||||
}); |
||||
|
||||
CodeMirror.defineMIME("text/xml", "xml"); |
||||
CodeMirror.defineMIME("application/xml", "xml"); |
||||
if (!CodeMirror.mimeModes.hasOwnProperty("text/html")) |
||||
CodeMirror.defineMIME("text/html", {name: "xml", htmlMode: true}); |
||||
|
||||
}); |
@ -0,0 +1,92 @@
@@ -0,0 +1,92 @@
|
||||
#explorer { |
||||
max-width: 500px; |
||||
max-height: 500px; |
||||
white-space: nowrap; |
||||
overflow: scroll; |
||||
padding: 10px; |
||||
|
||||
border: 1px solid #eee; |
||||
border-radius: 5px; |
||||
font-family: monospace; |
||||
|
||||
} |
||||
|
||||
@media (max-width: 914px) { |
||||
#explorer { |
||||
margin: 8%; |
||||
|
||||
} |
||||
} |
||||
|
||||
.textNode { |
||||
display: inline-block; |
||||
max-width: 400px; |
||||
vertical-align: middle; |
||||
white-space: pre; |
||||
overflow: scroll; |
||||
margin-bottom: 1px; |
||||
margin-top: 1px; |
||||
} |
||||
|
||||
.textNode { |
||||
background-color: rgb(255, 238, 174); |
||||
color: rgb(48, 48, 97); |
||||
padding: 2px; |
||||
border-radius: 3px; |
||||
} |
||||
|
||||
.html { |
||||
background-color: #F5F5F5; |
||||
} |
||||
|
||||
.comma, .ellipsis { |
||||
color: grey; |
||||
} |
||||
|
||||
.nullNode { |
||||
color: grey; |
||||
} |
||||
|
||||
.numberNode { |
||||
color: rgb(203, 48, 48); |
||||
} |
||||
|
||||
.booleanNode { |
||||
color: rgb(174, 44, 164); |
||||
} |
||||
|
||||
.label { |
||||
color: rgb(76, 162, 242); |
||||
} |
||||
|
||||
.clickable { |
||||
cursor: pointer; |
||||
} |
||||
|
||||
.indent { |
||||
padding-left: 30px; |
||||
display: inline-block; |
||||
} |
||||
|
||||
|
||||
/*.collapsed, .expanded { |
||||
position: relative; |
||||
} |
||||
*/ |
||||
/*.collapsed::before { |
||||
content: "▶"; |
||||
position: absolute; |
||||
left: -16px; |
||||
} |
||||
|
||||
.expanded::before { |
||||
content: "▼"; |
||||
position: absolute; |
||||
left: -16px; |
||||
} |
||||
|
||||
.swiper{ |
||||
padding-left: 40px; |
||||
margin-top: 8px; |
||||
} |
||||
*/ |
@ -0,0 +1,397 @@
@@ -0,0 +1,397 @@
|
||||
"use strict"; |
||||
|
||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); |
||||
|
||||
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } }; |
||||
|
||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
||||
|
||||
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) subClass.__proto__ = superClass; } |
||||
|
||||
function array_join(array, glue) { |
||||
var new_array = []; |
||||
for (var i = 0; i < array.length; i++) { |
||||
new_array.push(array[i]); |
||||
if (i != array.length - 1) new_array.push(glue); |
||||
} |
||||
return new_array; |
||||
} |
||||
|
||||
var Node = (function (_React$Component) { |
||||
function Node(props) { |
||||
var _this = this; |
||||
|
||||
_classCallCheck(this, Node); |
||||
|
||||
_get(Object.getPrototypeOf(Node.prototype), "constructor", this).call(this, props); |
||||
|
||||
this.toggleExpand = function (e) { |
||||
_this.setState({ expanded: !_this.state.expanded }); |
||||
}; |
||||
|
||||
this.state = { |
||||
expanded: props.expanded |
||||
}; |
||||
} |
||||
|
||||
_inherits(Node, _React$Component); |
||||
|
||||
_createClass(Node, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props = this.props; |
||||
var node = _props.node; |
||||
var label = _props.label; |
||||
var expanded = this.state.expanded; |
||||
|
||||
var rep; |
||||
if (typeof node === "string") { |
||||
rep = React.createElement(TextNode, { html: label === "html", node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (typeof node === "boolean") { |
||||
rep = React.createElement(BooleanNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (typeof node === "number") { |
||||
rep = React.createElement(NumberNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (Array.isArray(node)) { |
||||
rep = React.createElement(ListNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else { |
||||
rep = React.createElement(ObjectNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} |
||||
|
||||
if (!label) { |
||||
return rep; |
||||
} |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
null, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "label clickable", onClick: this.toggleExpand }, |
||||
label |
||||
), |
||||
": ", |
||||
rep |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Node; |
||||
})(React.Component); |
||||
|
||||
var TextNode = (function (_React$Component2) { |
||||
function TextNode() { |
||||
_classCallCheck(this, TextNode); |
||||
|
||||
_get(Object.getPrototypeOf(TextNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(TextNode, _React$Component2); |
||||
|
||||
_createClass(TextNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props2 = this.props; |
||||
var node = _props2.node; |
||||
var expanded = _props2.expanded; |
||||
var html = _props2.html; |
||||
var toggleExpand = _props2.toggleExpand; |
||||
|
||||
if (expanded) { |
||||
var content = node; |
||||
if (html) { |
||||
var content = []; |
||||
CodeMirror.runMode(node, { name: "xml", htmlMode: true }, function (text, className) { |
||||
content.push(React.createElement( |
||||
"span", |
||||
{ className: "cm-" + className }, |
||||
text |
||||
)); |
||||
}); |
||||
} |
||||
return React.createElement( |
||||
"span", |
||||
{ className: (html ? "cm-s-default html " : "") + "textNode expanded clickable", onClick: toggleExpand }, |
||||
content |
||||
); |
||||
} else { |
||||
return React.createElement( |
||||
"span", |
||||
null, |
||||
React.createElement( |
||||
"span", |
||||
{ className: (html ? "html " : "") + "textNode clickable", onClick: toggleExpand }, |
||||
node.substring(0, 30) |
||||
), |
||||
node.length > 30 ? React.createElement( |
||||
"span", |
||||
{ className: "ellipsis" }, |
||||
"..." |
||||
) : "" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return TextNode; |
||||
})(React.Component); |
||||
|
||||
var BooleanNode = (function (_React$Component3) { |
||||
function BooleanNode() { |
||||
_classCallCheck(this, BooleanNode); |
||||
|
||||
_get(Object.getPrototypeOf(BooleanNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(BooleanNode, _React$Component3); |
||||
|
||||
_createClass(BooleanNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var node = this.props.node; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "booleanNode" }, |
||||
JSON.stringify(node) |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return BooleanNode; |
||||
})(React.Component); |
||||
|
||||
var NumberNode = (function (_React$Component4) { |
||||
function NumberNode() { |
||||
_classCallCheck(this, NumberNode); |
||||
|
||||
_get(Object.getPrototypeOf(NumberNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(NumberNode, _React$Component4); |
||||
|
||||
_createClass(NumberNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var node = this.props.node; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "numberNode" }, |
||||
JSON.stringify(node) |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return NumberNode; |
||||
})(React.Component); |
||||
|
||||
var ListNode = (function (_React$Component5) { |
||||
function ListNode() { |
||||
_classCallCheck(this, ListNode); |
||||
|
||||
_get(Object.getPrototypeOf(ListNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(ListNode, _React$Component5); |
||||
|
||||
_createClass(ListNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props3 = this.props; |
||||
var node = _props3.node; |
||||
var expanded = _props3.expanded; |
||||
var toggleExpand = _props3.toggleExpand; |
||||
|
||||
if (expanded) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "listNode expanded" }, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "clickable", onClick: toggleExpand }, |
||||
"[" |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ className: "indent" }, |
||||
array_join(node.map(function (e, i) { |
||||
return React.createElement(Node, { node: e }); |
||||
}), React.createElement(Comma, { br: true })) |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ onClick: toggleExpand }, |
||||
"]" |
||||
) |
||||
); |
||||
} else { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "listNode clickable", onClick: toggleExpand }, |
||||
"[", |
||||
node.length, |
||||
"]" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return ListNode; |
||||
})(React.Component); |
||||
|
||||
var ObjectNode = (function (_React$Component6) { |
||||
function ObjectNode() { |
||||
_classCallCheck(this, ObjectNode); |
||||
|
||||
_get(Object.getPrototypeOf(ObjectNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(ObjectNode, _React$Component6); |
||||
|
||||
_createClass(ObjectNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props4 = this.props; |
||||
var node = _props4.node; |
||||
var expanded = _props4.expanded; |
||||
var toggleExpand = _props4.toggleExpand; |
||||
|
||||
if (null === node) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "nullNode" }, |
||||
"null" |
||||
); |
||||
} else if (expanded) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "objectNode expanded" }, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "clickable", onClick: toggleExpand }, |
||||
"{" |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ className: "indent" }, |
||||
array_join(Object.keys(node).map(function (key) { |
||||
return React.createElement(Node, { node: node[key], label: key }); |
||||
}), React.createElement(Comma, { br: true })) |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ onClick: toggleExpand }, |
||||
"}" |
||||
) |
||||
); |
||||
} else { |
||||
var keys = Object.keys(node), |
||||
toolong = false; |
||||
if (keys.length > 4) { |
||||
keys = keys.slice(0, 4); |
||||
toolong = true; |
||||
} |
||||
var contents = array_join(keys.map(function (k) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "label" }, |
||||
k |
||||
); |
||||
}), React.createElement(Comma, null)); |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "objectNode clickable", onClick: toggleExpand }, |
||||
"{", |
||||
contents, |
||||
toolong ? React.createElement(Ellipsis, null) : "", |
||||
"}" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return ObjectNode; |
||||
})(React.Component); |
||||
|
||||
var Comma = (function (_React$Component7) { |
||||
function Comma() { |
||||
_classCallCheck(this, Comma); |
||||
|
||||
_get(Object.getPrototypeOf(Comma.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(Comma, _React$Component7); |
||||
|
||||
_createClass(Comma, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var br = this.props.br; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "comma" }, |
||||
", ", |
||||
br ? React.createElement("br", null) : "" |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Comma; |
||||
})(React.Component); |
||||
|
||||
var Ellipsis = (function (_React$Component8) { |
||||
function Ellipsis() { |
||||
_classCallCheck(this, Ellipsis); |
||||
|
||||
_get(Object.getPrototypeOf(Ellipsis.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(Ellipsis, _React$Component8); |
||||
|
||||
_createClass(Ellipsis, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "ellipsis" }, |
||||
"..." |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Ellipsis; |
||||
})(React.Component); |
||||
|
||||
var simplething = { |
||||
hello: 42, |
||||
derp: 324, |
||||
wumbo: [1, 2, 3, 4, "hello", { |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd" |
||||
}], |
||||
merp: { |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd" |
||||
}, |
||||
strings: "asdfsd", |
||||
asdoijfo: { |
||||
strings: "asdfsd", |
||||
adfds: { |
||||
asdf: { |
||||
asdfadsf: {}, |
||||
merp: 32 |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
// React.render(<Node node={simplething} />, document.getElementById('explorer'))
|
||||
; |
@ -0,0 +1,33 @@
@@ -0,0 +1,33 @@
|
||||
class Dora extends Component { |
||||
|
||||
constructor(props){ |
||||
super(props) |
||||
this.state = { |
||||
expanded: false |
||||
} |
||||
} |
||||
|
||||
render(){ |
||||
|
||||
var {node} = this.props; |
||||
var {expanded} = this.state; |
||||
|
||||
if(Array.isArray(node)){ |
||||
return node.map(x => React.createElement(Dora, {node: x})) |
||||
}else if(typeof node == "number" || "boolean" || "string"){ |
||||
return React.createElement("span", null, JSON.stringify(node)) |
||||
}else{ |
||||
if(expanded){ |
||||
return Object.keys(node).map(key => { |
||||
return React.createElement("div", null, React.createElement(Dora, {node: key}), ": ", React.createElement(Dora, {node: node[key]}), ",") |
||||
}) |
||||
}else{ |
||||
return React.createElement("span", {onClick: e => this.setState({expanded: true})}, "click me to expand") |
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
|
||||
|
||||
React.render(React.createElement(Dora, {node: window}), document.getElementById('explorer')) |
@ -0,0 +1,33 @@
@@ -0,0 +1,33 @@
|
||||
class Dora extends React.Component { |
||||
|
||||
constructor(props){ |
||||
super(props) |
||||
this.state = { |
||||
expanded: false |
||||
} |
||||
} |
||||
|
||||
render(){ |
||||
|
||||
var {node} = this.props; |
||||
var {expanded} = this.state; |
||||
|
||||
if(Array.isArray(node)){ |
||||
return node.map(x => React.createElement(Dora, {node: x})) |
||||
}else if(typeof node == "number" || "boolean" || "string"){ |
||||
return React.createElement("span", null, JSON.stringify(node)) |
||||
}else{ |
||||
if(expanded){ |
||||
return Object.keys(node).map(key => { |
||||
return React.createElement("div", null, React.createElement(Dora, {node: key}), ": ", React.createElement(Dora, {node: node[key]}), ",") |
||||
}) |
||||
}else{ |
||||
return React.createElement("span", {onClick: e => this.setState({expanded: true})}, "click me to expand") |
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
|
||||
|
||||
React.render(React.createElement(Dora, {node: window}), document.getElementById('explorer')) |
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
{".js":"11df343c069ebf0a9691a0f47695eea12a3246f2.js"} |
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
{".js":"3f0e760c414349d4f3aef786a00f95e1bbacad28.js"} |
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
{".js":"a833cdc804f637f590c1fdf859f154ba446f4d50.js"} |
@ -0,0 +1 @@
@@ -0,0 +1 @@
|
||||
{".js":"dca5af936ce0fef1e04b7ffc040275e21f24f20b.js"} |
@ -0,0 +1,397 @@
@@ -0,0 +1,397 @@
|
||||
"use strict"; |
||||
|
||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); |
||||
|
||||
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } }; |
||||
|
||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } |
||||
|
||||
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) subClass.__proto__ = superClass; } |
||||
|
||||
function array_join(array, glue) { |
||||
var new_array = []; |
||||
for (var i = 0; i < array.length; i++) { |
||||
new_array.push(array[i]); |
||||
if (i != array.length - 1) new_array.push(glue); |
||||
} |
||||
return new_array; |
||||
} |
||||
|
||||
var Node = (function (_React$Component) { |
||||
function Node(props) { |
||||
var _this = this; |
||||
|
||||
_classCallCheck(this, Node); |
||||
|
||||
_get(Object.getPrototypeOf(Node.prototype), "constructor", this).call(this, props); |
||||
|
||||
this.toggleExpand = function (e) { |
||||
_this.setState({ expanded: !_this.state.expanded }); |
||||
}; |
||||
|
||||
this.state = { |
||||
expanded: props.expanded |
||||
}; |
||||
} |
||||
|
||||
_inherits(Node, _React$Component); |
||||
|
||||
_createClass(Node, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props = this.props; |
||||
var node = _props.node; |
||||
var label = _props.label; |
||||
var expanded = this.state.expanded; |
||||
|
||||
var rep; |
||||
if (typeof node === "string") { |
||||
rep = React.createElement(TextNode, { html: label === "html", node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (typeof node === "boolean") { |
||||
rep = React.createElement(BooleanNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (typeof node === "number") { |
||||
rep = React.createElement(NumberNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else if (Array.isArray(node)) { |
||||
rep = React.createElement(ListNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} else { |
||||
rep = React.createElement(ObjectNode, { node: node, className: "clickable", onClick: this.toggleExpand, toggleExpand: this.toggleExpand, expanded: expanded }); |
||||
} |
||||
|
||||
if (!label) { |
||||
return rep; |
||||
} |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
null, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "label clickable", onClick: this.toggleExpand }, |
||||
label |
||||
), |
||||
": ", |
||||
rep |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Node; |
||||
})(React.Component); |
||||
|
||||
var TextNode = (function (_React$Component2) { |
||||
function TextNode() { |
||||
_classCallCheck(this, TextNode); |
||||
|
||||
_get(Object.getPrototypeOf(TextNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(TextNode, _React$Component2); |
||||
|
||||
_createClass(TextNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props2 = this.props; |
||||
var node = _props2.node; |
||||
var expanded = _props2.expanded; |
||||
var html = _props2.html; |
||||
var toggleExpand = _props2.toggleExpand; |
||||
|
||||
if (expanded) { |
||||
var content = node; |
||||
if (html) { |
||||
var content = []; |
||||
CodeMirror.runMode(node, { name: "xml", htmlMode: true }, function (text, className) { |
||||
content.push(React.createElement( |
||||
"span", |
||||
{ className: "cm-" + className }, |
||||
text |
||||
)); |
||||
}); |
||||
} |
||||
return React.createElement( |
||||
"span", |
||||
{ className: (html ? "cm-s-default html " : "") + "textNode expanded clickable", onClick: toggleExpand }, |
||||
content |
||||
); |
||||
} else { |
||||
return React.createElement( |
||||
"span", |
||||
null, |
||||
React.createElement( |
||||
"span", |
||||
{ className: (html ? "html " : "") + "textNode clickable", onClick: toggleExpand }, |
||||
node.substring(0, 30) |
||||
), |
||||
node.length > 30 ? React.createElement( |
||||
"span", |
||||
{ className: "ellipsis" }, |
||||
"..." |
||||
) : "" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return TextNode; |
||||
})(React.Component); |
||||
|
||||
var BooleanNode = (function (_React$Component3) { |
||||
function BooleanNode() { |
||||
_classCallCheck(this, BooleanNode); |
||||
|
||||
_get(Object.getPrototypeOf(BooleanNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(BooleanNode, _React$Component3); |
||||
|
||||
_createClass(BooleanNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var node = this.props.node; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "booleanNode" }, |
||||
JSON.stringify(node) |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return BooleanNode; |
||||
})(React.Component); |
||||
|
||||
var NumberNode = (function (_React$Component4) { |
||||
function NumberNode() { |
||||
_classCallCheck(this, NumberNode); |
||||
|
||||
_get(Object.getPrototypeOf(NumberNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(NumberNode, _React$Component4); |
||||
|
||||
_createClass(NumberNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var node = this.props.node; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "numberNode" }, |
||||
JSON.stringify(node) |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return NumberNode; |
||||
})(React.Component); |
||||
|
||||
var ListNode = (function (_React$Component5) { |
||||
function ListNode() { |
||||
_classCallCheck(this, ListNode); |
||||
|
||||
_get(Object.getPrototypeOf(ListNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(ListNode, _React$Component5); |
||||
|
||||
_createClass(ListNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props3 = this.props; |
||||
var node = _props3.node; |
||||
var expanded = _props3.expanded; |
||||
var toggleExpand = _props3.toggleExpand; |
||||
|
||||
if (expanded) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "listNode expanded" }, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "clickable", onClick: toggleExpand }, |
||||
"[" |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ className: "indent" }, |
||||
array_join(node.map(function (e, i) { |
||||
return React.createElement(Node, { node: e }); |
||||
}), React.createElement(Comma, { br: true })) |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ onClick: toggleExpand }, |
||||
"]" |
||||
) |
||||
); |
||||
} else { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "listNode clickable", onClick: toggleExpand }, |
||||
"[", |
||||
node.length, |
||||
"]" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return ListNode; |
||||
})(React.Component); |
||||
|
||||
var ObjectNode = (function (_React$Component6) { |
||||
function ObjectNode() { |
||||
_classCallCheck(this, ObjectNode); |
||||
|
||||
_get(Object.getPrototypeOf(ObjectNode.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(ObjectNode, _React$Component6); |
||||
|
||||
_createClass(ObjectNode, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var _props4 = this.props; |
||||
var node = _props4.node; |
||||
var expanded = _props4.expanded; |
||||
var toggleExpand = _props4.toggleExpand; |
||||
|
||||
if (null === node) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "nullNode" }, |
||||
"null" |
||||
); |
||||
} else if (expanded) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "objectNode expanded" }, |
||||
React.createElement( |
||||
"span", |
||||
{ className: "clickable", onClick: toggleExpand }, |
||||
"{" |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ className: "indent" }, |
||||
array_join(Object.keys(node).map(function (key) { |
||||
return React.createElement(Node, { node: node[key], label: key }); |
||||
}), React.createElement(Comma, { br: true })) |
||||
), |
||||
React.createElement("br", null), |
||||
React.createElement( |
||||
"span", |
||||
{ onClick: toggleExpand }, |
||||
"}" |
||||
) |
||||
); |
||||
} else { |
||||
var keys = Object.keys(node), |
||||
toolong = false; |
||||
if (keys.length > 4) { |
||||
keys = keys.slice(0, 4); |
||||
toolong = true; |
||||
} |
||||
var contents = array_join(keys.map(function (k) { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "label" }, |
||||
k |
||||
); |
||||
}), React.createElement(Comma, null)); |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "objectNode clickable", onClick: toggleExpand }, |
||||
"{", |
||||
contents, |
||||
toolong ? React.createElement(Ellipsis, null) : "", |
||||
"}" |
||||
); |
||||
} |
||||
} |
||||
}]); |
||||
|
||||
return ObjectNode; |
||||
})(React.Component); |
||||
|
||||
var Comma = (function (_React$Component7) { |
||||
function Comma() { |
||||
_classCallCheck(this, Comma); |
||||
|
||||
_get(Object.getPrototypeOf(Comma.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(Comma, _React$Component7); |
||||
|
||||
_createClass(Comma, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
var br = this.props.br; |
||||
|
||||
return React.createElement( |
||||
"span", |
||||
{ className: "comma" }, |
||||
", ", |
||||
br ? React.createElement("br", null) : "" |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Comma; |
||||
})(React.Component); |
||||
|
||||
var Ellipsis = (function (_React$Component8) { |
||||
function Ellipsis() { |
||||
_classCallCheck(this, Ellipsis); |
||||
|
||||
_get(Object.getPrototypeOf(Ellipsis.prototype), "constructor", this).apply(this, arguments); |
||||
} |
||||
|
||||
_inherits(Ellipsis, _React$Component8); |
||||
|
||||
_createClass(Ellipsis, [{ |
||||
key: "render", |
||||
value: function render() { |
||||
return React.createElement( |
||||
"span", |
||||
{ className: "ellipsis" }, |
||||
"..." |
||||
); |
||||
} |
||||
}]); |
||||
|
||||
return Ellipsis; |
||||
})(React.Component); |
||||
|
||||
var simplething = { |
||||
hello: 42, |
||||
derp: 324, |
||||
wumbo: [1, 2, 3, 4, "hello", { |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd" |
||||
}], |
||||
merp: { |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd" |
||||
}, |
||||
strings: "asdfsd", |
||||
asdoijfo: { |
||||
strings: "asdfsd", |
||||
adfds: { |
||||
asdf: { |
||||
asdfadsf: {}, |
||||
merp: 32 |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
// React.render(<Node node={simplething} />, document.getElementById('explorer'))
|
||||
; |
File diff suppressed because one or more lines are too long
@ -0,0 +1,191 @@
@@ -0,0 +1,191 @@
|
||||
function array_join(array, glue){ |
||||
var new_array = [] |
||||
for(var i = 0; i < array.length; i++){ |
||||
new_array.push(array[i]) |
||||
if(i != array.length - 1) new_array.push(glue); |
||||
} |
||||
return new_array |
||||
} |
||||
|
||||
|
||||
class Node extends React.Component { |
||||
constructor(props){ |
||||
super(props) |
||||
this.state = { |
||||
expanded: props.expanded |
||||
} |
||||
} |
||||
|
||||
toggleExpand = e => { |
||||
this.setState({expanded: !this.state.expanded}) |
||||
} |
||||
|
||||
render(){ |
||||
var {node, label} = this.props |
||||
var {expanded} = this.state |
||||
|
||||
var rep |
||||
if(typeof node === "string"){ |
||||
rep = <TextNode html={label === "html"} node={node} className="clickable" onClick={this.toggleExpand} toggleExpand={this.toggleExpand} expanded={expanded}/> |
||||
} |
||||
else if(typeof node === "boolean"){ |
||||
rep = <BooleanNode node={node} className="clickable" onClick={this.toggleExpand} toggleExpand={this.toggleExpand} expanded={expanded}/> |
||||
} |
||||
else if(typeof node === "number"){ |
||||
rep = <NumberNode node={node} className="clickable" onClick={this.toggleExpand} toggleExpand={this.toggleExpand} expanded={expanded}/> |
||||
} |
||||
else if(Array.isArray(node)){ |
||||
rep = <ListNode node={node} className="clickable" onClick={this.toggleExpand} toggleExpand={this.toggleExpand} expanded={expanded}/> |
||||
} |
||||
else { |
||||
rep = <ObjectNode node={node} className="clickable" onClick={this.toggleExpand} toggleExpand={this.toggleExpand} expanded={expanded}/> |
||||
} |
||||
|
||||
if(!label){ |
||||
return rep |
||||
} |
||||
|
||||
return <span><span className="label clickable" onClick={this.toggleExpand}>{label}</span>: {rep}</span> |
||||
|
||||
} |
||||
} |
||||
|
||||
class TextNode extends React.Component { |
||||
render(){ |
||||
var {node, expanded, html, toggleExpand} = this.props |
||||
if(expanded){ |
||||
var content = node |
||||
if (html) { |
||||
var content = [] |
||||
CodeMirror.runMode(node, {name: 'xml', htmlMode: true}, (text, className) => { |
||||
content.push(<span className={"cm-"+className}>{text}</span>) |
||||
}) |
||||
} |
||||
return <span className={(html ? "cm-s-default html ":"") + "textNode expanded clickable"} onClick={toggleExpand} >{content}</span> |
||||
} |
||||
else{ |
||||
return <span> |
||||
<span className={(html? "html " : "")+"textNode clickable"} onClick={toggleExpand} >{node.substring(0,30)}</span> |
||||
{node.length > 30 ? <span className="ellipsis">...</span> : ''} |
||||
</span> |
||||
} |
||||
} |
||||
} |
||||
|
||||
class BooleanNode extends React.Component { |
||||
render(){ |
||||
var {node} = this.props |
||||
return <span className="booleanNode">{JSON.stringify(node)}</span> |
||||
} |
||||
} |
||||
|
||||
class NumberNode extends React.Component { |
||||
render(){ |
||||
var {node} = this.props |
||||
return <span className="numberNode">{JSON.stringify(node)}</span> |
||||
} |
||||
} |
||||
|
||||
class ListNode extends React.Component { |
||||
render(){ |
||||
var {node, expanded, toggleExpand} = this.props |
||||
if(expanded){ |
||||
return <span className="listNode expanded"> |
||||
<span className="clickable" onClick={toggleExpand}>[</span> |
||||
<br /> |
||||
<span className="indent"> |
||||
{array_join(node.map((e, i) => |
||||
<Node node={e} /> |
||||
),<Comma br/>)} |
||||
|
||||
</span> |
||||
<br /> |
||||
<span onClick={toggleExpand}>]</span> |
||||
</span> |
||||
} |
||||
else{ |
||||
return <span className="listNode clickable" onClick={toggleExpand}>[{node.length}]</span> |
||||
} |
||||
} |
||||
} |
||||
|
||||
class ObjectNode extends React.Component { |
||||
render(){ |
||||
var {node, expanded, toggleExpand} = this.props |
||||
|
||||
if(null === node){ |
||||
return <span className="nullNode">null</span> |
||||
} |
||||
else if(expanded){ |
||||
return <span className="objectNode expanded"> |
||||
<span className="clickable" onClick={toggleExpand}>{"{"}</span> |
||||
<br /> |
||||
<span className="indent"> |
||||
{array_join(Object.keys(node).map( |
||||
key => <Node node={node[key]} label={key} /> |
||||
),<Comma br/>)} |
||||
</span> |
||||
<br /> |
||||
<span onClick={toggleExpand}>{"}"}</span> |
||||
</span> |
||||
} |
||||
else{ |
||||
var keys = Object.keys(node), toolong = false |
||||
if (keys.length > 4) { |
||||
keys = keys.slice(0,4) |
||||
toolong = true |
||||
} |
||||
var contents = array_join(keys.map(k => <span className="label">{k}</span>), <Comma />) |
||||
return <span className="objectNode clickable" onClick={toggleExpand} >{"{"}{contents}{toolong?<Ellipsis /> : ''}{"}"}</span> |
||||
} |
||||
} |
||||
} |
||||
|
||||
class Comma extends React.Component { |
||||
render(){ |
||||
var {br} = this.props |
||||
return <span className="comma">, {br?<br />:''}</span> |
||||
} |
||||
} |
||||
|
||||
class Ellipsis extends React.Component { |
||||
render(){ |
||||
return <span className="ellipsis">...</span> |
||||
} |
||||
} |
||||
|
||||
var simplething = { |
||||
hello: 42, |
||||
derp: 324, |
||||
wumbo: [ |
||||
1, |
||||
2, |
||||
3, |
||||
4, |
||||
"hello", |
||||
{ |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd", |
||||
} |
||||
], |
||||
merp: { |
||||
blah: 32, |
||||
asdf: [], |
||||
walp: 32, |
||||
strings: "asdfsd", |
||||
}, |
||||
strings: "asdfsd", |
||||
asdoijfo: { |
||||
strings: "asdfsd", |
||||
adfds: { |
||||
asdf: { |
||||
asdfadsf: {}, |
||||
merp: 32 |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
// React.render(<Node node={simplething} />, document.getElementById('explorer'))
|
After Width: | Height: | Size: 261 KiB |
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 32 KiB |
After Width: | Height: | Size: 141 KiB |
After Width: | Height: | Size: 2.1 MiB |
After Width: | Height: | Size: 1.1 MiB |
@ -0,0 +1,61 @@
@@ -0,0 +1,61 @@
|
||||
var svg = (function(colors){ |
||||
var canvas = document.createElement('canvas'), |
||||
ctx = canvas.getContext('2d'); |
||||
|
||||
canvas.width = 10 |
||||
canvas.height = 2 |
||||
var upscale = 10 |
||||
|
||||
var im = ctx.getImageData(0,0,canvas.width,canvas.height) |
||||
for (var i = 0; i < im.data.length; i+=4) { |
||||
im.data[i] = Math.round(Math.random()*255) |
||||
im.data[i+1] = Math.round(Math.random()*255) |
||||
im.data[i+2] = Math.round(Math.random()*255) |
||||
im.data[i+3] = 255 |
||||
}; |
||||
ctx.putImageData(im,0,0) |
||||
var url = canvas.toDataURL() |
||||
im = new Image() |
||||
im.src = url |
||||
canvas.width *= upscale |
||||
canvas.height *= upscale |
||||
ctx.drawImage(im,0,0,canvas.width, canvas.height) |
||||
im = ctx.getImageData(0,0,canvas.width,canvas.height) |
||||
|
||||
var xmlns = "http://www.w3.org/2000/svg"; |
||||
var svg = document.createElementNS(xmlns, 'svg') |
||||
svg.setAttribute('viewBox',"0 0 "+im.width+" "+im.height) |
||||
for (var i = 0; i < im.data.length; i+=4) { |
||||
var mindist = 195075 |
||||
var mincolor = [0,0,0] |
||||
var pix = [im.data[i],im.data[i+1],im.data[i+2]] |
||||
for (var j = 0; j < colors.length; j++) { |
||||
var color = colors[j] |
||||
var d0 = color[0] - pix[0] |
||||
var d1 = color[1] - pix[1] |
||||
var d2 = color[2] - pix[2] |
||||
var d = Math.abs(d0)+Math.abs(d1)+Math.abs(d2) |
||||
if (d<mindist) { |
||||
mindist = d |
||||
mincolor = color |
||||
} |
||||
}; |
||||
|
||||
var n = i/4 |
||||
var elem = document.createElementNS(xmlns, "rect"); |
||||
elem.setAttributeNS(null,"x",n%im.width); |
||||
elem.setAttributeNS(null,"y",Math.floor(n/im.width)); |
||||
elem.setAttributeNS(null,"width",1.5); |
||||
elem.setAttributeNS(null,"height",1.5); |
||||
elem.setAttributeNS(null,"fill", 'rgba('+Math.min(mincolor[0]+0%2*20,255)+', '+mincolor[1]+', '+mincolor[2]+',1)'); |
||||
|
||||
svg.appendChild(elem); |
||||
}; |
||||
return svg |
||||
})([ |
||||
[39, 198, 249], |
||||
[6, 188, 249], |
||||
// [154, 218, 198],
|
||||
[116, 218, 251], |
||||
[91, 211, 251]]) |
||||
document.getElementById('marterial').appendChild(svg) |
Loading…
Reference in new issue