completepage: 🍻 文件页面删除和批量下载,修改部分页面bug

This commit is contained in:
Bunny 2024-10-13 02:41:56 +08:00
parent 2ed9f007f0
commit 73a2e70354
8 changed files with 121 additions and 58 deletions

View File

@ -7,8 +7,13 @@ export const fetchGetFilesList = (data: any) => {
};
/** 系统文件管理---下载系统文件 */
export const fetchDownloadFiles = (data: any) => {
return http.request<any>('get', `files/downloadFiles/${data.id}`);
export const downloadFilesByFileId = (data: any) => {
return http.request<any>('get', `files/downloadFilesByFileId/${data.id}`, { responseType: 'blob' });
};
/** 系统文件管理---下载系统文件 */
export const downloadFilesByFilepath = (data: any) => {
return http.request<any>('get', `files/downloadFilesByFilepath`, { params: data, responseType: 'blob' });
};
/** 系统文件管理---添加系统文件管理 */

View File

@ -128,11 +128,8 @@ export default defineComponent({
...props.options,
});
if (!result.ready) {
isReady.value = true;
realTimeCroppered();
emit('readied', cropper.value);
}
// 如果图片不存在直接将加载变为加载完成
if (!result.ready) emit('readied', cropper.value);
cropper.value = result;
}

View File

