CodeMaster/node_modules/.cache/vue-loader/44034cd1b5400ade9725cee9db6991ba.json
2025-04-02 21:57:33 +08:00

1 line
31 KiB
JSON

{"remainingRequest":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/src/views/race/Race.vue?vue&type=script&lang=js","dependencies":[{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/src/views/race/Race.vue","mtime":1742646402777},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js","mtime":1743264595665},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/babel-loader/lib/index.js","mtime":1743264596348},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js","mtime":1743264595665},{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/vue-loader/lib/index.js","mtime":1743264596512}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
import { raceLevelMap, raceLevels,competitionStatus } from '@/utils/const';
import { AllUser } from '@/api';
import { exportData } from '@/utils/excel';
import EditRace from '@/components/edit/EditRace';
import Baoming from '@/components/edit/Baoming';
import AddRecord from '@/components/record/AddRecord';
import dayjs from 'dayjs';

export default {
  name: 'Race',
  metaInfo: {
    title: '赛事管理',
  },
  data() {
    return {
      selectedKeys: [],
      loading: false,
      exporting: false,
      races: [],
      users: [], // 用于存储用户信息
      current: 1,
			originalRaces: [],
			query:{},
      pageSize: 10,
      total: 0,
      tableColumns: [],
      searchOptions: this.createSearchOptions(),
    };
  },
  computed: {
    pagination() {
      return {
        current: this.current,
        pageSize: this.pageSize,
        total: this.total,
      };
    },
    isStudent() {
      return this.$store.state.user.userPrivileges == 2;
    },
  },
	async mounted() {
    await this.getAllUsers(); // 确保在表格列设置前获取用户信息
    this.$watch(() => [this.pageSize, this.current], this.getData, { immediate: true });
  },
  methods: {
		async getAllUsers() {
      try {
        const response = await AllUser();
        this.users = response.data;
        this.tableColumns = this.createTableColumns(this.users); // 利用获取的用户信息来设置表格列
      } catch (error) {
        console.error("Failed to load users", error);
      }
    },createTableColumns(users) {
    const competitionStatusMap = [
        { label: '进行中', value: 0 },
        { label: '已终止', value: 1 },
    ];
		console.log(users)
    return [
       
        { title: '赛事名称', dataIndex: 'competitionName', align: 'center' },
        {
            title: '负责人',
            dataIndex: 'userId',
            customRender: (text) => {
                if (!text) {
                    return '无';
                }
                const user = users.find(u => u.userId === text);
                return user ? user.userName : '无';
            }, align: 'center'
        },
        {
            title: '开始时间',
            dataIndex: 'registrationStartTime',
            customRender: (text, record) => formatDate(record.registrationStartTime)
						, align: 'center'
        },
        {
            title: '结束时间',
            dataIndex: 'registrationEndTime',
            customRender: (text, record) => formatDate(record.registrationEndTime)
						, align: 'center'
        },
        { title: '参考材料', dataIndex: 'announcementLink' , align: 'center'},
        {
            title: '状态',
            dataIndex: 'competitionStatus',
            customRender: (text, record) => {
                const statusObject = competitionStatusMap.find(item => item.value === record.competitionStatus);
                return statusObject ? statusObject.label : '未知状态';
            }
						, align: 'center'
        },
        {
            title: '操作',
            align: 'center',
            scopedSlots: {
                customRender: 'action',
            },
        },
    ];
},createSearchOptions() {
  return [
    {
      label: '赛事名称',
      key: 'title',
      default: '',
      component: 'input',
    },
    {
      label: '负责人',
      key: 'sponsor',
      default: '',
      component: 'input',
    },
		{
      label: '状态',
      key: 'collageId',
      default: undefined,
      component: 'select',
      props: {
        options: competitionStatus,
      },
    },

    {
      label: '时间',
      key: 'date',
      default: () => [],
      mapper: ({ date }) => date.join('~'),
      component: 'range-picker',
    },
  ];
},
    changePage({ pageSize, current }) {
      Object.assign(this, { pageSize, current });
    },
    search() {
      this.current = 1;
      this.getData();
    },
    getData() {
			this.query = this.$refs.searchForm.getResult();
			console.log(this.query)
      this.loading = true;
				this.$api.AllCompetition({
      }).then(data => {
        this.originalRaces = data.data;
				this.filterRaces(); // 调用过滤方法
        this.total = data.data.length;
      }).catch(e => {
        console.error(e);
        this.$message.error(e.msg || '获取数据失败');
      }).finally(() => {
        this.loading = false;
      });
    },
		// 过滤比赛
		filterRaces() {
  		let filteredRaces = this.originalRaces.slice(); // 复制原始用户数据
			console.log(filteredRaces)
				// 状态
  if (this.query.collageId) {
    filteredRaces = filteredRaces.filter(user => user.competitionStatus == this.query.collageId);
  }
// 名称
  if (this.query.title) {
    filteredRaces = filteredRaces.filter(user => user.competitionName.includes(this.query.title));
  }
// 负责人
  if (this.query.sponsor) {
		filteredRaces = filteredRaces.filter(user => user.userName.includes(this.query.sponsor));
  }


  this.races = filteredRaces;
},
// 我要报名
    addBao() {
      let vnode;
      this.$confirm({
        title: '我要报名',
        content: h => (vnode = <Baoming />),
        onOk: async () => {
          const values = await vnode.componentInstance.validate();
					const data = {
    				studentId: this.$store.state.user.userId,
						competitionId: values.competitionId,
						teamLeaderId: values.teamLeaderId,
						competitionType: values.competitionType,
						registrationTime: dayjs(new Date).format('YYYY-M-D HH:mm:ss'),
						registrationStatus: '等待学校审核',
					};
					console.log(data)
          return this.$api.Enroll(data).then(data => {
            this.$message.success("报名成功");
          }).catch(e => {
            this.$message.error(e.msg || '报名失败');
            throw e;
          });
        },
      });
    },
		// 新增比赛
    addRace() {
      let vnode;
      this.$confirm({
        title: '新增赛事',
        content: h => (vnode = <EditRace />),
        onOk: async () => {
          const values = await vnode.componentInstance.validate();
					const data = {
    				competitionName: values.competitionName,
						userId: values.userId,
						registrationStartTime: values.registrationStartTime,
						registrationEndTime: values.registrationEndTime,
						announcementLink: values.announcementLink,
						competitionStatus: values.competitionStatus,
					};
          return this.$api.AddCompetition(data).then(data => {
            this.$message.success("添加成功");
            this.getData();
          }).catch(e => {
            this.$message.error(e.msg || '添加失败');
            throw e;
          });
        },
      });
    },// 定义格式化日期时间函数
  formatDateTime(isoDateTime) {
    const date = new Date(isoDateTime);
    const formattedDateTime = `${date.getFullYear()}-${this.padZero(date.getMonth() + 1)}-${this.padZero(date.getDate())} ${this.padZero(date.getHours())}:${this.padZero(date.getMinutes())}:${this.padZero(date.getSeconds())}`;
    return formattedDateTime;
  },
  // 定义补零函数
  padZero(num) {
    return num < 10 ? '0' + num : num;
  },
		// 修改比赛
    editRace(race) {
      let vnode;
      this.$confirm({
        title: '编辑赛事',
        content: h => (vnode = <EditRace data={race} />),
        onOk: async () => {
          const values = await vnode.componentInstance.validate();
					// 调用formatDateTime函数来格式化日期时间
					values.registrationStartTime = this.formatDateTime(values.registrationStartTime);
        	values.registrationEndTime = this.formatDateTime(values.registrationEndTime);
          values.competitionId = race.competitionId;
					const data = {
    					competitionId: values.competitionId,
    					competitionName: values.competitionName,
    					userId: values.userId,
    					registrationStartTime: values.registrationStartTime,
    					registrationEndTime: values.registrationEndTime,
							announcementLink: values.announcementLink,
    					competitionStatus: values.competitionStatus,
							};

					return this.$api.UpCompetition(data).then(data => {
    				this.$message.success('修改成功');
    				this.getData();
					}).catch(e => {
    					this.$message.error(e.msg || '修改失败');
    					throw e;
					});
        },
      });
    },
		// 删除竞赛
    deleteRace(race) {
      this.loading = true;
      this.$api.DeleteCompetition([race.competitionId]).then(data => {
        this.$message.success(data.msg);
        this.getData();
      }).catch(e => {
        console.error(e);
        this.$message.error(e.msg || '删除失败');
      }).finally(() => {
        this.loading = false;
      });
    },
    batchDelete() {
      this.$modal.confirm({
        title: `确认删除选中的${this.selectedKeys.length}项数据?`,
        onOk: () => this.$api.deleteRace(this.selectedKeys)
          .then(() => {
            this.$message.success('删除成功!');
            this.selectedKeys.splice(0);
            this.getData();
          }).catch(e => {
            this.$message.error(e.msg || '删除失败!');
            throw e;
          }),
      });
    },
    addRecord(race) {
      let vnode;
      this.$confirm({
        title: '成绩录入',
        content: h => (vnode = <AddRecord />),
        onOk: async () => {
          const form = vnode.componentInstance;
          const values = await form.validate();
          return this.$api.addRecord({
            race_id: race.race_id,
            sid: this.$store.state.user.account,
            score: values.score,
            tid: values.tid,
          }).then(data => {
            this.$message.success(data.msg);
          }).catch(e => {
            this.$message.error(e.msg || '系统错误');
            throw e;
          });
        },
      });
    },
    exportAll() {
      this.exporting = true;
      this.$api.AllCompetition(this.query).then(data => {
        return exportExcel(data.data);
      }).catch(e => {
        console.error(e);
        this.$message.error(e.msg || '导出失败');
      }).finally(() => {
        this.exporting = false;
      });
    },
  },
};

