Added defineModel support for PreviewText and added missing Customize component in GlitchTextDemo.

This commit is contained in:
snepsnepy
2025-07-16 16:17:28 +03:00
parent f09a3cea0e
commit 14f6d2d18b
3 changed files with 7 additions and 30 deletions

View File

@@ -3,24 +3,18 @@
<span class="text-label">{{ title }}</span> <span class="text-label">{{ title }}</span>
<input <input
:value="modelValue" v-model="model"
@input="handleChange"
class="w-[300px] px-3 py-2 bg-[#0b0b0b] border border-[#333] rounded-md text-white focus:outline-none focus:border-[#666]" class="w-[300px] px-3 py-2 bg-[#0b0b0b] border border-[#333] rounded-md text-white focus:outline-none focus:border-[#666]"
/> />
</div> </div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
const emit = defineEmits(['update:modelValue']);
defineProps<{ defineProps<{
title: string; title: string;
modelValue: string;
}>(); }>();
const handleChange = (event: Event) => { const model = defineModel<string>();
const target = event.target as HTMLInputElement;
emit('update:modelValue', target.value);
};
</script> </script>
<style scoped> <style scoped>

View File

@@ -14,31 +14,13 @@
</div> </div>
<Customize> <Customize>
<PreviewText title="Text" v-model="text" @update:model-value="forceRerender" /> <PreviewText title="Text" v-model="text" />
<PreviewSlider <PreviewSlider title="ASCII Font Size" v-model="asciiFontSize" :min="2" :max="20" :step="1" />
title="ASCII Font Size"
v-model="asciiFontSize"
:min="2"
:max="20"
:step="1"
/>
<PreviewSlider <PreviewSlider title="Text Font Size" v-model="textFontSize" :min="100" :max="400" :step="25" />
title="Text Font Size"
v-model="textFontSize"
:min="100"
:max="400"
:step="25"
/>
<PreviewSlider <PreviewSlider title="Base Height" v-model="planeBaseHeight" :min="4" :max="16" :step="1" />
title="Base Height"
v-model="planeBaseHeight"
:min="4"
:max="16"
:step="1"
/>
<PreviewSwitch title="Enable Waves" v-model="enableWaves" /> <PreviewSwitch title="Enable Waves" v-model="enableWaves" />

View File

@@ -46,6 +46,7 @@ import PropTable from '../../components/common/PropTable.vue';
import PreviewText from '../../components/common/PreviewText.vue'; import PreviewText from '../../components/common/PreviewText.vue';
import PreviewSlider from '../../components/common/PreviewSlider.vue'; import PreviewSlider from '../../components/common/PreviewSlider.vue';
import PreviewSwitch from '../../components/common/PreviewSwitch.vue'; import PreviewSwitch from '../../components/common/PreviewSwitch.vue';
import Customize from '@/components/common/Customize.vue';
import { glitchText } from '@/constants/code/TextAnimations/glitchTextCode'; import { glitchText } from '@/constants/code/TextAnimations/glitchTextCode';
const text = ref('Vue Bits'); const text = ref('Vue Bits');