index.vue 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. <template>
  2. <ContentWrap class="w-300px h-full mb-[0!important]">
  3. <el-radio-group v-model="generateMode" class="mb-15px">
  4. <el-radio-button label="desc">
  5. 描述模式
  6. </el-radio-button>
  7. <el-radio-button label="lyric">
  8. 歌词模式
  9. </el-radio-button>
  10. </el-radio-group>
  11. <!-- 描述模式/歌词模式 切换 -->
  12. <component :is="generateMode === 'desc' ? desc : lyric" ref="modeRef"/>
  13. <el-button type="primary" round class="w-full" @click="generateMusic">
  14. 创作音乐
  15. </el-button>
  16. </ContentWrap>
  17. </template>
  18. <script lang="ts" setup>
  19. import desc from './desc.vue'
  20. import lyric from './lyric.vue'
  21. defineOptions({ name: 'Index' })
  22. const emits = defineEmits(['generate-music'])
  23. const generateMode = ref('lyric')
  24. const modeRef = ref<Nullable<{ formData: Recordable }>>(null)
  25. /*
  26. *@Description: 根据信息生成音乐
  27. *@MethodAuthor: xiaohong
  28. *@Date: 2024-06-27 16:40:16
  29. */
  30. function generateMusic () {
  31. emits('generate-music', {formData: unref(modeRef)?.formData.value})
  32. }
  33. </script>