diff options
Diffstat (limited to 'packages/frontend/src/components')
| -rw-r--r-- | packages/frontend/src/components/MkNumber.vue | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/packages/frontend/src/components/MkNumber.vue b/packages/frontend/src/components/MkNumber.vue new file mode 100644 index 0000000000..f54ec764f9 --- /dev/null +++ b/packages/frontend/src/components/MkNumber.vue @@ -0,0 +1,23 @@ +<template> +<span>{{ number(tweened.number.toFixed(0)) }}</span> +</template> + +<script lang="ts" setup> +import { ref, reactive, watch } from 'vue'; +import gsap from 'gsap'; +import number from '@/filters/number'; + +const props = defineProps<{ + value: number; +}>(); + +const tweened = reactive({ + number: 0, +}); + +watch(() => props.value, (n) => { + gsap.to(tweened, { duration: 0.5, number: Number(n) || 0 }); +}, { + immediate: true, +}); +</script> |