1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
| <template>
| <div class="">
| <Title title="歌词" desc="自己编写歌词或使用Ai生成歌词,两节/8行效果最佳">
| <el-input
| v-model="formData.lyric"
| :autosize="{ minRows: 6, maxRows: 6}"
| resize="none"
| type="textarea"
| maxlength="1200"
| show-word-limit
| placeholder="请输入您自己的歌词"
| />
| </Title>
|
| <Title title="音乐风格">
| <el-space class="flex-wrap">
| <el-tag v-for="tag in tags" :key="tag" round class="mb-8px">{{tag}}</el-tag>
| </el-space>
|
| <el-button
| :type="showCustom ? 'primary': 'default'"
| round
| size="small"
| class="mb-6px"
| @click="showCustom = !showCustom"
| >自定义风格
| </el-button>
| </Title>
|
| <Title v-show="showCustom" desc="描述您想要的音乐风格,Suno无法识别艺术家的名字,但可以理解流派和氛围" class="-mt-12px">
| <el-input
| v-model="formData.style"
| :autosize="{ minRows: 4, maxRows: 4}"
| resize="none"
| type="textarea"
| maxlength="256"
| show-word-limit
| placeholder="输入音乐风格(英文)"
| />
| </Title>
|
| <Title title="音乐/歌曲名称">
| <el-input v-model="formData.name" placeholder="请输入音乐/歌曲名称"/>
| </Title>
|
| <Title title="版本">
| <el-select v-model="formData.version" placeholder="请选择">
| <el-option
| v-for="item in [{
| value: '3',
| label: 'V3'
| }, {
| value: '2',
| label: 'V2'
| }]"
| :key="item.value"
| :label="item.label"
| :value="item.value"
| />
| </el-select>
| </Title>
| </div>
| </template>
|
| <script lang="ts" setup>
| import Title from '../title/index.vue'
| defineOptions({ name: 'Lyric' })
|
| const tags = ['rock', 'punk', 'jazz', 'soul', 'country', 'kidsmusic', 'pop']
|
| const showCustom = ref(false)
|
| const formData = reactive({
| lyric: '',
| style: '',
| name: '',
| version: ''
| })
|
| defineExpose({
| formData
| })
| </script>
|
|