|
@@ -0,0 +1,237 @@
|
|
|
|
+<template>
|
|
|
|
+ <div>
|
|
|
|
+ <div class="tw-bg-white tw-p-5 tw-rounded-xl tw-mb-5">
|
|
|
|
+ <span class="tw-mr-4"></span>
|
|
|
|
+ <CourseSelect :root-org-id="rootOrgId" v-model:value="courseId" />
|
|
|
|
+ <span class="tw-mr-4"></span>
|
|
|
|
+ <span class="tw-mr-4"></span>
|
|
|
|
+ <a-button @click="search">查询</a-button>
|
|
|
|
+
|
|
|
|
+ <div class="tw-mt-4">
|
|
|
|
+ <a-button @click="importModalVisible = true">批量导入</a-button>
|
|
|
|
+ <a-button @click="handleExport">批量导出</a-button>
|
|
|
|
+ <a-button @click="goBack">返回</a-button>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <div class="tw-bg-white tw-p-5 tw-rounded-xl">
|
|
|
|
+ <a-table
|
|
|
|
+ row-key="id"
|
|
|
|
+ :columns="columns"
|
|
|
|
+ :data-source="data"
|
|
|
|
+ :pagination="{
|
|
|
|
+ pageSize: pageSize,
|
|
|
|
+ current: pageNo,
|
|
|
|
+ total: totalElements,
|
|
|
|
+ showTotal: (total: number) => `总数:${total}`,
|
|
|
|
+ onChange: (pageNoChanged: number, pageSizeChanged: number) => {
|
|
|
|
+ pageNo = pageNoChanged;
|
|
|
|
+ pageSize = pageSizeChanged;
|
|
|
|
+ }
|
|
|
|
+ }"
|
|
|
|
+ >
|
|
|
|
+ <template #course="{ record }">
|
|
|
|
+ <a>{{ `${record.courseName}(${record.courseCode})` }}</a>
|
|
|
|
+ </template>
|
|
|
|
+ <template #action="{ record }">
|
|
|
|
+ <span>
|
|
|
|
+ <a-button @click="showModal(record)">编辑</a-button>
|
|
|
|
+ </span>
|
|
|
|
+ </template>
|
|
|
|
+ </a-table>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <a-modal
|
|
|
|
+ v-model:visible="visible"
|
|
|
|
+ title="单科线设置页"
|
|
|
|
+ @ok="handleOk"
|
|
|
|
+ ok-text="确定"
|
|
|
|
+ cancel-text="取消"
|
|
|
|
+ >
|
|
|
|
+ <a-form>
|
|
|
|
+ <a-form-item label="项目名称">
|
|
|
|
+ <a-input disabled v-model:value="projectObj.projectName"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="项目名称">
|
|
|
|
+ <a-input
|
|
|
|
+ disabled
|
|
|
|
+ :value="projectObj.courseName + '(' + projectObj.courseCode + ')'"
|
|
|
|
+ ></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="项目名称">
|
|
|
|
+ <CourseTypeSelect :value="projectObj.courseType" disabled />
|
|
|
|
+ </a-form-item>
|
|
|
|
+
|
|
|
|
+ <a-form-item label="国家单科线">
|
|
|
|
+ <a-input v-model:value="projectObj.nationalScore"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="复试科目线">
|
|
|
|
+ <a-input v-model:value="projectObj.retestScore"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="国家总分线">
|
|
|
|
+ <a-input v-model:value="projectObj.nationalTotalScore"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="复试总分线">
|
|
|
|
+ <a-input v-model:value="projectObj.retestTotalScore"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="总分满分线">
|
|
|
|
+ <a-input v-model:value="projectObj.totalScoreLine"></a-input>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ </a-form>
|
|
|
|
+ </a-modal>
|
|
|
|
+
|
|
|
|
+ <a-modal
|
|
|
|
+ v-model:visible="importModalVisible"
|
|
|
|
+ title="单科线批量导入"
|
|
|
|
+ @ok="handleImport"
|
|
|
|
+ ok-text="确定"
|
|
|
|
+ cancel-text="取消"
|
|
|
|
+ >
|
|
|
|
+ <a-form>
|
|
|
|
+ <a-form-item label="文件地址">
|
|
|
|
+ <input id="file-input" :multiple="false" type="file" />
|
|
|
|
+ </a-form-item>
|
|
|
|
+ <a-form-item label="下载模板">
|
|
|
|
+ <a-button @click="downloadTpl">下载模板</a-button>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ </a-form>
|
|
|
|
+ </a-modal>
|
|
|
|
+ </div>
|
|
|
|
+</template>
|
|
|
|
+
|
|
|
|
+<script setup lang="ts">
|
|
|
|
+import {
|
|
|
|
+ exportProjectParams,
|
|
|
|
+ getProjectCourseList,
|
|
|
|
+ importProjectParams,
|
|
|
|
+ updateProjectCourse,
|
|
|
|
+} from "@/api/projectParamsManagementPage";
|
|
|
|
+import { useMainStore } from "@/store";
|
|
|
|
+import { downloadFileURL, goBack } from "@/utils/utils";
|
|
|
|
+import { message } from "ant-design-vue";
|
|
|
|
+import { watch, onMounted, ref, reactive, toRaw } from "vue-demi";
|
|
|
|
+import { useRoute } from "vue-router";
|
|
|
|
+
|
|
|
|
+const store = useMainStore();
|
|
|
|
+store.currentLocation = "基础管理 / 项目列表";
|
|
|
|
+
|
|
|
|
+let rootOrgId = $ref(undefined as unknown as number);
|
|
|
|
+let name = $ref("");
|
|
|
|
+let courseId = $ref(undefined as undefined | number);
|
|
|
|
+const route = useRoute();
|
|
|
|
+const projectId = +route.params.id;
|
|
|
|
+
|
|
|
|
+let data = $ref([]);
|
|
|
|
+let pageSize = $ref(10);
|
|
|
|
+let pageNo = $ref(1);
|
|
|
|
+let totalElements = $ref(0);
|
|
|
|
+
|
|
|
|
+async function search() {
|
|
|
|
+ await fetchData();
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+watch(() => [pageNo, pageSize], fetchData);
|
|
|
|
+
|
|
|
|
+async function fetchData() {
|
|
|
|
+ const res = await getProjectCourseList({
|
|
|
|
+ projectId,
|
|
|
|
+ pageSize,
|
|
|
|
+ pageNo,
|
|
|
|
+ });
|
|
|
|
+ // console.log(res);
|
|
|
|
+ data = res.data.content;
|
|
|
|
+ pageNo = res.data.pageNo;
|
|
|
|
+ pageSize = res.data.pageSize;
|
|
|
|
+ totalElements = res.data.totalElements;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+const columns = [
|
|
|
|
+ {
|
|
|
|
+ title: "科目",
|
|
|
|
+ dataIndex: "course",
|
|
|
|
+ slots: { customRender: "course" },
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "国家单科线",
|
|
|
|
+ dataIndex: "nationalScore",
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "复试科目线",
|
|
|
|
+ dataIndex: "retestScore",
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "国家总分线",
|
|
|
|
+ dataIndex: "nationalTotalScore",
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "复试总分线",
|
|
|
|
+ dataIndex: "retestTotalScore",
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "总分满分线",
|
|
|
|
+ dataIndex: "totalScoreLine",
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: "操作",
|
|
|
|
+ key: "action",
|
|
|
|
+ slots: { customRender: "action" },
|
|
|
|
+ },
|
|
|
|
+];
|
|
|
|
+
|
|
|
|
+onMounted(async () => {
|
|
|
|
+ rootOrgId = store.userInfo.rootOrgId;
|
|
|
|
+ await search();
|
|
|
|
+});
|
|
|
|
+
|
|
|
|
+const visible = ref<boolean>(false);
|
|
|
|
+
|
|
|
|
+const showModal = (record: any) => {
|
|
|
|
+ Object.assign(projectObj, record);
|
|
|
|
+ visible.value = true;
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+const handleOk = async (e: MouseEvent) => {
|
|
|
|
+ await updateProjectCourse(toRaw(projectObj));
|
|
|
|
+ visible.value = false;
|
|
|
|
+ await search();
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+const initProject = {
|
|
|
|
+ id: 0,
|
|
|
|
+ nationalScore: 0,
|
|
|
|
+ nationalTotalScore: 0,
|
|
|
|
+ retestScore: 0,
|
|
|
|
+ retestTotalScore: 0,
|
|
|
|
+ totalScoreLine: 0,
|
|
|
|
+ projectName: "",
|
|
|
|
+ courseName: "",
|
|
|
|
+ courseCode: "",
|
|
|
|
+ courseType: undefined,
|
|
|
|
+};
|
|
|
|
+const projectObj = reactive({ ...initProject });
|
|
|
|
+
|
|
|
|
+/** <handleImport> */
|
|
|
|
+let importModalVisible = ref<boolean>(false);
|
|
|
|
+async function handleImport() {
|
|
|
|
+ const files = (document.querySelector("#file-input") as HTMLInputElement)
|
|
|
|
+ .files;
|
|
|
|
+ const fileToImport = files && files[0];
|
|
|
|
+ if (!fileToImport) {
|
|
|
|
+ message.warn({ content: "请选择文件" });
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ await importProjectParams(projectId, fileToImport);
|
|
|
|
+ message.success({ content: "导入成功" });
|
|
|
|
+}
|
|
|
|
+/** </handleImport> */
|
|
|
|
+
|
|
|
|
+async function handleExport() {
|
|
|
|
+ await exportProjectParams(projectId);
|
|
|
|
+ message.success({ content: "导出成功" });
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+async function downloadTpl() {
|
|
|
|
+ downloadFileURL("/api/ess/projectCourse/template");
|
|
|
|
+}
|
|
|
|
+</script>
|