CodeMaster/node_modules/.cache/babel-loader/f2c370cf5190cb28bb39b6377b1eb145.json
2025-04-02 21:57:33 +08:00

1 line
25 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/Record.vue?vue&type=script&lang=js","dependencies":[{"path":"/Users/shuguang/Desktop/毕设/CodeMaster/CodeMaster/src/views/race/Record.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 { exportData } from '@/utils/excel';
import { AllCompetition } from '@/api';
import RecordAction from '@/components/record/RecordAction';
export default {
  name: 'Record',
  components: {
    RecordAction
  },
  metaInfo: {
    title: '参赛记录'
  },
  data() {
    return {
      selectedKeys: [],
      loading: false,
      exporting: false,
      records: [],
      originalRaces: [],
      query: {},
      current: 1,
      pageSize: 10,
      total: 0,
      tableColumns: createTableColumns.call(this, this.$createElement),
      searchOptions: createSearchOptions.call(this)
    };
  },
  computed: {
    pagination() {
      return {
        current: this.current,
        pageSize: this.pageSize,
        total: this.total
      };
    }
  },
  mounted() {
    this.$watch(() => [this.pageSize, this.current], this.getData, {
      immediate: true
    });
  },
  methods: {
    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.RegistrationAll({}).then(data => {
        // 如果筛选出来用户身份为学生
        if (this.$store.state.user.userPrivileges == 2) {
          // 筛选学生用户自己的比赛
          this.records = data.data.filter(item => {
            return item.studentId == this.$store.state.user.userId; // 添加 return 语句
          });
          this.total = this.records.length; // 更新 total 的计算方式
          console.log(this.records);
        } else {
          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.status) {
        filteredRaces = filteredRaces.filter(user => user.competitionStatus == this.query.status);
      }
      // 名称
      if (this.query.title) {
        filteredRaces = filteredRaces.filter(user => user.competitionName.includes(this.query.title));
      }
      // 负责人
      if (this.query.sname) {
        filteredRaces = filteredRaces.filter(user => user.studentName.includes(this.query.sname));
      }
      // 成绩
      if (this.query.score != null) {
        filteredRaces = filteredRaces.filter(user => user.awardLevel.includes(this.query.sname));
      }
      this.records = filteredRaces;
    },
    batchDelete() {
      this.$modal.confirm({
        title: `确认删除选中的${this.selectedKeys.length}项数据?`,
        onOk: () => this.$api.deleteRecord(this.selectedKeys).then(() => {
          this.$message.success('删除成功!');
          this.selectedKeys.splice(0);
          this.getData();
        }).catch(e => {
          this.$message.error(e.msg || '删除失败!');
          throw e;
        })
      });
    },
    exportAll() {
      this.exporting = true;
      this.$api.getRecordList(this.query).then(data => {
        return exportExcel(data.data);
      }).catch(e => {
        console.error(e);
        this.$message.error(e.msg || '导出失败');
      }).finally(() => {
        this.exporting = false;
      });
    }
  }
};
const statusMap = {
  0: {
    style: 'color: lightgrey',
    type: 'question-circle',
    text: '待审核'
  },
  1: {
    style: 'color: limegreen',
    type: 'check-circle',
    text: '审核通过'
  },
  2: {
    style: 'color: red',
    type: 'exclamation-circle',
    text: '审核失败'
  }
};
// 格式化日期函数
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 createTableColumns(h) {
  return [{
    title: '名称',
    dataIndex: 'competitionName'
  }, {
    title: '参赛人',
    dataIndex: 'studentName'
  }, {
    title: '队长',
    dataIndex: 'teamLeaderName'
  }, {
    title: '类型',
    dataIndex: 'competitionType'
  }, {
    title: '成绩',
    dataIndex: 'awardLevel',
    customRender: (text, record) => {
      // 如果 awardLevel 不存在或为空，则显示“未获奖”，否则显示实际成绩
      return text ? text : '未获奖';
    }
  }, {
    title: '备注信息',
    dataIndex: 'additionalInfo',
    customRender: (text, record) => {
      // 如果 additionalInfo 不存在或为空，则显示“未获奖”，否则显示实际成绩
      return text ? text : '无';
    }
  }, {
    title: '获奖证书',
    dataIndex: 'certificatePath',
    customRender: (text, record) => {
      // 如果 certificatePath 存在，则显示图片
      if (text) {
        return h("img", {
          "attrs": {
            "src": text
          },
          "style": {
            width: '100px',
            height: 'auto'
          }
        });
      } else {
        return '无';
      }
    }
  }, {
    title: '状态',
    dataIndex: 'registrationStatus'
  }, {
    title: '登记时间',
    dataIndex: 'registrationTime',
    customRender: (text, record) => formatDate(record.registrationTime)
  }, {
    title: '操作',
    align: 'center',
    scopedSlots: {
      customRender: 'action'
    }
  }];
}
function exportExcel(data) {
  const header = createTableColumns().map(v => v.title);
  header.pop(); // 去掉最后一栏操作栏
  return exportData({
    name: '参赛记录信息',
    data,
    header,
    keyMap: {
      competitionId: '名称',
      studentId: '参赛人',
      teamLeaderId: '组队编号',
      competitionType: '类型',
      awardLevel: '成绩',
      competitionType: '类型',
      registrationStatus: ['状态', status => {
        var _statusMap$registrati;
        return (_statusMap$registrati = statusMap[registrationStatus]) === null || _statusMap$registrati === void 0 ? void 0 : _statusMap$registrati.text;
      }],
      registrationTime: '登记时间'
    }
  });
}
function createSearchOptions() {
  return [{
    label: '赛事名称',
    key: 'title',
    default: '',
    component: 'input',
    align: 'center'
  }, {
    label: '参赛人',
    key: 'sname',
    default: '',
    component: 'input',
    align: 'center'
  }, {
    label: '成绩',
    key: 'score',
    default: '',
    component: 'input',
    align: 'center'
  }, {
    label: '审核状态',
    key: 'status',
    default: undefined,
    component: 'select',
    align: 'center',
    props: {
      options: [{
        label: '等待学校审核',
        value: '等待学校审核'
      }, {
        label: '成功报名',
        value: '成功报名'
      }, {
        label: '审核失败',
        value: '审核失败'
      }]
    }
  }];
}"},{"version":3,"names":["exportData","AllCompetition","RecordAction","name","components","metaInfo","title","data","selectedKeys","loading","exporting","records","originalRaces","query","current","pageSize","total","tableColumns","createTableColumns","call","$createElement","searchOptions","createSearchOptions","computed","pagination","mounted","$watch","getData","immediate","methods","changePage","Object","assign","search","$refs","searchForm","getResult","console","log","$api","RegistrationAll","then","$store","state","user","userPrivileges","filter","item","studentId","userId","length","filterRaces","catch","e","error","$message","msg","finally","filteredRaces","slice","status","competitionStatus","competitionName","includes","sname","studentName","score","awardLevel","batchDelete","$modal","confirm","onOk","deleteRecord","success","splice","exportAll","getRecordList","exportExcel","statusMap","style","type","text","formatDate","dateString","date","Date","isNaN","getTime","year","getFullYear","month","String","getMonth","padStart","day","getDate","h","dataIndex","customRender","record","width","height","registrationTime","align","scopedSlots","header","map","v","pop","keyMap","competitionId","teamLeaderId","competitionType","registrationStatus","_statusMap$registrati","label","key","default","component","undefined","props","options","value"],"sources":["src/views/race/Record.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=\"record_id\"\n :loading=\"loading\"\n :data-source=\"records\"\n :pagination=\"pagination\"\n :columns=\"tableColumns\"\n @change=\"changePage\"\n >\n <template #header>\n <a-button-group>\n <a-button\n \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 <RecordAction :record=\"record\" :fresh-data=\"getData\" />\n </template>\n </AntTable>\n </div>\n</template>\n\n<script>\nimport { exportData } from '@/utils/excel';\nimport { AllCompetition } from '@/api';\nimport RecordAction from '@/components/record/RecordAction';\n\nexport default {\n name: 'Record',\n components: { RecordAction },\n metaInfo: {\n title: '参赛记录',\n },\n data() {\n return {\n selectedKeys: [],\n loading: false,\n exporting: false,\n records: [],\n\t\t\toriginalRaces: [],\n\t\t\tquery:{},\n current: 1,\n pageSize: 10,\n total: 0,\n tableColumns: createTableColumns.call(this, this.$createElement),\n searchOptions: createSearchOptions.call(this),\n };\n },\n computed: {\n pagination() {\n return {\n current: this.current,\n pageSize: this.pageSize,\n total: this.total,\n };\n },\n },\n mounted() {\n this.$watch(() => [this.pageSize, this.current], this.getData, { immediate: true });\n },\n methods: {\n changePage({ pageSize, current }) {\n Object.assign(this, { pageSize, current });\n },\n search() {\n this.current = 1;\n this.getData();\n },\n\t\tgetData() {\n\tthis.query = this.$refs.searchForm.getResult();\n\tconsole.log(this.query)\n this.loading = true;\n this.$api.RegistrationAll({\n }).then(data => {\n\t\t// 如果筛选出来用户身份为学生\n if(this.$store.state.user.userPrivileges == 2){\n\t\t\t// 筛选学生用户自己的比赛\n this.records = data.data.filter(item => {\n return item.studentId == this.$store.state.user.userId; // 添加 return 语句\n });\n this.total = this.records.length; // 更新 total 的计算方式\n console.log(this.records);\n } else {\n this.originalRaces = data.data;\n\t\t\tthis.filterRaces(); // 调用过滤方法\n this.total = data.data.length;\n }\n }).catch(e => {\n console.error(e);\n this.$message.error(e.msg || '获取数据失败');\n }).finally(() => {\n this.loading = false;\n });\n},\n// 过滤\n// 过滤比赛\nfilterRaces() {\n \t\tlet filteredRaces = this.originalRaces.slice(); // 复制原始用户数据\n\t\t\tconsole.log(filteredRaces)\n\t\t\t\t// 状态\n if (this.query.status) {\n filteredRaces = filteredRaces.filter(user => user.competitionStatus == this.query.status);\n }\n// 名称\n if (this.query.title) {\n filteredRaces = filteredRaces.filter(user => user.competitionName.includes(this.query.title));\n }\n// 负责人\n if (this.query.sname) {\n\t\tfilteredRaces = filteredRaces.filter(user => user.studentName.includes(this.query.sname));\n }\n// 成绩\nif (this.query.score!=null) {\n\t\tfilteredRaces = filteredRaces.filter(user => user.awardLevel.includes(this.query.sname));\n }\n this.records = filteredRaces;\n},\n batchDelete() {\n this.$modal.confirm({\n title: `确认删除选中的${this.selectedKeys.length}项数据?`,\n onOk: () => this.$api.deleteRecord(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 exportAll() {\n this.exporting = true;\n this.$api.getRecordList(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\nconst statusMap = {\n 0: { style: 'color: lightgrey', type: 'question-circle', text: '待审核' },\n 1: { style: 'color: limegreen', type: 'check-circle', text: '审核通过' },\n 2: { style: 'color: red', type: 'exclamation-circle', text: '审核失败' },\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 createTableColumns(h) {\n return [\n\t\t{ title: '名称', dataIndex: 'competitionName' },\n { title: '参赛人', dataIndex: 'studentName' },\n\t\t{ title: '队长', dataIndex: 'teamLeaderName' },\n { title: '类型', dataIndex: 'competitionType' },\n\t\t{ \n title: '成绩', \n dataIndex: 'awardLevel',\n customRender: (text, record) => {\n // 如果 awardLevel 不存在或为空,则显示“未获奖”,否则显示实际成绩\n return text ? text : '未获奖';\n }\n },\n\t\t{ \n title: '备注信息', \n dataIndex: 'additionalInfo',\n customRender: (text, record) => {\n // 如果 additionalInfo 不存在或为空,则显示“未获奖”,否则显示实际成绩\n return text ? text : '无';\n }\n },\n\t\t{ \n title: '获奖证书', \n dataIndex: 'certificatePath',\n customRender: (text, record) => {\n // 如果 certificatePath 存在,则显示图片\n if (text) {\n return <img src={text} style={{ width: '100px', height: 'auto' }} />;\n } else {\n return '无';\n }\n }\n },\n\t\t{ title: '状态', dataIndex: 'registrationStatus' },\n { title: '登记时间', \n\t\t\tdataIndex: 'registrationTime',\n\t \tcustomRender: (text, record) => formatDate(record.registrationTime)\n\t},\n {\n title: '操作',\n align: 'center',\n scopedSlots: {\n customRender: 'action',\n },\n },\n ];\n}\n\nfunction exportExcel(data) {\n const header = createTableColumns().map(v => v.title);\n header.pop(); // 去掉最后一栏操作栏\n return exportData({\n name: '参赛记录信息',\n data,\n header,\n keyMap: {\n competitionId: '名称',\n studentId: '参赛人',\n teamLeaderId: '组队编号',\n competitionType: '类型',\n awardLevel: '成绩',\n competitionType: '类型',\n registrationStatus: ['状态', status => statusMap[registrationStatus]?.text],\n registrationTime: '登记时间',\n },\n });\n}\n\nfunction createSearchOptions() {\n return [\n {\n label: '赛事名称',\n key: 'title',\n default: '',\n component: 'input',\n\t\t\talign: 'center'\n },\n {\n label: '参赛人',\n key: 'sname',\n default: '',\n component: 'input',\n\t\t\talign: 'center'\n },\n {\n label: '成绩',\n key: 'score',\n default: '',\n component: 'input',\n\t\t\talign: 'center'\n },\n {\n label: '审核状态',\n key: 'status',\n default: undefined,\n component: 'select',\n\t\t\talign: 'center',\n props: {\n options: [\n { label: '等待学校审核', value: '等待学校审核' },\n { label: '成功报名', value: '成功报名' },\n { label: '审核失败', value: '审核失败' },\n ],\n },\n },\n ];\n}\n</script>\n\n<style scoped>\n</style>\n"],"mappings":"AA8CA,SAAAA,UAAA;AACA,SAAAC,cAAA;AACA,OAAAC,YAAA;AAEA;EACAC,IAAA;EACAC,UAAA;IAAAF;EAAA;EACAG,QAAA;IACAC,KAAA;EACA;EACAC,KAAA;IACA;MACAC,YAAA;MACAC,OAAA;MACAC,SAAA;MACAC,OAAA;MACAC,aAAA;MACAC,KAAA;MACAC,OAAA;MACAC,QAAA;MACAC,KAAA;MACAC,YAAA,EAAAC,kBAAA,CAAAC,IAAA,YAAAC,cAAA;MACAC,aAAA,EAAAC,mBAAA,CAAAH,IAAA;IACA;EACA;EACAI,QAAA;IACAC,WAAA;MACA;QACAV,OAAA,OAAAA,OAAA;QACAC,QAAA,OAAAA,QAAA;QACAC,KAAA,OAAAA;MACA;IACA;EACA;EACAS,QAAA;IACA,KAAAC,MAAA,aAAAX,QAAA,OAAAD,OAAA,QAAAa,OAAA;MAAAC,SAAA;IAAA;EACA;EACAC,OAAA;IACAC,WAAA;MAAAf,QAAA;MAAAD;IAAA;MACAiB,MAAA,CAAAC,MAAA;QAAAjB,QAAA;QAAAD;MAAA;IACA;IACAmB,OAAA;MACA,KAAAnB,OAAA;MACA,KAAAa,OAAA;IACA;IACAA,QAAA;MACA,KAAAd,KAAA,QAAAqB,KAAA,CAAAC,UAAA,CAAAC,SAAA;MACAC,OAAA,CAAAC,GAAA,MAAAzB,KAAA;MACA,KAAAJ,OAAA;MACA,KAAA8B,IAAA,CAAAC,eAAA,EACA,GAAAC,IAAA,CAAAlC,IAAA;QACA;QACA,SAAAmC,MAAA,CAAAC,KAAA,CAAAC,IAAA,CAAAC,cAAA;UACA;UACA,KAAAlC,OAAA,GAAAJ,IAAA,CAAAA,IAAA,CAAAuC,MAAA,CAAAC,IAAA;YACA,OAAAA,IAAA,CAAAC,SAAA,SAAAN,MAAA,CAAAC,KAAA,CAAAC,IAAA,CAAAK,MAAA;UACA;UACA,KAAAjC,KAAA,QAAAL,OAAA,CAAAuC,MAAA;UACAb,OAAA,CAAAC,GAAA,MAAA3B,OAAA;QACA;UACA,KAAAC,aAAA,GAAAL,IAAA,CAAAA,IAAA;UACA,KAAA4C,WAAA;UACA,KAAAnC,KAAA,GAAAT,IAAA,CAAAA,IAAA,CAAA2C,MAAA;QACA;MACA,GAAAE,KAAA,CAAAC,CAAA;QACAhB,OAAA,CAAAiB,KAAA,CAAAD,CAAA;QACA,KAAAE,QAAA,CAAAD,KAAA,CAAAD,CAAA,CAAAG,GAAA;MACA,GAAAC,OAAA;QACA,KAAAhD,OAAA;MACA;IACA;IACA;IACA;IACA0C,YAAA;MACA,IAAAO,aAAA,QAAA9C,aAAA,CAAA+C,KAAA;MACAtB,OAAA,CAAAC,GAAA,CAAAoB,aAAA;MACA;MACA,SAAA7C,KAAA,CAAA+C,MAAA;QACAF,aAAA,GAAAA,aAAA,CAAAZ,MAAA,CAAAF,IAAA,IAAAA,IAAA,CAAAiB,iBAAA,SAAAhD,KAAA,CAAA+C,MAAA;MACA;MACA;MACA,SAAA/C,KAAA,CAAAP,KAAA;QACAoD,aAAA,GAAAA,aAAA,CAAAZ,MAAA,CAAAF,IAAA,IAAAA,IAAA,CAAAkB,eAAA,CAAAC,QAAA,MAAAlD,KAAA,CAAAP,KAAA;MACA;MACA;MACA,SAAAO,KAAA,CAAAmD,KAAA;QACAN,aAAA,GAAAA,aAAA,CAAAZ,MAAA,CAAAF,IAAA,IAAAA,IAAA,CAAAqB,WAAA,CAAAF,QAAA,MAAAlD,KAAA,CAAAmD,KAAA;MACA;MACA;MACA,SAAAnD,KAAA,CAAAqD,KAAA;QACAR,aAAA,GAAAA,aAAA,CAAAZ,MAAA,CAAAF,IAAA,IAAAA,IAAA,CAAAuB,UAAA,CAAAJ,QAAA,MAAAlD,KAAA,CAAAmD,KAAA;MACA;MACA,KAAArD,OAAA,GAAA+C,aAAA;IACA;IACAU,YAAA;MACA,KAAAC,MAAA,CAAAC,OAAA;QACAhE,KAAA,iBAAAE,YAAA,CAAA0C,MAAA;QACAqB,IAAA,EAAAA,CAAA,UAAAhC,IAAA,CAAAiC,YAAA,MAAAhE,YAAA,EACAiC,IAAA;UACA,KAAAc,QAAA,CAAAkB,OAAA;UACA,KAAAjE,YAAA,CAAAkE,MAAA;UACA,KAAA/C,OAAA;QACA,GAAAyB,KAAA,CAAAC,CAAA;UACA,KAAAE,QAAA,CAAAD,KAAA,CAAAD,CAAA,CAAAG,GAAA;UACA,MAAAH,CAAA;QACA;MACA;IACA;IACAsB,UAAA;MACA,KAAAjE,SAAA;MACA,KAAA6B,IAAA,CAAAqC,aAAA,MAAA/D,KAAA,EAAA4B,IAAA,CAAAlC,IAAA;QACA,OAAAsE,WAAA,CAAAtE,IAAA,CAAAA,IAAA;MACA,GAAA6C,KAAA,CAAAC,CAAA;QACAhB,OAAA,CAAAiB,KAAA,CAAAD,CAAA;QACA,KAAAE,QAAA,CAAAD,KAAA,CAAAD,CAAA,CAAAG,GAAA;MACA,GAAAC,OAAA;QACA,KAAA/C,SAAA;MACA;IACA;EACA;AACA;AAEA,MAAAoE,SAAA;EACA;IAAAC,KAAA;IAAAC,IAAA;IAAAC,IAAA;EAAA;EACA;IAAAF,KAAA;IAAAC,IAAA;IAAAC,IAAA;EAAA;EACA;IAAAF,KAAA;IAAAC,IAAA;IAAAC,IAAA;EAAA;AACA;AACA;AACA,SAAAC,WAAAC,UAAA;EACA,MAAAC,IAAA,OAAAC,IAAA,CAAAF,UAAA;EACA,IAAAG,KAAA,CAAAF,IAAA,CAAAG,OAAA;IACAlD,OAAA,CAAAiB,KAAA,kBAAA6B,UAAA;IACA;EACA;EACA,MAAAK,IAAA,GAAAJ,IAAA,CAAAK,WAAA;EACA,MAAAC,KAAA,GAAAC,MAAA,CAAAP,IAAA,CAAAQ,QAAA,QAAAC,QAAA;EACA,MAAAC,GAAA,GAAAH,MAAA,CAAAP,IAAA,CAAAW,OAAA,IAAAF,QAAA;EACA,UAAAL,IAAA,IAAAE,KAAA,IAAAI,GAAA;AACA;AACA,SAAA5E,mBAAA8E,CAAA;EACA,QACA;IAAA1F,KAAA;IAAA2F,SAAA;EAAA,GACA;IAAA3F,KAAA;IAAA2F,SAAA;EAAA,GACA;IAAA3F,KAAA;IAAA2F,SAAA;EAAA,GACA;IAAA3F,KAAA;IAAA2F,SAAA;EAAA,GACA;IACA3F,KAAA;IACA2F,SAAA;IACAC,YAAA,EAAAA,CAAAjB,IAAA,EAAAkB,MAAA;MACA;MACA,OAAAlB,IAAA,GAAAA,IAAA;IACA;EACA,GACA;IACA3E,KAAA;IACA2F,SAAA;IACAC,YAAA,EAAAA,CAAAjB,IAAA,EAAAkB,MAAA;MACA;MACA,OAAAlB,IAAA,GAAAA,IAAA;IACA;EACA,GACA;IACA3E,KAAA;IACA2F,SAAA;IACAC,YAAA,EAAAA,CAAAjB,IAAA,EAAAkB,MAAA;MACA;MACA,IAAAlB,IAAA;QACA,OAAAe,CAAA;UAAA;YAAA,OAAAf;UAAA;UAAA;YAAAmB,KAAA;YAAAC,MAAA;UAAA;QAAA;MACA;QACA;MACA;IACA;EACA,GACA;IAAA/F,KAAA;IAAA2F,SAAA;EAAA,GACA;IAAA3F,KAAA;IACA2F,SAAA;IACAC,YAAA,EAAAA,CAAAjB,IAAA,EAAAkB,MAAA,KAAAjB,UAAA,CAAAiB,MAAA,CAAAG,gBAAA;EACA,GACA;IACAhG,KAAA;IACAiG,KAAA;IACAC,WAAA;MACAN,YAAA;IACA;EACA,EACA;AACA;AAEA,SAAArB,YAAAtE,IAAA;EACA,MAAAkG,MAAA,GAAAvF,kBAAA,GAAAwF,GAAA,CAAAC,CAAA,IAAAA,CAAA,CAAArG,KAAA;EACAmG,MAAA,CAAAG,GAAA;EACA,OAAA5G,UAAA;IACAG,IAAA;IACAI,IAAA;IACAkG,MAAA;IACAI,MAAA;MACAC,aAAA;MACA9D,SAAA;MACA+D,YAAA;MACAC,eAAA;MACA7C,UAAA;MACA6C,eAAA;MACAC,kBAAA,SAAArD,MAAA;QAAA,IAAAsD,qBAAA;QAAA,QAAAA,qBAAA,GAAApC,SAAA,CAAAmC,kBAAA,eAAAC,qBAAA,uBAAAA,qBAAA,CAAAjC,IAAA;MAAA;MACAqB,gBAAA;IACA;EACA;AACA;AAEA,SAAAhF,oBAAA;EACA,QACA;IACA6F,KAAA;IACAC,GAAA;IACAC,OAAA;IACAC,SAAA;IACAf,KAAA;EACA,GACA;IACAY,KAAA;IACAC,GAAA;IACAC,OAAA;IACAC,SAAA;IACAf,KAAA;EACA,GACA;IACAY,KAAA;IACAC,GAAA;IACAC,OAAA;IACAC,SAAA;IACAf,KAAA;EACA,GACA;IACAY,KAAA;IACAC,GAAA;IACAC,OAAA,EAAAE,SAAA;IACAD,SAAA;IACAf,KAAA;IACAiB,KAAA;MACAC,OAAA,GACA;QAAAN,KAAA;QAAAO,KAAA;MAAA,GACA;QAAAP,KAAA;QAAAO,KAAA;MAAA,GACA;QAAAP,KAAA;QAAAO,KAAA;MAAA;IAEA;EACA,EACA;AACA","ignoreList":[]}]}