This commit is contained in:
lyc 2025-01-06 17:24:56 +08:00
parent 1814f811d4
commit 7be60a3d72
3 changed files with 119 additions and 113 deletions

View File

@ -107,9 +107,13 @@ const getBackGroundV2 = async () => {
}
};
const createOutlineV2 = async (data) => {
const createOutlineV2 = async (params) => {
try {
const response = await req("/api/aipptV2/createOutlineV2", "POST", data);
const response = await request({
url:"/api/aipptV2/createOutlineV2",
method: "POST",
params
});
console.log("createOutline response:", response);
return response.data;

View File

@ -36,6 +36,7 @@ import emitter from '@/utils/mitt'
import * as commUtils from '@/utils/comm.js'
import { createChart, sendChart } from '@/api/ai/index'
import { completion, addSyllabus, syllabuss, removeSyllabus } from '@/api/mode/index.js'
import { createOutlineV2 } from '@/utils/ppt-request.js'
import TypingEffect from '@/components/typing-effect/index.vue'
import useUserStore from '@/store/modules/user'
@ -59,6 +60,7 @@ const modeOptions = ref([
//
const selectedData = ref([])
emitter.on('selected', (data)=>{
console.log(data,3000)
selectedData.value = data
})
//
@ -119,9 +121,11 @@ const createAi = async ()=>{
//
else {
const res = await completion(params)
data = res.data
}
console.log(data)
const res = await createOutlineV2({query: data.answer})
console.log(res)
emitter.emit('onResult', data.answer)
answer.value = getResult(data.answer)

View File

@ -4,8 +4,11 @@
<span>教学模式</span>
<div>
<el-button type="primary" link @click="resetSelect">重置</el-button>
<el-button type="primary" link @click="addVisible = true; addChild = false; isEdit = false"><i class="iconfont icon-jiahao"
></i>新增</el-button>
<el-button type="primary" link @click="
addVisible = true
addChild = false
isEdit = false
"><i class="iconfont icon-jiahao"></i>新增</el-button>
</div>
</div>
<div class="left-list">
@ -25,21 +28,22 @@
<!--减号 选中之后显示-->
<i v-show="item.selected" class="iconfont icon-zuixiaohua"></i>
</div>
<div class="item-child flex" :class="child.selected ? 'act-child' : ''" v-for="child in item.children" :key="child.id"
@mouseenter="child.isAdd = true" @mouseleave="child.isAdd = false" @click="toggleChild(item,child)">
<div class="item-child flex" :class="child.selected ? 'act-child' : ''" v-for="child in item.children"
:key="child.id" @mouseenter="child.isAdd = true" @mouseleave="child.isAdd = false"
@click="toggleChild(item, child)">
<div>
<span>{{ child.name }}</span>
<!--个人教学模式才会有编辑-->
<el-button v-if="!child.ex3" class="ml-3" type="primary" link @click.stop="editMode(child)">编辑</el-button>
</div>
<i v-show="child.isAdd && !child.selected" class="iconfont icon-jiahao"></i>
<i v-show="child.selected" class="iconfont icon-zuixiaohua "></i>
<i v-show="child.selected" class="iconfont icon-zuixiaohua"></i>
</div>
</div>
</div>
<!--弹窗-->
<el-dialog v-model="addVisible" append-to-body :show-close="false" width="550" :before-close="handleBeforeClose"
style="border-radius: 10px; padding: 10px 15px;">
style="border-radius: 10px; padding: 10px 15px">
<template #header>
<div class="mode-dialog-header flex">
<span>{{ addChild ? '教学环节' : '教学模式' }}</span>
@ -48,8 +52,8 @@
</template>
<el-form ref="ruleFormRef" style="max-width: 600px" :model="ruleForm" :rules="rules" label-width="auto"
class="demo-ruleForm">
<el-form-item :label="`教学${ addChild ? '环节' : '模式'}名称`" prop="name">
<div class="flex" style="width: 100%;">
<el-form-item :label="`教学${addChild ? '环节' : '模式'}名称`" prop="name">
<div class="flex" style="width: 100%">
<el-input v-model="ruleForm.name" />
<el-button v-if="isEdit" link type="danger" class="ml-5 mr-3" @click="onDel">删除</el-button>
</div>
@ -64,7 +68,6 @@
</div>
</el-dialog>
</div>
</template>
<script setup>
@ -77,127 +80,130 @@ import { ElMessage, ElMessageBox } from 'element-plus'
import { addChildTemp, editChildTemp, removeChildTemp, syllabusList } from '@/api/mode'
import { cloneDeep } from 'lodash'
const { user } = useUserStore()
//
//
const loading = ref(false)
let list = ref([])
const getTemplate = async (id) => {
loading.value = true
const { rows } = await modelList({ createUser: user.userId, model: 4, type: 1, pageNum: 1, pageSize: 10000 })
loading.value = false
list.value = rows
if (list.value.length) {
getChildTemp(id)
}
}
//
const templateList = ref([])
const getChildTemp = async () => {
templateList.value = []
const getTemplate = async () => {
loading.value = true
for (let item of list.value) {
try {
let { rows } = await modelList({ model: 4, type: 2, parentId: item.id })
templateList.value.push({
...item,
children: rows
const { rows } = await modelList({
createUser: user.userId,
model: 4,
pageNum: 1,
pageSize: 10000
})
} finally {
loading.value = false
}
}
// type 1
let ary1 = rows.filter((item) => item.type === 1)
templateList.value = ary1.map((parent) => {
parent.children = rows.filter((child) => child.type === 2 && child.parentId === parent.id)
return parent
})
getSyllabus()
}
//
const getSyllabus = async () =>{
const { rows } = await syllabusList()
if(rows && rows.length){
const idsAry = rows.at(-1).modelIds.split(',').map(item => Number(item));
const getSyllabus = async () => {
const { rows } = await syllabusList({
createUserId: user.userId,
eduId: curNode.id,
sourceType: 1,
pageSize: 1,
orderByColumn: 'createTime',
isAsc: 'desc'
})
if (rows && rows.length) {
const idsAry = rows
.at(-1)
.modelIds.split(',')
.map((item) => Number(item))
//
let ary = []
templateList.value.forEach((parent) => {
parent.children.forEach((child) => {
child.selected = idsAry.includes(child.id);
});
child.selected = idsAry.includes(child.id)
if (child.selected) {
ary.push(child)
}
})
// selected
parent.selected = parent.children.every((child) => child.selected);
});
parent.selected = parent.children.every((child) => child.selected)
})
//
emitter.emit('onShow', rows.at(-1))
emitter.emit('selected', ary)
}
}
//
const resetSelect = () =>{
templateList.value.forEach(item =>{
const resetSelect = () => {
templateList.value.forEach((item) => {
item.selected = false
item.children.forEach( el=>{
item.children.forEach((el) => {
el.selected = false
})
})
emitter.emit('selected', [])
}
emitter.on('resetSelect', () =>{
emitter.on('resetSelect', () => {
resetSelect()
})
//
const toggleParent = (parent) => {
parent.selected = !parent.selected;
parent.children.forEach(child => {
child.selected = parent.selected;
});
const selectedData = templateList.value.map((item) => item.children.filter((child) => child.selected)).flat()
parent.selected = !parent.selected
parent.children.forEach((child) => {
child.selected = parent.selected
})
const selectedData = templateList.value
.map((item) => item.children.filter((child) => child.selected))
.flat()
// .flat()
emitter.emit('selected', selectedData)
}
//
const toggleChild = (parent,child) =>{
child.selected = !child.selected;
const toggleChild = (parent, child) => {
child.selected = !child.selected
updateParentSelection(parent)
const selectedData = templateList.value.map((item) => item.children.filter((child) => child.selected)).flat()
const selectedData = templateList.value
.map((item) => item.children.filter((child) => child.selected))
.flat()
emitter.emit('selected', selectedData)
}
// ()()
const updateParentSelection = (parent) => {
parent.selected = parent.children.every((child) => child.selected);
parent.selected = parent.children.every((child) => child.selected)
}
//
const addVisible = ref(false)
const ruleFormRef = ref()
const rules = reactive({
name: [
{ required: true, message: '不能为空', trigger: 'blur' },
]
name: [{ required: true, message: '不能为空', trigger: 'blur' }]
})
const ruleForm = reactive({
name: '',
prompt: ''
})
//
const onSubmit = async (formEl) =>{
const onSubmit = async (formEl) => {
if (!formEl) return
await formEl.validate(async (valid, fields) => {
if (valid) {
//
if(isEdit.value){
if (isEdit.value) {
let data = cloneDeep(curEditItem)
data.name = ruleForm.name
await editChildTemp(data)
}
//
else{
else {
let obj = {
ex1: curNode.edustage,
ex2: curNode.edusubject,
@ -207,13 +213,12 @@ const onSubmit = async (formEl) =>{
type: 1
}
//
if(addChild.value){
if (addChild.value) {
obj.parentId = curEditItem.id
obj.prompt = ruleForm.prompt
obj.type = 2
}
await addChildTemp(obj)
}
ElMessage.success('操作成功')
resetForm()
@ -231,7 +236,7 @@ const isEdit = ref(false)
const addChild = ref(false)
const curEditItem = reactive({})
const addModeChild = (item) =>{
const addModeChild = (item) => {
isEdit.value = false
Object.assign(curEditItem, item)
addChild.value = true
@ -240,7 +245,7 @@ const addModeChild = (item) =>{
//
const editMode = (item)=>{
const editMode = (item) => {
isEdit.value = true
addChild.value = false
Object.assign(curEditItem, item)
@ -249,16 +254,12 @@ const editMode = (item)=>{
}
//
const onDel = () =>{
ElMessageBox.confirm(
'确定要删除模板吗?',
'温馨提示',
{
const onDel = () => {
ElMessageBox.confirm('确定要删除模板吗?', '温馨提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}
)
type: 'warning'
})
.then(async () => {
await removeChildTemp(curEditItem.id)
ElMessage.success('操作成功')
@ -266,36 +267,33 @@ const onDel = () =>{
addVisible.value = false
getTemplate()
})
.catch(() => {})
.catch(() => { })
}
const closeDialog = () =>{
handleBeforeClose(() => addVisible.value = false);
const closeDialog = () => {
handleBeforeClose(() => (addVisible.value = false))
}
const handleBeforeClose = (done) =>{
const handleBeforeClose = (done) => {
resetForm()
done()
}
const resetForm = () => {
if (ruleFormRef.value) {
ruleFormRef.value.resetFields();
ruleFormRef.value.resetFields()
}
};
}
const curNode = reactive({})
onMounted(() => {
let data = sessionStore.get('subject.curNode')
Object.assign(curNode, data);
Object.assign(curNode, data)
getTemplate()
})
onUnmounted(()=>{
onUnmounted(() => {
emitter.off('resetSelect')
})
</script>
<style lang="scss" scoped>
@ -342,7 +340,7 @@ onUnmounted(()=>{
position: relative;
&::after {
content: "";
content: '';
width: 5px;
height: 5px;
border-radius: 50%;
@ -352,7 +350,6 @@ onUnmounted(()=>{
top: 50%;
transform: translate(0, -50%);
}
}
.iconfont {
@ -389,7 +386,8 @@ onUnmounted(()=>{
cursor: pointer;
}
}
.form-btn{
.form-btn {
text-align: right;
margin-bottom: 10px;
}