<template>
|
<a-button
|
v-if="typeAngint == 'edit'"
|
type="text"
|
size="small"
|
@click="editClick"
|
>
|
<template #icon>
|
<icon-tool />
|
</template>
|
</a-button>
|
<!-- <a-button v-if="typeAngint=='add'" style="margin-left: 10px" type="primary" @click="handleClick">确定</a-button>-->
|
<a-modal
|
v-model:visible="visible"
|
title=""
|
@before-open="handleOpened"
|
@cancel="handleCancel"
|
:footer="false"
|
title-align="start"
|
fullscreen
|
>
|
<div class="main-container">
|
<div class="main-container-lf">
|
<div style="padding: 10px;font-size: 16px;background: var(--color-neutral-3);">智能体配置</div>
|
<div style="display: flex;width: 100%;" :style="{height:height}">
|
<div style="width: 50%;height: 100%">
|
<div style="padding: 10px;font-size: 12px;color: #2a2a2b;">智能体画像</div>
|
<div>
|
<a-textarea v-model="system" placeholder="" disabled style="height: 400px;" />
|
</div>
|
|
</div>
|
<div style="width: 50%;border: 1px solid var(--color-neutral-3);background: var(--color-neutral-3)">
|
<a-form ref="formRef" :rules="rules" :model="form" @submit="handleSubmit" layout="vertical" >
|
<a-collapse :default-active-key="['1']">
|
<a-collapse-item header="基础信息" key="0" v-if="typeAngint == 'edit'">
|
<a-input v-model="form.name" placeholder="请输入智能体名称" style="width:200px;margin-top: 10px" />
|
</a-collapse-item>
|
<a-collapse-item header="AI模型配置" key="1">
|
<a-form-item field="llm_id" label="模型">
|
<a-space direction="vertical" size="large">
|
<a-select :size="'large'" field="llm_id" v-model="form.llm_id" :style="{width:'25rem'}" placeholder="请选择 ...">
|
<a-optgroup
|
:label="index"
|
v-for="(item, index) in modelList"
|
:key="index"
|
>
|
<a-option
|
v-for="obj in item"
|
:key="obj.fid"
|
:disabled="!obj.available"
|
:value="obj.llm_id"
|
>
|
{{ obj.llm_name }}
|
</a-option>
|
</a-optgroup>
|
</a-select>
|
</a-space>
|
</a-form-item>
|
</a-collapse-item>
|
<a-collapse-item header="开场引导" :key="'2'" disabled>
|
</a-collapse-item>
|
<a-collapse-item header="知识库" key="3">
|
<a-form-item field="kb_ids" label="知识库">
|
<a-select
|
v-model="form.kb_ids"
|
:style="{ width: '25rem' }"
|
placeholder="请选择 ..."
|
multiple
|
>
|
<a-option
|
v-for="item in tabs"
|
:key="item.id"
|
:value="item.id"
|
>{{ item.name }}</a-option
|
>
|
</a-select>
|
</a-form-item>
|
</a-collapse-item>
|
<a-collapse-item header="工具" key="4" disabled>
|
</a-collapse-item>
|
<a-collapse-item header="工作流" key="5" disabled>
|
</a-collapse-item>
|
</a-collapse>
|
|
<a-form-item>
|
<div
|
style="
|
position: absolute;
|
right: 10px;
|
top: 0px;
|
z-index: 99999;
|
"
|
>
|
<!-- <a-button @click="visible = false">取消</a-button>-->
|
<a-button
|
style="margin-left: 10px"
|
type="primary"
|
html-type="submit"
|
>保存</a-button
|
>
|
</div>
|
</a-form-item>
|
</a-form>
|
</div>
|
</div>
|
</div>
|
<div class="main-container-rt">
|
<sessionAction></sessionAction>
|
</div>
|
</div>
|
</a-modal>
|
</template>
|
|
<script lang="ts" setup>
|
import { onMounted, onBeforeMount, reactive, ref, nextTick } from 'vue';
|
import { IconSend } from '@arco-design/web-vue/es/icon';
|
import { queryKbList, queryModelList } from '@/api/kbList';
|
import useLoading from '@/hooks/loading';
|
import { dialogSet } from '@/api/Agent';
|
import { Message } from '@arco-design/web-vue';
|
import EventBus from "@/utils/EventBus";
|
import sessionAction from "@/views/dmx/IntelligentAgent/components/sessionAction.vue";
|
const { setLoading } = useLoading(true);
|
const props = defineProps(['typeAngint', 'formData']);
|
const visible = ref(false);
|
const loading = ref(false);
|
const form = reactive({
|
name: '',
|
icon: '',
|
language: 'English',
|
prompt_config: {
|
empty_response: '',
|
prologue: '你好! 我是你的助理,有什么可以帮到你的吗?',
|
quote: true,
|
self_rag: true,
|
system:
|
'示例:\n' +
|
'你是 XX,具有 XX 经验,擅长 XX,…\n' +
|
'你的任务是 XX ,需要按照以下步骤执行:\n' +
|
'1. XX\n' +
|
'2. XX\n' +
|
'3. …\n' +
|
'{knowlege}',
|
parameters: [
|
{
|
key: 'knowledge',
|
optional: false,
|
},
|
],
|
},
|
kb_ids: [],
|
llm_id: 'qwen-plus',
|
llm_setting: {
|
temperature: 0.1,
|
top_p: 0.3,
|
presence_penalty: 0.4,
|
frequency_penalty: 0.7,
|
max_tokens: 512,
|
},
|
similarity_threshold: 0.2,
|
vector_similarity_weight: 0.30000000000000004,
|
top_n: 8,
|
});
|
const system = ref('');
|
const embdId = ref('');
|
const modelList = ref({});
|
const renderData = ref([]);
|
const formRef = ref(null);
|
let tabs = ref([]);
|
const height = ref('calc(100vh - 150px)');
|
const emit = defineEmits(['cancelModal']);
|
const rules = {
|
name: [
|
{
|
required: true,
|
message: '名称不允许为空',
|
},
|
],
|
llm_id: [
|
{
|
required: true,
|
message: '模型不能为空',
|
},
|
],
|
kb_ids: [
|
{
|
required: true,
|
message: '知识库不能为空',
|
},
|
],
|
};
|
|
const handleSubmit = async ({ values, errors }) => {
|
// console.log('values:', values, '\nerrors:', errors)
|
if(!errors){
|
let title = '创建成功';
|
let formNew = { ...form };
|
if (props.typeAngint == 'edit') {
|
formNew.dialog_id = form.id;
|
delete formNew.id;
|
delete formNew.off;
|
title = '修改成功';
|
}
|
const data = await dialogSet(formNew);
|
if (data.code == 0) {
|
Message.success(title);
|
handleCancel();
|
EventBus.emit('queryList');
|
}
|
}
|
};
|
|
const editClick = (data) => {
|
visible.value = true;
|
|
console.log(props.formData);
|
Object.assign(form, props.formData);
|
console.log(form);
|
system.value = form.prompt_config.system;
|
};
|
|
const handleClick = (data) => {
|
visible.value = true;
|
nextTick(() => {
|
Object.assign(form, data);
|
console.log(form,'传值');
|
system.value = form.prompt_config.system;
|
if(tabs.value && tabs.value.length>0){
|
form.kb_ids = [tabs.value[0].id];
|
}
|
});
|
};
|
defineExpose({
|
handleClick,
|
});
|
const handleBeforeOk = (done) => {
|
formRef.value.validate().then((res) => {
|
console.log('form:', form);
|
if (!form.name) {
|
done(false);
|
} else {
|
console.log('请求数据');
|
}
|
});
|
};
|
const handleCancel = () => {
|
visible.value = false;
|
emit('cancelModal');
|
};
|
|
const handleOpened = (el) => {
|
// formRef.value.resetFields();
|
};
|
const queryModel = async (params) => {
|
try {
|
const data = await queryModelList(params);
|
console.log(data.data, '大模型列表');
|
modelList.value = data.data;
|
} catch (err) {
|
// you can report use errorHandler or other
|
} finally {
|
}
|
};
|
const file = ref();
|
|
const onChange = (_, currentFile) => {
|
file.value = {
|
...currentFile,
|
// url: URL.createObjectURL(currentFile.file),
|
};
|
};
|
const onProgress = (currentFile) => {
|
file.value = currentFile;
|
};
|
|
const knowledgeData = async (params = { page: 1, page_size: 20 }) => {
|
setLoading(true);
|
try {
|
const { data } = await queryKbList(params);
|
console.log(data, 'data');
|
nextTick(() => {
|
tabs.value = data;
|
console.log(tabs.value, 'tabs');
|
});
|
} catch (err) {
|
// you can report use errorHandler or other
|
} finally {
|
setLoading(false);
|
}
|
};
|
|
onBeforeMount(() => {
|
queryModel({});
|
knowledgeData();
|
});
|
onMounted(() => {});
|
</script>
|
|
<style scoped lang="less">
|
.main-container {
|
width: 100%;
|
display: flex;
|
.main-container-lf {
|
width: 60%;
|
}
|
.main-container-rt {
|
position: relative;
|
width: 40%;
|
}
|
}
|
.bottom {
|
width: 100%;
|
position: absolute;
|
bottom: 40px;
|
left: 0;
|
.input {
|
margin-left: 20%;
|
width: 60%;
|
}
|
.text {
|
margin-left: 40%;
|
font-size: 12px;
|
color: lightgrey;
|
line-height: 40px;
|
}
|
}
|
:deep(.arco-textarea-wrapper.arco-textarea-disabled){
|
background: var(--color-bg-2);
|
color: var(--color-text-1);
|
}
|
</style>
|