123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- <template>
- <div v-loading.fullscreen.lock="fullscreenLoading">
- <div class="gva-table-box">
- <warning-bar
- title="点击“文件名/备注”可以编辑文件名或者备注内容。"
- />
- <div class="gva-btn-list">
- <upload-common
- :image-common="imageCommon"
- @on-success="getTableData"
- />
- <upload-image
- :image-url="imageUrl"
- :file-size="512"
- :max-w-h="1080"
- @on-success="getTableData"
- />
- <el-input
- v-model="search.keyword"
- class="keyword"
- placeholder="请输入文件名或备注"
- />
- <el-button
- type="primary"
- icon="search"
- @click="getTableData"
- >查询</el-button>
- </div>
- <el-table :data="tableData">
- <el-table-column
- align="left"
- label="预览"
- width="100"
- >
- <template #default="scope">
- <CustomPic
- pic-type="file"
- :pic-src="scope.row.url"
- preview
- />
- </template>
- </el-table-column>
- <el-table-column
- align="left"
- label="日期"
- prop="UpdatedAt"
- width="180"
- >
- <template #default="scope">
- <div>{{ formatDate(scope.row.UpdatedAt) }}</div>
- </template>
- </el-table-column>
- <el-table-column
- align="left"
- label="文件名/备注"
- prop="name"
- width="180"
- >
- <template #default="scope">
- <div
- class="name"
- @click="editFileNameFunc(scope.row)"
- >{{ scope.row.name }}</div>
- </template>
- </el-table-column>
- <el-table-column
- align="left"
- label="链接"
- prop="url"
- min-width="300"
- />
- <el-table-column
- align="left"
- label="标签"
- prop="tag"
- width="100"
- >
- <template #default="scope">
- <el-tag
- :type="scope.row.tag === 'jpg' ? 'info' : 'success'"
- disable-transitions
- >{{ scope.row.tag }}
- </el-tag>
- </template>
- </el-table-column>
- <el-table-column
- align="left"
- label="操作"
- width="160"
- >
- <template #default="scope">
- <el-button
- icon="download"
- type="primary"
- link
- @click="downloadFile(scope.row)"
- >下载</el-button>
- <el-button
- icon="delete"
- type="primary"
- link
- @click="deleteFileFunc(scope.row)"
- >删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <div class="gva-pagination">
- <el-pagination
- :current-page="page"
- :page-size="pageSize"
- :page-sizes="[10, 30, 50, 100]"
- :style="{ float: 'right', padding: '20px' }"
- :total="total"
- layout="total, sizes, prev, pager, next, jumper"
- @current-change="handleCurrentChange"
- @size-change="handleSizeChange"
- />
- </div>
- </div>
- </div>
- </template>
- <script setup>
- import { getFileList, deleteFile, editFileName } from '@/api/fileUploadAndDownload'
- import { downloadImage } from '@/utils/downloadImg'
- import CustomPic from '@/components/customPic/index.vue'
- import UploadImage from '@/components/upload/image.vue'
- import UploadCommon from '@/components/upload/common.vue'
- import { formatDate } from '@/utils/format'
- import WarningBar from '@/components/warningBar/warningBar.vue'
- import { ref } from 'vue'
- import { ElMessage, ElMessageBox } from 'element-plus'
- defineOptions({
- name: 'Upload',
- })
- const path = ref(import.meta.env.VITE_BASE_API)
- const imageUrl = ref('')
- const imageCommon = ref('')
- const page = ref(1)
- const total = ref(0)
- const pageSize = ref(10)
- const search = ref({})
- const tableData = ref([])
- // 分页
- const handleSizeChange = (val) => {
- pageSize.value = val
- getTableData()
- }
- const handleCurrentChange = (val) => {
- page.value = val
- getTableData()
- }
- // 查询
- const getTableData = async() => {
- const table = await getFileList({ page: page.value, pageSize: pageSize.value, ...search.value })
- if (table.code === 0) {
- tableData.value = table.data.list
- total.value = table.data.total
- page.value = table.data.page
- pageSize.value = table.data.pageSize
- }
- }
- getTableData()
- const deleteFileFunc = async(row) => {
- ElMessageBox.confirm('此操作将永久删除文件, 是否继续?', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning',
- })
- .then(async() => {
- const res = await deleteFile(row)
- if (res.code === 0) {
- ElMessage({
- type: 'success',
- message: '删除成功!',
- })
- if (tableData.value.length === 1 && page.value > 1) {
- page.value--
- }
- getTableData()
- }
- })
- .catch(() => {
- ElMessage({
- type: 'info',
- message: '已取消删除',
- })
- })
- }
- const downloadFile = (row) => {
- if (row.url.indexOf('http://') > -1 || row.url.indexOf('https://') > -1) {
- downloadImage(row.url, row.name)
- } else {
- debugger
- downloadImage(path.value + '/' + row.url, row.name)
- }
- }
- /**
- * 编辑文件名或者备注
- * @param row
- * @returns {Promise<void>}
- */
- const editFileNameFunc = async(row) => {
- ElMessageBox.prompt('请输入文件名或者备注', '编辑', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- inputPattern: /\S/,
- inputErrorMessage: '不能为空',
- inputValue: row.name
- }).then(async({ value }) => {
- row.name = value
- // console.log(row)
- const res = await editFileName(row)
- if (res.code === 0) {
- ElMessage({
- type: 'success',
- message: '编辑成功!',
- })
- getTableData()
- }
- }).catch(() => {
- ElMessage({
- type: 'info',
- message: '取消修改'
- })
- })
- }
- </script>
- <style scoped>
- .name {
- cursor: pointer;
- }
- </style>
|