mirror of
https://github.com/1Panel-dev/MaxKB.git
synced 2025-12-26 01:33:05 +00:00
--bug=1048275 --user=王孝刚 【应用】有一个应用设置日志清除策略,提示“引用分段数”字段必填 https://www.tapd.cn/57709429/s/1601736
143 lines
4.4 KiB
Vue
143 lines
4.4 KiB
Vue
<template>
|
||
<el-dialog
|
||
:title="$t('views.applicationOverview.appInfo.EditAvatarDialog.title')"
|
||
v-model="dialogVisible"
|
||
:close-on-click-modal="false"
|
||
:close-on-press-escape="false"
|
||
>
|
||
<el-radio-group v-model="radioType" class="radio-block 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('views.applicationOverview.appInfo.EditAvatarDialog.cancel') }}</el-button
|
||
>
|
||
<el-button type="primary" @click="submit" :loading="loading">
|
||
{{ $t('views.applicationOverview.appInfo.EditAvatarDialog.save') }}</el-button
|
||
>
|
||
</span>
|
||
</template>
|
||
</el-dialog>
|
||
</template>
|
||
<script setup lang="ts">
|
||
import { ref, watch } from 'vue'
|
||
import { useRoute } from 'vue-router'
|
||
import overviewApi from '@/api/application-overview'
|
||
import { cloneDeep } from 'lodash'
|
||
import { MsgSuccess, MsgError } from '@/utils/message'
|
||
import { defaultIcon, isAppIcon } from '@/utils/application'
|
||
import useStore from '@/stores'
|
||
import { t } from '@/locales'
|
||
|
||
const { application } = useStore()
|
||
|
||
const route = useRoute()
|
||
const {
|
||
params: { id } //应用id
|
||
} = route
|
||
|
||
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') {
|
||
application.asyncPutApplication(id as string, { icon: defaultIcon }, loading).then((res) => {
|
||
emit('refresh')
|
||
MsgSuccess(t('views.applicationOverview.appInfo.EditAvatarDialog.setSuccess'))
|
||
dialogVisible.value = false
|
||
})
|
||
} else if (radioType.value === 'custom' && iconFile.value) {
|
||
let fd = new FormData()
|
||
fd.append('file', iconFile.value.raw)
|
||
overviewApi.putAppIcon(id as string, fd, loading).then((res: any) => {
|
||
emit('refresh')
|
||
MsgSuccess(t('views.applicationOverview.appInfo.EditAvatarDialog.setSuccess'))
|
||
dialogVisible.value = false
|
||
})
|
||
} else {
|
||
MsgError(t('views.applicationOverview.appInfo.EditAvatarDialog.uploadImagePrompt'))
|
||
}
|
||
}
|
||
|
||
defineExpose({ open })
|
||
</script>
|
||
<style lang="scss" scope></style>
|