mirror of
				https://github.com/continew-org/continew-admin.git
				synced 2025-10-26 18:58:37 +08:00 
			
		
		
		
	feat: 新增公共上传接口,完善系统配置 Logo、favicon 上传
This commit is contained in:
		| @@ -38,3 +38,7 @@ export function listRoleDict(params: RoleParam) { | ||||
| export function listDict(code: string) { | ||||
|   return axios.get<LabelValueState[]>(`${BASE_URL}/dict/${code}`); | ||||
| } | ||||
|  | ||||
| export function upload(data: FormData) { | ||||
|   return axios.post(`${BASE_URL}/file`, data); | ||||
| } | ||||
|   | ||||
							
								
								
									
										13
									
								
								continew-admin-ui/src/utils/file.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								continew-admin-ui/src/utils/file.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| export default function getFile(file: string | undefined) { | ||||
|   if (file) { | ||||
|     const baseUrl = import.meta.env.VITE_API_BASE_URL; | ||||
|     if ( | ||||
|       !file.startsWith('http://') && | ||||
|       !file.startsWith('https://') && | ||||
|       !file.startsWith('blob:') | ||||
|     ) { | ||||
|       return `${baseUrl}/file/${file}`; | ||||
|     } | ||||
|   } | ||||
|   return file; | ||||
| } | ||||
| @@ -16,6 +16,7 @@ | ||||
|             <br /> | ||||
|             <a-upload | ||||
|               :file-list="faviconFile ? [faviconFile] : []" | ||||
|               accept="image/*" | ||||
|               :show-file-list="false" | ||||
|               :custom-request="handleUploadFavicon" | ||||
|               @change="handleChangeFavicon" | ||||
| @@ -32,7 +33,7 @@ | ||||
|                     v-if="faviconFile && faviconFile.url" | ||||
|                     class="arco-upload-list-picture custom-upload-avatar favicon" | ||||
|                   > | ||||
|                     <img :src="faviconFile.url" /> | ||||
|                     <img :src="getFile(faviconFile.url)" /> | ||||
|                     <div | ||||
|                       v-if="isEdit" | ||||
|                       class="arco-upload-list-picture-mask favicon" | ||||
| @@ -59,6 +60,7 @@ | ||||
|             <br /> | ||||
|             <a-upload | ||||
|               :file-list="logoFile ? [logoFile] : []" | ||||
|               accept="image/*" | ||||
|               :show-file-list="false" | ||||
|               :custom-request="handleUploadLogo" | ||||
|               @change="handleChangeLogo" | ||||
| @@ -75,7 +77,7 @@ | ||||
|                     v-if="logoFile && logoFile.url" | ||||
|                     class="arco-upload-list-picture custom-upload-avatar logo" | ||||
|                   > | ||||
|                     <img :src="logoFile.url" /> | ||||
|                     <img :src="getFile(logoFile.url)" /> | ||||
|                     <div | ||||
|                       v-if="isEdit" | ||||
|                       class="arco-upload-list-picture-mask logo" | ||||
| @@ -109,8 +111,15 @@ | ||||
|         > | ||||
|           <a-input v-model="form.site_copyright" placeholder="请输入版权信息" /> | ||||
|         </a-form-item> | ||||
|         <div> | ||||
|         <div style="margin-top: 20px"> | ||||
|           <a-space> | ||||
|             <a-button | ||||
|               v-if="!isEdit" | ||||
|               v-permission="['system:config:reset']" | ||||
|               @click="toResetValue" | ||||
|             > | ||||
|               <template #icon><icon-redo /></template>恢复默认 | ||||
|             </a-button> | ||||
|             <a-button | ||||
|               v-if="!isEdit" | ||||
|               v-permission="['system:config:update']" | ||||
| @@ -119,13 +128,6 @@ | ||||
|             > | ||||
|               <template #icon><icon-edit /></template>修改 | ||||
|             </a-button> | ||||
|             <a-button | ||||
|               v-if="!isEdit" | ||||
|               v-permission="['system:config:reset']" | ||||
|               @click="toResetValue" | ||||
|             > | ||||
|               <template #icon><icon-redo /></template>恢复默认 | ||||
|             </a-button> | ||||
|             <a-button | ||||
|               v-if="isEdit" | ||||
|               v-permission="['system:config:update']" | ||||
| @@ -166,6 +168,8 @@ | ||||
|     save, | ||||
|     resetValue, | ||||
|   } from '@/api/system/config'; | ||||
|   import { upload } from '@/api/common'; | ||||
|   import getFile from '@/utils/file'; | ||||
|  | ||||
|   const { proxy } = getCurrentInstance() as any; | ||||
|   const dataList = ref<DataRecord[]>([]); | ||||
| @@ -189,6 +193,20 @@ | ||||
|   }); | ||||
|   const { queryParams, form, rules } = toRefs(data); | ||||
|  | ||||
|   /** | ||||
|    * 重置表单 | ||||
|    */ | ||||
|   const reset = () => { | ||||
|     form.value = { | ||||
|       site_title: siteTitle.value?.value, | ||||
|       site_copyright: siteCopyright.value?.value, | ||||
|       site_logo: siteLogo.value?.value, | ||||
|       site_favicon: siteFavicon.value?.value, | ||||
|     }; | ||||
|     logoFile.value.url = siteLogo.value?.value; | ||||
|     faviconFile.value.url = siteFavicon.value?.value; | ||||
|   }; | ||||
|  | ||||
|   /** | ||||
|    * 查询配置 | ||||
|    */ | ||||
| @@ -207,14 +225,7 @@ | ||||
|     siteFavicon.value = dataList.value.find( | ||||
|       (option) => option.code === 'site_favicon' | ||||
|     ); | ||||
|     form.value = { | ||||
|       site_title: siteTitle.value?.value, | ||||
|       site_copyright: siteCopyright.value?.value, | ||||
|       site_logo: siteLogo.value?.value, | ||||
|       site_favicon: siteFavicon.value?.value, | ||||
|     }; | ||||
|     logoFile.value.url = siteLogo.value?.value; | ||||
|     faviconFile.value.url = siteFavicon.value?.value; | ||||
|     reset(); | ||||
|   }; | ||||
|   getConfig(); | ||||
|  | ||||
| @@ -254,8 +265,28 @@ | ||||
|    * @param options / | ||||
|    */ | ||||
|   const handleUploadLogo = (options: RequestOption) => { | ||||
|     console.log(options); | ||||
|     const controller = new AbortController(); | ||||
|     (async function requestWrap() { | ||||
|       const { | ||||
|         onProgress, | ||||
|         onError, | ||||
|         onSuccess, | ||||
|         fileItem, | ||||
|         name = 'file', | ||||
|       } = options; | ||||
|       onProgress(20); | ||||
|       const formData = new FormData(); | ||||
|       formData.append(name as string, fileItem.file as Blob); | ||||
|       upload(formData) | ||||
|         .then((res) => { | ||||
|           onSuccess(res); | ||||
|           form.value.site_logo = res.data; | ||||
|           proxy.$message.success(res.msg); | ||||
|         }) | ||||
|         .catch((error) => { | ||||
|           onError(error); | ||||
|         }); | ||||
|     })(); | ||||
|     return { | ||||
|       abort() { | ||||
|         controller.abort(); | ||||
| @@ -269,8 +300,28 @@ | ||||
|    * @param options / | ||||
|    */ | ||||
|   const handleUploadFavicon = (options: RequestOption) => { | ||||
|     console.log(options); | ||||
|     const controller = new AbortController(); | ||||
|     (async function requestWrap() { | ||||
|       const { | ||||
|         onProgress, | ||||
|         onError, | ||||
|         onSuccess, | ||||
|         fileItem, | ||||
|         name = 'file', | ||||
|       } = options; | ||||
|       onProgress(20); | ||||
|       const formData = new FormData(); | ||||
|       formData.append(name as string, fileItem.file as Blob); | ||||
|       upload(formData) | ||||
|         .then((res) => { | ||||
|           onSuccess(res); | ||||
|           form.value.site_favicon = res.data; | ||||
|           proxy.$message.success(res.msg); | ||||
|         }) | ||||
|         .catch((error) => { | ||||
|           onError(error); | ||||
|         }); | ||||
|     })(); | ||||
|     return { | ||||
|       abort() { | ||||
|         controller.abort(); | ||||
| @@ -287,7 +338,6 @@ | ||||
|   const handleChangeLogo = (_: any, currentFile: any) => { | ||||
|     logoFile.value = { | ||||
|       ...currentFile, | ||||
|       // url: URL.createObjectURL(currentFile.file), | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
| @@ -300,7 +350,6 @@ | ||||
|   const handleChangeFavicon = (_: any, currentFile: any) => { | ||||
|     faviconFile.value = { | ||||
|       ...currentFile, | ||||
|       // url: URL.createObjectURL(currentFile.file), | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
| @@ -335,13 +384,6 @@ | ||||
|   const toEdit = () => { | ||||
|     isEdit.value = true; | ||||
|   }; | ||||
|  | ||||
|   /** | ||||
|    * 重置表单 | ||||
|    */ | ||||
|   const reset = () => { | ||||
|     proxy.$refs.formRef?.resetFields(); | ||||
|   }; | ||||
| </script> | ||||
|  | ||||
| <style scoped lang="less"> | ||||
| @@ -359,7 +401,8 @@ | ||||
|     line-height: 16px; | ||||
|   } | ||||
|  | ||||
|   .arco-form .image-item { | ||||
|   .arco-form .image-item, | ||||
|   .input-item { | ||||
|     margin-bottom: 0; | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| export default { | ||||
|   'menu.system.config': '系统配置(开发中)', | ||||
|   'menu.system.config': '系统配置', | ||||
| }; | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
|     <a-space :size="54"> | ||||
|       <a-upload | ||||
|         :file-list="avatarList" | ||||
|         accept="image/*" | ||||
|         :show-file-list="false" | ||||
|         list-type="picture-card" | ||||
|         :show-upload-button="true" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user