123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 |
- <script setup lang="ts">
- import { ref, onMounted } from "vue";
- import { useRoute, useRouter } from "vue-router";
- import * as XLSX from "xlsx";
- import {
- assessmentDownloadDataRosterTemplateApi,
- importAssessmentQuotaDisplayBackData,
- postImportAssessmentTemplate
- } from "@/api/download";
- import { ElMessage } from "element-plus";
- defineOptions({
- name: "IndexDefineImport"
- });
- const route = useRoute();
- const router = useRouter();
- const emit = defineEmits(["handleImport"]);
- const uploadShow = ref(true);
- const query = ref({});
- const fileDocument = ref<File | null>(null);
- const assessmentType = ref();
- onMounted(() => {
-
- Object.assign(query.value, route.query);
- assessmentType.value = Number(query.value.assessmentType);
- console.log("111", query.value);
- });
- const uploadFile = () => {};
- const tableHeaders = ref<any>([]);
- const tableData = ref<any>([]);
- const handleUploadChange = async (file: File) => {
- fileDocument.value = file;
- const formData = new FormData();
- formData.append("file", fileDocument.value);
- const fileToSend = formData.get("file");
- const { code, data, msg } = await importAssessmentQuotaDisplayBackData({
- file: fileToSend,
- type: route.query.assessmentType,
- assessmentId: route.query.id
- });
- const reader = new FileReader();
- let fileType = file.name.slice(-4);
-
- if (data.code == 200) {
- uploadShow.value = false;
- tableData.value = data.data;
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- console.log(data);
- } else {
- ElMessage.error(data.msg);
- }
-
-
-
- reader.readAsArrayBuffer(file);
- };
- const postImportAssessmentTemplateApi = async data => {
- if (!fileDocument.value) {
- ElMessage.error("请先上传文件");
- return;
- }
- try {
- const formData = new FormData();
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- formData.append("file", fileDocument.value);
-
- const fileToSend = formData.get("file");
-
- const { data } = await postImportAssessmentTemplate({
- file: fileToSend,
- type: route.query.assessmentType,
- assessmentId: route.query.id
- });
- if (data.code === 200) {
-
- ElMessage.success(data.msg);
-
- router.back();
- uploadShow.value = !uploadShow.value;
- tableHeaders.value = [];
- tableData.value = [
- { name: "" },
- { defin: "" },
- { caliber: "" },
- { type: "" },
- { from: "" }
- ];
- } else {
- ElMessage.error(data.msg);
- }
- } catch (error) {
- ElMessage.error("上传失败,请重试");
- console.error(error);
- }
- };
- const backDefine = () => {
- router.back();
- };
- </script>
- <template>
- <div>
- <div class="w-3/4 m-auto mt-4">
- <div class="w-full bg p-3">
- <h5>1.下载导入模板</h5>
- <p class="text-xs mt-2 text">根据提升信息完善表格内容</p>
- <el-button class="mt-2"
- ><el-icon> <Download /> </el-icon
- ><a
- v-if="query.assessmentType == 0 || query.assessmentType == 3"
- href="http://172.16.9.165:8765/download/考核数据导入模板-人员.xlsx"
- download="考核数据导入模板-人员.xlsx"
- >下载空的模板表格</a
- >
- <a
- v-if="query.assessmentType == 1"
- href="http://172.16.9.165:8765/download/考核数据导入模板-部门.xlsx"
- download="考核数据导入模板-部门.xlsx"
- >下载空的模板表格</a
- >
- <a
- v-if="query.assessmentType == 2"
- href="http://172.16.9.165:8765/download/考核数据导入模板-用户组.xlsx"
- download="考核数据导入模板-用户组.xlsx"
- >下载空的模板表格</a
- ></el-button
- >
- </div>
- <div class="w-full mt-4 bg p-3">
- <h5>2.上传完善后的模板</h5>
- <p class="text-xs mt-2 text mb-2">
- 更新信息的模板中,如有空的数据列,则相应字段信息会被清空,请谨慎填写
- </p>
- <div v-if="uploadShow">
- <el-upload
- class="upload-demo"
- drag
- action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
- :before-upload="file => handleUploadChange(file)"
- :show-file-list="false"
- >
- <el-icon class="el-icon--upload"><upload-filled /></el-icon>
- <div class="el-upload__text">
- 点击<em>图标选择上传</em>或者将文件拖拽到此区域
- </div>
- </el-upload>
- </div>
- <div v-else class="mb-2">
- <el-table
- v-if="query.assessmentType == 0 || query.assessmentType == 3"
- :data="tableData"
- border
- style="width: 100%"
- max-height="250"
- >
- <el-table-column label="工号" prop="hospitalCode" />
- <el-table-column label="人员" prop="realName" />
- <el-table-column label="考核模板" prop="tpName" />
- <el-table-column label="指标名称" prop="quotaName" />
- <el-table-column label="完成值" prop="finalValue" />
- <el-table-column label="得分" prop="score" />
- </el-table>
- <el-table
- v-if="query.assessmentType == 1"
- :data="tableData"
- border
- style="width: 100%"
- max-height="250"
- >
- <el-table-column label="部门" prop="deptName" />
- <el-table-column label="部门编号" prop="hospitalCode" />
- <el-table-column label="考核模板" prop="tpName" />
- <el-table-column label="指标名称" prop="quotaName" />
- <el-table-column label="完成值" prop="finalValue" />
- <el-table-column label="得分" prop="score" />
- </el-table>
- <el-table
- v-if="query.assessmentType == 2"
- :data="tableData"
- border
- style="width: 100%"
- max-height="250"
- >
- <el-table-column label="用户组" prop="groupName" />
- <el-table-column label="用户组编号" prop="hospitalCode" />
- <el-table-column label="考核模板" prop="tpName" />
- <el-table-column label="指标名称" prop="quotaName" />
- <el-table-column label="完成值" prop="finalValue" />
- <el-table-column label="得分" prop="score" />
- </el-table>
- </div>
- <div class="float-right">
- <el-button @click="backDefine">取消</el-button>
- <el-button type="primary" @click="postImportAssessmentTemplateApi"
- >确认</el-button
- >
- </div>
- <p class="h-11 no-select">.</p>
- </div>
- </div>
- </div>
- </template>
- <style lang="scss" scoped>
- .bg {
- background-color: #f8f9fa;
- }
- .text {
- color: #999;
- }
- .upoload {
- float: right;
- }
- .no-select {
- color: rgb(255 255 255 / 0%);
- user-select: none;
- }
- </style>
|