mirror of
https://github.com/1Panel-dev/MaxKB.git
synced 2025-12-26 01:33:05 +00:00
130 lines
3.8 KiB
Vue
130 lines
3.8 KiB
Vue
<template>
|
||
<el-dialog
|
||
:title="`Logo ${$t('common.setting')}`"
|
||
v-model="dialogVisible"
|
||
:close-on-click-modal="false"
|
||
:close-on-press-escape="false"
|
||
>
|
||
<el-radio-group v-model="radioType" class="radio-block-avatar mb-16">
|
||
<div>
|
||
<el-radio value="default">
|
||
<p>{{ $t('views.applicationOverview.appInfo.EditAvatarDialog.default') }}</p>
|
||
<AppAvatar
|
||
v-if="detail?.name"
|
||
:name="detail?.name"
|
||
pinyinColor
|
||
class="mt-8 mb-8"
|
||
shape="square"
|
||
:size="32"
|
||
/>
|
||
</el-radio>
|
||
</div>
|
||
<div class="mt-8">
|
||
<el-radio value="custom">
|
||
<p>{{ $t('views.applicationOverview.appInfo.EditAvatarDialog.customizeUpload') }}</p>
|
||
<div class="flex mt-8">
|
||
<AppAvatar
|
||
v-if="fileURL"
|
||
shape="square"
|
||
:size="32"
|
||
style="background: none"
|
||
class="mr-16"
|
||
>
|
||
<img :src="fileURL" alt="" />
|
||
</AppAvatar>
|
||
<el-upload
|
||
ref="uploadRef"
|
||
action="#"
|
||
:auto-upload="false"
|
||
:show-file-list="false"
|
||
accept="image/jpeg, image/png, image/gif"
|
||
:on-change="onChange"
|
||
>
|
||
<el-button icon="Upload" :disabled="radioType !== 'custom'"
|
||
>{{ $t('views.applicationOverview.appInfo.EditAvatarDialog.upload') }}
|
||
</el-button>
|
||
</el-upload>
|
||
</div>
|
||
<div class="el-upload__tip info mt-16">
|
||
{{ $t('views.applicationOverview.appInfo.EditAvatarDialog.sizeTip') }}
|
||
</div>
|
||
</el-radio>
|
||
</div>
|
||
</el-radio-group>
|
||
<template #footer>
|
||
<span class="dialog-footer">
|
||
<el-button @click.prevent="dialogVisible = false"> {{ $t('common.cancel') }}</el-button>
|
||
<el-button type="primary" @click="submit" :loading="loading">
|
||
{{ $t('common.save') }}</el-button
|
||
>
|
||
</span>
|
||
</template>
|
||
</el-dialog>
|
||
</template>
|
||
<script setup lang="ts">
|
||
import { ref, watch } from 'vue'
|
||
import functionLibApi from '@/api/function-lib'
|
||
import { cloneDeep } from 'lodash'
|
||
import { MsgError, MsgSuccess } from '@/utils/message'
|
||
import { defaultIcon, isAppIcon } from '@/utils/application'
|
||
import { t } from '@/locales'
|
||
|
||
const emit = defineEmits(['refresh'])
|
||
|
||
const iconFile = ref<any>(null)
|
||
const fileURL = ref<any>(null)
|
||
|
||
const dialogVisible = ref<boolean>(false)
|
||
const loading = ref(false)
|
||
const detail = ref<any>(null)
|
||
const radioType = ref('default')
|
||
|
||
watch(dialogVisible, (bool) => {
|
||
if (!bool) {
|
||
iconFile.value = null
|
||
fileURL.value = null
|
||
}
|
||
})
|
||
|
||
const open = (data: any) => {
|
||
radioType.value = isAppIcon(data.icon) ? 'custom' : 'default'
|
||
fileURL.value = isAppIcon(data.icon) ? data.icon : null
|
||
detail.value = cloneDeep(data)
|
||
dialogVisible.value = true
|
||
}
|
||
|
||
const onChange = (file: any) => {
|
||
//1、判断文件大小是否合法,文件限制不能大于10MB
|
||
const isLimit = file?.size / 1024 / 1024 < 10
|
||
if (!isLimit) {
|
||
// @ts-ignore
|
||
MsgError(t('views.applicationOverview.appInfo.EditAvatarDialog.fileSizeExceeded'))
|
||
return false
|
||
} else {
|
||
iconFile.value = file
|
||
fileURL.value = URL.createObjectURL(file.raw)
|
||
}
|
||
}
|
||
|
||
function submit() {
|
||
if (radioType.value === 'default') {
|
||
emit('refresh', '/ui/favicon.ico')
|
||
dialogVisible.value = false
|
||
} else if (radioType.value === 'custom' && iconFile.value) {
|
||
let fd = new FormData()
|
||
fd.append('file', iconFile.value.raw)
|
||
functionLibApi.putFunctionLibIcon(detail.value.id, fd, loading).then((res: any) => {
|
||
emit('refresh', res.data)
|
||
dialogVisible.value = false
|
||
})
|
||
} else {
|
||
MsgError(t('views.applicationOverview.appInfo.EditAvatarDialog.uploadImagePrompt'))
|
||
}
|
||
}
|
||
|
||
defineExpose({ open })
|
||
</script>
|
||
<style lang="scss" scoped>
|
||
|
||
</style>
|