|
@@ -3,16 +3,7 @@
|
|
|
<QuestionBase>
|
|
|
<template #content>
|
|
|
<div class="stem">
|
|
|
- <el-input
|
|
|
- v-if="data.property.stem_type === stemTypeList[0].value"
|
|
|
- v-model="data.stem"
|
|
|
- rows="3"
|
|
|
- resize="none"
|
|
|
- type="textarea"
|
|
|
- placeholder="输入题干"
|
|
|
- />
|
|
|
-
|
|
|
- <RichText v-if="data.property.stem_type === stemTypeList[1].value" v-model="data.stem" placeholder="输入题干" />
|
|
|
+ <RichText v-model="data.stem" placeholder="输入题干" />
|
|
|
|
|
|
<el-input
|
|
|
v-show="isEnable(data.property.is_enable_description)"
|
|
@@ -31,10 +22,14 @@
|
|
|
<span class="question-number" title="双击切换序号类型" @dblclick="changeOptionType(data)">
|
|
|
{{ computedQuestionNumber(i, data.option_number_show_mode) }}
|
|
|
</span>
|
|
|
- <div class="option-content">
|
|
|
- <RichText v-model="item.content" placeholder="输入内容" :inline="true" />
|
|
|
- </div>
|
|
|
+ <el-input
|
|
|
+ v-if="data.other.audio_generation_method === 'auto'"
|
|
|
+ v-model="item.content"
|
|
|
+ placeholder="拼音间用空格隔开"
|
|
|
+ @change="item.audio_file_id = ''"
|
|
|
+ />
|
|
|
<UploadAudio
|
|
|
+ v-if="data.other.audio_generation_method === 'upload'"
|
|
|
:key="item.audio_file_id || i"
|
|
|
:file-id="item.audio_file_id"
|
|
|
:item-index="i"
|
|
@@ -42,6 +37,16 @@
|
|
|
@upload="uploads"
|
|
|
@deleteFile="deleteFiles"
|
|
|
/>
|
|
|
+ <div v-else-if="data.other.audio_generation_method === 'auto'" class="auto-matically">
|
|
|
+ <AudioPlay v-if="item.audio_file_id" :file-id="item.audio_file_id" theme-color="gray" />
|
|
|
+ <span
|
|
|
+ v-loading="loading_list[i] ? loading_list[i].loading : false"
|
|
|
+ class="auto-btn"
|
|
|
+ @click="handleMatically(item, i)"
|
|
|
+ >{{ item.audio_file_id ? '已生成' : '自动生成' }}</span
|
|
|
+ >
|
|
|
+ </div>
|
|
|
+ <SoundRecord v-else :wav-blob.sync="item.audio_file_id" />
|
|
|
<SvgIcon icon-class="delete" class="delete pointer" @click="deleteOption(i, item.audio_file_id)" />
|
|
|
</li>
|
|
|
</ul>
|
|
@@ -56,16 +61,6 @@
|
|
|
|
|
|
<template #property>
|
|
|
<el-form :model="data.property">
|
|
|
- <el-form-item label="题干">
|
|
|
- <el-radio
|
|
|
- v-for="{ value, label } in stemTypeList"
|
|
|
- :key="value"
|
|
|
- v-model="data.property.stem_type"
|
|
|
- :label="value"
|
|
|
- >
|
|
|
- {{ label }}
|
|
|
- </el-radio>
|
|
|
- </el-form-item>
|
|
|
<el-form-item label="题号">
|
|
|
<el-input v-model="data.property.question_number" />
|
|
|
</el-form-item>
|
|
@@ -106,6 +101,16 @@
|
|
|
:step="data.property.score_type === scoreTypeList[0].value ? 1 : 0.1"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
+ <el-form-item label="音频">
|
|
|
+ <el-radio
|
|
|
+ v-for="{ value, label } in audioGenerationMethodList"
|
|
|
+ :key="value"
|
|
|
+ v-model="data.other.audio_generation_method"
|
|
|
+ :label="value"
|
|
|
+ >
|
|
|
+ {{ label }}
|
|
|
+ </el-radio>
|
|
|
+ </el-form-item>
|
|
|
</el-form>
|
|
|
</template>
|
|
|
</QuestionBase>
|
|
@@ -114,23 +119,53 @@
|
|
|
<script>
|
|
|
import UploadAudio from '../common/UploadAudio.vue';
|
|
|
import QuestionMixin from '../common/QuestionMixin.js';
|
|
|
+import SoundRecord from '../common/SoundRecord.vue';
|
|
|
|
|
|
import { selectTypeList, changeOptionType } from '@/views/exercise_questions/data/common';
|
|
|
-import { repeatData, getOption } from '@/views/exercise_questions/data/repeat';
|
|
|
+import { repeatData, getOption, audioGenerationMethodList } from '@/views/exercise_questions/data/repeat';
|
|
|
+import { GetStaticResources } from '@/api/app';
|
|
|
|
|
|
export default {
|
|
|
name: 'RepeatQuestion',
|
|
|
components: {
|
|
|
UploadAudio,
|
|
|
+ SoundRecord,
|
|
|
},
|
|
|
mixins: [QuestionMixin],
|
|
|
data() {
|
|
|
return {
|
|
|
selectTypeList,
|
|
|
+ audioGenerationMethodList,
|
|
|
changeOptionType,
|
|
|
data: JSON.parse(JSON.stringify(repeatData)),
|
|
|
+ loading_list: [
|
|
|
+ {
|
|
|
+ loading: false,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ loading: false,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ loading: false,
|
|
|
+ },
|
|
|
+ ],
|
|
|
};
|
|
|
},
|
|
|
+ watch: {
|
|
|
+ 'data.option_list.length': {
|
|
|
+ handler(val) {
|
|
|
+ this.loading_list = [];
|
|
|
+ for (let i = 0; i < val; i++) {
|
|
|
+ let obj = {
|
|
|
+ loading: false,
|
|
|
+ };
|
|
|
+ this.loading_list.push(obj);
|
|
|
+ }
|
|
|
+ },
|
|
|
+ deep: true,
|
|
|
+ immediate: true,
|
|
|
+ },
|
|
|
+ },
|
|
|
methods: {
|
|
|
/**
|
|
|
* 智能识别
|
|
@@ -168,9 +203,31 @@ export default {
|
|
|
.then(() => {
|
|
|
this.data.option_list.splice(i, 1);
|
|
|
this.data.file_id_list.splice(this.data.file_id_list.indexOf(file_id), 1);
|
|
|
+ this.loading_list.splice(i, 1);
|
|
|
})
|
|
|
.catch(() => {});
|
|
|
},
|
|
|
+ // 自动生成音频
|
|
|
+ handleMatically(item, i) {
|
|
|
+ if (item.content.trim()) {
|
|
|
+ this.loading_list[i].loading = true;
|
|
|
+ let MethodName = 'tool-PinyinToVoiceFile';
|
|
|
+ let data = {
|
|
|
+ pinyin: item.content.trim().split(' ').join(','),
|
|
|
+ };
|
|
|
+ GetStaticResources(MethodName, data)
|
|
|
+ .then((res) => {
|
|
|
+ this.loading_list[i].loading = false;
|
|
|
+ if (res.status === 1) {
|
|
|
+ item.audio_file_id = res.file_id;
|
|
|
+ this.data.file_id_list.push(res.file_id);
|
|
|
+ }
|
|
|
+ })
|
|
|
+ .catch(() => {
|
|
|
+ this.loading_list[i].loading = false;
|
|
|
+ });
|
|
|
+ }
|
|
|
+ },
|
|
|
},
|
|
|
};
|
|
|
</script>
|
|
@@ -187,5 +244,47 @@ export default {
|
|
|
text-overflow: ellipsis;
|
|
|
white-space: nowrap;
|
|
|
}
|
|
|
+
|
|
|
+ .auto-matically {
|
|
|
+ display: flex;
|
|
|
+ flex-shrink: 0;
|
|
|
+ align-items: center;
|
|
|
+ width: 233px;
|
|
|
+ padding: 5px 12px;
|
|
|
+ background-color: $fill-color;
|
|
|
+ border-radius: 2px;
|
|
|
+
|
|
|
+ .audio-wrapper {
|
|
|
+ margin-right: 12px;
|
|
|
+
|
|
|
+ :deep .audio-play {
|
|
|
+ width: 16px;
|
|
|
+ height: 16px;
|
|
|
+ color: #000;
|
|
|
+ background-color: initial;
|
|
|
+ }
|
|
|
+
|
|
|
+ :deep .audio-play.not-url {
|
|
|
+ color: #a1a1a1;
|
|
|
+ }
|
|
|
+
|
|
|
+ :deep .voice-play {
|
|
|
+ width: 16px;
|
|
|
+ height: 16px;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ .auto-btn {
|
|
|
+ font-size: 14px;
|
|
|
+ font-weight: 400;
|
|
|
+ line-height: 22px;
|
|
|
+ color: #1d2129;
|
|
|
+ cursor: pointer;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ .delete {
|
|
|
+ flex-shrink: 0;
|
|
|
+ }
|
|
|
}
|
|
|
</style>
|