Skip to content

Instantly share code, notes, and snippets.

@Ephellon
Created October 15, 2015 22:47
Show Gist options
  • Save Ephellon/baa215ca359b7d8fa6e4 to your computer and use it in GitHub Desktop.
Save Ephellon/baa215ca359b7d8fa6e4 to your computer and use it in GitHub Desktop.
node-mode 4.0.Baysx
<script src="../pen/ByPOee.js"></script>
<script>
setUpdate(true);
</script>
<node-mode>
[- no console mode -]
doctype: html
[- multi-line comment -]
!~ single line comment
%h4..icon-incognito paper-like rounded-edges fixed-to-left background=update background:transparent opacity:1 :1500ms > /h4/
%h4..page paper-like paper-ripple-right text-center text-to-none background=black background:matte:off-black color=update-darker color:update border@bottom border=update-darker border:update :1500ms >
\#node: node-mode 4.0.Ba&gamma;s&chi;
=..ripple background=update > =/
/h4/
%h4..page paper-like paper-ripple-left text-center text-to-none background=white background:gray color=update-darker color:update-lighter! border@bottom border=black border:update! :1500ms >
=..implant-time@12 implant:time@24 > It's =/
=..ripple background=update! > =/
/h4/
--!--
</node-mode>
<style>
body {
background: #525554;
}
</style>
// The node-mode project [Ephellon Dantzler]: December 15, 2014
// Ephellon Dantzler - May 16, 2015
// Original source, NM-IV Basic
// Beautified using Uglify
document.body.style = "display:none";
var __console__ = {
font: "Arial",
start: "#00aced",
comment: "#ff5312",
text: "#fff",
tag: "#bfbf00",
value: "#fe8",
attribute: "#8f8",
background: "inherit"
}, nm = {
get: {
form: {
data: function() {
x = 0;
l = window.location.search + "";
if (/\?/.test(l) === !1) return !1;
l = l
.replace("?", "")
.replace(/\\("|')/g, "\\\\\\$1")
.replace(/[^\\]("|')/g, "\\$1");
if (!l || "" === l) return !1;
a = l
.replace(/=/g, '":"').split("&");
R = '{"';
for (;x < a.length - 1; ) {
R += a[x] + '","';
x++;
}
R += a[x] + '"}';
R = (R + "")
.replace(",\n", ",");
R = JSON.parse(R);
return input = R, R;
}
}
},
storage: {
set: function() {
for (var e = 0, t = !1; e < arguments.length; ) {
if ("undefined" != typeof Storage) {
localStorage.setItem(arguments[e], arguments[e + 1]);
e += 2;
t = !0;
}
e += 2;
}
return t;
},
check: function(e) {
var t = !!nm.storage.get(e);
return t;
},
get: function(e) {
e = localStorage.getItem(e);
return e;
},
"delete": function(e) {
localStorage.setItem(e, null);
return 1 != nm.storage.check(e);
}
},
attr: function(e, t, a) {
if (e) if (!a) return e.getAttribute(t); else return "!" != a ? e.setAttribute(t, a) : e.getAttribute(t);
},
id: function(e, t, a) {
if ("!" != e && e) {
g = document.getElementById(e) || document.getElementById(e + " ");
if (a) return nm.attr(g, t, a);
if (t) if ("$html" != t) g.innerHTML = t; else return g.innerHTML;
return g;
}
},
notify: function(e, t, a) {
if (Notification) {
if ("granted" !== Notification.permission) Notification.requestPermission();
var r = new Notification(t, {
body: e,
icon: a.icon || "",
dir: a.dir || "",
lang: a.lang || "",
tag: a.tag || ""
});
r.onclick = function() {
if (a.href) window.open(a.href);
if (a.notice) alert(a.notice);
if (a.prompt) return prompt(a.prompt, a.promptDefault);
if (a.confirm) return confirm(a.confirm); else return void 0;
};
r.onerror = function() {
alert(a.error || "an error occured");
};
r.onclose = function() {
alert(a.close || "closed");
};
r.onshow = function() {
alert(a.show || "opened");
};
} else alert(e);
},
"class": function(e, t, a, r) {
if ("!" != e && e) {
g = document.getElementsByClassName(e);
if (!r) {
if (a) if ("$html" != a) g[t].innerHTML = a; else return g[t].innerHTML;
return g;
} else nm.attr(g[t], a, r);
}
},
tag: function(e, t, a, r) {
if ("!" != e && e) {
g = document.getElementsByTagName(e);
if (!r) {
if (a) if ("$html" != a) g[t].innerHTML = a; else return g[t].innerHTML;
return g;
} else nm.attr(g[t], a, r);
}
},
ele: function(e, t, a, r) {
if ("!" != e && e) {
g = document.querySelectorAll(e);
if (g.length < 2) t = 0;
if (!r) {
if (a) if ("$html" != a) g[t].innerHTML = a; else return g[t].innerHTML;
return g;
} else nm.attr(g[t], a, r);
}
},
save: function(e, t) {
k = window.location + "";
t = t || k.substring(k.lastIndexOf("/") + 1, k.length) + ".cache";
nm.storage.set(t, e);
return nm.storage.check(t);
},
load: function(e, t, a, r) {
a = a || !1;
e = a ? encodeURI(name) : name;
r = r || document.body;
t = t || e.substr(0, e.indexOf("."));
k = window.location + "";
e = e || k.substring(k.lastIndexOf("/") + 1, k.length) + ".cache";
return nm.storage.get(name);
},
"delete": function(e) {
k = window.location + "";
e = e || k.substring(k.lastIndexOf("/") + 1, k.length) + ".cache";
g = nm.storage.delete(name);
return g;
}
}, getFormData = nm.get.form.data, setStorage = nm.storage.set, getStorage = nm.storage.get, checkStorage = nm.storage.check, deleteStorage = nm.storage.delete, getClass = getClass || nm.class, getTag = getTag || nm.tag, getElement = getElement || nm.ele, notify = nm.notify, Save = nm.save, Load = nm.load, Delete = nm.delete, attr = attr || nm.attr, getId = getId || nm.id;
function node_mode(r) {
r = r || 0;
var stack = getTag("node-mode")[parseInt(r + "")] || document.body;
if (!stack.node_mode) {
stack.innerHTML = stack.innerHTML
.replace(/--!--/g, "[- end node-mode -]");
Ele = stack.innerHTML + (/(\[-\send\snode-mode\s-\])/g.test(stack.innerHTML) ? "" : "[- end node-mode -]");
Ele = Ele.substr(0, Ele.indexOf("[- end node-mode -]"));
ele = [];
pat = /@for/g;
for (var cons = /\[-\sconsole\smode\s-\]/gm.test(Ele) === !0 && /\[-\sno\sconsole\smode\s-\]/gim.test(Ele) === !1; pat.test(Ele); ) {
for (var lett = Ele.substring(Ele.indexOf("@for ") + 5, Ele.indexOf(" loop(")), num = Ele.substring(Ele.indexOf("loop(") + 5, Ele.indexOf("x)")), expr = Ele.substring(Ele.indexOf("x)") + 2, Ele.indexOf("@end " + lett)), back_ = "", k = 0; k < eval(num); k++) {
equ = expr.substring(expr.indexOf("$" + lett + "=%(") + (4 + lett.length), expr.indexOf(")%"));
equ = /\s{1,}/.test(equ) ? "this" : equ;
val = equ
.replace(/this/g, k);
val = eval(val);
for_ = RegExp("\\$" + lett, "gm");
back_ += expr
.replace("$" + lett + "=%(" + equ + ")%", val)
.replace(for_, val);
}
Ele = Ele
.replace("@for " + lett + " loop(" + num + "x)" + expr + "@end " + lett, back_);
}
Ele = manage(Ele, attr(getTag("node-mode")[r], "compile-language"));
stack.innerHTML = ele[ele.length] = Ele;
stack.node_mode = "true";
ifs = getTag("if");
if (ifs) for (var K = 0; K < ifs.length; K++) if (eval("(" + attr(ifs[K], "boolean") + " === true)")) attr(ifs[K], "pass", "true"); else ifs[K].innerHTML = attr(ifs[K], "else")
.replace(/@html/g, ifs[K].innerHTML) || "";
if (cons === !0) {
stack.innerHTML = stack.innerHTML
.replace(/~/g, "~til")
.replace(/<\!\-\-\sconsole\smode\s\-\->/g, "~style~~ body, node-mode, [node-mode] {color:" + (__console__.text || "#fff") + ";font-family:" + (__console__.font || "monospace") + ";background-color:" + (__console__.background || "#000") + ";margin: 0; padding: 0; border: 0;font-size: 100%;vertical-align: baseline;} [a]{color:" + (__console__.value || "#fe8") + ";} [d]{color:" + (__console__.tag || "#bfbf00") + ";} [c]{color:" + (__console__.attribute || "#8f8") + ";} [e]{color:" + (__console__.comment || "#ff5312") + ";}~/style~~ ~span style ='color:" + (__console__.start || "#00aced") + ";'~~ [console mode] ~/span~~~br/~~");
a = "~span a~~";
a_ = "~/span~~";
b = "~span b~~";
c = "~span c~~";
d = "~span d~~";
e = "~span e~~";
e_ = d_ = c_ = b_ = a_;
stack.innerHTML = stack.innerHTML
.replace(/(<|&lt;)/g, "&lt;")
.replace(/(>|&gt;)/g, "&gt;")
.replace(/\s"/g, '" ')
.replace(/"(.+)"/g, a + '"$1"' + a_)
.replace(/(accept|accept-charset|accesskey|action|align|alt|async|autocomplete|autofocus|autoplay|autosave|bgcolor|boolean|border|buffered|challenge|charset|checked|cite|class|code|codebase|color|cols|colspan|content|contenteditable|contextmenu|controlas|coords|data|data-\w+|datetime|default|defer|dir|dirname|disabled|download|draggable|dropzone|else|enctype|for|form|formaction|headers|height|hidden|high|href|hreflang|http-equiv|icon|id|ismap|itemprop|keytype|kind|label|lang|language|list|loop|low|manifest|max|maxlength|media|method|min|multiple|name|novalidate|open|optimum|pattern|ping|placeholder|poter|preload|pubdate|radiogroup|readonly|rel|required|reversed|rows|rowspan|sandbox|scope|scoped|seamless|selected|shape|size|sizes|span|spellcheck|src|srcdoc|srclang|srcset|start|step|style|summary|tabindex|target|title|type|usemap|value|width|wrap)[\=]/g, c + "$1=" + c_)
.replace(/&lt;\/(\w+)&gt;/g, "&lt;/$1&gt;~br/~~")
.replace(/&gt;\s+&lt;/g, "&gt;&lt;")
.replace(/\s+&lt;/g, "~br/~~&lt;")
.replace(/\n/g, "~br/~~")
.replace(/&lt;(\w+)\s*/g, d + "&lt;$1 " + d_)
.replace(/(&lt;\/(.+)&gt;)/g, d + "$1" + d_)
.replace(/(\n|\s|")\s*&gt;/g, d + "&gt;" + d_)
.replace(/&lt;!--(.+)--&gt;/g, e + "&lt;!--$1--&gt;" + e_)
.replace(/\s{2,}/g, "&nbsp;")
.replace(/~~/g, ">")
.replace(/~/g, "<")
.replace(/~til/g, "~");
}
}
}
function pattern(e, t, a) {
if (e) {
t += "";
e = RegExp(e);
t = t
.replace(e, a);
return t;
}
}
function manage(e, l) {
e = e
.replace(/\[\[\s+\]\]/g, "")
.replace(/\[\[\]\]/g, "");
e = e
.replace(/@set.(.+).\{(.+)\};/g, '<span script-data:$1 style="display:none" id="data-$1">$2</span>');
e = e
.replace(/@bind.\(\{(.+)\}:\{(.+)\}\);/g, "<span script-bind:$1::$2 style=\"display:none\" id=\"data-$2\" $=\"getId('data-$2').bound = '#$1'; attr(getId('data-$2'), 'bound', '#$1'); ( getId('data-$1') || getId('data-onerror') ).innerHTML\"></span>");
e = e
.replace(/@get.(.+);/g, "<span script-get:$1 $=\"( getId('data-$1') || getId('data-onerror') ).innerHTML\"></span>");
e = e
.replace(/@import.\(\{\s*(.+)\s*\}\).(.+)\.(\w+);/g, "<link script-import:$1 rel=\"import prefetch\" id=\"import-$1\" onload=\"window.$1 = $1 = getId('import-$1').import; if('$3' == 'js'){ eval('window.$1 = $1 = $1.body.innerText'); eval($1) } console.log('@import successful for: $1 [$3]');\" onerror=\"console.log('@import error for: $1, $2 [$3]')\" href=\"http://codepen.io/Ephellon/debug/qdzebY?url=$2\">");
l = l || "native";
for (;/\[\[/g.test(e) && /\]\]/g.test(e); ) {
native = e.substring(e.indexOf("[[") + 2, e.indexOf("]]"));
native = native
.replace(/\\/g, "\\\\")
.replace(/#/g, "\\#")
.replace(/\./g, "\\.")
.replace(/\//g, "\\/")
.replace(/--/g, "\\--")
.replace(/\=/g, "\\=")
.replace(/%/g, "\\%")
.replace(/\{/g, "\\{")
.replace(/\}/g, "\\}")
.replace(/\[/g, "\\[")
.replace(/\]/g, "\\]")
.replace(/\(/g, "\\(")
.replace(/\)/g, "\\)");
e = e
.replace(/\[\[.+\]\]/m, native);
}
e = e
.replace(/~/g, "~til")
.replace(/(\|\s+|\.)\.\./gm, "~elp")
.replace(/(\|\s+)\.\.\//gm, "~up1")
.replace(/(\\|\|\s+)\{/g, "~ocb")
.replace(/(\\|\|\s+)\}/g, "~ccb")
.replace(/(\\|\|\s+)\[/g, "~ob")
.replace(/(\\|\|\s+)\]/g, "~cb")
.replace(/(\\|\|\s+)\(/g, "~op")
.replace(/(\\|\|\s+)\)/g, "~cp")
.replace(/(\\|\s)#/g, "~has")
.replace(/(\\|\|\s+)\./g, "~per")
.replace(/(\\|\|\s+)\//g, "~fws")
.replace(/(\\|\|\s+)\=/g, "~equ")
.replace(/(\\|\|\s+)%/g, "~pec")
.replace(/(\\|\|\s+)\\/g, "~bks")
.replace(/\\--/g, "~dds")
.replace(/(\\|\|\s+)-/gm, "~das")
.replace(/(\\|\|\s+)\?/g, "~que")
.replace(/(\\|\|\s+)!/g, "~exc")
.replace(/(\|\s+|\\)\\$/gm, "~dol")
.replace(/!\s{3,}/gm, "");
switch (l) {
case "haml":
break;
case "jade":
break;
case "slim":
break;
case "":
case "none":
e = e || document.body.innerHTML;
break;
case "node-mode-4":
case "node-mode-3":
case "native":
e = e
.replace(/doctype:(.+)/gim, "<!DOCTYPE $1>")
.replace(/@\{/gm, "[- %{")
.replace(/\}@/gm, "}% -]")
.replace(/%%/gm, "%~pec")
.replace(/%(\/|\{|\[|\()/gm, "~pec$1")
.replace(/(\/|\}|\]|\))%/gm, "$1~pec")
.replace(/=( = | == )/gm, "~equ$1")
.replace(/%(a|area|link):\.\./g, '%$1 href="~up1')
.replace(/%(a|area|link):#/g, '%$1 href="~has')
.replace(/%(a|area|link):/g, '%$1 href="')
.replace(/%(embed|frame|iframe|img|input|script|style):/g, '%$1 src="')
.replace(/=#/g, "%span#")
.replace(/%#/g, "%div#")
.replace(/%([\w\d\$_-]+)#([\w\d\.\$_-]+)(\s|\.\.|\s--|&gt;|>)/g, '%$1 id="$2" $3')
.replace(/=\.\./g, "%span..")
.replace(/%\.\./g, "%div..")
.replace(/%([\w\d\$_-]+)\.\.(.+)\s*(--|&gt;|>)/g, '%$1 class="$2" $3')
.replace(/=\//g, " /span>")
.replace(/\s+--/g, ' "')
.replace(/\(\(/g, "%div ")
.replace(/(\)\)|%\/)/g, " /div>")
.replace(/o\{(\s+)\n/g, "o{>")
.replace(/o\{/g, "%ol ")
.replace(/\}o/g, "/ol>")
.replace(/u\{(\s+)\n/g, "u{>")
.replace(/u\{/g, "%ul ")
.replace(/\}u/g, "/ul>")
.replace(/s\{(\s+)\n/g, "s{>")
.replace(/s\{/g, "%select ")
.replace(/\}s/g, "/select>")
.replace(/l\{(\s+)\n/g, "l{>")
.replace(/l\{/g, "%li ")
.replace(/\}l/g, "/li>")
.replace(/p\{(\s+)\n/g, "p{>")
.replace(/p\{/g, "%option ")
.replace(/\}p/g, "/option>")
.replace(/%/g, "<")
.replace(/\/(\n|\s)/g, "/>$1")
.replace(/(\n|\s)\//g, "$1</")
.replace(/&gt;/g, ">")
.replace(/!~(til)(.+)\n/g, "[-$2-]")
.replace(/\[-/g, "<!--")
.replace(/-\]/g, "-->")
.replace(/[^=]"">/g, '">');
}
e = e
.replace(/~til/g, "~")
.replace(/~elp/gm, "...")
.replace(/~up1/gm, "../")
.replace(/~ocb/g, "{")
.replace(/~ccb/g, "}")
.replace(/~ob/g, "[")
.replace(/~cb/g, "]")
.replace(/~op/g, "(")
.replace(/~cp/g, ")")
.replace(/~has/g, "#")
.replace(/~per/g, ".")
.replace(/~fws/g, "/")
.replace(/~equ/g, "=")
.replace(/~pec/g, "%")
.replace(/~bks/g, "\\")
.replace(/~dds/g, "--")
.replace(/~das/gm, "-")
.replace(/~que/g, "?")
.replace(/~exc/g, "!")
.replace(/~dol/gm, "$");
n = [ "\\$" ];
for (var b = 0; b < n.length; b++) for (;RegExp(n[b] + "\\{", "g").test(e) && RegExp("\\}" + n[b], "g").test(e); ) {
var t = n[b], _b = e.substring(e.indexOf(t + "{") + 2, e.indexOf("}" + t)), b_ = JSON.parse('{"back":"function() {return ' + _b + ';}"}');
b_ = b_.back;
eval("b_ = " + b_);
e = e
.replace(t + "{" + _b + "}" + t, "<!-- SCRIPT: " + b_ + " -->");
}
n = [ "%", "~", "%1", "%2", "%3", "%4", "%5", "%6", "%7", "%8", "%9" ];
for (var b = 0; b < n.length; b++) for (;RegExp(n[b] + "\\{", "g").test(e) && RegExp("\\}" + n[b], "g").test(e); ) {
var t = n[b], _b = e.substring(e.indexOf(t + "{") + 2, e.indexOf("}" + t)), b_ = JSON.parse('{"back":"function() {return ' + _b + ';}"}');
b_ = b_.back;
eval("b_ = " + b_);
e = e
.replace(t + "{" + _b + "}" + t, b_);
}
n = [ "@" ];
for (var b = 0; b < n.length; b++) for (;RegExp(n[b] + "\\{", "g").test(e) && RegExp("\\}" + n[b], "g").test(e); ) {
var t = n[b], _b = e.substring(e.indexOf(t + "{") + 2, e.indexOf("}" + t)), b_ = JSON.parse('{"back":"function() {' + _b + '; return;}"}');
b_ = b_.back;
eval("b_ = " + b_);
e = e
.replace(t + "{" + _b + "}" + t, b_);
}
return e;
}
if (document.onreadystatechange) document.onreadystatechange = function() {
if ("complete" === document.readyState) {
document.body.innerHTML = document.body.innerHTML.replace(/"\=""/g, "");
document.body.style = "display:initial";
node_mode();
k = getElement("[\\$]");
for (var p = 0; p < k.length; p++) {
k[p].innerHTML = eval(attr(k[p], "$"));
attr(k[p], "$", "");
}
}
}; else {
document.body.innerHTML = document.body.innerHTML.replace(/"\=""/g, "");
document.body.style = "display:initial";
node_mode();
k = getElement("[\\$]");
for (var p = 0; p < k.length; p++) {
k[p].innerHTML = eval(attr(k[p], "$"));
attr(k[p], "$", "");
}
}
/* (c) icons to Chromium Authors
* icon-name
* incognito
* mic
* dino
* error
* cloud
* search
* minus
* plus
* plugins
* help
* warn
* delete
* hazard
* CodePen badges, (c) "CodePen"
* badge
* badge-pro
* badge-hire
* badge-delete
* badge-details
* badge-ok
* badge-yellow
* badge-blue
* badge-red
* badge-pruple
* badge-green
* badge-pink
* badge-orange
* badge-black
* badge-white
*/
.node-mode-disable, .nmd\!, [\:nmd\!], [\#\!nmd] {
pointer-events: none;
}
.badge, .badge-pro, .badge-hire, .badge-delete, .badge-details, .badge-ok, .badge-yellow, .badge-blue, .badge-red, .badge-pruple, .badge-green, .badge-pink, .badge-orange, .badge-black, .badge-white {
font-size: 0.8rem;
border-radius: 3px;
position: relative;
top: 0;
-na-text-transform: uppercase;
padding: 1px 3px 1px 3px;
color: #000;
text-shadow: none;
white-space: nowrap;
font-weight: 700;
}
.badge-pro, .badge-yellow {
background: linear-gradient(#f7ec13, #b8892d);
} .badge-pro:after {
content: 'PRO';
}
.badge-hire, .badge-blue {
background: linear-gradient(#59c1d4, #268ad0);
} .badge-hire:after {
content: 'HIRE-ME';
}
.badge-delete, .badge-red {
background: linear-gradient(#f00, #a00808);
} .badge-delete:after {
content: 'DELETE';
}
.badge-details, .badge-purple {
background: linear-gradient(#a561cb, #7221c7);
} .badge-details:after {
content: 'DETAILS';
}
.badge-ok, .badge-green {
background: linear-gradient(#66ce5b, #339b28);
} .badge-ok:after {
content: 'OK';
}
.badge-pink {
background: linear-gradient(#ff69b4, #cc3681);
}
.badge-orange {
background: linear-gradient(#ed8820, #ba5500);
}
.badge-black {
color: #fff;
background: linear-gradient(#333, #000);
}
.badge-white {
background: linear-gradient(#fff, #ede);
}
.icon-incognito {
padding: 1px;
content: url('');
}
.icon-mic {
padding: 1px;
content: url('');
}
.icon-dino {
padding: 1px;
content: url('');
}
.icon-error {
padding: 1px;
content: url('');
}
.icon-cloud {
padding: 1px;
content: url('');
}
.icon-search {
padding: 1px;
content: url('');
}
.icon-minus {
padding: 1px;
content: url('');
}
.icon-plus {
padding: 1px;
content: url('');
}
.icon-plugins {
padding: 1px;
content: url('');
}
.icon-help {
padding: 1px;
content: url('');
}
.icon-warn {
padding: 1px;
content: url('');
}
.icon-delete {
padding: 1px;
content: url('');
}
.icon-hazard {
padding: 1px;
content: url()
}
<link href="http://codepen.io/Ephellon/pen/ByPOee.css" rel="stylesheet" />
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment