|  |  |  | 
|---|
|  |  |  | <a-form-item field="api_base" label="基础URL"> | 
|---|
|  |  |  | <a-input v-model="form.api_base" placeholder="请输入基础URL" /> | 
|---|
|  |  |  | </a-form-item> | 
|---|
|  |  |  | <!-- <a-form-item | 
|---|
|  |  |  | <a-form-item field="name" label="API-Key"> | 
|---|
|  |  |  | <a-input v-model="form.name" placeholder="API-Key" /> | 
|---|
|  |  |  | </a-form-item> | 
|---|
|  |  |  | <!-- <a-form-item field="describe" label="Base-Url"> | 
|---|
|  |  |  | <a-input v-model="form.name" placeholder="Base-Url" /> | 
|---|
|  |  |  | </a-form-item> --> | 
|---|
|  |  |  | <a-form-item | 
|---|
|  |  |  | field="raptor" | 
|---|
|  |  |  | label="是否支持 Vision" | 
|---|
|  |  |  | v-if="form.model_type === 'chat'" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <a-switch v-model="form.raptor" /> | 
|---|
|  |  |  | </a-form-item> --> | 
|---|
|  |  |  | </a-form-item> | 
|---|
|  |  |  | <a-form-item field="logo" label="模型图片"> | 
|---|
|  |  |  | <a-space direction="vertical" :style="{ width: '100%' }"> | 
|---|
|  |  |  | <a-space | 
|---|
|  |  |  | direction="vertical" | 
|---|
|  |  |  | v-model="form.logo" | 
|---|
|  |  |  | :style="{ width: '100%' }" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <Upload | 
|---|
|  |  |  | :action="uploadAction" | 
|---|
|  |  |  | :limit="1" | 
|---|
|  |  |  | :url="form.urlS" | 
|---|
|  |  |  | @handleRemove="deleteRemove" | 
|---|
|  |  |  | @update:fileList="updateFileList" | 
|---|
|  |  |  | @success="handleSuccess" | 
|---|
|  |  |  | ></Upload> | 
|---|
|  |  |  | 
|---|
|  |  |  | :action="uploadAction" | 
|---|
|  |  |  | :limit="1" | 
|---|
|  |  |  | :url="form.urlS" | 
|---|
|  |  |  | @handleRemove="deleteRemove" | 
|---|
|  |  |  | @update:fileList="updateFileList" | 
|---|
|  |  |  | @success="handleSuccess" | 
|---|
|  |  |  | ></Upload> | 
|---|
|  |  |  | 
|---|
|  |  |  | import { Modal, Message } from '@arco-design/web-vue'; | 
|---|
|  |  |  | import message from '@arco-design/web-vue/es/message'; | 
|---|
|  |  |  | import { resolveUnref } from '@vueuse/core'; | 
|---|
|  |  |  | import { useUserStore } from '@/store'; | 
|---|
|  |  |  | import { userModelState } from '@/store'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const userStore = useUserStore(); | 
|---|
|  |  |  | const modelStore = userModelState(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const addPageModelVisible = defineModel('show'); | 
|---|
|  |  |  | const loading = ref(false); | 
|---|
|  |  |  | 
|---|
|  |  |  | multiSelect: ['section one'], | 
|---|
|  |  |  | treeSelect: '', | 
|---|
|  |  |  | raptor: false, | 
|---|
|  |  |  | addFomList: [], | 
|---|
|  |  |  | addFomList: <any[]>[], | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | const form_ref = ref(null); | 
|---|
|  |  |  | const form_ref = ref(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const rules = { | 
|---|
|  |  |  | model_type: [ | 
|---|
|  |  |  | 
|---|
|  |  |  | message: '请输入api_base', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | logo: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | required: true, | 
|---|
|  |  |  | message: '模型图片不能为空', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const uploadAction = '/api/v1/llm/upload'; // 替换为你的上传API | 
|---|
|  |  |  | const fileList = ref([]); | 
|---|
|  |  |  | const imageUrls = ref([]); | 
|---|
|  |  |  | const imageUrls = ref<any[]>([]); | 
|---|
|  |  |  | const uploadUrl = ref([]); | 
|---|
|  |  |  | const httpUrl = localStorage.getItem('httpUrl'); | 
|---|
|  |  |  | const httpUrl = modelStore.hrefUrl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const updateFileList = (newFileList) => { | 
|---|
|  |  |  | fileList.value = newFileList; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const handleSuccess = (urls) => { | 
|---|
|  |  |  | uploadUrl.value = urls; | 
|---|
|  |  |  | form.logo = urls[0]; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const urlsArr = urls.map((url) => { | 
|---|
|  |  |  | return httpUrl + url; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | imageUrls.value = urlsArr; // 拿到上传的图片地址 | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | const deleteRemove = () => { | 
|---|
|  |  |  | form.logo = ''; | 
|---|
|  |  |  | uploadUrl.value = []; | 
|---|
|  |  |  | imageUrls.value = []; | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const emit = defineEmits(['refresh-parent']); | 
|---|
|  |  |  | const handleSubmit = ({ values, errors }) => { | 
|---|
|  |  |  | const all_params = form.addFomList.map((item) => { | 
|---|
|  |  |  | 
|---|
|  |  |  | volc_sk: form.volc_sk, | 
|---|
|  |  |  | api_base: form.api_base, | 
|---|
|  |  |  | all_params: all_params, | 
|---|
|  |  |  | logo: uploadUrl.value[0], | 
|---|
|  |  |  | logo: uploadUrl.value[0] || '', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if ((data as any).code == 200) { | 
|---|
|  |  |  | 
|---|
|  |  |  | volc_sk: form.volc_sk, | 
|---|
|  |  |  | api_base: form.api_base, | 
|---|
|  |  |  | all_params: all_params, | 
|---|
|  |  |  | logo: uploadUrl.value[0], | 
|---|
|  |  |  | logo: uploadUrl.value[0] || '', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if ((data as any).code == 200) { | 
|---|