2019-06-23 17:17:35 +00:00
|
|
|
function output(inp) {
|
|
|
|
document.body.appendChild(document.createElement('pre')).innerHTML = inp;
|
|
|
|
}
|
|
|
|
|
|
|
|
function syntaxHighlight(json) {
|
2019-07-10 19:10:36 +00:00
|
|
|
console.log(json)
|
2019-06-23 17:17:35 +00:00
|
|
|
json = JSON.stringify(JSON.parse(json.replace(/"/g, '"')), undefined, 4)
|
2019-07-24 18:46:13 +00:00
|
|
|
json = json.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>').replace(/\p{C}+/g, '?'); // replace all non-printable characters
|
2019-06-23 17:17:35 +00:00
|
|
|
return json.replace(/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g, function (match) {
|
|
|
|
var cls = 'number';
|
|
|
|
if (/^"/.test(match)) {
|
|
|
|
if (/:$/.test(match)) {
|
|
|
|
cls = 'key';
|
|
|
|
} else {
|
|
|
|
cls = 'string';
|
|
|
|
}
|
|
|
|
} else if (/true|false/.test(match)) {
|
|
|
|
cls = 'boolean';
|
|
|
|
} else if (/null/.test(match)) {
|
|
|
|
cls = 'null';
|
|
|
|
}
|
|
|
|
return '<span class="' + cls + '">' + match + '</span>';
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function from_server(json_string){
|
|
|
|
console.log(json_string)
|
2019-07-24 18:46:13 +00:00
|
|
|
json_string = JSON.parse(json_string.replace(/"/g, '"').replace(/\p{C}+/g, '?'))
|
2019-06-23 17:17:35 +00:00
|
|
|
window.devbug = json_string
|
|
|
|
}
|
2019-07-24 20:59:15 +00:00
|
|
|
|
|
|
|
const navbar = document.getElementById('navbar')
|
|
|
|
const sticky = navbar.offsetTop;
|
|
|
|
|
|
|
|
window.onscroll = () => {
|
|
|
|
if ( window.pageYOffset >= sticky ) {
|
|
|
|
navbar.classList.add('sticky')
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
navbar.classList.remove('sticky')
|
|
|
|
}
|
|
|
|
}
|