2024-08-06 16:24:43 +08:00
|
|
|
|
<template>
|
2024-08-07 23:12:42 +08:00
|
|
|
|
<el-upload ref="uploadRef" :on-preview="previewFile" :limit="1" :on-change="changeFile" :auto-upload="false"
|
|
|
|
|
|
:data="uploadForm.data">
|
2024-08-06 16:24:43 +08:00
|
|
|
|
<template #trigger>
|
2024-08-07 23:12:42 +08:00
|
|
|
|
<el-button type="primary">选取工单文件</el-button>
|
2024-08-06 16:24:43 +08:00
|
|
|
|
</template>
|
2024-08-07 23:12:42 +08:00
|
|
|
|
<el-button style="margin-left: 10px;" type="success" @click="uploadOrders">上传工单数据</el-button>
|
2024-08-06 16:24:43 +08:00
|
|
|
|
</el-upload>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<script setup>
|
|
|
|
|
|
import store from '@/store'
|
|
|
|
|
|
import { ref, reactive } from 'vue';
|
2024-08-07 23:12:42 +08:00
|
|
|
|
import { uploadExcelOrders } from '@/api/excel.js'
|
2024-08-06 16:24:43 +08:00
|
|
|
|
import { ElMessage } from 'element-plus'
|
|
|
|
|
|
import { sizeFormatter } from '@/utils/formatter.js'
|
|
|
|
|
|
const file = ref()
|
|
|
|
|
|
const uploadForm = reactive({
|
|
|
|
|
|
data: {
|
|
|
|
|
|
fileId: '',
|
|
|
|
|
|
name: '',
|
|
|
|
|
|
type: '',
|
2024-08-07 23:12:42 +08:00
|
|
|
|
size: null,
|
|
|
|
|
|
userName: store.getters.getUserName
|
2024-08-06 16:24:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
const changeFile = (uploadFile) => {
|
|
|
|
|
|
file.value = uploadFile
|
|
|
|
|
|
uploadForm.data = {
|
|
|
|
|
|
fileId: file.value.raw.uid,
|
|
|
|
|
|
name: file.value.raw.name,
|
|
|
|
|
|
type: file.value.raw.type,
|
|
|
|
|
|
size: sizeFormatter(file.value.raw.size),
|
|
|
|
|
|
userName: store.getters.getUserName
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
const uploadRef = ref()
|
2024-08-07 23:12:42 +08:00
|
|
|
|
const uploadOrders = () => {
|
2024-08-06 16:24:43 +08:00
|
|
|
|
if (uploadForm == undefined || file.value == undefined) {
|
2024-08-07 23:12:42 +08:00
|
|
|
|
ElMessage.error('请选择文件之后再上传')
|
2024-08-06 16:24:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
const jsonStr = JSON.stringify(uploadForm.data);
|
|
|
|
|
|
const blob = new Blob([jsonStr], {
|
|
|
|
|
|
type: 'application/json'
|
|
|
|
|
|
});
|
|
|
|
|
|
let formData = new FormData();
|
|
|
|
|
|
// 这里很重要 file.value.raw才是真实的file文件,file.value只是一个Proxy代理对象
|
|
|
|
|
|
formData.append("obj", blob);
|
|
|
|
|
|
formData.append("file", file.value.raw);
|
2024-08-07 23:12:42 +08:00
|
|
|
|
uploadExcelOrders(formData).then(res => {
|
2024-08-06 16:24:43 +08:00
|
|
|
|
if (res.data.code == 0) {
|
|
|
|
|
|
ElMessage({
|
2024-08-07 23:12:42 +08:00
|
|
|
|
message: '上传成功',
|
2024-08-06 16:24:43 +08:00
|
|
|
|
type: 'success',
|
|
|
|
|
|
})
|
2024-08-07 23:12:42 +08:00
|
|
|
|
clearFileInfos()
|
2024-08-06 16:24:43 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
ElMessage.error(res.data.message)
|
|
|
|
|
|
}
|
|
|
|
|
|
}).catch(err => {
|
|
|
|
|
|
console.log(err)
|
2024-08-07 23:12:42 +08:00
|
|
|
|
ElMessage.error('上传错误')
|
2024-08-06 16:24:43 +08:00
|
|
|
|
})
|
|
|
|
|
|
}
|
2024-08-07 23:12:42 +08:00
|
|
|
|
const clearFileInfos = () => {
|
|
|
|
|
|
// 清空选择的文件项
|
|
|
|
|
|
uploadRef.value.clearFiles()
|
|
|
|
|
|
uploadForm.data = {
|
|
|
|
|
|
fileId: '',
|
|
|
|
|
|
name: '',
|
|
|
|
|
|
type: '',
|
|
|
|
|
|
size: null,
|
|
|
|
|
|
userName: store.getters.getUserName
|
|
|
|
|
|
}
|
|
|
|
|
|
file.value = undefined
|
|
|
|
|
|
}
|
2024-08-06 16:24:43 +08:00
|
|
|
|
const previewFile = () => {
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
|
|
<style scoped></style>
|