// ==UserScript==
// @name JSON Viewer
// @namespace http://tampermonkey.net/
// @version v0.7.2
// @author Feny
// @description 格式化显示JSON使数据看起来更加漂亮,支持折叠/展开格式化后的数据,支持JSON脑图让调用层级看着更清晰,支持复制JSON脑图节点路径
// @icon 
// @homepage https://github.com/xFeny/monkey-jsonviewer
// @match *://*/*
// @require https://unpkg.com/[email protected]/dist/dom-to-image.min.js
// @require https://unpkg.com/[email protected]/dist/jquery.min.js
// @require data:application/javascript,%3Bwindow.jQuery%3DjQuery%3B%3Bwindow.jquery%3DjQuery%3B
// @require https://unpkg.com/[email protected]/es6/jsmind.js
// @require data:application/javascript,%3Bwindow.jsMind%3DjsMind%3Bwindow.jsmind%3DjsMind%3B
// @require https://unpkg.com/[email protected]/es6/jsmind.screenshot.js
// @require https://unpkg.com/[email protected]/dist/system.min.js
// @require https://unpkg.com/[email protected]/dist/extras/named-register.min.js
// @require data:application/javascript,%3B(typeof%20System!%3D'undefined')%26%26(System%3Dnew%20System.constructor())%3B
// @resource jsmind https://unpkg.com/[email protected]/style/jsmind.css
// @grant GM_addStyle
// @grant GM_getResourceText
// @grant GM_getValue
// @grant GM_openInTab
// @grant GM_registerMenuCommand
// @grant GM_setClipboard
// @grant GM_setValue
// @grant unsafeWindow
// @note v0.6.9 切换为暗黑主题,tab栏和JSONCrak的也跟着改变
// @note v0.6.6 增加多一种暗黑主题,默认主题色修改
// @note v0.6.3 修复暗黑主题,tab颜色问题
// @note v0.6.2 脑图增加JSON Crack
// @note v0.6.1 增加多一种浅色主题
// @note v0.6.0 增加简单HTTP 请求功能,可请求GET/POST/PUT/DELETE的API接口,而不单单只能GET请求使用
// @note v0.5.9 jsonp格式小优化
// @note v0.5.8 增加JSON手动输入
// @note v0.5.7 一些小细节优化
// @note v0.5.6 修复BUG
// @note v0.5.5 解决@require jquery-simple-tree-table.min.js依赖加载失败问题
// @note v0.5.4 单击复制修改为CTRL+单击复制JSONPath功能,JSON格式化风格增加table格式
// @note v0.5.3 增加暗黑主题色
// @note v0.5.2 单击JSON格式化的key可复制JSONPath
// @note v0.5.1 修复JSONPath提示有误
// @note v0.5.0 解决chrome 120+以上内核JSON格式化不执行和引入layer报错问题
// @note v0.4.9 布局修改,增加保存JSON/脑图为文件,增加JSON过滤,鼠标移入key提示JSONPath
// @note v0.4.8 代码优化
// @note v0.4.7 增加对JSONP的判断,代码优化
// @note v0.4.6 增加复制按钮,JSON脑图CSS样式细节优化,JSON脑图增加收起/展开子节点按钮
// @note v0.4.5 在json-viewer-updated原基础上进行了一些修改,主要有CSS样式修改,新增折叠/展开全部功能,新增JSON脑图功能,脑图节点点击显示调用路径
// ==/UserScript==
(o=>{window.addEventListener("message",a=>{const{data:t}=a;if(t&&t.isJSON){if(typeof GM_addStyle=="function"){GM_addStyle(o);return}const r=document.createElement("style");r.textContent=o,document.head.append(r)}})})(' @charset "UTF-8";body,html{margin:0;padding:0;font-size:14px}body td,html td{font-size:14px}body li::marker,html li::marker{content:""}body input:focus,body select:focus,body textarea:focus,html input:focus,html select:focus,html textarea:focus{outline:0}.hidden{display:none!important}.layui-layer-tips{width:auto!important}.format-container{z-index:10;position:fixed;width:100vw;height:100vh;display:flex;flex-direction:column}.format-container .tabs,.format-container .toolbar{display:flex;line-height:28px;background-color:#ececec;border-bottom:1px solid #ccc}.format-container .toolbar{line-height:23px}.format-container .toolbar .searchbox{display:flex;flex-grow:1}.format-container .toolbar .searchbox input{flex-grow:1;border:none;outline:none;font-size:12px;padding-left:23px;background-size:12px;background-repeat:no-repeat;background-position:7px center;background-image:url()}.format-container .toolbar .searchbox .clear{flex:0 0 auto;align-self:center;margin:0 4px;padding:0;border:0;width:16px;height:16px;background-color:transparent;background-image:url()}.format-container .tabs-item{border-width:3px;border-top:3px solid #ececec}.format-container .tabs-item.active{color:#0060df;border-top-color:#0060df;background-color:#e9e9e9}.format-container .tabs-item:hover{border-top-color:#c3c3c6}.format-container .tabs-item,.format-container .toolbar-item{cursor:pointer;padding:0 10px;font-size:12px}.format-container .tabs-item:hover,.format-container .toolbar-item:hover{background-color:#d4d4d4}.format-container .tabs .selectbox{position:absolute;right:200px;display:flex;font-size:13px}.format-container .inputJson,.format-container .fetchApi{cursor:pointer;color:#0060df;margin-left:15px}.format-container .tabs-container{flex-grow:1;overflow:auto;line-height:1.4;font-family:monospace}.format-container .tabs-container>div{display:none}.format-container .tabs-container>div.active{display:block}.format-container .tabs-container #formatContainer{padding:10px}.format-container .tabs-container #rawTextContainer{padding:0 10px}.format-container .tabs-container #rawTextContainer pre{display:block!important;overflow-wrap:break-word;white-space:pre-wrap}.format-container .jsonp{color:#93983a}.format-container ul.json-object,.format-container ul.json-array{margin:0 0 0 2px;list-style-type:none;border-left:1px dotted #5d6d7e;padding-left:24px}.format-container .json-brackets{font-weight:700}.format-container .json-key{color:#910f93;cursor:pointer}.format-container .json-string,.format-container .json-string a{color:#2e7c16}.format-container .json-number{color:#164ff1}.format-container .json-boolean{color:#905}.format-container .json-null{color:#228fec}.format-container a.json-toggle{position:rElative;color:inherit;opacity:.2;text-decoration:none}.format-container a.json-toggle:hover{opacity:.35}.format-container a.json-toggle:active{opacity:.5}.format-container a.json-toggle:focus{outline:none}.format-container a.json-toggle:before{top:2.5px;left:-15px;position:absolute;content:"";display:block;width:0;height:0;border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent currentColor;transform:rotate(90deg)}.format-container a.json-toggle.collapsed:before{transform:rotate(0)}.format-container a.json-placeholder{color:#ccc;font-size:12px;padding:0 1em;text-decoration:none}.format-container a.json-placeholder:hover{text-decoration:underline}.format-container .json-curly-brackets{color:#6d9331}.format-container .json-square-brackets{color:#8e9331}.format-container #jmContainer{width:100vw;height:calc(100vh - 57px)}.format-container #jmContainer jmnode{display:flex;align-items:center;padding:0 7px 0 22px;color:#475872!important;box-shadow:none!important;background-color:transparent!important}.format-container #jmContainer jmnode.root{padding:0;color:transparent!important}.format-container #jmContainer jmnode:before{content:"";top:50%!important;margin-top:1.5px;position:absolute;border-radius:50%;transform:translateY(-50%)}.format-container #jmContainer jmnode.root:before{left:50%;width:18px;height:18px;transform:translate(-18px,-50%)}.format-container #jmContainer jmnode:hover{text-shadow:0px 0px 1px currentColor}.format-container #jmContainer jmnode:not(.root):before{left:0;width:15px;height:15px}.format-container #jmContainer jmexpander{margin-top:1px;line-height:9px}.format-container #jmContainer .datatype{opacity:.6;font-size:12px;margin-top:2px;padding-left:5px}.format-container table{width:-webkit-fill-available;margin-left:20px;border-collapse:collapse}.format-container table tr:hover{background-color:#f0f9fe}.format-container table tr.selected td,.format-container table tr.selected td a{color:#fff!important;background-color:#3875d7}.format-container table tr td:first-child{width:120px}.format-container table .tree-len{color:#ccc;font-size:13px}.format-container table .simple-tree-table-icon{color:#000;opacity:.2;width:0!important;margin:0!important;line-height:0!important}.format-container table .simple-tree-table-icon:before{top:.5px;left:-15px;position:relative;content:"";width:0;height:0;display:none;border-style:solid;border-width:5px 0 5px 8px;border-color:transparent transparent transparent currentColor;transform:rotate(90deg)}.format-container table .simple-tree-table-icon::hover{opacity:.35}.format-container table .simple-tree-table-icon:after{content:""!important}.format-container table .simple-tree-table-icon::active{opacity:.5}.format-container table .simple-tree-table-opened .simple-tree-table-icon:before{display:block}.format-container table .simple-tree-table-closed .simple-tree-table-icon:before{display:block;transform:rotate(0)}.httpRequest{padding:20px}.httpRequest input,.httpRequest select{border-radius:0;padding-left:10px;border:1px solid #ccc}.requestbox,.textarea{width:700px;display:flex}.requestbox{height:35px;margin-bottom:15px}.requestbox input{flex-grow:1}.requestbox button{cursor:pointer;padding:0 15px;border:1px solid #ccc}.requestbox button:active{background-color:#cfcfcf}.textarea input{flex-grow:1;height:30px}.light .json-key{color:#0040cf}.light .json-string,.light .json-string a{color:#a31515}.light .json-number{color:#0b7500}.light .json-boolean{color:#00f}.light .json-null{color:#05f}body.dark .format-container li,body.dark .format-container pre,body.dark_IntelliJ .format-container li,body.dark_IntelliJ .format-container pre{color:#ccc}body.dark .format-container .tabs,body.dark .format-container .toolbar,body.dark_IntelliJ .format-container .tabs,body.dark_IntelliJ .format-container .toolbar{color:#c4c4c4;border-bottom-color:#464646;background-color:#333}body.dark .format-container .tabs .tabs-item,body.dark .format-container .toolbar .tabs-item,body.dark_IntelliJ .format-container .tabs .tabs-item,body.dark_IntelliJ .format-container .toolbar .tabs-item{border-top-color:#333}body.dark .format-container .tabs .tabs-item.active,body.dark .format-container .toolbar .tabs-item.active,body.dark_IntelliJ .format-container .tabs .tabs-item.active,body.dark_IntelliJ .format-container .toolbar .tabs-item.active{color:#c4c4c4;border-top-color:#64b7ff;background-color:#464646}body.dark .format-container .tabs .tabs-item:hover,body.dark .format-container .tabs .toolbar-item:hover,body.dark .format-container .toolbar .tabs-item:hover,body.dark .format-container .toolbar .toolbar-item:hover,body.dark_IntelliJ .format-container .tabs .tabs-item:hover,body.dark_IntelliJ .format-container .tabs .toolbar-item:hover,body.dark_IntelliJ .format-container .toolbar .tabs-item:hover,body.dark_IntelliJ .format-container .toolbar .toolbar-item:hover{border-top-color:#64b7ff;background-color:#464646}body.dark .format-container .searchbox input,body.dark_IntelliJ .format-container .searchbox input{color:#ccc;background-color:#464646;border-left:1.5px solid #333333}body.dark .format-container .searchbox .clear,body.dark_IntelliJ .format-container .searchbox .clear{filter:invert(.8)}body.dark .format-container .selectbox select,body.dark_IntelliJ .format-container .selectbox select{border:0;color:#333;background-color:#ccc}body.dark .format-container .selectbox .inputJson,body.dark .format-container .selectbox .fetchApi,body.dark_IntelliJ .format-container .selectbox .inputJson,body.dark_IntelliJ .format-container .selectbox .fetchApi{color:#85c6ff}body.dark .format-container .jsonp,body.dark_IntelliJ .format-container .jsonp{color:#f1d700}body.dark .format-container .json-toggle,body.dark_IntelliJ .format-container .json-toggle{opacity:.35}body.dark .format-container .json-toggle:hover,body.dark_IntelliJ .format-container .json-toggle:hover{opacity:.5}body.dark .format-container jmnode,body.dark_IntelliJ .format-container jmnode{filter:brightness(2)}body.dark .format-container jmexpander,body.dark_IntelliJ .format-container jmexpander{background-color:#dfdfdf}body.dark .format-container table tr:hover,body.dark_IntelliJ .format-container table tr:hover{background-color:#353b48}body.dark .format-container .simple-tree-table-icon,body.dark_IntelliJ .format-container .simple-tree-table-icon{color:#fff;opacity:.5}body.dark .format-container .tabs-container{background-color:#252526}body.dark .format-container .json-curly-brackets{color:#ce70d6}body.dark .format-container .json-square-brackets{color:#f1d700}body.dark .format-container .json-key{color:#9cdcfe}body.dark .format-container .json-string,body.dark .format-container .json-string a{color:#ce9178}body.dark .format-container .json-number{color:#b5cea8}body.dark .format-container .json-boolean{color:#358cd6}body.dark .format-container .json-null{color:#569cd6}body.dark_IntelliJ .format-container .tabs-container{background-color:#1e1f22}body.dark_IntelliJ .format-container .json-curly-brackets{color:#bb9667}body.dark_IntelliJ .format-container .json-square-brackets{color:#bbbda3}body.dark_IntelliJ .format-container .json-key{color:#c77dbb}body.dark_IntelliJ .format-container .json-string,body.dark_IntelliJ .format-container .json-string a{color:#499472}body.dark_IntelliJ .format-container .json-number{color:#27abb7}body.dark_IntelliJ .format-container .json-boolean{color:#ce8d66}body.dark_IntelliJ .format-container .json-null{color:#c06235}.scroll-top{width:48px;height:48px;z-index:999;position:fixed;right:30px;bottom:30px;display:none;background-image:url()} ');
System.addImportMap({ imports: {"jquery":"user:jquery","jsmind":"user:jsmind","jsmind/screenshot":"user:jsmind/screenshot"} });
System.set("user:jquery", (()=>{const _=jquery;('default' in _)||(_.default=_);return _})());
System.set("user:jsmind", (()=>{const _=jsmind;('default' in _)||(_.default=_);return _})());
System.set("user:jsmind/screenshot", (()=>{const _=jsmind;('default' in _)||(_.default=_);return _})());
System.register("./__entry.js", ['./__monkey.entry-DwqE-ama.js'], (function (exports, module) {
'use strict';
return {
setters: [null],
execute: (function () {
})
};
}));
System.register("./__monkey.entry-DwqE-ama.js", ['jquery'], (function (exports, module) {
'use strict';
var $;
return {
setters: [module => {
$ = module.default;
}],
execute: (function () {
const scriptRel = function detectScriptRel() {
const relList = typeof document !== "undefined" && document.createElement("link").relList;
return relList && relList.supports && relList.supports("modulepreload") ? "modulepreload" : "preload";
}();
const assetsURL = function(dep) {
return "/" + dep;
};
const seen = {};
const __vitePreload = function preload(baseModule, deps, importerUrl) {
let promise = Promise.resolve();
if (deps && deps.length > 0) {
document.getElementsByTagName("link");
const cspNonceMeta = document.querySelector(
"meta[property=csp-nonce]"
);
const cspNonce = (cspNonceMeta == null ? void 0 : cspNonceMeta.nonce) || (cspNonceMeta == null ? void 0 : cspNonceMeta.getAttribute("nonce"));
promise = Promise.allSettled(
deps.map((dep) => {
dep = assetsURL(dep);
if (dep in seen) return;
seen[dep] = true;
const isCss = dep.endsWith(".css");
const cssSelector = isCss ? '[rel="stylesheet"]' : "";
if (document.querySelector(`link[href="${dep}"]${cssSelector}`)) {
return;
}
const link = document.createElement("link");
link.rel = isCss ? "stylesheet" : scriptRel;
if (!isCss) {
link.as = "script";
}
link.crossOrigin = "";
link.href = dep;
if (cspNonce) {
link.setAttribute("nonce", cspNonce);
}
document.head.appendChild(link);
if (isCss) {
return new Promise((res, rej) => {
link.addEventListener("load", res);
link.addEventListener(
"error",
() => rej(new Error(`Unable to preload CSS for ${dep}`))
);
});
}
})
);
}
function handlePreloadError(err) {
const e = new Event("vite:preloadError", {
cancelable: true
});
e.payload = err;
window.dispatchEvent(e);
if (!e.defaultPrevented) {
throw err;
}
}
return promise.then((res) => {
for (const item of res || []) {
if (item.status !== "rejected") continue;
handlePreloadError(item.reason);
}
return baseModule().catch(handlePreloadError);
});
};
const Utils = exports("U", {
// 检查字符串是否为URL
isUrl: function(string) {
const regexp = /^(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?/;
return regexp.test(string);
},
// 检查是否是图片链接
isImg: function(pathImg) {
const regexp = /\.(ico|bmp|gif|jpg|jpeg|png|svg|webp|GIF|JPG|PNG|WEBP|SVG)([\w#!:.?+=&%@!\-\/])?/i;
return regexp.test(pathImg);
},
// 检验内容是否是json格式的内容
isJSON: function(str) {
try {
JSON.parse(str);
return true;
} catch (e) {
console.log("is not json");
return false;
}
},
// 获取数据类型
getType: function(value) {
return Object.prototype.toString.call(value).match(/\s(.+)]/)[1].toLowerCase();
},
// 获取数组中对象key最多的对象
findMaxKeysObject: function(arr) {
let maxKeysCount = 0, maxKeysObject;
for (const obj of arr) {
const keysCount = Object.keys(obj).length;
if (keysCount > maxKeysCount) {
maxKeysCount = keysCount;
maxKeysObject = obj;
}
}
return maxKeysObject;
},
// 随机rgb颜色
randomColor: (opacity) => {
const red = Math.floor(Math.random() * 256);
const green = Math.floor(Math.random() * 256);
const blue = Math.floor(Math.random() * 256);
return `rgba(${red}, ${green}, ${blue}, ${opacity})`;
},
/**
* 是否满足JSON
* @returns
*/
isJSONDocument: function(contentType) {
const docType = [
"application/vnd.api+json",
"application/javascript",
"application/json",
"text/javascript",
"text/plain",
"text/json"
];
if (!docType.includes(contentType)) {
return false;
}
return true;
}
});
const URL = exports("d", {
JSON_CRACK_WIDGET: "https://jsoncrack.feny.ink/widget",
EXAMPLE_JSON: "https://fetch-api.feny.ink/example.json",
LAYUI_JS: "https://unpkg.com/[email protected]/dist/layui.js",
LAYUI_CSS: "https://unpkg.com/[email protected]/dist/css/layui.css",
ONLINE_HTTP_REQUEST: "https://fetch-api.feny.ink/httpRequest"
});
var _GM_addStyle = /* @__PURE__ */ (() => typeof GM_addStyle != "undefined" ? GM_addStyle : void 0)();
var _GM_getValue = exports("a", /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)());
var _GM_openInTab = /* @__PURE__ */ (() => typeof GM_openInTab != "undefined" ? GM_openInTab : void 0)();
var _GM_registerMenuCommand = /* @__PURE__ */ (() => typeof GM_registerMenuCommand != "undefined" ? GM_registerMenuCommand : void 0)();
var _GM_setClipboard = exports("c", /* @__PURE__ */ (() => typeof GM_setClipboard != "undefined" ? GM_setClipboard : void 0)());
var _GM_setValue = exports("_", /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)());
var _unsafeWindow = exports("b", /* @__PURE__ */ (() => typeof unsafeWindow != "undefined" ? unsafeWindow : void 0)());
(function() {
if (!Utils.isJSONDocument(document.contentType)) {
return;
}
_unsafeWindow.GLOBAL_SOURCE_ELEMENT = $("pre").first();
if (_unsafeWindow.GLOBAL_SOURCE_ELEMENT.length === 0) {
const text = document.body.innerText;
if (!Utils.isJSON(text)) {
return;
}
const pre = document.createElement("pre");
pre.innerText = text;
document.body.insertAdjacentHTML("afterbegin", pre);
_unsafeWindow.GLOBAL_SOURCE_ELEMENT = $(pre);
}
let rawText = _unsafeWindow.GLOBAL_SOURCE_ELEMENT.text();
if (!rawText) {
return;
}
let tokens = rawText.match(/^([^\s(]*)\s*\(([\s\S]*)\)\s*;?$/);
if (tokens && tokens[1] && tokens[2]) {
_unsafeWindow.GLOBAL_JSONP_FUN = tokens[1];
rawText = tokens[2];
}
if (!Utils.isJSON(rawText)) {
return;
}
window.postMessage({ isJSON: true });
setTimeout(() => {
_unsafeWindow.GLOBAL_SOURCE_ELEMENT.hide();
try {
_unsafeWindow.GLOBAL_JSON = eval(`(${rawText})`);
} catch (e) {
_unsafeWindow.GLOBAL_JSON = JSON.parse(rawText);
}
$(document.head).append(`<link href="${URL.LAYUI_CSS}" rel="stylesheet">`).append(`<script src="${URL.LAYUI_JS}">`);
_GM_addStyle(
`jmnode.root::before{background-color: ${Utils.randomColor(0.5)}}
jmnode:not(.root)::before{background-color: ${Utils.randomColor(0.5)}}
`
);
__vitePreload(() => module.import('./index-Dqs87KRh-uTztYeYN.js'), void 0 );
__vitePreload(() => module.import('./index-DN2GzJuT-cOWnfWLz.js'), void 0 ).then((format) => format.default.init()).then(() => __vitePreload(() => module.import('./index-BmehyE8w-BPCL2Fwp.js'), void 0 )).then(() => __vitePreload(() => module.import('./index-Cgl7hcfy-DaTAQqy4.js'), void 0 ));
});
const openInTab = () => _GM_openInTab(URL.EXAMPLE_JSON);
_GM_registerMenuCommand("测试JSON( Alt + j )", openInTab);
document.addEventListener("keydown", function(event) {
if (event.altKey && event.key === "j") {
openInTab();
}
});
})();
})
};
}));
System.register("./index-Dqs87KRh-uTztYeYN.js", [], (function (exports, module) {
'use strict';
return {
execute: (function () {
const layout = `
<div class="format-container">
<div class="panel">
<div class="tabs">
<div class="tabs-item btn active" id="format">JSON格式化</div>
<div class="tabs-item btn" id="viewJsonMind">JSON脑图</div>
<div class="tabs-item btn" id="viewRawText">原始数据</div>
<div class="selectbox">
<div class="formatStyle">
<label>风格:</label>
<select>
<option value="default">默认</option>
<option value="treaTable">表格</option>
</select>
</div>
<div class="theme" style="margin: 0 15px">
<label>主题: </label>
<select>
<option value="default">默认</option>
<option value="light">浅色</option>
<option value="dark">暗黑</option>
<option value="dark_IntelliJ">暗黑+</option>
</select>
</div>
<span class="inputJson">JSON 输入</span>
<span class="fetchApi">HTTP 请求</span>
</div>
</div>
<div class="toolbar">
<div class="toolbar-item btn" id="saveJson">保存</div>
<div class="toolbar-item btn" id="copyJson">复制</div>
<div class="toolbar-item btn" id="collapseAll">全部折叠</div>
<div class="toolbar-item btn" id="expandAll">全部展开</div>
<div class="toolbar-item btn" id="jsoncrack" style="display: none;">JSON Crack</div>
<div class="toolbar-item btn" id="beautify" style="display: none;">美化输出</div>
<div class="searchbox">
<input type="text" placeholder="过滤 JSON "/>
<button class="clear" hidden></button>
</div>
</div>
</div>
<div class="tabs-container">
<div class="active" id="formatContainer"></div>
<div id="jmContainer"></div>
<div id="rawTextContainer"><pre></pre></div>
</div>
</div>`;
document.body.insertAdjacentHTML("afterbegin", layout);
})
};
}));
System.register("./index-DN2GzJuT-cOWnfWLz.js", ['jquery', './__monkey.entry-DwqE-ama.js'], (function (exports, module) {
'use strict';
var $, _GM_setValue, _GM_getValue, _unsafeWindow, Utils, _GM_setClipboard;
return {
setters: [module => {
$ = module.default;
}, module => {
_GM_setValue = module._;
_GM_getValue = module.a;
_unsafeWindow = module.b;
Utils = module.U;
_GM_setClipboard = module.c;
}],
execute: (function () {
(function($2) {
function isCollapsable(arg) {
return arg instanceof Object && Object.keys(arg).length > 0;
}
function json2html(json, parentPath = "") {
let html = "", type = Utils.getType(json);
switch (type) {
case "array":
case "object":
let len = json.length || Object.keys(json).length;
if (len > 0) {
html += `<span class="json-brackets ${type == "array" ? "json-square-brackets" : "json-curly-brackets"}">`;
html += type === "array" ? '[</span><ol class="json-array">' : '{</span><ul class="json-object">';
for (var key in json) {
if (json.hasOwnProperty(key)) {
let comma = --len > 0 ? "," : "", jsonPath = parentPath + "." + key, collapse = isCollapsable(json[key]) ? '<a href class="json-toggle"></a>' : "", res = json2html(json[key], jsonPath);
let toHtml = type === "array" ? res : `<span class="json-key">"${key}"</span>: ${res}`;
html += [
`<li json-path="${jsonPath}">`,
collapse,
toHtml,
comma,
"</li>"
].join("");
}
}
if (type === "array") {
html += `</ol><span class="json-brackets json-square-brackets">]</span>`;
} else {
html += `</ul><span class="json-brackets json-curly-brackets">}</span>`;
}
} else {
html += `<span class="json-brackets ${type == "array" ? "json-square-brackets" : "json-curly-brackets"}">`;
html += type === "array" ? "[]" : "{}";
html += "</span>";
}
break;
default:
json = type === "string" ? json.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">") : json;
if (Utils.isUrl(json)) {
html += `<a target="_blank" href="${json}" class="json-string">"${json}"</a>`;
} else {
json = type === "string" ? `"${json}"` : json;
html += `<span class="json-${type}">${json}</span>`;
}
break;
}
return html;
}
$2.fn.jsonViewer = function(json, jsonpFn) {
return this.each(function() {
var html = json2html(json);
if (jsonpFn !== void 0 && jsonpFn !== null) {
html = `<div class="jsonp">${jsonpFn}(</div>${html}<div class="jsonp">)</div>`;
}
$2(this).html(html);
$2(this).off("click");
$2(this).on("click", "a.json-toggle", function() {
var target = $2(this).toggleClass("collapsed").siblings("ul.json-object, ol.json-array");
target.toggle();
if (target.is(":visible")) {
target.siblings(".json-placeholder").remove();
} else {
var count = target.children('li:not([class*="hidden"])').length;
var placeholder = count + (count > 1 ? " items" : " item");
target.after(
'<a href class="json-placeholder">' + placeholder + "</a>"
);
}
return false;
});
$2(this).on("click", "a.json-placeholder", function() {
$2(this).siblings("a.json-toggle").click();
$2(this).siblings("a.json-placeholder").remove();
return false;
});
});
};
})($);
!function(e) {
var t = {};
function n(o) {
if (t[o]) return t[o].exports;
var i = t[o] = { i: o, l: false, exports: {} };
return e[o].call(i.exports, i, i.exports, n), i.l = true, i.exports;
}
n.m = e, n.c = t, n.d = function(e2, t2, o) {
n.o(e2, t2) || Object.defineProperty(e2, t2, { enumerable: true, get: o });
}, n.r = function(e2) {
"undefined" != typeof Symbol && Symbol.toStringTag && Object.defineProperty(e2, Symbol.toStringTag, { value: "Module" }), Object.defineProperty(e2, "__esModule", { value: true });
}, n.t = function(e2, t2) {
if (1 & t2 && (e2 = n(e2)), 8 & t2) return e2;
if (4 & t2 && "object" == typeof e2 && e2 && e2.__esModule) return e2;
var o = /* @__PURE__ */ Object.create(null);
if (n.r(o), Object.defineProperty(o, "default", { enumerable: true, value: e2 }), 2 & t2 && "string" != typeof e2) for (var i in e2) n.d(o, i, (function(t3) {
return e2[t3];
}).bind(null, i));
return o;
}, n.n = function(e2) {
var t2 = e2 && e2.__esModule ? function() {
return e2.default;
} : function() {
return e2;
};
return n.d(t2, "a", t2), t2;
}, n.o = function(e2, t2) {
return Object.prototype.hasOwnProperty.call(e2, t2);
}, n.p = "/dist", n(n.s = 5);
}([function(e, t) {
e.exports = $;
}, function(e, t, n) {
var o = n(2), i = n(3);
"string" == typeof (i = i.__esModule ? i.default : i) && (i = [[e.i, i, ""]]);
var a = { insert: "head", singleton: false };
o(i, a);
e.exports = i.locals || {};
}, function(e, t, n) {
var o, i = function() {
return void 0 === o && (o = Boolean(window && document && document.all && !window.atob)), o;
}, a = /* @__PURE__ */ function() {
var e2 = {};
return function(t2) {
if (void 0 === e2[t2]) {
var n2 = document.querySelector(t2);
if (window.HTMLIFrameElement && n2 instanceof window.HTMLIFrameElement) try {
n2 = n2.contentDocument.head;
} catch (e3) {
n2 = null;
}
e2[t2] = n2;
}
return e2[t2];
};
}(), r = [];
function s(e2) {
for (var t2 = -1, n2 = 0; n2 < r.length; n2++) if (r[n2].identifier === e2) {
t2 = n2;
break;
}
return t2;
}
function c(e2, t2) {
for (var n2 = {}, o2 = [], i2 = 0; i2 < e2.length; i2++) {
var a2 = e2[i2], c2 = t2.base ? a2[0] + t2.base : a2[0], l2 = n2[c2] || 0, u2 = "".concat(c2, " ").concat(l2);
n2[c2] = l2 + 1;
var d2 = s(u2), f2 = { css: a2[1], media: a2[2], sourceMap: a2[3] };
-1 !== d2 ? (r[d2].references++, r[d2].updater(f2)) : r.push({ identifier: u2, updater: y(f2, t2), references: 1 }), o2.push(u2);
}
return o2;
}
function l(e2) {
var t2 = document.createElement("style"), o2 = e2.attributes || {};
if (void 0 === o2.nonce) {
var i2 = n.nc;
i2 && (o2.nonce = i2);
}
if (Object.keys(o2).forEach(function(e3) {
t2.setAttribute(e3, o2[e3]);
}), "function" == typeof e2.insert) e2.insert(t2);
else {
var r2 = a(e2.insert || "head");
if (!r2) throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");
r2.appendChild(t2);
}
return t2;
}
var u, d = (u = [], function(e2, t2) {
return u[e2] = t2, u.filter(Boolean).join("\n");
});
function f(e2, t2, n2, o2) {
var i2 = n2 ? "" : o2.media ? "@media ".concat(o2.media, " {").concat(o2.css, "}") : o2.css;
if (e2.styleSheet) e2.styleSheet.cssText = d(t2, i2);
else {
var a2 = document.createTextNode(i2), r2 = e2.childNodes;
r2[t2] && e2.removeChild(r2[t2]), r2.length ? e2.insertBefore(a2, r2[t2]) : e2.appendChild(a2);
}
}
function h(e2, t2, n2) {
var o2 = n2.css, i2 = n2.media, a2 = n2.sourceMap;
if (i2 ? e2.setAttribute("media", i2) : e2.removeAttribute("media"), a2 && btoa && (o2 += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a2)))), " */")), e2.styleSheet) e2.styleSheet.cssText = o2;
else {
for (; e2.firstChild; ) e2.removeChild(e2.firstChild);
e2.appendChild(document.createTextNode(o2));
}
}
var p = null, v = 0;
function y(e2, t2) {
var n2, o2, i2;
if (t2.singleton) {
var a2 = v++;
n2 = p || (p = l(t2)), o2 = f.bind(null, n2, a2, false), i2 = f.bind(null, n2, a2, true);
} else n2 = l(t2), o2 = h.bind(null, n2, t2), i2 = function() {
!function(e3) {
if (null === e3.parentNode) return false;
e3.parentNode.removeChild(e3);
}(n2);
};
return o2(e2), function(t3) {
if (t3) {
if (t3.css === e2.css && t3.media === e2.media && t3.sourceMap === e2.sourceMap) return;
o2(e2 = t3);
} else i2();
};
}
e.exports = function(e2, t2) {
(t2 = t2 || {}).singleton || "boolean" == typeof t2.singleton || (t2.singleton = i());
var n2 = c(e2 = e2 || [], t2);
return function(e3) {
if (e3 = e3 || [], "[object Array]" === Object.prototype.toString.call(e3)) {
for (var o2 = 0; o2 < n2.length; o2++) {
var i2 = s(n2[o2]);
r[i2].references--;
}
for (var a2 = c(e3, t2), l2 = 0; l2 < n2.length; l2++) {
var u2 = s(n2[l2]);
0 === r[u2].references && (r[u2].updater(), r.splice(u2, 1));
}
n2 = a2;
}
};
};
}, function(e, t, n) {
(t = n(4)(false)).push([e.i, ".simple-tree-table-icon{display:inline-block;width:1.5em;line-height:1.5em;margin:0.1em;background-color:#eee;text-align:center;cursor:pointer}.simple-tree-table-opened .simple-tree-table-icon:after{content:'-'}.simple-tree-table-closed .simple-tree-table-icon:after{content:'+'}\n", ""]), e.exports = t;
}, function(e, t, n) {
e.exports = function(e2) {
var t2 = [];
return t2.toString = function() {
return this.map(function(t3) {
var n2 = function(e3, t4) {
var n3 = e3[1] || "", o = e3[3];
if (!o) return n3;
if (t4 && "function" == typeof btoa) {
var i = (r = o, s = btoa(unescape(encodeURIComponent(JSON.stringify(r)))), c = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(s), "/*# ".concat(c, " */")), a = o.sources.map(function(e4) {
return "/*# sourceURL=".concat(o.sourceRoot || "").concat(e4, " */");
});
return [n3].concat(a).concat([i]).join("\n");
}
var r, s, c;
return [n3].join("\n");
}(t3, e2);
return t3[2] ? "@media ".concat(t3[2], " {").concat(n2, "}") : n2;
}).join("");
}, t2.i = function(e3, n2, o) {
"string" == typeof e3 && (e3 = [[null, e3, ""]]);
var i = {};
if (o) for (var a = 0; a < this.length; a++) {
var r = this[a][0];
null != r && (i[r] = true);
}
for (var s = 0; s < e3.length; s++) {
var c = [].concat(e3[s]);
o && i[c[0]] || (n2 && (c[2] ? c[2] = "".concat(n2, " and ").concat(c[2]) : c[2] = n2), t2.push(c));
}
}, t2;
};
}, function(e, t, n) {
n.r(t);
var o = n(0), i = n.n(o);
function a(e2, t2) {
if (!(e2 instanceof t2)) throw new TypeError("Cannot call a class as a function");
}
function r(e2, t2) {
for (var n2 = 0; n2 < t2.length; n2++) {
var o2 = t2[n2];
o2.enumerable = o2.enumerable || false, o2.configurable = true, "value" in o2 && (o2.writable = true), Object.defineProperty(e2, o2.key, o2);
}
}
function s(e2, t2, n2) {
return t2 && r(e2.prototype, t2), e2;
}
var c = function() {
function e2() {
var t2 = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
a(this, e2), this.opts = { type: t2.type || "session", key: t2.key }, this.inst = new l(this.opts);
}
return s(e2, [{ key: "get", value: function() {
var e3 = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null;
return this.inst.get(this.opts.key) || e3;
} }, { key: "set", value: function(e3) {
this.inst.set(this.opts.key, e3);
} }, { key: "remove", value: function() {
this.inst.remove(this.opts.key);
} }]), e2;
}(), l = function() {
function e2() {
var t2 = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
a(this, e2), this.storage = { local: window.localStorage, session: window.sessionStorage }[t2.type];
}
return s(e2, [{ key: "get", value: function(e3) {
try {
var t2 = this.storage.getItem(e3);
return t2 ? JSON.parse(t2) : null;
} catch (e4) {
return console.log(e4), null;
}
} }, { key: "set", value: function(e3, t2) {
try {
this.storage.setItem(e3, JSON.stringify(t2));
} catch (e4) {
console.log(e4);
}
} }, { key: "remove", value: function(e3) {
this.storage.removeItem(e3);
} }]), e2;
}(), u = (n(1), "simple-tree-table");
function d(e2, t2) {
if (!(e2 instanceof t2)) throw new TypeError("Cannot call a class as a function");
}
function f(e2, t2) {
for (var n2 = 0; n2 < t2.length; n2++) {
var o2 = t2[n2];
o2.enumerable = o2.enumerable || false, o2.configurable = true, "value" in o2 && (o2.writable = true), Object.defineProperty(e2, o2.key, o2);
}
}
var h = { expander: null, collapser: null, opened: "all", margin: 20, iconPosition: "> :first-child", iconTemplate: "<span />", store: null, storeKey: null }, p = function() {
function e2(t3) {
var n3 = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : {};
d(this, e2), this.options = i.a.extend({}, h, n3), this.$table = i()(t3), this.$expander = i()(this.options.expander), this.$collapser = i()(this.options.collapser), this.options.store && this.options.storeKey && (this.store = new c({ type: this.options.store, key: this.options.storeKey })), this.init(), this.load();
}
var t2, n2, o2;
return t2 = e2, o2 = [{ key: "getDefaults", value: function() {
return h;
} }, { key: "setDefaults", value: function(e3) {
return i.a.extend(h, e3);
} }], (n2 = [{ key: "init", value: function() {
this.$table.addClass(u), this.build(), this.unbind(), this.bind();
} }, { key: "destroy", value: function() {
var e3 = function(e4, t3) {
var n3 = new RegExp("".concat(u, "(-\\S+)?"), "g");
return (t3.match(n3) || []).join(" ");
};
this.$table.removeClass(e3), this.nodes().removeClass(e3), this.$table.find(".".concat(u, "-icon")).remove(), this.unbind();
} }, { key: "build", value: function() {
var e3 = this;
this.nodes().not("[data-node-depth]").each(function(t3, n3) {
var o3 = i()(n3), a2 = e3.depth(o3);
o3.data("node-depth", a2), 1 == a2 && o3.addClass("".concat(u, "-root"));
}), this.nodes().filter(function(t3, n3) {
return 0 == i()(n3).find(e3.options.iconPosition).find(".".concat(u, "-handler")).length;
}).each(function(t3, n3) {
var o3 = i()(n3), a2 = e3.depth(o3), r2 = e3.options.margin * (a2 - 1), s2 = i()(e3.options.iconTemplate).addClass("".concat(u, "-handler ").concat(u, "-icon")).css("margin-left", "".concat(r2, "px"));
o3.find(e3.options.iconPosition).prepend(s2);
}), this.nodes().not(".".concat(u, "-empty, .").concat(u, "-opened, .").concat(u, "-closed")).each(function(t3, n3) {
var o3 = i()(n3);
e3.hasChildren(o3) ? e3.opensDefault(o3) ? o3.addClass("".concat(u, "-opened")) : o3.addClass("".concat(u, "-closed")) : o3.addClass("".concat(u, "-empty"));
}), this.nodes().filter(".".concat(u, "-opened")).each(function(t3, n3) {
e3.show(i()(n3));
}), this.nodes().filter(".".concat(u, "-closed")).each(function(t3, n3) {
e3.hide(i()(n3));
});
} }, { key: "opensDefault", value: function(e3) {
var t3 = this.options.opened;
return t3 && ("all" == t3 || -1 != t3.indexOf(e3.data("node-id")));
} }, { key: "bind", value: function() {
var e3 = this;
this.$expander.on("click.".concat(u), function(t3) {
e3.expand();
}), this.$collapser.on("click.".concat(u), function(t3) {
e3.collapse();
}), this.$table.on("click.".concat(u), "tr .".concat(u, "-handler"), function(t3) {
var n3 = i()(t3.currentTarget).closest("tr");
n3.hasClass("".concat(u, "-opened")) ? e3.close(n3) : e3.open(n3);
});
} }, { key: "unbind", value: function() {
this.$expander.off(".".concat(u)), this.$collapser.off(".".concat(u)), this.$table.off(".".concat(u, " node:open node:close"));
} }, { key: "expand", value: function() {
var e3 = this;
this.nodes().each(function(t3, n3) {
e3.show(i()(n3));
}), this.save();
} }, { key: "collapse", value: function() {
var e3 = this;
this.nodes().each(function(t3, n3) {
e3.hide(i()(n3));
}), this.save();
} }, { key: "nodes", value: function() {
return this.$table.find("tr[data-node-id]");
} }, { key: "depth", value: function(e3) {
var t3 = e3.data("node-depth");
if (t3) return t3;
var n3 = this.findByID(e3.data("node-pid"));
return 0 != n3.length ? this.depth(n3) + 1 : 1;
} }, { key: "open", value: function(e3) {
this.show(e3), this.save(), e3.trigger("node:open", [e3]);
} }, { key: "show", value: function(e3) {
e3.hasClass("".concat(u, "-empty")) || (e3.removeClass("".concat(u, "-closed")).addClass("".concat(u, "-opened")), this.showDescs(e3));
} }, { key: "showDescs", value: function(e3) {
var t3 = this;
this.findChildren(e3).each(function(e4, n3) {
var o3 = i()(n3);
o3.show(), o3.hasClass("".concat(u, "-opened")) && t3.showDescs(o3);
});
} }, { key: "close", value: function(e3) {
this.hide(e3), this.save(), e3.trigger("node:close", [e3]);
} }, { key: "hide", value: function(e3) {
e3.hasClass("".concat(u, "-empty")) || (e3.removeClass("".concat(u, "-opened")).addClass("".concat(u, "-closed")), this.hideDescs(e3));
} }, { key: "hideDescs", value: function(e3) {
var t3 = this;
this.findChildren(e3).each(function(e4, n3) {
var o3 = i()(n3);
o3.hide(), t3.hideDescs(o3);
});
} }, { key: "hasChildren", value: function(e3) {
return 0 != this.findChildren(e3).length;
} }, { key: "findChildren", value: function(e3) {
var t3 = e3.data("node-id");
return this.$table.find('tr[data-node-pid="'.concat(t3, '"]'));
} }, { key: "findDescendants", value: function(e3) {
var t3 = this, n3 = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : [], o3 = this.findChildren(e3);
return n3.push(o3), o3.each(function(e4, o4) {
t3.findDescendants(i()(o4), n3);
}), n3;
} }, { key: "findByID", value: function(e3) {
return this.$table.find('tr[data-node-id="'.concat(e3, '"]'));
} }, { key: "openByID", value: function(e3) {
this.open(this.findByID(e3));
} }, { key: "closeByID", value: function(e3) {
this.close(this.findByID(e3));
} }, { key: "load", value: function() {
var e3 = this;
if (this.store) {
var t3 = this.store.get();
t3 && (this.nodes().each(function(t4, n3) {
e3.show(i()(n3));
}), this.nodes().filter(function(e4, n3) {
return -1 != t3.indexOf(i()(n3).data("node-id"));
}).each(function(t4, n3) {
e3.hide(i()(n3));
}));
}
} }, { key: "save", value: function() {
if (this.store) {
var e3 = this.nodes().filter(".".concat(u, "-closed")).map(function(e4, t3) {
return i()(t3).data("node-id");
}).get();
this.store.set(e3);
}
} }]) && f(t2.prototype, n2), o2 && f(t2, o2), e2;
}();
i.a.fn.simpleTreeTable = function(e2) {
return this.each(function(t2, n2) {
var o2 = i()(n2);
o2.data(u) && o2.data(u).destroy(), o2.data(u, new p(o2, e2));
});
}, i.a.SimpleTreeTable = p;
}]);
function treeTableTrHTML(json, level = 0, pId = "", pChain = "") {
let tr = "";
for (const key in json) {
let val = json[key], type = Utils.getType(val), tId = key + "_" + Math.random(), chain = pChain + "." + key;
if (["array", "object"].includes(type)) {
let brackets = "", len = Object.keys(val).length, res = treeTableTrHTML(val, level + 1, tId, chain);
if (!res) {
if (type === "array") {
brackets = `<span class="json-brackets json-square-brackets">[]</span>`;
} else {
brackets = `<span class="json-brackets json-curly-brackets">{}</span>`;
}
}
tr += `
<tr data-node-id="${tId}" data-node-pid="${pId}" type="${type}">
<td class="json-key" json-path="${chain}" style="padding-left: ${level * 19}px">${key}:
<span class="tree-len">${len > 0 ? type === "array" ? "[" + len + "]" : "{" + len + "}" : ""}</span>
</td>
<td>${brackets}</td>
</tr>`;
tr += res;
} else {
val = type === "string" ? val.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">") : val;
tr += `<tr data-node-id="${tId}" data-node-pid="${pId}" type="${type}">
<td class="json-key" json-path="${chain}" style="padding-left: ${level * 19}px">${key}:</td>`;
if (Utils.isUrl(val)) {
tr += `<td class="json-${type}"><a target="_blank" href="${val}">"${val}"</a></td>`;
} else {
val = type === "string" ? `"${val}"` : val;
tr += `<td class="json-${type}">${val}</td>`;
}
tr += "</tr>";
}
}
return tr;
}
const evnet = {
/**
* a标签鼠标移入,看是否是图片,是图片生成预览图
* @returns this
*/
urlHover: function() {
$("#formatContainer").on(
{
mouseenter: function() {
var that = $(this), href = that.attr("href");
if (Utils.isImg(href)) {
layer.tips(`<img src="${href}" />`, that, {
time: 0,
anim: 5,
maxWidth: 500,
tips: [3, "#d9d9d9"]
});
}
},
mouseleave: () => layer.closeAll()
},
"a[href]"
);
return this;
},
/**
* 鼠标移入key提示JSONPath
* @returns this
*/
tipsJsonPath: function() {
var that = this;
$("#formatContainer").on(
{
mouseenter: function() {
const jsonPath = that.getJsonPath(this);
const tips = `<b>ctrl + 点击复制</b><br/>${jsonPath}`;
layer.tips(tips, this, {
time: 0,
anim: 5,
maxWidth: 500,
tips: [1, "#2e59a7"]
});
},
mouseleave: () => layer.closeAll()
},
".json-key"
);
return this;
},
/**
* 复制key的JSONPath
* @returns
*/
copyJsonPath: function() {
var that = this;
$("#formatContainer").on("click", ".json-key", function(event) {
if (event.ctrlKey) {
const jsonPath = that.getJsonPath(this);
_GM_setClipboard(jsonPath);
layer.msg("复制成功", { time: 1500 });
}
});
return this;
},
/**
* 给定htmlElement获取JSONPath
* @param {*} element
* @returns
*/
getJsonPath: function(element) {
const style = _GM_getValue("formatStyle") || "default";
const jsonPath = style == "default" ? $(element).parent().attr("json-path") : $(element).attr("json-path");
return jsonPath.split(".").reduce(
(prev, next) => /^\d+$/.test(next) ? prev + `[${next}]` : prev + "." + next
);
},
init: function() {
this.urlHover().tipsJsonPath().copyJsonPath();
}
};
const formatStyle = exports("default", {
// 切换风格
changeStyle: function() {
const that = this;
$(".formatStyle select").on("change", function(e) {
layer.load(0, { shade: false });
const val = $(e.target).val();
_GM_setValue("formatStyle", val);
that.setStyle();
});
return this;
},
// 设置风格
setStyle: function() {
const style = _GM_getValue("formatStyle") || "default";
$(".formatStyle select").val(style);
$("input").val("");
$("#formatContainer").html("");
if (style === "default") {
$("#formatContainer").jsonViewer(
_unsafeWindow.GLOBAL_JSON,
_unsafeWindow.GLOBAL_JSONP_FUN
);
layer.closeAll();
} else {
const trHTML = treeTableTrHTML(_unsafeWindow.GLOBAL_JSON);
let appendHtml = `<table id="treeTable">${trHTML}</table>`;
if (_unsafeWindow.GLOBAL_JSONP_FUN !== void 0 && _unsafeWindow.GLOBAL_JSONP_FUN !== null) {
appendHtml = `<div class="jsonp">${_unsafeWindow.GLOBAL_JSONP_FUN}(</div>${appendHtml}<div class="jsonp">)</div>`;
}
$("#formatContainer").append(appendHtml);
setTimeout(() => {
$("#treeTable").simpleTreeTable({
expander: "#expandAll",
collapser: "#collapseAll"
});
layer.closeAll();
});
$("#treeTable").on("mousedown", "tr", function() {
$(".selected").not(this).removeClass("selected");
$(this).toggleClass("selected");
});
}
return this;
},
init: function() {
this.setStyle().changeStyle();
evnet.init();
}
});
window.addEventListener("message", function(event) {
const { data } = event;
if (data && data.reload) {
formatStyle.setStyle();
}
});
})
};
}));
System.register("./index-BmehyE8w-BPCL2Fwp.js", ['jquery', './__monkey.entry-DwqE-ama.js', 'jsmind', 'jsmind/screenshot'], (function (exports, module) {
'use strict';
var $, _unsafeWindow, _GM_setClipboard, _GM_getValue, URL$1, Utils, _GM_setValue, jsMind;
return {
setters: [module => {
$ = module.default;
}, module => {
_unsafeWindow = module.b;
_GM_setClipboard = module.c;
_GM_getValue = module.a;
URL$1 = module.d;
Utils = module.U;
_GM_setValue = module._;
}, module => {
jsMind = module.default;
}, null],
execute: (function () {
const cssLoader = (e) => {
const t = GM_getResourceText(e);
return GM_addStyle(t), t;
};
cssLoader("jsmind");
const jsonMind = {
isFirst: true,
// JSON数据转换为jsMind所需要的数据结构
convert: function(json2) {
const children = [];
if (typeof json2 === "object") {
for (const key in json2) {
let val = json2[key], isArray = Array.isArray(val);
if (isArray && val.length > 0) {
val = Utils.findMaxKeysObject(val);
}
const type = Object.prototype.toString.call(val).match(/\s(.+)]/)[1];
children.push({
isArray,
chain: key,
id: key + "_" + Math.random(),
topic: `${key}<span class="datatype">${type}</span>`,
children: this.convert(val)
});
}
}
return children;
},
// 脑图节点调用链
mindChain: function(node) {
let chain = node.data.chain;
if (!node.parent) {
return chain;
}
const parent = node.parent, parentChain = this.mindChain(parent);
chain = parent.data.isArray ? `${parentChain}[0].${chain}` : `${parentChain}.${chain}`;
return chain;
},
// 显示脑图
show: function(json2) {
let isArr = Array.isArray(json2);
if (isArr) {
if (typeof json2[0] !== "object") {
layer.msg("数据结构无法生成脑图", { time: 1e3 });
return this;
}
json2 = Utils.findMaxKeysObject(json2);
}
if (!this.isFirst) {
return this;
}
_unsafeWindow.GLOBAL_JSMIND.show({
meta: {
name: "JSON脑图",
author: "[email protected]",
version: "1.0"
},
format: "node_tree",
/* 数据内容 */
data: {
id: "root",
topic: "Response",
direction: "left",
children: this.convert(json2),
chain: isArr ? "Response[0]" : "Response"
}
});
this.isFirst = false;
return this;
},
// 脑图节点事件
event: function() {
const jsonMind2 = this;
$("jmnode").on("dblclick mouseover mouseout", function(event) {
const that2 = $(this), node = _unsafeWindow.GLOBAL_JSMIND.get_node(that2.attr("nodeid"));
if (!node.parent) {
return;
}
switch (event.type) {
case "dblclick":
_GM_setClipboard(jsonMind2.mindChain(node));
layer.msg("节点路径复制成功", { time: 1500 });
break;
case "mouseover":
const s = `<b>节点路径(双击复制)</b><br/>${jsonMind2.mindChain(node)}`;
layer.tips(s, that2, {
time: 0,
tips: [2, "#2e59a7"]
});
break;
default:
layer.closeAll();
break;
}
});
return this;
},
init: function(json2) {
if (!_unsafeWindow.GLOBAL_JSMIND) {
_unsafeWindow.GLOBAL_JSMIND = new jsMind({
mode: "side",
editable: false,
container: "jmContainer",
view: {
hmargin: 50,
// 思维导图距容器外框的最小水平距离
vmargin: 50,
// 思维导图距容器外框的最小垂直距离
engine: "svg",
// 思维导图各节点之间线条的绘制引擎
draggable: true,
// 当容器不能完全容纳思维导图时,是否允许拖动画布代替鼠标滚动
support_html: false,
line_color: "#C4C9D0"
},
zoom: {
// 配置缩放
min: 0.1,
// 最小的缩放比例
max: 2.1,
// 最大的缩放比例
step: 0.1
// 缩放比例间隔
},
layout: {
vspace: 7,
// 节点之间的垂直间距
hspace: 150
// 节点之间的水平空间
}
});
}
this.show(json2).event();
}
};
const tabsEvent = {
firstFormat: true,
isBeautify: false,
$rawText: $("#rawTextContainer"),
/**
* 保存为文件
*/
download: {
download: function(content, filename) {
const link = document.createElement("a");
link.href = content;
link.download = filename;
link.click();
},
saveJSON: function(text2) {
const blob = new Blob([text2], { type: "text/plain;charset=utf-8" });
const url = URL.createObjectURL(blob);
const filename = (/* @__PURE__ */ new Date()).getTime() + ".json";
this.download(url, filename);
URL.revokeObjectURL(url);
},
savePNG: () => _unsafeWindow.GLOBAL_JSMIND.shoot()
},
saveJson: function() {
if ($("#jmContainer").is(":visible")) {
this.download.savePNG();
} else {
this.download.saveJSON(this.$rawText.text());
}
},
// 复制JSON文本内容
copyJson: function() {
_GM_setClipboard(this.$rawText.text());
layer.msg("复制成功", { time: 1500 });
},
// 全部折叠
collapseAll: function() {
if ($("#formatContainer").is(":visible")) {
try {
$("a.json-toggle").not(".collapsed").click();
} catch (e) {
}
} else {
_unsafeWindow.GLOBAL_JSMIND.collapse_all();
}
},
// 全部展开
expandAll: function() {
if ($("#formatContainer").is(":visible")) {
try {
$("a.json-placeholder").click().remove();
} catch (e) {
}
} else {
_unsafeWindow.GLOBAL_JSMIND.expand_all();
_unsafeWindow.GLOBAL_JSMIND.scroll_node_to_center(
_unsafeWindow.GLOBAL_JSMIND.get_root()
);
}
},
format: function() {
},
// 显示JSON脑图
viewJsonMind: function() {
jsonMind.init(_unsafeWindow.GLOBAL_JSON);
_unsafeWindow.GLOBAL_JSMIND.scroll_node_to_center(
_unsafeWindow.GLOBAL_JSMIND.get_root()
);
},
// 查看原始JSON内容
viewRawText: function() {
if (this.firstFormat) {
this.$rawText.html(_unsafeWindow.GLOBAL_SOURCE_ELEMENT.clone());
this.firstFormat = false;
}
},
// 美化
beautify: function() {
this.isBeautify = !this.isBeautify;
if (this.isBeautify) {
let str = JSON.stringify(_unsafeWindow.GLOBAL_JSON, null, 2);
if (_unsafeWindow.GLOBAL_JSONP_FUN !== void 0 && _unsafeWindow.GLOBAL_JSONP_FUN !== null) {
str = `${_unsafeWindow.GLOBAL_JSONP_FUN}(${str})`;
}
this.$rawText.find("pre").text(str);
} else {
this.$rawText.html(_unsafeWindow.GLOBAL_SOURCE_ELEMENT.clone());
}
},
jsoncrack: function() {
let theme2 = _GM_getValue("theme") || "light";
theme2 = theme2.replace(/_.*/, "");
layer.closeAll();
const index = layer.open({
type: 1,
title: false,
maxmin: true,
shadeClose: true,
area: ["900px", "600px"],
content: `<iframe style="width: 100%;height: 100%;border: 0;" id="jsoncrackEmbed" src="${URL$1.JSON_CRACK_WIDGET}"></iframe>`,
success: function(layero) {
const jsonCrackEmbed = layero.find("#jsoncrackEmbed")[0];
window == null ? void 0 : window.addEventListener("message", () => {
jsonCrackEmbed.contentWindow.postMessage(
{
options: { theme: theme2 },
json: JSON.stringify(_unsafeWindow.GLOBAL_JSON)
},
"*"
);
});
}
});
layer.full(index);
},
init: function() {
this.viewRawText();
$(".btn").on("click", (e) => {
const target = e.target, id = target.id;
if (target.classList.contains("tabs-item")) {
const index = $(target).index();
$(target).addClass("active").siblings().removeClass("active");
$(".tabs-container > div").removeClass("active").eq(index).addClass("active");
const beautifyEl = $("#beautify"), searchEl = $(".searchbox"), copyJsonEl = $("#copyJson"), jsoncrackEl = $("#jsoncrack"), aEl = $("#collapseAll, #expandAll");
id === "format" ? searchEl.show() : searchEl.hide();
id === "viewJsonMind" ? copyJsonEl.hide() && jsoncrackEl.show() : copyJsonEl.show() && jsoncrackEl.hide();
id === "viewRawText" ? beautifyEl.show() && aEl.hide() : beautifyEl.hide() && aEl.show();
}
this[id](target);
});
return this;
}
};
window.addEventListener("message", function(event) {
const { data } = event;
if (data && data.reload) {
jsonMind.isFirst = true;
jsonMind.init(_unsafeWindow.GLOBAL_JSON);
tabsEvent.isBeautify = false;
tabsEvent.$rawText.html(_unsafeWindow.GLOBAL_SOURCE_ELEMENT.clone());
}
});
const jsonFilter = {
// 过滤 JSON
filterJSON: function(filter) {
const style = _GM_getValue("formatStyle") || "default";
if (!filter) {
style == "default" ? $("#formatContainer li").removeClass("hidden") : $(".json-key").parent().removeClass("hidden");
return;
}
const chainSet = /* @__PURE__ */ new Set();
document.querySelectorAll("#formatContainer *[json-path]").forEach((el) => {
let chain = $(el).attr("json-path");
if (!chain) {
return;
}
const newChain = chain.substr(chain.lastIndexOf("."));
if (!newChain.toLowerCase().includes(filter.toLowerCase())) {
return;
}
chainSet.add(chain);
while (chain = chain.substr(0, chain.lastIndexOf("."))) {
chainSet.add(chain);
}
});
document.querySelectorAll(
"#formatContainer *[class*='json-']:not([class*='json-key']):not([class*='json-brackets'])"
).forEach((el) => {
const target = $(el);
let chain = style == "default" ? target.parent().attr("json-path") : target.siblings(".json-key").attr("json-path");
if (!chain) {
return;
}
const text2 = target.text();
if (!text2.toLowerCase().includes(filter.toLowerCase())) {
return;
}
chainSet.add(chain);
while (chain = chain.substring(0, chain.lastIndexOf("."))) {
chainSet.add(chain);
}
});
style == "default" ? $("#formatContainer li").addClass("hidden") : $(".json-key").parent().addClass("hidden");
chainSet.forEach((chain) => {
style == "default" ? $(`#formatContainer *[json-path="${chain}"]`).removeClass("hidden") : $(`#formatContainer *[json-path="${chain}"]`).parent().removeClass("hidden");
});
},
// JSON 过滤
input: function() {
const that2 = this;
$("input").on("input", function() {
const val = $(this).val();
val === "" ? $(".clear").attr("hidden", true) : $(".clear").attr("hidden", false);
that2.filterJSON(val);
});
return that2;
},
// 清空输入框内容
clear: function() {
const that2 = this;
$(".clear").click(function() {
that2.filterJSON();
$("input").val("");
$(this).attr("hidden", true);
});
return this;
},
init: function() {
this.input().clear();
}
};
const theme = {
// 切换主题
changeTheme: function() {
const that2 = this;
$(".theme select").on("change", function(e) {
const val = $(e.target).val();
_GM_setValue("theme", val);
that2.setTheme();
});
return this;
},
// 设置主题
setTheme: function() {
const theme2 = _GM_getValue("theme") || "default";
$("body").removeClass().addClass(theme2);
$(".theme select").val(theme2);
return this;
},
init: function() {
this.setTheme().changeTheme();
}
};
const tools = {
inputJson: function() {
const that = this;
$(".inputJson").off("click").on("click", function() {
layer.prompt(
{
title: "JSON 输入",
formType: 2,
shadeClose: true,
maxlength: 1e6
},
function(text) {
if (!text) {
layer.msg("内容不能为空", { time: 1500 });
return;
}
const rawText = text, oldJSONPFun = _unsafeWindow.GLOBAL_JSONP_FUN;
const match = text.match(/^([^\s(]*)\s*\(([\s\S]*)\)\s*;?$/);
if (match && match[1] && match[2]) {
_unsafeWindow.GLOBAL_JSONP_FUN = match[1];
text = match[2];
}
try {
const json = JSON.parse(JSON.stringify(eval(`(${text})`)));
that.reload(json, rawText);
} catch (e) {
console.log(e);
_unsafeWindow.GLOBAL_JSONP_FUN = oldJSONPFun;
layer.msg("JSON不合法", { time: 1500 });
}
}
);
});
return this;
},
fetchApi: function() {
const that2 = this;
$(".fetchApi").off("click").on("click", function() {
layer.open({
type: 1,
closeBtn: 0,
//不显示关闭按钮
shadeClose: true,
//开启遮罩关闭
title: "HTTP 请求",
content: `<form class="httpRequest">
<div class="requestbox">
<select name="method">
<option value="POST">POST</option>
<option value="GET">GET</option>
<option value="PUT">PUT</option>
<option value="DELETE">DELETE</option>
</select>
<input name="url" placeholder="请求地址" />
<select name="contentType">
<option value="application/x-www-form-urlencoded;charset=UTF-8">urlencoded</option>
<option value="application/json;charset=UTF-8">application/json</option>
</select>
<button type="submit">发送</button>
</div>
<div class="textarea">
<input name="headers" placeholder='请求头 {"token": "test"}' />
<input name="params" placeholder='请求参数 {"id": "test", ""name": "test"}' />
</div>
</form>`
});
$("form").on("submit", function(event) {
event.preventDefault();
const serialize = $(this).serializeArray();
const form = {};
for (const key in serialize) {
const it = serialize[key];
form[it.name] = it.value;
}
if (form.url === "") {
layer.msg("请求URL不能为空");
return;
}
let headers = form.headers;
let params = form.params;
try {
if (headers) {
headers = JSON.parse(headers);
}
} catch (e) {
layer.msg("请求头格式不合法");
return;
}
try {
if (params) {
params = JSON.parse(params);
}
} catch (e) {
layer.msg("请求参数格式不合法");
return;
}
layer.load(0, { shade: false });
$.ajax({
url: URL$1.ONLINE_HTTP_REQUEST,
type: "POST",
data: JSON.stringify(form),
contentType: "application/json"
}).then(
(response) => {
_unsafeWindow.GLOBAL_JSONP_FUN = null;
that2.reload(response, JSON.stringify(response));
},
(error) => {
layer.closeAll();
console.log(error);
}
);
});
});
return this;
},
reload: function(json2, rawText2) {
_unsafeWindow.GLOBAL_JSON = json2;
_unsafeWindow.GLOBAL_SOURCE_ELEMENT.text(rawText2);
window.postMessage({ reload: true });
layer.closeAll();
},
init: function() {
this.inputJson().fetchApi();
}
};
theme.init();
tools.init();
tabsEvent.init();
jsonFilter.init();
})
};
}));
System.register("./index-Cgl7hcfy-DaTAQqy4.js", ['jquery'], (function (exports, module) {
'use strict';
var $;
return {
setters: [module => {
$ = module.default;
}],
execute: (function () {
$(document.body).append('<div class="scroll-top"></div>').find(".tabs-container").on("scroll", function(e) {
const scrollTop = $(this).scrollTop();
scrollTop > 500 ? $(".scroll-top").fadeIn() : $(".scroll-top").fadeOut();
}).parents().find(".scroll-top").on("click", function() {
$(".tabs-container").animate(
{
scrollTop: "0"
},
1e3
);
});
})
};
}));
System.import("./__entry.js", "./");