// 格式化日期函数
function formatDate(dateString) {
  const date = new Date(dateString);
  if (isNaN(date.getTime())) {
    console.error(`Invalid date: ${dateString}`);
    return 'Invalid Date';
  }
  const year = date.getFullYear();
  const month = String(date.getMonth() + 1).padStart(2, '0');
  const day = String(date.getDate()).padStart(2, '0');
  return `${year}-${month}-${day}`;
}
function exportExcel(data) {
  const header = this.createTableColumns().map(v => v.title);
  header.pop(); // 去掉最后一栏操作栏
  return exportData({
    name: '赛事信息',
    data,
    header,
    keyMap: {
      competitionName: '赛事名称',
      userId: '主办方',
      announcementLink: '参考资料',
      registrationStartTime: '开始时间',
      registrationEndTime: '结束时间',
    },
  });
}
"},{"version":3,"sources":["Race.vue"],"names":[],"mappings":";AA6EA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"Race.vue","sourceRoot":"src/views/race","sourcesContent":["<template>\n <div>\n <SearchForm\n ref=\"searchForm\"\n :loading=\"loading\"\n :options=\"searchOptions\"\n @search=\"search\"\n @reset=\"search\"\n />\n\n <!--信息列表-->\n <AntTable\n v-model=\"selectedKeys\"\n row-key=\"competitionId\"\n :loading=\"loading\"\n :data-source=\"races\"\n :pagination=\"pagination\"\n :columns=\"tableColumns\"\n @change=\"changePage\"\n >\n <template #header>\n <a-button-group>\n <a-button type=\"primary\" v-if=\"$store.state.user.userPrivileges!=2\" @click=\"addRace\">\n 添加赛事\n </a-button>\n\t\t\t\t\t<a-button type=\"primary\" v-if=\"$store.state.user.userPrivileges==2\" @click=\"addBao\">\n\t\t\t\t\t\t\n 我要报名\n </a-button>\n <a-button\n\t\t\t\t\tv-if=\"$store.state.user.userPrivileges!=2\"\n :disabled=\"!selectedKeys.length\"\n @click=\"batchDelete\"\n >\n 批量删除 ({{ selectedKeys.length }})\n </a-button>\n <a-button\n \n :loading=\"exporting\"\n @click=\"exportAll\"\n >\n 全量导出\n </a-button>\n </a-button-group>\n </template>\n <template #action=\"record\">\n <a-space>\n <!-- 成绩录入 -->\n <a-tooltip v-if=\"isStudent\" title=\"无权限\">\n <a>\n 无权限\n </a>\n </a-tooltip>\n <!--编辑-->\n <a @click=\"editRace(record)\" \tv-if=\"$store.state.user.userPrivileges!=2\">\n\t\t\t\t\t\n <a-icon type=\"edit\" />\n </a>\n <!--删除-->\n <a-popconfirm\n\t\t\t\t\tv-if=\"$store.state.user.userPrivileges!=2\"\n title=\"确认删除?\"\n placement=\"left\"\n @confirm=\"deleteRace(record)\"\n >\n <template #icon>\n <a-icon type=\"question-circle-o\" style=\"color: orange\" />\n </template>\n <a><a-icon type=\"delete\" /></a>\n </a-popconfirm>\n </a-space>\n </template>\n </AntTable>\n </div>\n</template>\n\n<script>\nimport { raceLevelMap, raceLevels,competitionStatus } from '@/utils/const';\nimport { AllUser } from '@/api';\nimport { exportData } from '@/utils/excel';\nimport EditRace from '@/components/edit/EditRace';\nimport Baoming from '@/components/edit/Baoming';\nimport AddRecord from '@/components/record/AddRecord';\nimport dayjs from 'dayjs';\n\nexport default {\n name: 'Race',\n metaInfo: {\n title: '赛事管理',\n },\n data() {\n return {\n selectedKeys: [],\n loading: false,\n exporting: false,\n races: [],\n users: [], // 用于存储用户信息\n current: 1,\n\t\t\toriginalRaces: [],\n\t\t\tquery:{},\n pageSize: 10,\n total: 0,\n tableColumns: [],\n searchOptions: this.createSearchOptions(),\n };\n },\n computed: {\n pagination() {\n return {\n current: this.current,\n pageSize: this.pageSize,\n total: this.total,\n };\n },\n isStudent() {\n return this.$store.state.user.userPrivileges == 2;\n },\n },\n\tasync mounted() {\n await this.getAllUsers(); // 确保在表格列设置前获取用户信息\n this.$watch(() => [this.pageSize, this.current], this.getData, { immediate: true });\n },\n methods: {\n\t\tasync getAllUsers() {\n try {\n const response = await AllUser();\n this.users = response.data;\n this.tableColumns = this.createTableColumns(this.users); // 利用获取的用户信息来设置表格列\n } catch (error) {\n console.error(\"Failed to load users\", error);\n }\n },createTableColumns(users) {\n const competitionStatusMap = [\n { label: '进行中', value: 0 },\n { label: '已终止', value: 1 },\n ];\n\t\tconsole.log(users)\n return [\n \n { title: '赛事名称', dataIndex: 'competitionName', align: 'center' },\n {\n title: '负责人',\n dataIndex: 'userId',\n customRender: (text) => {\n if (!text) {\n return '无';\n }\n const user = users.find(u => u.userId === text);\n return user ? user.userName : '无';\n }, align: 'center'\n },\n {\n title: '开始时间',\n dataIndex: 'registrationStartTime',\n customRender: (text, record) => formatDate(record.registrationStartTime)\n\t\t\t\t\t\t, align: 'center'\n },\n {\n title: '结束时间',\n dataIndex: 'registrationEndTime',\n customRender: (text, record) => formatDate(record.registrationEndTime)\n\t\t\t\t\t\t, align: 'center'\n },\n { title: '参考材料', dataIndex: 'announcementLink' , align: 'center'},\n {\n title: '状态',\n dataIndex: 'competitionStatus',\n customRender: (text, record) => {\n const statusObject = competitionStatusMap.find(item => item.value === record.competitionStatus);\n return statusObject ? statusObject.label : '未知状态';\n }\n\t\t\t\t\t\t, align: 'center'\n },\n {\n title: '操作',\n align: 'center',\n scopedSlots: {\n customRender: 'action',\n },\n },\n ];\n},createSearchOptions() {\n return [\n {\n label: '赛事名称',\n key: 'title',\n default: '',\n component: 'input',\n },\n {\n label: '负责人',\n key: 'sponsor',\n default: '',\n component: 'input',\n },\n\t\t{\n label: '状态',\n key: 'collageId',\n default: undefined,\n component: 'select',\n props: {\n options: competitionStatus,\n },\n },\n\n {\n label: '时间',\n key: 'date',\n default: () => [],\n mapper: ({ date }) => date.join('~'),\n component: 'range-picker',\n },\n ];\n},\n changePage({ pageSize, current }) {\n Object.assign(this, { pageSize, current });\n },\n search() {\n this.current = 1;\n this.getData();\n },\n getData() {\n\t\t\tthis.query = this.$refs.searchForm.getResult();\n\t\t\tconsole.log(this.query)\n this.loading = true;\n\t\t\t\tthis.$api.AllCompetition({\n }).then(data => {\n this.originalRaces = data.data;\n\t\t\t\tthis.filterRaces(); // 调用过滤方法\n this.total = data.data.length;\n }).catch(e => {\n console.error(e);\n this.$message.error(e.msg || '获取数据失败');\n }).finally(() => {\n this.loading = false;\n });\n },\n\t\t// 过滤比赛\n\t\tfilterRaces() {\n \t\tlet filteredRaces = this.originalRaces.slice(); // 复制原始用户数据\n\t\t\tconsole.log(filteredRaces)\n\t\t\t\t// 状态\n if (this.query.collageId) {\n filteredRaces = filteredRaces.filter(user => user.competitionStatus == this.query.collageId);\n }\n// 名称\n if (this.query.title) {\n filteredRaces = filteredRaces.filter(user => user.competitionName.includes(this.query.title));\n }\n// 负责人\n if (this.query.sponsor) {\n\t\tfilteredRaces = filteredRaces.filter(user => user.userName.includes(this.query.sponsor));\n }\n\n\n this.races = filteredRaces;\n},\n// 我要报名\n addBao() {\n let vnode;\n this.$confirm({\n title: '我要报名',\n content: h => (vnode = <Baoming />),\n onOk: async () => {\n const values = await vnode.componentInstance.validate();\n\t\t\t\t\tconst data = {\n \t\t\t\tstudentId: this.$store.state.user.userId,\n\t\t\t\t\t\tcompetitionId: values.competitionId,\n\t\t\t\t\t\tteamLeaderId: values.teamLeaderId,\n\t\t\t\t\t\tcompetitionType: values.competitionType,\n\t\t\t\t\t\tregistrationTime: dayjs(new Date).format('YYYY-M-D HH:mm:ss'),\n\t\t\t\t\t\tregistrationStatus: '等待学校审核',\n\t\t\t\t\t};\n\t\t\t\t\tconsole.log(data)\n return this.$api.Enroll(data).then(data => {\n this.$message.success(\"报名成功\");\n }).catch(e => {\n this.$message.error(e.msg || '报名失败');\n throw e;\n });\n },\n });\n },\n\t\t// 新增比赛\n addRace() {\n let vnode;\n this.$confirm({\n title: '新增赛事',\n content: h => (vnode = <EditRace />),\n onOk: async () => {\n const values = await vnode.componentInstance.validate();\n\t\t\t\t\tconst data = {\n \t\t\t\tcompetitionName: values.competitionName,\n\t\t\t\t\t\tuserId: values.userId,\n\t\t\t\t\t\tregistrationStartTime: values.registrationStartTime,\n\t\t\t\t\t\tregistrationEndTime: values.registrationEndTime,\n\t\t\t\t\t\tannouncementLink: values.announcementLink,\n\t\t\t\t\t\tcompetitionStatus: values.competitionStatus,\n\t\t\t\t\t};\n return this.$api.AddCompetition(data).then(data => {\n this.$message.success(\"添加成功\");\n this.getData();\n }).catch(e => {\n this.$message.error(e.msg || '添加失败');\n throw e;\n });\n },\n });\n },// 定义格式化日期时间函数\n formatDateTime(isoDateTime) {\n const date = new Date(isoDateTime);\n const formattedDateTime = `${date.getFullYear()}-${this.padZero(date.getMonth() + 1)}-${this.padZero(date.getDate())} ${this.padZero(date.getHours())}:${this.padZero(date.getMinutes())}:${this.padZero(date.getSeconds())}`;\n return formattedDateTime;\n },\n // 定义补零函数\n padZero(num) {\n return num < 10 ? '0' + num : num;\n },\n\t\t// 修改比赛\n editRace(race) {\n let vnode;\n this.$confirm({\n title: '编辑赛事',\n content: h => (vnode = <EditRace data={race} />),\n onOk: async () => {\n const values = await vnode.componentInstance.validate();\n\t\t\t\t\t// 调用formatDateTime函数来格式化日期时间\n\t\t\t\t\tvalues.registrationStartTime = this.formatDateTime(values.registrationStartTime);\n \tvalues.registrationEndTime = this.formatDateTime(values.registrationEndTime);\n values.competitionId = race.competitionId;\n\t\t\t\t\tconst data = {\n \t\t\t\t\tcompetitionId: values.competitionId,\n \t\t\t\t\tcompetitionName: values.competitionName,\n \t\t\t\t\tuserId: values.userId,\n \t\t\t\t\tregistrationStartTime: values.registrationStartTime,\n \t\t\t\t\tregistrationEndTime: values.registrationEndTime,\n\t\t\t\t\t\t\tannouncementLink: values.announcementLink,\n \t\t\t\t\tcompetitionStatus: values.competitionStatus,\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\treturn this.$api.UpCompetition(data).then(data => {\n \t\t\t\tthis.$message.success('修改成功');\n \t\t\t\tthis.getData();\n\t\t\t\t\t}).catch(e => {\n \t\t\t\t\tthis.$message.error(e.msg || '修改失败');\n \t\t\t\t\tthrow e;\n\t\t\t\t\t});\n },\n });\n },\n\t\t// 删除竞赛\n deleteRace(race) {\n this.loading = true;\n this.$api.DeleteCompetition([race.competitionId]).then(data => {\n this.$message.success(data.msg);\n this.getData();\n }).catch(e => {\n console.error(e);\n this.$message.error(e.msg || '删除失败');\n }).finally(() => {\n this.loading = false;\n });\n },\n batchDelete() {\n this.$modal.confirm({\n title: `确认删除选中的${this.selectedKeys.length}项数据?`,\n onOk: () => this.$api.deleteRace(this.selectedKeys)\n .then(() => {\n this.$message.success('删除成功!');\n this.selectedKeys.splice(0);\n this.getData();\n }).catch(e => {\n this.$message.error(e.msg || '删除失败!');\n throw e;\n }),\n });\n },\n addRecord(race) {\n let vnode;\n this.$confirm({\n title: '成绩录入',\n content: h => (vnode = <AddRecord />),\n onOk: async () => {\n const form = vnode.componentInstance;\n const values = await form.validate();\n return this.$api.addRecord({\n race_id: race.race_id,\n sid: this.$store.state.user.account,\n score: values.score,\n tid: values.tid,\n }).then(data => {\n this.$message.success(data.msg);\n }).catch(e => {\n this.$message.error(e.msg || '系统错误');\n throw e;\n });\n },\n });\n },\n exportAll() {\n this.exporting = true;\n this.$api.AllCompetition(this.query).then(data => {\n return exportExcel(data.data);\n }).catch(e => {\n console.error(e);\n this.$message.error(e.msg || '导出失败');\n }).finally(() => {\n this.exporting = false;\n });\n },\n },\n};\n\n// 格式化日期函数\nfunction formatDate(dateString) {\n const date = new Date(dateString);\n if (isNaN(date.getTime())) {\n console.error(`Invalid date: ${dateString}`);\n return 'Invalid Date';\n }\n const year = date.getFullYear();\n const month = String(date.getMonth() + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n return `${year}-${month}-${day}`;\n}\nfunction exportExcel(data) {\n const header = this.createTableColumns().map(v => v.title);\n header.pop(); // 去掉最后一栏操作栏\n return exportData({\n name: '赛事信息',\n data,\n header,\n keyMap: {\n competitionName: '赛事名称',\n userId: '主办方',\n announcementLink: '参考资料',\n registrationStartTime: '开始时间',\n registrationEndTime: '结束时间',\n },\n });\n}\n</script>\n"]}]}