|
<template>
|
<a-button type="text" @click="handleClick" size="small">
|
<template #icon>
|
<icon-tool />
|
</template>
|
</a-button>
|
<a-modal
|
v-model:visible="visible"
|
title=" "
|
@before-open="handleOpened"
|
@cancel="handleCancel"
|
:footer="false"
|
title-align="start"
|
width="900px"
|
>
|
<a-tabs default-active-key="1">
|
<a-tab-pane key="1">
|
<template #title>
|
<icon-calendar/> 解析方法
|
</template>
|
<div style="width: 100%">
|
<div style="display: flex;align-items: center;">
|
<div>
|
解析方法:
|
</div>
|
<div style="margin-left: 10px">
|
<a-select v-model="form.parser_id" placeholder="请选择" >
|
<a-option v-for="item in parser_ids" :key="item.value" :label="item.name" :value="item.value"></a-option>
|
</a-select>
|
</div>
|
</div>
|
<div class="parser">
|
<a-form ref="formRef" :rules="rules" :model="form" auto-label-width @submit="handleSubmit" >
|
<a-divider style="margin-top: 10px" />
|
<a-form-item field="slider" label="块token数"
|
:rules="[{type:'number', min:1,message:'slider is min than 1'}]">
|
<a-slider v-model="form.chunk_token_num" :max="1000" show-input />
|
</a-form-item>
|
<a-divider style="margin-top: 10px" />
|
<a-form-item field="raptor" label="使用召回增强RAPTOR策略">
|
<a-space direction="vertical" size="large">
|
<a-switch v-model="form.use_raptor" @change="onChangeRAPTOR" />
|
</a-space>
|
</a-form-item>
|
<div v-if="form.use_raptor">
|
<a-form-item field="prompt" label="提示词">
|
<a-textarea
|
v-model="form.prompt"
|
style="height: 10rem;border: 1px solid var(--color-fill-3);border-radius: 4px" placeholder="请填写提示词" />
|
</a-form-item>
|
<a-form-item field="slider" label="最大token数"
|
:rules="[{type:'number', min:5,message:'slider is min than 5'}]">
|
<a-slider v-model="form.max_token" :min="1" :max="1000" show-input/>
|
</a-form-item>
|
<a-form-item field="slider" label="阈值" :rules="[{type:'number', min:5,message:'slider is min than 5'}]">
|
<a-slider v-model="form.threshold" show-tooltip show-input/>
|
</a-form-item>
|
<a-form-item field="slider" label="最大聚类数"
|
:rules="[{type:'number', min:5,message:'slider is min than 5'}]">
|
<a-slider v-model="form.max_cluster" :max="1000" show-input/>
|
</a-form-item>
|
<a-form-item field="slider" label="随机种子" v-model="form.random_seed"
|
:rules="[{type:'number', min:5,message:'slider is min than 5'}]">
|
<a-input-number v-model="form.random_seed" :style="{width:'300px',marginRight:'1rem',borderRadius:'4px'}"
|
placeholder="请输入" class="input-demo" :min="10" :max="100" />
|
<a-button type="primary" @click="randomNumber">
|
<icon-plus />
|
</a-button>
|
|
</a-form-item>
|
|
</div>
|
<a-form-item>
|
<div style="width: 100%;text-align: right">
|
<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>
|
</a-tab-pane>
|
<a-tab-pane key="2">
|
<template #title>
|
<icon-clock-circle/> 创建解析块
|
</template>
|
<div class="details">
|
<div class="details-header">
|
<div style="display: flex; align-items: center;justify-content: flex-end;">
|
<a-radio-group v-model="radio" type="button" style="margin-right: 10px" @change="onRadioChange">
|
<a-radio value="1">全文</a-radio>
|
<a-radio value="2">省略</a-radio>
|
</a-radio-group>
|
<a-popover position="bottom">
|
<a-button type="outline" class="button" style="margin-right: 10px;">批量<icon-down style="margin-left: 4px" /></a-button>
|
<template #content>
|
<a-space direction="vertical">
|
<a-checkbox :model-value="checkedAll" :indeterminate="indeterminate" @change="handleChangeAll" style="margin-left: 10px">
|
选择所有
|
</a-checkbox>
|
</a-space>
|
<a-divider style="margin: 10px 0" />
|
<p>
|
<a-button type="text" class="button" style="color: #2a2a2b">
|
<template #icon>
|
<icon-check-circle />
|
</template>
|
启用选定的
|
</a-button>
|
</p>
|
<p>
|
<a-button type="text" class="button" style="color: #2a2a2b">
|
<template #icon>
|
<icon-close-circle />
|
</template>
|
禁用选定的
|
</a-button>
|
</p>
|
<a-divider style="margin: 10px 0" />
|
<p>
|
<a-button type="text" class="button" style="color: #2a2a2b">
|
<template #icon>
|
<icon-delete />
|
</template>
|
删除选定的
|
</a-button>
|
</p>
|
</template>
|
</a-popover>
|
<a-button type="outline" class="button" style="margin-right: 10px">
|
<template #icon>
|
<icon-search />
|
</template>
|
</a-button>
|
<a-popover position="bottom">
|
<a-button type="outline" class="button" style="margin-right: 10px"><icon-sort /></a-button>
|
<template #content>
|
<a-radio-group v-model="available_int" direction="vertical" size="large" @change="onChangeavailable">
|
<a-radio value="">所有</a-radio>
|
<a-radio value="1">启用</a-radio>
|
<a-radio value="0">禁用</a-radio>
|
</a-radio-group>
|
</template>
|
</a-popover>
|
<addDetails></addDetails>
|
</div>
|
</div>
|
<a-divider style="margin-top: 10px" />
|
<div class="groupMain">
|
<a-checkbox-group v-model="data" @change="handleChange" >
|
<div class="groupList" :style="{background:keyBg=='1'?'#eff8ff':'white'}">
|
<a-checkbox value="1"></a-checkbox>
|
<div class="groupList-content" @click="groupListContentClick('1')">
|
而 stable version 是最新稳定版,经过充分测试和验证,bug 较少,
|
适合用于生产环境。其版本号通常为双数,如 1.26。legacy versions
|
则是之前发布的稳定版,对于需要
|
特定旧版本的兼容性或安全性支持的用户有用,但一般不
|
推荐用于新项目,除非有特殊需求。在实际使用中,如果追求最新功能
|
且愿意面对可能存在的一些不稳定因素,可以尝试使用主线版本进行测试和研究;如果是用于生产环境
|
</div>
|
<div class="groupList-right">
|
<a-switch v-model="switchType" checked-value="1" unchecked-value="0" @change="handleChangeStatus()"/>
|
</div>
|
</div>
|
|
<div class="groupList" :style="{background:keyBg=='2'?'#eff8ff':'white'}">
|
<a-checkbox value="1"></a-checkbox>
|
<div class="groupList-content" @click="groupListContentClick('2')">
|
而 stable version 是最新稳定版,经过充分测试和验证,bug 较少,
|
适合用于生产环境。其版本号通常为双数,如 1.26。legacy versions
|
则是之前发布的稳定版,对于需要
|
</div>
|
<div class="groupList-right">
|
<a-switch v-model="switchType" checked-value="1" unchecked-value="0" @change="handleChangeStatus()"/>
|
</div>
|
</div>
|
|
</a-checkbox-group>
|
</div>
|
</div>
|
</a-tab-pane>
|
</a-tabs>
|
|
|
|
</a-modal>
|
</template>
|
|
<script lang="ts" setup>
|
import { onMounted, onBeforeMount, reactive, ref, computed } from "vue";
|
import { Message } from "@arco-design/web-vue";
|
import {kbdocumentchangeparser} from "@/api/kbList";
|
import addDetails from '@/views/dmx/knowledgeLib/addDetails.vue'
|
const visible = ref(false);
|
const loading = ref(false);
|
const radio = ref('1');
|
const keyBg = ref('');
|
|
const props = defineProps(['kbtenantInfo','item','kbdetail'])
|
// const emit = defineEmits(['upTabdateItem'])
|
|
let threshold = computed(()=>{
|
return form.threshold/100;
|
})
|
|
const kbtenantInfo = props.kbtenantInfo;
|
|
let parser_ids = kbtenantInfo.parser_ids.split(',').map((item) => {
|
const [value1, value2] = item.split(':');
|
return {
|
name: value2,
|
value: value1,
|
};
|
});
|
|
const form = reactive({
|
parser_id: props.item.parser_id,
|
doc_id: props.item.id,
|
max_token: 698,
|
threshold: 30,
|
max_cluster: 233,
|
random_seed: 1500,
|
chunk_token_num: 128,
|
use_raptor: false,
|
pages: {},
|
prompt: '请总结以下段落。 小心数字,不要编造。 段落如下:\n' +
|
' {cluster_content}\n' +
|
'以上就是你需要总结的内容。',
|
});
|
const formRef = ref(null);
|
|
const rules = {
|
prompt: [
|
{
|
required: true,
|
message:'提示词不允许为空',
|
},
|
],
|
}
|
const formatter = (value) => {
|
return value / 100
|
};
|
function randomNumber() {
|
// 生成一个介于min和max之间的随机整数(包含min和max)
|
const min = 1; // 最小值
|
const max = 10000; // 最大值
|
form.random_seed = Math.floor(Math.random() * (max - min + 1)) + min;
|
}
|
|
const handleSubmit = async ({values, errors}) => {
|
if(!errors){
|
let data = await kbdocumentchangeparser({
|
parser_id: form.parser_id,
|
doc_id: form.doc_id,
|
parser_config: {
|
raptor: {
|
use_raptor: form.use_raptor,
|
prompt: form.prompt,
|
max_token: form.max_token,
|
threshold: form.threshold,
|
max_cluster: form.max_cluster,
|
random_seed: form.random_seed,
|
},
|
chunk_token_num: form.chunk_token_num,
|
pages: [
|
|
]
|
}
|
})
|
if(data.code == 0){
|
Message.success('配置成功');
|
}else{
|
Message.error('配置失败');
|
}
|
visible.value = false;
|
}
|
}
|
|
const handleClick = () => {
|
visible.value = true;
|
};
|
const handleCancel = () => {
|
visible.value = false;
|
}
|
|
const handleOpened =(el) => {
|
// console.log('props',props.kbtenantInfo);
|
// console.log('props',props.item);
|
// console.log('props',props.kbdetail);
|
console.log(parser_ids, 'parser_ids');
|
// Object.assign(form,{
|
// name: '',// 用户名
|
// nameJoin: '',// 昵称
|
// post: '',// 岗位
|
// txt: '',// 备注
|
// });
|
// formRef.value.resetFields();
|
}
|
|
|
const onChangeRAPTOR = () => {
|
|
};
|
|
|
|
|
|
|
|
|
const indeterminate = ref(false)
|
const checkedAll = ref(false)
|
const data = ref([])
|
const switchType = ref(false)
|
const available_int = ref('')
|
const onRadioChange = () => {
|
console.log(radio.value);
|
|
|
|
};
|
const handleChangeAll = (value) => {
|
indeterminate.value = false;
|
if (value) {
|
checkedAll.value = true;
|
data.value = ['1', '2', '3']
|
} else {
|
checkedAll.value = false;
|
data.value = []
|
}
|
}
|
|
const handleChange = (values) => {
|
if (values.length === 3) {
|
checkedAll.value = true
|
indeterminate.value = false;
|
} else if (values.length === 0) {
|
checkedAll.value = false
|
indeterminate.value = false;
|
} else {
|
checkedAll.value = false
|
indeterminate.value = true;
|
}
|
}
|
|
|
const groupListContentClick = (value) => {
|
keyBg.value = value;
|
}
|
|
|
const onChangeavailable = ()=>{
|
console.log(available_int.value);
|
}
|
|
const handleChangeStatus = ()=>{
|
console.log(switchType.value);
|
}
|
|
onBeforeMount(()=>{
|
|
})
|
onMounted(()=>{
|
|
|
})
|
</script>
|
|
<style scoped lang="less">
|
.parser{
|
width: 100%;
|
::v-deep .arco-btn-outline:hover, .arco-btn-outline, .arco-btn-outline[type='button']{
|
color: #2a2a2b;
|
border: 1px solid #2a2a2b;
|
}
|
.button{
|
//color: #2a2a2b!important;
|
}
|
}
|
.groupMain{
|
width: 100%;
|
height: 500px;
|
overflow: auto;
|
display: flex;
|
justify-content: center;
|
.groupList{
|
display: flex;
|
padding: 24px;
|
border-radius: 8px;
|
//background: #eff8ff;
|
border: 1px solid #f0f0f0;
|
margin-bottom: 20px;
|
overflow: auto;
|
.groupList-content{
|
width: 700px;
|
//height: 100px;
|
overflow: auto;
|
box-sizing: border-box;
|
margin: 0;
|
padding: 0;
|
color: rgba(0, 0, 0, 0.88);
|
font-size: 14px;
|
font-family: Inter;
|
position: relative;
|
|
|
}
|
}
|
}
|
</style>
|