refactor: 选择模型时支持按照模型类型筛选

This commit is contained in:
CaptainB 2024-10-16 11:18:19 +08:00 committed by 刘瑞斌
parent 67f3ec34a1
commit 084f8503e7
3 changed files with 57 additions and 2 deletions

View File

@ -162,6 +162,14 @@ class Provide(APIView):
, tags=["模型"])
@has_permissions(PermissionConstants.MODEL_READ)
def get(self, request: Request):
model_type = request.query_params.get('model_type')
if model_type:
providers = []
for key in ModelProvideConstants.__members__:
if len([item for item in ModelProvideConstants[key].value.get_model_type_list() if
item['value'] == model_type]) > 0:
providers.append(ModelProvideConstants[key].value.get_model_provide_info().to_dict())
return result.success(providers)
return result.success(
[ModelProvideConstants[key].value.get_model_provide_info().to_dict() for key in
ModelProvideConstants.__members__])

View File

@ -34,6 +34,13 @@ const getProvider: (loading?: Ref<boolean>) => Promise<Result<Array<Provider>>>
return get(`${prefix_provider}`, {}, loading)
}
/**
*
*/
const getProviderByModelType: (model_type: string, loading?: Ref<boolean>) => Promise<Result<Array<Provider>>> = (model_type, loading) => {
return get(`${prefix_provider}`, {model_type}, loading)
}
/**
*
* @param provider
@ -187,5 +194,6 @@ export default {
getModelMetaById,
pauseDownload,
getModelParamsForm,
updateModelParamsForm
updateModelParamsForm,
getProviderByModelType
}

View File

@ -6,9 +6,29 @@
:close-on-press-escape="false"
:destroy-on-close="true"
:before-close="close"
title="选择供应商"
append-to-body
>
<template #title>
<div class="flex-between">
<h4>选择供应商</h4>
<el-dropdown>
<span class="el-dropdown-link">
{{ currentModelType || '全部模型' }}
<el-icon class="el-icon--right">
<arrow-down />
</el-icon>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item v-for="item in modelTypeOptions" :key="item.value" @click="checkModelType(item.value)">
<span>{{ item.text }}</span>
<el-icon v-if="currentModelType === item.text"><Check /></el-icon>
</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</div>
</template>
<el-row :gutter="12" v-loading="loading">
<el-col :span="12" class="mb-16" v-for="(data, index) in list_provider" :key="index">
<el-card shadow="hover" @click="go_create(data)">
@ -25,9 +45,20 @@
import { ref } from 'vue'
import ModelApi from '@/api/model'
import type { Provider } from '@/api/type/model'
const loading = ref<boolean>(false)
const dialogVisible = ref<boolean>(false)
const list_provider = ref<Array<Provider>>([])
const currentModelType = ref('')
const modelTypeOptions = ref([
{ text: '全部模型', value:''},
{ text: '大语言模型', value:'LLM'},
{ text: '向量模型', value:'EMBEDDING'},
{ text: '重排模型', value:'RERANKER'},
{ text: '语音识别', value:'STT'},
{ text: '语音合成', value:'TTS'}
])
const open = () => {
dialogVisible.value = true
@ -39,6 +70,14 @@ const open = () => {
const close = () => {
dialogVisible.value = false
}
const checkModelType = (model_type: string) => {
currentModelType.value = modelTypeOptions.value.filter((item) => item.value === model_type)[0].text
ModelApi.getProviderByModelType(model_type, loading).then((ok) => {
list_provider.value = ok.data
})
}
const emit = defineEmits(['change'])
const go_create = (provider: Provider) => {
close()