@ -1,9 +1,7 @@
<script lang="ts" setup>
import userAvatarIcon from '@/assets/svg/user_avatar.svg?component';
import { columns } from './columns';
import TablePlus from '@/components/TableBar/src/TablePlus.vue';
import { onMounted, ref } from 'vue';
import { fetchGetUserinfoById } from '@/api/v1/adminUser';
import userAvatarIcon from '@/assets/svg/user_avatar.svg?component';
import { $t } from '@/plugins/i18n';
const props = defineProps({
@ -35,22 +33,42 @@ onMounted(() => {
</script>
<template>
<div class="list-card-item">
<div v-if="userId && userinfo" class="list-card-item_detail bg-bg_color">
<div v-if="userId && userinfo" class="list-card-item bg-bg_color">
<el-row justify="space-between">
<div class="flex flex-row justify-center items-center">
<div class="list-card-item_detail--logo">
<userAvatarIcon />
</div>
<h1 class="list-card-item_detail--name">{{ $t('user_details') }}</h1>
</div>
<el-tag :color="userinfo.status ? '#F67676' : '#00a870'" class="mx-1 list-card-item_detail--operation--tag" effect="dark">
{{ $t('user_status') }}{{ userinfo.status ? $t('disable') : $t('normal') }}
</el-tag>
</el-row>
<p class="list-card-item_detail--name text-text_color_primary">{{ $t('user_details') }}</p>
<TablePlus :column="columns" :data-list="[userinfo]" :loading="loading" />
</div>
<el-empty v-else description="无数据" />
<el-descriptions border>
<el-descriptions-item :label="$t('avatar')" :width="100" align="center">
<el-image :src="userinfo.avatar" style="width: 100px; height: 100px" />
</el-descriptions-item>
<el-descriptions-item :label="$t('username')" :width="100">{{ userinfo.username }}</el-descriptions-item>
<el-descriptions-item :label="$t('nickName')" :width="100">{{ userinfo.nickName }}</el-descriptions-item>
<el-descriptions-item :label="$t('email')"> {{ userinfo.email }}</el-descriptions-item>
<el-descriptions-item :label="$t('phone')">{{ userinfo.phone }}</el-descriptions-item>
<el-descriptions-item :label="$t('sex')">
<el-tag v-if="userinfo.sex === 1"></el-tag>
<el-tag v-if="userinfo.sex === 0" type="danger"></el-tag>
</el-descriptions-item>
<el-descriptions-item :label="$t('personDescription')" span="3">
{{ userinfo.personDescription }}
</el-descriptions-item>
<el-descriptions-item :label="$t('table.createTime')" span="1.5">{{ userinfo.createTime }}</el-descriptions-item>
<el-descriptions-item :label="$t('table.updateTime')" span="1.5">{{ userinfo.updateTime }}</el-descriptions-item>
</el-descriptions>
</div>
<el-empty v-else :description="$t('no_data')" />
</template>
<style lang="scss" scoped>
@ -63,10 +81,6 @@ onMounted(() => {
border-radius: 3px;
&_detail {
flex: 1;
min-height: 140px;
padding: 24px 32px;
&--logo {
display: flex;
align-items: center;
@ -88,27 +102,16 @@ onMounted(() => {
height: 100%;
&--tag {
margin: 15px 0;
border: 0;
}
}
&--name {
margin: 24px 0 8px;
margin: 0 0 0 8px;
font-size: 16px;
font-weight: 400;
}
&--desc {
display: -webkit-box;
height: 40px;
margin-bottom: 24px;
overflow: hidden;
font-size: 12px;
line-height: 20px;
text-overflow: ellipsis;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}
}
&__disabled {

View File

@ -51,3 +51,24 @@ import { getQueryMap, subBefore } from '@pureadmin/utils';
return;
}
})();
/**
*
* @param blob
* @param filename
*/
export function download(blob: any, filename: string) {
// 创建一个临时的 URL用于下载文件
const a = document.createElement('a');
const url = window.URL.createObjectURL(new Blob([blob]));
a.href = url;
// 创建一个<a>元素,设置其 download 属性和 href 属性,模拟点击下载
a.download = filename;
document.body.appendChild(a);
a.click();
// 清理创建的临时元素和 URL
URL.revokeObjectURL(url);
document.body.removeChild(a);
}

View File

@ -4,7 +4,7 @@ import { columns } from '@/views/configuration/emailTemplate/utils/columns';
import PureTableBar from '@/components/TableBar/src/bar';
import AddFill from '@iconify-icons/ri/add-circle-line';
import PureTable from '@pureadmin/table';
import { onAdd, onDelete, onSearch, onUpdate } from '@/views/configuration/emailTemplate/utils/hooks';
import { onAdd, onDelete, onDeleteBatch, onSearch, onUpdate, selectRows } from '@/views/configuration/emailTemplate/utils/hooks';
import Delete from '@iconify-icons/ep/delete';
import EditPen from '@iconify-icons/ep/edit-pen';
import Refresh from '@iconify-icons/ep/refresh';
@ -44,6 +44,11 @@ const resetForm = async formEl => {
await onSearch();
};
/** 选择多行 */
const onSelectionChange = (rows: Array<any>) => {
selectRows.value = rows;
};
onMounted(() => {
onSearch();
});
@ -73,6 +78,11 @@ onMounted(() => {
<PureTableBar :columns="columns" title="邮件模板表" @fullscreen="tableRef.setAdaptive()" @refresh="onSearch">
<template #buttons>
<el-button :icon="useRenderIcon(AddFill)" type="primary" @click="onAdd"> {{ $t('add_new') }}</el-button>
<!-- 批量删除按钮 -->
<el-button v-show="selectRows.length > 0" :icon="useRenderIcon(Delete)" type="danger" @click="onDeleteBatch">
{{ $t('delete_batches') }}
</el-button>
</template>
<template v-slot="{ size, dynamicColumns }">
@ -92,6 +102,7 @@ onMounted(() => {
row-key="id"
showOverflowTooltip
table-layout="auto"
@selection-change="onSelectionChange"
@page-size-change="onPageSizeChange"
@page-current-change="onCurrentPageChange"
>

View File

@ -6,6 +6,8 @@ import { messageBox } from '@/utils/message';
import type { FormItemProps } from '@/views/configuration/emailTemplate/utils/types';
import { $t } from '@/plugins/i18n';
// 选择的row列表
export const selectRows = ref([]);
export const formRef = ref();
const emailTemplateStore = useEmailTemplateStore();
@ -104,3 +106,21 @@ export const onDelete = async (row: any) => {
await emailTemplateStore.deleteEmailTemplate([id]);
await onSearch();
};
/** 批量删除 */
export const onDeleteBatch = async () => {
const ids = selectRows.value.map((row: any) => row.id);
// 是否确认删除
const result = await messageBox({
title: $t('confirm_delete'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('cancel_delete'),
});
if (!result) return;
// 删除数据
await emailTemplateStore.deleteEmailTemplate(ids);
await onSearch();
};

View File

@ -4,8 +4,9 @@ import { columns } from '@/views/monitor/files/utils/columns';
import PureTableBar from '@/components/TableBar/src/bar';
import AddFill from '@iconify-icons/ri/add-circle-line';
import PureTable from '@pureadmin/table';
import { onAdd, onDelete, onDeleteBatch, onDownload, onSearch, onUpdate, selectIds } from '@/views/monitor/files/utils/hooks';
import { onAdd, onDelete, onDeleteBatch, onDownload, onDownloadBatch, onSearch, onUpdate, selectRows } from '@/views/monitor/files/utils/hooks';
import Delete from '@iconify-icons/ep/delete';
import Download from '@iconify-icons/ep/download';
import EditPen from '@iconify-icons/ep/edit-pen';
import Refresh from '@iconify-icons/ep/refresh';
import { selectUserinfo } from '@/components/Table/Userinfo/columns';
@ -39,7 +40,7 @@ const resetForm = async (formEl: FormInstance) => {
/** 选择多行 */
const onSelectionChange = (rows: Array<any>) => {
selectIds.value = rows.map((row: any) => row.id);
selectRows.value = rows;
};
onMounted(() => {
@ -72,8 +73,13 @@ onMounted(() => {
<template #buttons>
<el-button :icon="useRenderIcon(AddFill)" type="primary" @click="onAdd"> {{ $t('add_new') }}</el-button>
<!-- 批量下载 -->
<el-button v-show="selectRows.length > 0" :icon="useRenderIcon(Download)" type="success" @click="onDownloadBatch">
{{ $t('download_batch') }}
</el-button>
<!-- 批量删除按钮 -->
<el-button v-show="selectIds.length > 0" :icon="useRenderIcon(Delete)" type="danger" @click="onDeleteBatch">
<el-button v-show="selectRows.length > 0" :icon="useRenderIcon(Delete)" type="danger" @click="onDeleteBatch">
{{ $t('delete_batches') }}
</el-button>
</template>

View File

@ -5,9 +5,11 @@ import { h, ref } from 'vue';
import { messageBox } from '@/utils/message';
import type { FormItemProps } from '@/views/monitor/files/utils/types';
import { $t } from '@/plugins/i18n';
import { downloadFilesByFileId, downloadFilesByFilepath } from '@/api/v1/files';
import { download } from '@/utils/sso';
// 选择的id列表
export const selectIds = ref([]);
// 选择的row列表
export const selectRows = ref([]);
export const formRef = ref();
const filesStore = useFilesStore();
@ -109,7 +111,7 @@ export const onDelete = async (row: any) => {
/** 批量删除 */
export const onDeleteBatch = async () => {
const ids = selectIds.value;
const ids = selectRows.value.map(row => row.id);
// 是否确认删除
const result = await messageBox({
@ -130,18 +132,16 @@ export const onDeleteBatch = async () => {
* @param row
*/
export const onDownload = async (row: any) => {
const id = row.id;
const blob = await downloadFilesByFilepath({ filepath: row.filepath });
fetch(`/admin/files/downloadFiles/${id}`)
.then(response => response.blob()) // 将响应转换为Blob对象
.then(blob => {
// 创建一个链接元素
const link = document.createElement('a');
link.href = URL.createObjectURL(blob);
link.download = 'filename.jpg'; // 指定下载文件名
document.body.appendChild(link);
link.click(); // 模拟点击
document.body.removeChild(link); // 下载后移除元素
})
.catch(error => console.error('下载失败:', error));
download(blob, row.filename);
};
/** 批量下载文件 */
export const onDownloadBatch = () => {
selectRows.value.forEach(async row => {
const blob = await downloadFilesByFileId({ id: row.id });
download(blob, row.filename);
});
};