1 line
40 KiB
JSON
1 line
40 KiB
JSON
{"remainingRequest":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/babel-loader/lib/index.js!/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/node_modules/cache-loader/dist/cjs.js??ref--1-0!/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/babel.config.js","mtime":1742646402652},{"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() {
      const h = this.$createElement;
      let vnode;
      this.$confirm({
        title: '我要报名',
        content: h => vnode = h(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() {
      const h = this.$createElement;
      let vnode;
      this.$confirm({
        title: '新增赛事',
        content: h => vnode = h(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) {
      const h = this.$createElement;
      let vnode;
      this.$confirm({
        title: '编辑赛事',
        content: h => vnode = h(EditRace, {
          "attrs": {
            "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) {
      const h = this.$createElement;
      let vnode;
      this.$confirm({
        title: '成绩录入',
        content: h => vnode = h(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,"names":["raceLevelMap","raceLevels","competitionStatus","AllUser","exportData","EditRace","Baoming","AddRecord","dayjs","name","metaInfo","title","data","selectedKeys","loading","exporting","races","users","current","originalRaces","query","pageSize","total","tableColumns","searchOptions","createSearchOptions","computed","pagination","isStudent","$store","state","user","userPrivileges","mounted","getAllUsers","$watch","getData","immediate","methods","response","createTableColumns","error","console","competitionStatusMap","label","value","log","dataIndex","align","customRender","text","find","u","userId","userName","record","formatDate","registrationStartTime","registrationEndTime","statusObject","item","scopedSlots","key","default","component","undefined","props","options","mapper","date","join","changePage","Object","assign","search","$refs","searchForm","getResult","$api","AllCompetition","then","filterRaces","length","catch","e","$message","msg","finally","filteredRaces","slice","collageId","filter","competitionName","includes","sponsor","addBao","h","$createElement","vnode","$confirm","content","onOk","values","componentInstance","validate","studentId","competitionId","teamLeaderId","competitionType","registrationTime","Date","format","registrationStatus","Enroll","success","addRace","announcementLink","AddCompetition","formatDateTime","isoDateTime","formattedDateTime","getFullYear","padZero","getMonth","getDate","getHours","getMinutes","getSeconds","num","editRace","race","UpCompetition","deleteRace","DeleteCompetition","batchDelete","$modal","confirm","splice","addRecord","form","race_id","sid","account","score","tid","exportAll","exportExcel","dateString","isNaN","getTime","year","month","String","padStart","day","header","map","v","pop","keyMap"],"sources":["src/views/race/Race.vue"],"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"],"mappings":"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","ignoreList":[]}]} |