From f4606242ab284b8db3197d76deab5c62cab4e63f Mon Sep 17 00:00:00 2001 From: Bobbie Goede Date: Fri, 19 Apr 2024 17:54:10 +0200 Subject: [PATCH 1/2] fix(component): apply delay to `visible` and `visibleOnce` variants --- src/components/Motion.ts | 12 +++++++++-- src/utils/directive.ts | 43 ++++++++++------------------------------ 2 files changed, 21 insertions(+), 34 deletions(-) diff --git a/src/components/Motion.ts b/src/components/Motion.ts index 97fdb0d6..63615d5d 100644 --- a/src/components/Motion.ts +++ b/src/components/Motion.ts @@ -107,9 +107,17 @@ export default defineComponent({ } if (props.delay) { - config.enter.transition = { ...config.enter.transition } || {} - config.enter.transition.delay = parseInt(props.delay as string) + const delayNumber = parseInt(props.delay as string) + + // Apply delay to existing variants where applicable + for (const configKey of ['enter', 'visible', 'visibleOnce']) { + if (!config[configKey]) continue + + config[configKey].transition ??= {} + config[configKey].transition.delay = delayNumber + } } + return config }) diff --git a/src/utils/directive.ts b/src/utils/directive.ts index c8e46e08..15ec3683 100644 --- a/src/utils/directive.ts +++ b/src/utils/directive.ts @@ -24,50 +24,29 @@ export function resolveVariants(node: VNode { - if (key === 'delay') { - if (target && target[key] && typeof target[key] === 'number') { - const delay = target[key] + for (let key of directivePropsKeys) { + if (!target || !target[key]) return - if (variantsRef && variantsRef.value) { - if (variantsRef.value.enter) { - if (!variantsRef.value.enter.transition) variantsRef.value.enter.transition = {} + if (key === 'delay' && typeof target[key] === 'number') { + // Apply delay to existing variants where applicable + for (const variantKey of ['enter', 'visible', 'visibleOnce'] as const) { + const variantConfig = variantsRef.value[variantKey] - variantsRef.value.enter.transition = { - delay, - ...variantsRef.value.enter.transition, - } - } + if (variantConfig == null) continue - if (variantsRef.value.visible) { - if (!variantsRef.value.visible.transition) variantsRef.value.visible.transition = {} - - variantsRef.value.visible.transition = { - delay, - ...variantsRef.value.visible.transition, - } - } - - if (variantsRef.value.visibleOnce) { - if (!variantsRef.value.visibleOnce.transition) variantsRef.value.visibleOnce.transition = {} - - variantsRef.value.visibleOnce.transition = { - delay, - ...variantsRef.value.visibleOnce.transition, - } - } - } + variantConfig.transition ??= {} + variantConfig.transition.delay = target[key] } return } // @ts-expect-error - Fix errors later for typescript 5 - if (target && target[key] && isObject(target[key])) { + if (isObject(target[key])) { const prop = target[key] if (key === 'visible-once') key = 'visibleOnce' variantsRef.value[key as keyof MotionVariants] = prop } - }) + } } } From 5480839db638389c33de2d510f843eabd8e932a9 Mon Sep 17 00:00:00 2001 From: Bobbie Goede Date: Fri, 19 Apr 2024 18:07:08 +0200 Subject: [PATCH 2/2] fix: replace `return` with `continue` in `for` loop --- src/utils/directive.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/utils/directive.ts b/src/utils/directive.ts index 15ec3683..4182ec0e 100644 --- a/src/utils/directive.ts +++ b/src/utils/directive.ts @@ -25,7 +25,7 @@ export function resolveVariants(node: VNode(node: VNode