it-tools/src/tools/json-viewer/json.models.ts

45 lines
1.2 KiB
TypeScript
Raw Normal View History

import { type MaybeRef, get } from '@vueuse/core';
2023-03-29 23:25:39 +02:00
import JSON5 from 'json5';
export { sortObjectKeys, formatJson };
function sortObjectKeys<T>(obj: T): T {
if (typeof obj !== 'object' || obj === null) {
return obj;
}
if (Array.isArray(obj)) {
return obj.map(sortObjectKeys) as unknown as T;
2023-03-29 23:25:39 +02:00
}
return Object.keys(obj)
.sort((a, b) => a.localeCompare(b))
2023-03-29 23:25:39 +02:00
.reduce((sortedObj, key) => {
sortedObj[key] = sortObjectKeys((obj as Record<string, unknown>)[key]);
return sortedObj;
}, {} as Record<string, unknown>) as T;
}
2025-03-25 15:17:57 +08:00
function unescapeUnicodeJSON(str: string) {
return str.replace(/\\u([\dA-Fa-f]{4})/g, (match, grp) =>
String.fromCharCode(Number.parseInt(grp, 16)),
);
}
2023-03-29 23:25:39 +02:00
function formatJson({
rawJson,
sortKeys = true,
indentSize = 3,
2025-03-25 15:17:57 +08:00
unescapeUnicode = false,
2023-03-29 23:25:39 +02:00
}: {
rawJson: MaybeRef<string>
sortKeys?: MaybeRef<boolean>
indentSize?: MaybeRef<number>
2025-03-25 15:17:57 +08:00
unescapeUnicode?: MaybeRef<boolean>
2023-03-29 23:25:39 +02:00
}) {
2025-03-25 15:17:57 +08:00
const raw = get(rawJson);
const parsedObject = JSON5.parse(get(unescapeUnicode) ? unescapeUnicodeJSON(raw) : raw);
2023-03-29 23:25:39 +02:00
return JSON.stringify(get(sortKeys) ? sortObjectKeys(parsedObject) : parsedObject, null, get(indentSize));
}