diff options
Diffstat (limited to 'src/tools/json-minify')
-rw-r--r-- | src/tools/json-minify/index.ts | 11 | ||||
-rw-r--r-- | src/tools/json-minify/json-minify.vue | 57 |
2 files changed, 68 insertions, 0 deletions
diff --git a/src/tools/json-minify/index.ts b/src/tools/json-minify/index.ts new file mode 100644 index 0000000..e6a02db --- /dev/null +++ b/src/tools/json-minify/index.ts @@ -0,0 +1,11 @@ +import { Braces } from '@vicons/tabler'; +import { defineTool } from '../tool'; + +export const tool = defineTool({ + name: 'JSON minify', + path: '/json-minify', + description: 'Minify and compress your JSON by removing unnecessary white spaces.', + keywords: ['json', 'minify', 'format'], + component: () => import('./json-minify.vue'), + icon: Braces, +}); diff --git a/src/tools/json-minify/json-minify.vue b/src/tools/json-minify/json-minify.vue new file mode 100644 index 0000000..92ab7d2 --- /dev/null +++ b/src/tools/json-minify/json-minify.vue @@ -0,0 +1,57 @@ +<template> + <n-form-item + label="Your raw json" + :feedback="rawJsonValidation.message" + :validation-status="rawJsonValidation.status" + > + <n-input + ref="inputElement" + v-model:value="rawJson" + placeholder="Paste your raw json here..." + type="textarea" + rows="20" + autocomplete="off" + autocorrect="off" + autocapitalize="off" + spellcheck="false" + /> + </n-form-item> + <n-form-item label="Minify version of your JSON"> + <textarea-copyable :value="cleanJson" language="json" :follow-height-of="inputElement" /> + </n-form-item> +</template> + +<script setup lang="ts"> +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'; + +const inputElement = ref<HTMLElement>(); + +const rawJson = ref('{\n\t"hello": [\n\t\t"world"\n\t]\n}'); +const cleanJson = computed(() => withDefaultOnError(() => JSON.stringify(JSON5.parse(rawJson.value), null, 0), '')); + +const rawJsonValidation = useValidation({ + source: rawJson, + rules: [ + { + validator: (v) => v === '' || JSON5.parse(v), + message: 'Provided JSON is not valid.', + }, + ], +}); +</script> + +<style lang="less" scoped> +.result-card { + position: relative; + + .copy-button { + position: absolute; + top: 10px; + right: 10px; + } +} +</style> |