feat: file

pull/1/MERGE
xingyuv 2023-03-22 17:40:56 +08:00
parent a438064ea6
commit af6c5cc446
3 changed files with 142 additions and 1 deletions

View File

@ -0,0 +1,77 @@
import { BasicColumn, FormSchema, useRender } from '@/components/Table'
export const columns: BasicColumn[] = [
{
title: '日志编号',
dataIndex: 'id',
width: 100
},
{
title: '文件名',
dataIndex: 'module',
width: 200
},
{
title: '文件路径',
dataIndex: 'path',
width: 250
},
{
title: '文件 URL',
dataIndex: 'url',
width: 300
},
{
title: '文件路径',
dataIndex: 'path',
width: 180
},
{
title: '文件大小',
dataIndex: 'size',
width: 180,
customRender: ({ text }) => {
const unitArr = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']
const srcSize = parseFloat(text)
const index = Math.floor(Math.log(srcSize) / Math.log(1024))
const size = srcSize / Math.pow(1024, index)
return size.toFixed(2) + ' ' + unitArr[index]
}
},
{
title: '文件类型',
dataIndex: 'type',
width: 180
},
{
title: '文件内容',
dataIndex: 'content',
width: 180,
customRender: ({ text }) => {
return useRender.renderImg(text)
}
},
{
title: '上传时间',
dataIndex: 'createTime',
width: 180,
customRender: ({ text }) => {
return useRender.renderDate(text)
}
}
]
export const searchFormSchema: FormSchema[] = [
{
label: '文件路径',
field: 'path',
component: 'Input',
colProps: { span: 8 }
},
{
label: '创建时间',
field: 'createTime',
component: 'RangePicker',
colProps: { span: 8 }
}
]

View File

@ -1,3 +1,67 @@
<template> <template>
<div>开发中</div> <div>
<BasicTable @register="registerTable">
<template #toolbar>
<a-button type="primary" :preIcon="IconEnum.UPLOAD" @click="handleAdd"> </a-button>
</template>
<template #bodyCell="{ column, record }">
<template v-if="column.key === 'action'">
<TableAction
:actions="[
{
icon: IconEnum.DELETE,
color: 'error',
label: t('action.delete'),
popConfirm: {
title: t('common.delMessage'),
placement: 'left',
confirm: handleDelete.bind(null, record)
}
}
]"
/>
</template>
</template>
</BasicTable>
</div>
</template> </template>
<script lang="ts" setup name="File">
import { useI18n } from '@/hooks/web/useI18n'
import { useMessage } from '@/hooks/web/useMessage'
import { IconEnum } from '@/enums/appEnum'
import { BasicTable, useTable, TableAction } from '@/components/Table'
import { deleteFileApi, getFilePageApi } from '@/api/infra/file'
import { columns, searchFormSchema } from './file.data'
const { t } = useI18n()
const { createMessage } = useMessage()
const [registerTable, { reload }] = useTable({
title: '文件列表',
api: getFilePageApi,
columns,
formConfig: {
labelWidth: 120,
schemas: searchFormSchema
},
useSearchForm: true,
showTableSetting: true,
showIndexColumn: false,
actionColumn: {
width: 140,
title: t('common.action'),
dataIndex: 'action',
fixed: 'right'
}
})
function handleAdd() {
console.info(1)
}
async function handleDelete(record: Recordable) {
await deleteFileApi(record.id)
createMessage.success(t('common.delSuccessText'))
reload()
}
</script>