refactor(PageContent): ♻️ 导入相关属性和方法命名修改
This commit is contained in:
@@ -416,28 +416,28 @@
|
|||||||
</el-dialog>
|
</el-dialog>
|
||||||
<!-- 导入弹窗 -->
|
<!-- 导入弹窗 -->
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="importsModalVisible"
|
v-model="importModalVisible"
|
||||||
:align-center="true"
|
:align-center="true"
|
||||||
title="导入数据"
|
title="导入数据"
|
||||||
width="600px"
|
width="600px"
|
||||||
style="padding-right: 0"
|
style="padding-right: 0"
|
||||||
@close="handleCloseImportsModal"
|
@close="handleCloseImportModal"
|
||||||
>
|
>
|
||||||
<!-- 滚动 -->
|
<!-- 滚动 -->
|
||||||
<el-scrollbar max-height="60vh">
|
<el-scrollbar max-height="60vh">
|
||||||
<!-- 表单 -->
|
<!-- 表单 -->
|
||||||
<el-form
|
<el-form
|
||||||
ref="importsFormRef"
|
ref="importFormRef"
|
||||||
label-width="auto"
|
label-width="auto"
|
||||||
style="padding-right: var(--el-dialog-padding-primary)"
|
style="padding-right: var(--el-dialog-padding-primary)"
|
||||||
:model="importsFormData"
|
:model="importFormData"
|
||||||
:rules="importsFormRules"
|
:rules="importFormRules"
|
||||||
>
|
>
|
||||||
<el-form-item label="文件名" prop="files">
|
<el-form-item label="文件名" prop="files">
|
||||||
<el-upload
|
<el-upload
|
||||||
class="w-full"
|
class="w-full"
|
||||||
ref="uploadRef"
|
ref="uploadRef"
|
||||||
v-model:file-list="importsFormData.files"
|
v-model:file-list="importFormData.files"
|
||||||
accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"
|
accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"
|
||||||
:drag="true"
|
:drag="true"
|
||||||
:limit="1"
|
:limit="1"
|
||||||
@@ -471,12 +471,12 @@
|
|||||||
<div style="padding-right: var(--el-dialog-padding-primary)">
|
<div style="padding-right: var(--el-dialog-padding-primary)">
|
||||||
<el-button
|
<el-button
|
||||||
type="primary"
|
type="primary"
|
||||||
:disabled="importsFormData.files.length === 0"
|
:disabled="importFormData.files.length === 0"
|
||||||
@click="handleImportsSubmit"
|
@click="handleImportSubmit"
|
||||||
>
|
>
|
||||||
确 定
|
确 定
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button @click="handleCloseImportsModal">取 消</el-button>
|
<el-button @click="handleCloseImportModal">取 消</el-button>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
@@ -706,19 +706,19 @@ function handleExports() {
|
|||||||
// 导入表单
|
// 导入表单
|
||||||
let isFileImport = false;
|
let isFileImport = false;
|
||||||
const uploadRef = ref<UploadInstance>();
|
const uploadRef = ref<UploadInstance>();
|
||||||
const importsModalVisible = ref(false);
|
const importModalVisible = ref(false);
|
||||||
const importsFormRef = ref<FormInstance>();
|
const importFormRef = ref<FormInstance>();
|
||||||
const importsFormData = reactive<{
|
const importFormData = reactive<{
|
||||||
files: UploadUserFile[];
|
files: UploadUserFile[];
|
||||||
}>({
|
}>({
|
||||||
files: [],
|
files: [],
|
||||||
});
|
});
|
||||||
const importsFormRules: FormRules = {
|
const importFormRules: FormRules = {
|
||||||
files: [{ required: true, message: "请选择文件" }],
|
files: [{ required: true, message: "请选择文件" }],
|
||||||
};
|
};
|
||||||
// 打开导入弹窗
|
// 打开导入弹窗
|
||||||
function handleOpenImportsModal(isFile: boolean = false) {
|
function handleOpenImportModal(isFile: boolean = false) {
|
||||||
importsModalVisible.value = true;
|
importModalVisible.value = true;
|
||||||
isFileImport = isFile;
|
isFileImport = isFile;
|
||||||
}
|
}
|
||||||
// 覆盖前一个文件
|
// 覆盖前一个文件
|
||||||
@@ -746,8 +746,8 @@ function handleDownloadTemplate() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 导入确认
|
// 导入确认
|
||||||
const handleImportsSubmit = useThrottleFn(() => {
|
const handleImportSubmit = useThrottleFn(() => {
|
||||||
importsFormRef.value?.validate((valid: boolean) => {
|
importFormRef.value?.validate((valid: boolean) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
if (isFileImport) {
|
if (isFileImport) {
|
||||||
handleImport();
|
handleImport();
|
||||||
@@ -758,11 +758,11 @@ const handleImportsSubmit = useThrottleFn(() => {
|
|||||||
});
|
});
|
||||||
}, 3000);
|
}, 3000);
|
||||||
// 关闭导入弹窗
|
// 关闭导入弹窗
|
||||||
function handleCloseImportsModal() {
|
function handleCloseImportModal() {
|
||||||
importsModalVisible.value = false;
|
importModalVisible.value = false;
|
||||||
importsFormRef.value?.resetFields();
|
importFormRef.value?.resetFields();
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
importsFormRef.value?.clearValidate();
|
importFormRef.value?.clearValidate();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// 文件导入
|
// 文件导入
|
||||||
@@ -772,9 +772,9 @@ function handleImport() {
|
|||||||
ElMessage.error("未配置importAction");
|
ElMessage.error("未配置importAction");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
importAction(importsFormData.files[0].raw as File).then(() => {
|
importAction(importFormData.files[0].raw as File).then(() => {
|
||||||
ElMessage.success("导入数据成功");
|
ElMessage.success("导入数据成功");
|
||||||
handleCloseImportsModal();
|
handleCloseImportModal();
|
||||||
handleRefresh(true);
|
handleRefresh(true);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -786,7 +786,7 @@ function handleImports() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 获取选择的文件
|
// 获取选择的文件
|
||||||
const file = importsFormData.files[0].raw as File;
|
const file = importFormData.files[0].raw as File;
|
||||||
// 创建Workbook实例
|
// 创建Workbook实例
|
||||||
const workbook = new ExcelJS.Workbook();
|
const workbook = new ExcelJS.Workbook();
|
||||||
// 使用FileReader对象来读取文件内容
|
// 使用FileReader对象来读取文件内容
|
||||||
@@ -833,7 +833,7 @@ function handleImports() {
|
|||||||
}
|
}
|
||||||
importsAction(data).then(() => {
|
importsAction(data).then(() => {
|
||||||
ElMessage.success("导入数据成功");
|
ElMessage.success("导入数据成功");
|
||||||
handleCloseImportsModal();
|
handleCloseImportModal();
|
||||||
handleRefresh(true);
|
handleRefresh(true);
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
@@ -854,7 +854,7 @@ function handleToolbar(name: string) {
|
|||||||
handleOpenExportsModal();
|
handleOpenExportsModal();
|
||||||
break;
|
break;
|
||||||
case "imports":
|
case "imports":
|
||||||
handleOpenImportsModal();
|
handleOpenImportModal();
|
||||||
break;
|
break;
|
||||||
case "search":
|
case "search":
|
||||||
emit("searchClick");
|
emit("searchClick");
|
||||||
@@ -866,7 +866,7 @@ function handleToolbar(name: string) {
|
|||||||
handleDelete();
|
handleDelete();
|
||||||
break;
|
break;
|
||||||
case "import":
|
case "import":
|
||||||
handleOpenImportsModal(true);
|
handleOpenImportModal(true);
|
||||||
break;
|
break;
|
||||||
case "export":
|
case "export":
|
||||||
emit("exportClick");
|
emit("exportClick");
|
||||||
|
|||||||
Reference in New Issue
Block a user