aboutsummaryrefslogtreecommitdiff
path: root/src/tools/json-viewer/json-viewer.vue
diff options
context:
space:
mode:
authorGravatar Corentin Thomasset <corentin.thomasset74@gmail.com> 2023-03-29 23:25:39 +0200
committerGravatar Corentin THOMASSET <corentin.thomasset74@gmail.com> 2023-03-29 23:33:30 +0200
commit3b625fd4736819b575f275ea39812c055565b13a (patch)
tree0dc0451e2b36e19888f51b02ae8bcaf8790b560d /src/tools/json-viewer/json-viewer.vue
parent863c8d0f6a7e23dbafaca69e6702870957488e8f (diff)
downloadit-tools-3b625fd4736819b575f275ea39812c055565b13a.tar.gz
it-tools-3b625fd4736819b575f275ea39812c055565b13a.tar.zst
it-tools-3b625fd4736819b575f275ea39812c055565b13a.zip
feat(json-prettify): sort keys
Diffstat (limited to 'src/tools/json-viewer/json-viewer.vue')
-rw-r--r--src/tools/json-viewer/json-viewer.vue21
1 files changed, 18 insertions, 3 deletions
diff --git a/src/tools/json-viewer/json-viewer.vue b/src/tools/json-viewer/json-viewer.vue
index a460643..60ae66c 100644
--- a/src/tools/json-viewer/json-viewer.vue
+++ b/src/tools/json-viewer/json-viewer.vue
@@ -1,4 +1,15 @@
<template>
+ <div style="flex: 0 0 100%">
+ <n-space style="margin: 0 auto; max-width: 600px" justify="center">
+ <n-form-item label="Sort keys :" label-placement="left" label-width="100">
+ <n-switch v-model:value="sortKeys" />
+ </n-form-item>
+ <n-form-item label="Indent size :" label-placement="left" label-width="100" :show-feedback="false">
+ <n-input-number v-model:value="indentSize" min="0" max="10" style="width: 100px" />
+ </n-form-item>
+ </n-space>
+ </div>
+
<n-form-item
label="Your raw json"
:feedback="rawJsonValidation.message"
@@ -25,13 +36,17 @@
import TextareaCopyable from '@/components/TextareaCopyable.vue';
import { useValidation } from '@/composable/validation';
import { withDefaultOnError } from '@/utils/defaults';
-import JSON5 from 'json5';
import { computed, ref } from 'vue';
+import JSON5 from 'json5';
+import { useStorage } from '@vueuse/core';
+import { formatJson } from './json.models';
const inputElement = ref<HTMLElement>();
-const rawJson = ref('{"hello": "world"}');
-const cleanJson = computed(() => withDefaultOnError(() => JSON.stringify(JSON5.parse(rawJson.value), null, 3), ''));
+const rawJson = useStorage('json-prettify:raw-json', '{"hello": "world", "foo": "bar"}');
+const indentSize = useStorage('json-prettify:indent-size', 3);
+const sortKeys = useStorage('json-prettify:sort-keys', true);
+const cleanJson = computed(() => withDefaultOnError(() => formatJson({ rawJson, indentSize, sortKeys }), ''));
const rawJsonValidation = useValidation({
source: rawJson,
m'>request-body-stream Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/src (unfollow)
AgeCommit message (Collapse)AuthorFilesLines
2023-10-17JSC.Weakjarred/postgresqlGravatar Jarred Sumner 1-0/+3
2023-10-17Add JSC.WeakGravatar Jarred Sumner 2-0/+293
2023-10-15more microtasksGravatar Jarred Sumner 1-11/+5
2023-10-15It's starting to workGravatar Jarred Sumner 6-49/+89
2023-10-15Things can happenGravatar Jarred Sumner 9-53/+150
2023-10-15FurtherGravatar Jarred Sumner 1-20/+30
2023-10-15The startup message sends successfullyGravatar Jarred Sumner 4-96/+130
2023-10-15it compiledGravatar Jarred Sumner 2-158/+238
2023-10-15okay we are starting to try itGravatar Jarred Sumner 4-9/+43
2023-10-15Okay most of the code is writtenGravatar Jarred Sumner 3-29/+398
2023-10-14MoreGravatar Jarred Sumner 7-66/+504
2023-10-14wipGravatar Jarred Sumner 8-16/+1194
2023-10-14More progressGravatar Jarred Sumner 4-36/+405
2023-10-13wipGravatar Jarred Sumner 8-48/+308