[ REFACT ] : CircularText Text Animation

This commit is contained in:
Utkarsh-Singhal-26
2026-02-01 12:59:28 +05:30
parent 101dde4c6d
commit 2e39338725
3 changed files with 94 additions and 127 deletions
+47 -48
View File
@@ -1,28 +1,14 @@
<template>
<TabbedLayout>
<template #preview>
<div class="demo-container h-[400px] overflow-hidden">
<CircularText
:key="rerenderKey"
text="VUE * BITS * IS * AWESOME * "
:spin-duration="spinDuration"
:on-hover="onHover"
class-name="text-blue-500"
/>
<div class="h-[400px] overflow-hidden demo-container">
<CircularText :key="rerenderKey" :text="text" :spin-duration="spinDuration" :on-hover="onHover" />
</div>
<Customize>
<div class="flex gap-4 flex-wrap">
<button
class="text-xs bg-[#0b0b0b] rounded-[10px] border border-[#1e3721] hover:bg-[#1e3721] text-white h-8 px-3 transition-colors"
@click="toggleOnHover"
>
On Hover:
<span class="text-[#a1a1aa]">&nbsp;{{ onHover }}</span>
</button>
</div>
<PreviewSlider title="Spin Duration (s)" v-model="spinDuration" :min="1" :max="50" :step="1" />
<PreviewText title="Text" v-model="text" />
<PreviewSelect title="On Hover" v-model="onHover" :options="hoverOptions" />
<PreviewSlider title="Spin Duration (s)" v-model="spinDuration" :min="1" :max="60" :step="1" />
</Customize>
<PropTable :data="propData" />
@@ -41,45 +27,58 @@
</template>
<script setup lang="ts">
import { ref } from 'vue';
import TabbedLayout from '../../components/common/TabbedLayout.vue';
import PropTable from '../../components/common/PropTable.vue';
import Dependencies from '../../components/code/Dependencies.vue';
import CliInstallation from '../../components/code/CliInstallation.vue';
import CodeExample from '../../components/code/CodeExample.vue';
import Customize from '../../components/common/Customize.vue';
import PreviewSlider from '../../components/common/PreviewSlider.vue';
import CircularText from '../../content/TextAnimations/CircularText/CircularText.vue';
import { circularText } from '@/constants/code/TextAnimations/circularTextCode';
import CliInstallation from '@/components/code/CliInstallation.vue';
import CodeExample from '@/components/code/CodeExample.vue';
import Dependencies from '@/components/code/Dependencies.vue';
import Customize from '@/components/common/Customize.vue';
import PreviewSelect from '@/components/common/PreviewSelect.vue';
import PreviewSlider from '@/components/common/PreviewSlider.vue';
import PreviewText from '@/components/common/PreviewText.vue';
import PropTable from '@/components/common/PropTable.vue';
import TabbedLayout from '@/components/common/TabbedLayout.vue';
import { useForceRerender } from '@/composables/useForceRerender';
import { circularText } from '@/constants/code/TextAnimations/circularTextCode';
import CircularText from '@/content/TextAnimations/CircularText/CircularText.vue';
import { ref } from 'vue';
const { rerenderKey } = useForceRerender();
const text = ref('VUE*BITS*COMPONENTS*');
const onHover = ref<'slowDown' | 'speedUp' | 'pause' | 'goBonkers'>('speedUp');
const spinDuration = ref(20);
const { rerenderKey, forceRerender } = useForceRerender();
const hoverOptions: Array<'slowDown' | 'speedUp' | 'pause' | 'goBonkers'> = [
'slowDown',
'speedUp',
'pause',
'goBonkers'
const hoverOptions = [
{ label: 'Slow Down', value: 'slowDown' },
{ label: 'Speed Up', value: 'speedUp' },
{ label: 'Pause', value: 'pause' },
{ label: 'Go Bonkers', value: 'goBonkers' }
];
const toggleOnHover = () => {
const currentIndex = hoverOptions.indexOf(onHover.value);
const nextIndex = (currentIndex + 1) % hoverOptions.length;
onHover.value = hoverOptions[nextIndex];
forceRerender();
};
const propData = [
{ name: 'text', type: 'string', default: '""', description: 'The text content to display in a circular pattern.' },
{ name: 'spinDuration', type: 'number', default: '20', description: 'Duration of one full rotation in seconds.' },
{
name: 'text',
type: 'string',
default: "''",
description: 'The text to display in a circular layout.'
},
{
name: 'spinDuration',
type: 'number',
default: '20',
description: 'The duration (in seconds) for one full rotation.'
},
{
name: 'onHover',
type: 'string',
default: '"speedUp"',
description: 'Hover behavior: "slowDown", "speedUp", "pause", or "goBonkers".'
type: "'slowDown' | 'speedUp' | 'pause' | 'goBonkers'",
default: 'undefined',
description:
"Specifies the hover behavior variant. Options include 'slowDown', 'speedUp', 'pause', and 'goBonkers'."
},
{ name: 'className', type: 'string', default: '""', description: 'Additional class names to style the component.' }
{
name: 'className',
type: 'string',
default: "''",
description: 'Optional additional CSS classes to apply to the component.'
}
];
</script>