From cb2f526db6b7154fb3a48249f7632775b3cc943a Mon Sep 17 00:00:00 2001 From: 3people Date: Thu, 10 Aug 2023 16:51:36 +0900 Subject: [PATCH] Create useCloned 3people.ts --- useCloned/3people.ts | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 useCloned/3people.ts diff --git a/useCloned/3people.ts b/useCloned/3people.ts new file mode 100644 index 0000000..c178acf --- /dev/null +++ b/useCloned/3people.ts @@ -0,0 +1,31 @@ +import { MaybeRefOrGetter, isRef, ref, toValue, watch } from "vue" + +interface UseClonedOptions { + manual?: boolean + clone?: (source: any) => any + deep?: boolean + immediate?: boolean +} + +export const useCloned = (data: MaybeRefOrGetter, options?: UseClonedOptions) => { + const { + manual = false, + clone = (source: any) => ({ ...source }), + deep = true, + immediate = true + } = options || {} + + const cloned = ref({}) + const sync = () => { + // toValue는 getter도 처리해준다 + cloned.value = clone(toValue(data)) + } + + if (!manual && (isRef(data) || typeof data === 'function')) { + watch(data, sync, { deep, immediate }) + } else { + sync() + } + + return { cloned, sync } +} \ No newline at end of file