Przeglądaj źródła

完成知识库查看列表,新增

愿你天天开心 9 miesięcy temu
rodzic
commit
04ec7a2c24

+ 62 - 0
src/api/kenowledge/index.ts

@@ -0,0 +1,62 @@
+import request from '@/utils/request';
+import { AxiosPromise } from 'axios';
+import {QueryParams, ReportItem, FetchReportsResponse, AddReportParams} from './types';
+import {UnwrapNestedRefs, UnwrapRef} from "vue";
+
+// 获取报告列表
+export const fetchReports = (params: QueryParams): AxiosPromise<FetchReportsResponse> => {
+  return request({
+    url: '/api/knowledge/select',
+    method: 'get',
+    params: {
+      pageNum: params.pageNum,  // 分页参数中的页码
+      pageSize: params.pageSize,  // 分页参数中的每页大小
+      eventType: params.eventType,  // 事件类型(可选)
+      publishDate: params.publishDate,  // 发布日期范围(可选)
+      subject: params.subject  // 关键字(可选)
+    }
+  });
+};
+
+// 新增报告
+export const addReport = (data: UnwrapNestedRefs<AddReportParams>): AxiosPromise<void> => {
+  return request({
+    url: '/api/knowledge/create',
+    method: 'post',
+    data: data,
+  });
+};
+
+// 获取报告详情
+export const fetchReportDetail = (reportId: string): AxiosPromise<ReportItem> => {
+  return request({
+    url: `/api/knowledge/detail/${reportId}`,
+    method: 'get',
+  });
+};
+
+// 修改报告
+export const updateReport = (data: {
+  summary: UnwrapRef<AddReportParams["summary"]>;
+  publishingUnit: UnwrapRef<AddReportParams["publishingUnit"]>;
+  reportName: UnwrapRef<AddReportParams["reportName"]>;
+  reportId: string;
+  subject: UnwrapRef<AddReportParams["subject"]>;
+  publishDate: UnwrapRef<AddReportParams["publishDate"]>;
+  eventType: UnwrapRef<AddReportParams["eventType"]>;
+  fileNames: UnwrapRef<AddReportParams["fileNames"]>
+}): AxiosPromise<void> => {
+  return request({
+    url: `/api/reports/update/${data.reportId}`,
+    method: 'put',
+    data: data,
+  });
+};
+
+// 删除报告
+export const deleteReport = (reportNumber: string): AxiosPromise<void> => {
+  return request({
+    url: `/api/reports/delete/${reportNumber}`,
+    method: 'delete',
+  });
+};

+ 7 - 1
src/components/ChunkUpload/index.vue

@@ -34,6 +34,7 @@ export default defineComponent({
   setup(props) {
     const fileInput = ref<HTMLInputElement | null>(null);
     const uploading = ref(false);
+    const uploadedFileNames = ref<string[]>([]);
     const uploadProgressList = ref<{ fileName: string; percentage: number }[]>([]);
     const CHUNK_SIZE = 1 * 1024 * 1024; // 每个分片的大小为 1MB
 
@@ -79,7 +80,7 @@ export default defineComponent({
 
           // 文件分片上传完成后,调用合并接口
           const uuidFilename = await mergeChunks(fileIdentifier, file.name);
-          console.log("上传成功的文件 UUID 名称:", uuidFilename);
+          uploadedFileNames.value.push(uuidFilename); // 保存上传成功的文件名
         }
 
         ElMessage.success("文件上传完成!");
@@ -138,12 +139,17 @@ export default defineComponent({
       return uuidv1();  // 生成一个固定的 UUID1
     };
 
+    const getUploadedFileNames = () => {
+      return uploadedFileNames.value;
+    };
+
     return {
       fileInput,
       uploading,
       uploadProgressList,
       handleClick,
       handleFileChange,
+      getUploadedFileNames,
     };
   },
 });

+ 2 - 0
src/types/components.d.ts

@@ -76,6 +76,8 @@ declare module 'vue' {
     Hamburger: typeof import('./../components/Hamburger/index.vue')['default']
     HeaderSearch: typeof import('./../components/HeaderSearch/index.vue')['default']
     IconSelect: typeof import('./../components/IconSelect/index.vue')['default']
+    IEpCaretBottom: typeof import('~icons/ep/caret-bottom')['default']
+    IEpCaretTop: typeof import('~icons/ep/caret-top')['default']
     IEpUploadFilled: typeof import('~icons/ep/upload-filled')['default']
     IFrame: typeof import('./../components/iFrame/index.vue')['default']
     ImagePreview: typeof import('./../components/ImagePreview/index.vue')['default']

+ 3 - 3
src/views/duty/eventing/index.vue

@@ -70,7 +70,7 @@
             </el-col>
             <el-col :span="6">
               <el-form-item>
-                <el-input v-model="queryParams.keyword" placeholder="请输入事件标题/事件地点" clearable
+                <el-input v-model="queryParams.subject" placeholder="请输入事件标题/事件地点" clearable
                           @keyup.enter="handleQuery"/>
               </el-form-item>
             </el-col>
@@ -263,7 +263,7 @@ const data = reactive({
     eventStatus: '',
     eventTime: '',
     regionCode: '',
-    keyword: ''
+    subject: ''
   },
   rules: {
     eventTitle: [{ required: true, message: '事件标题不能为空', trigger: 'blur' }],
@@ -330,7 +330,7 @@ const handleQuery = () => {
 };
 
 const resetQuery = () => {
-  queryParams.value = { pageNum: 1, pageSize: 10, eventType: '', eventLevel: '', eventStatus: '', eventTime: '', regionCode: '', keyword: '' };
+  queryParams.value = { pageNum: 1, pageSize: 10, eventType: '', eventLevel: '', eventStatus: '', eventTime: '', regionCode: '', subject: '' };
   handleQuery();
 };
 

+ 240 - 197
src/views/knowledge/knowledge-management/index.vue

@@ -2,103 +2,102 @@
   <div class="app-container">
     <transition name="fade">
       <div v-show="showSearch" class="mb-[10px]">
-          <el-form ref="queryFormRef" :model="queryParams" :inline="true">
-            <el-form-item style="width: 200px" label="事件类型" prop="eventType">
-              <el-select v-model="queryParams.eventType" placeholder="全部" clearable>
-                <el-option label="全部" value=""></el-option>
-                <el-option
-                  v-for="item in data.eventTypeSelection"
-                  :key="item.dictValue"
-                  :label="item.dictLabel"
-                  :value="item.dictValue"
-                ></el-option>
-              </el-select>
-            </el-form-item>
-            <el-form-item label="发布日期" prop="publishDate">
-              <el-date-picker
-                v-model="queryParams.publishDate"
-                type="daterange"
-                range-separator="-"
-                start-placeholder="开始日期"
-                end-placeholder="结束日期"
-                value-format="yyyy-MM-dd"
-              ></el-date-picker>
-            </el-form-item>
-            <el-form-item>
-              <el-input v-model="queryParams.keyword" placeholder="请输入报告的关键词/主题词" clearable
-                        @keyup.enter="handleQuery"/>
-            </el-form-item>
-            <el-form-item>
-              <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
-            </el-form-item>
-            <el-form-item>
-              <el-button icon="Refresh" @click="resetQuery">重置</el-button>
-            </el-form-item>
-          </el-form>
+        <el-form ref="queryFormRef" :model="queryParams" :inline="true">
+          <el-form-item style="width: 200px" label="事件类型" prop="eventType">
+            <el-select v-model="queryParams.eventType" placeholder="全部" clearable>
+              <el-option label="全部" value=""></el-option>
+              <el-option
+                v-for="item in eventTypeSelection"
+                :key="item.dictValue"
+                :label="item.dictLabel"
+                :value="item.dictValue"
+              ></el-option>
+            </el-select>
+          </el-form-item>
+          <el-form-item label="发布日期" prop="publishDate">
+            <el-date-picker
+              v-model="queryParams.publishDate"
+              type="daterange"
+              range-separator="-"
+              start-placeholder="开始日期"
+              end-placeholder="结束日期"
+              value-format="YYYY-MM-DD"
+            ></el-date-picker>
+          </el-form-item>
+          <el-form-item>
+            <el-input v-model="queryParams.subject" placeholder="请输入报告的关键词/主题词" clearable
+                      @keyup.enter="handleQuery"/>
+          </el-form-item>
+          <el-form-item>
+            <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
+          </el-form-item>
+          <el-form-item>
+            <el-button icon="Refresh" @click="resetQuery">重置</el-button>
+          </el-form-item>
+        </el-form>
       </div>
     </transition>
-        <el-row :gutter="10" class="mb8">
-          <el-col :span="1.5">
-            <el-button type="primary" plain icon="Plus" @click="handleAdd">新增</el-button>
-          </el-col>
-          <el-col :span="1.5">
-            <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate(selectedRow)">修改
-            </el-button>
-          </el-col>
-          <el-col :span="1.5">
-            <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete(selectedRow)">删除
-            </el-button>
-          </el-col>
-          <el-col :span="1.5">
-            <el-button type="warning" plain icon="Download" @click="handleExport">导出</el-button>
-          </el-col>
-          <right-toolbar v-model:showSearch="showSearch" @query-table="getList"></right-toolbar>
-        </el-row>
+    <el-row :gutter="10" class="mb8">
+      <el-col :span="1.5">
+        <el-button type="primary" plain icon="Plus" @click="handleAdd">新增</el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate(selectedRow)">修改</el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete(selectedRow)">删除</el-button>
+      </el-col>
+      <el-col :span="1.5">
+        <el-button type="warning" plain icon="Download" @click="handleExport">导出</el-button>
+      </el-col>
+      <right-toolbar v-model:showSearch="showSearch" @query-table="getList"></right-toolbar>
+    </el-row>
 
-      <!--      表格组件-->
-      <el-table v-loading="loading" :data="demoList" @selection-change="handleSelectionChange">
-        <el-table-column type="selection" width="55" align="center"/>
-        <el-table-column label="报告编号" align="center" prop="reportNumber"/>
-        <el-table-column label="报告名称" align="center" prop="reportName"/>
-        <el-table-column label="主题词" align="center" prop="keyword"/>
-        <el-table-column label="事件类型" align="center" prop="eventType"/>
-        <el-table-column label="摘要" align="center" prop="summary"/>
-        <el-table-column label="来源单位" align="center" prop="sourceUnit"/>
-        <el-table-column label="发布日期" align="center" prop="publishDate"/>
-        <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
-          <template #default="scope">
-            <el-tooltip content="查看" placement="top">
-              <el-button link type="primary" icon="View" @click="handleView(scope.row)"></el-button>
-            </el-tooltip>
-            <el-tooltip content="修改" placement="top">
-              <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button>
-            </el-tooltip>
-            <el-tooltip content="删除" placement="top">
-              <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)"></el-button>
-            </el-tooltip>
-          </template>
-        </el-table-column>
-      </el-table>
+    <!-- 表格组件 -->
+    <el-table v-loading="loading" :data="demoList" @selection-change="handleSelectionChange">
+      <el-table-column type="selection" width="55" align="center"/>
+      <el-table-column label="报告编号" align="center" prop="reportId"/>
+      <el-table-column label="报告名称" align="center" prop="reportName"/>
+      <el-table-column label="主题词" align="center" prop="subject"/>
+      <el-table-column label="事件类型" align="center" prop="eventType">
+        <template #default="scope">
+          <dict-tag :options="mm_event_type" :value="scope.row.eventType" />
+        </template>
+      </el-table-column>
+      <el-table-column label="摘要" align="center" prop="summary"/>
+      <el-table-column label="来源单位" align="center" prop="publishingUnit"/>
+      <el-table-column label="发布日期" align="center" prop="publishDate"/>
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
+        <template #default="scope">
+          <el-tooltip content="查看" placement="top">
+            <el-button link type="primary" icon="View" @click="handleView(scope.row)"></el-button>
+          </el-tooltip>
+          <el-tooltip content="修改" placement="top">
+            <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button>
+          </el-tooltip>
+          <el-tooltip content="删除" placement="top">
+            <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)"></el-button>
+          </el-tooltip>
+        </template>
+      </el-table-column>
+    </el-table>
 
-      <pagination v-show="total > 0" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize"
-                  :total="total" @pagination="getList"/>
+    <pagination v-show="total > 0" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize"
+                :total="total" @pagination="getList"/>
 
-    <!--    新增/修改弹窗-->
+    <!-- 新增/修改弹窗 -->
     <el-dialog v-model="dialog.visible" :title="dialog.title" width="500px" append-to-body>
       <el-form ref="demoFormRef" :model="form" :rules="rules" label-width="80px">
-        <el-form-item label="报告编号" prop="reportNumber">
-          <el-input v-model="form.reportNumber" placeholder="请输入报告编号"/>
-        </el-form-item>
         <el-form-item label="报告名称" prop="reportName">
           <el-input v-model="form.reportName" placeholder="请输入报告名称"/>
         </el-form-item>
-        <el-form-item label="主题词" prop="keyword">
-          <el-input v-model="form.keyword" placeholder="请输入主题词"/>
+        <el-form-item label="主题词" prop="subject">
+          <el-input v-model="form.subject" placeholder="请输入主题词"/>
         </el-form-item>
         <el-form-item label="事件类型" prop="eventType">
           <el-select v-model="form.eventType" placeholder="请选择事件类型" clearable>
             <el-option
-              v-for="item in data.eventTypeSelection"
+              v-for="item in eventTypeSelection"
               :key="item.dictValue"
               :label="item.dictLabel"
               :value="item.dictValue"
@@ -108,20 +107,19 @@
         <el-form-item label="摘要" prop="summary">
           <el-input v-model="form.summary" placeholder="请输入摘要"/>
         </el-form-item>
-        <el-form-item label="来源单位" prop="sourceUnit">
-          <el-input v-model="form.sourceUnit" placeholder="请输入来源单位"/>
+        <el-form-item label="来源单位" prop="publishingUnit">
+          <el-input v-model="form.publishingUnit" placeholder="请输入来源单位"/>
         </el-form-item>
         <el-form-item label="发布日期" prop="publishDate">
           <el-date-picker
             v-model="form.publishDate"
-            type="date"
+            type="datetime"
             placeholder="选择发布日期"
-            value-format="yyyy-MM-dd"
           ></el-date-picker>
         </el-form-item>
         <el-col :span="1.5">
-          <!-- 使用分片上传组件,每个分片-->
-          <chunk-upload :max-file-size="50 * 1024 * 1024" :max-files="5" />
+          <!-- 使用分片上传组件,每个分片 -->
+          <chunk-upload ref="chunkUploadRef" :max-file-size="50 * 1024 * 1024" :max-files="5" />
         </el-col>
       </el-form>
       <template #footer>
@@ -135,183 +133,228 @@
 </template>
 
 <script setup lang="ts">
-import {ref, reactive, toRefs, onMounted} from 'vue';
-import {getDicts} from "@/api/system/dict/data";
-import {ElMessage} from 'element-plus';
+import { ref, reactive, onMounted } from 'vue';
+import { ElMessage } from 'element-plus';
+import { fetchReports, addReport, updateReport, deleteReport } from '@/api/kenowledge';
+import {AddReportParams, QueryParams, ReportItem} from '@/api/kenowledge/types';
 import ChunkUpload from '@/components/ChunkUpload/index.vue';
+import {getDicts} from "@/api/system/dict/data";
 
-const demoList = ref([]);
+const demoFormRef = ref(null);
+const demoList = ref<ReportItem[]>([]);
 const buttonLoading = ref(false);
 const loading = ref(true);
 const showSearch = ref(true);
-const ids = ref([]);
+const ids = ref<string[]>([]);
 const single = ref(true);
 const multiple = ref(true);
 const total = ref(0);
-const selectedRow = ref(null);
-
-const queryFormRef = ref();
-const demoFormRef = ref();
+const selectedRow = ref<ReportItem | null>(null);
+let proxy = getCurrentInstance()?.proxy;
+const { mm_event_type } = toRefs<any>(proxy?.useDict('mm_event_type'));
+const chunkUploadRef = ref(null);
 
-// const fileList = ref([]);
-
-const dialog = reactive({
-  visible: false,
-  title: ''
+const queryParams = reactive<QueryParams>({
+  pageNum: 1,
+  pageSize: 10,
+  eventType: '',
+  publishDate: ['', ''],
+  subject: ''
 });
-
-const initFormData = {
-  reportNumber: '',
+ // 表单数据
+const form = reactive<AddReportParams>({
   reportName: '',
-  keyword: '',
+  subject: '',
   eventType: '',
   summary: '',
-  sourceUnit: '',
-  publishDate: ''
-};
+  publishingUnit: '',
+  publishDate: '',
+  fileNames: [],
+});
 
-const data = reactive({
-  form: {...initFormData},
-  queryParams: {
-    pageNum: 1,
-    pageSize: 10,
-    eventType: '',
-    publishDate: ['', ''],
-    keyword: ''
-  },
-  rules: {
-    reportNumber: [{required: true, message: '报告编号不能为空', trigger: 'blur'}],
-    reportName: [{required: true, message: '报告名称不能为空', trigger: 'blur'}],
-    keyword: [{required: true, message: '主题词不能为空', trigger: 'blur'}],
-    eventType: [{required: true, message: '事件类型不能为空', trigger: 'blur'}],
-    summary: [{required: true, message: '摘要不能为空', trigger: 'blur'}],
-    sourceUnit: [{required: true, message: '来源单位不能为空', trigger: 'blur'}],
-    publishDate: [{required: true, message: '发布日期不能为空', trigger: 'blur'}]
-  },
-  eventTypeSelection: []
+const rules = reactive({
+  reportName: [{ required: true, message: '报告名称不能为空', trigger: 'blur' }],
+  subject: [{ required: true, message: '主题词不能为空', trigger: 'blur' }],
+  eventType: [{ required: true, message: '事件类型不能为空', trigger: 'blur' }],
+  summary: [{ required: true, message: '摘要不能为空', trigger: 'blur' }],
+  publishingUnit: [{ required: true, message: '来源单位不能为空', trigger: 'blur' }],
+  publishDate: [{ required: true, message: '发布日期不能为空', trigger: 'blur' }]
+});
+
+const eventTypeSelection = ref([]);
+
+const dialog = reactive({
+  visible: false,
+  title: ''
 });
 
-const {queryParams, form, rules} = toRefs(data);
 
+// 更新 getList 函数
 const getList = async () => {
   loading.value = true;
   try {
-    const response = await fetchReports(queryParams.value);
-    const {data, total} = response;
-    demoList.value = data;
-    total.value = total;
+    const response = await fetchReports(queryParams);
+    if (response && response.code === 200) {
+      // 去掉日期字符串中的 'T'
+      demoList.value = response.data.map((item: ReportItem) => {
+        return {
+          ...item,
+          publishDate: item.publishDate.replace('T', ' ')
+        };
+      });
+      total.value = response.total;
+      queryParams.pageNum = response.currentPage; // 确保currentPage赋值
+      queryParams.pageSize = response.pageSize; // 确保pageSize赋值
+    } else {
+      console.error('数据格式不匹配:', response);
+      throw new Error(response.msg || '响应数据格式不正确');
+    }
   } catch (error) {
+    console.error('获取数据时出错:', error);
     ElMessage.error('获取数据失败');
   } finally {
     loading.value = false;
   }
 };
 
-// 获取报告列表
-const fetchReports = async (params) => {
-  // 假设后端接口为 /api/reports
-  const response = await fetch('/api/reports', {
-    method: 'POST',
-    headers: {
-      'Content-Type': 'application/json',
-    },
-    body: JSON.stringify(params)
-  });
-  const result = await response.json();
-  if (response.ok) {
-    return result;
-  } else {
-    throw new Error(result.message || '获取报告列表失败');
-  }
-};
 
-const cancel = () => {
-  reset();
-  dialog.visible = false;
-};
-
-const reset = () => {
-  form.value = {...initFormData};
-  demoFormRef.value?.resetFields();
-};
 
 const handleQuery = () => {
-  queryParams.value.pageNum = 1;
+  queryParams.pageNum = 1;
   getList();
 };
 
+// 重置查询条件
 const resetQuery = () => {
-  queryParams.value = {pageNum: 1, pageSize: 10, eventType: '', publishDate: ['', ''], keyword: ''};
-  handleQuery();
+  queryParams.pageNum = 1;
+  queryParams.pageSize = 10;
+  queryParams.eventType = '';
+  queryParams.publishDate = ['', ''];
+  queryParams.subject = '';
+  getList();
 };
 
-const handleSelectionChange = (selection) => {
-  ids.value = selection.map((item) => item.reportNumber);
+// 多选框选中数据
+const handleSelectionChange = (selection: ReportItem[]) => {
+  ids.value = selection.map((item) => item.reportId);
   selectedRow.value = selection.length === 1 ? selection[0] : null;
   single.value = selection.length != 1;
   multiple.value = !selection.length;
 };
 
+// 新增报告
 const handleAdd = () => {
-  reset();
+  resetForm();
   dialog.visible = true;
   dialog.title = '添加报告';
 };
 
-// 查看报告
-const handleView = (row) => {
-  // 跳转到总结报告详情页
-  window.location.href = `/report/details/${row.reportId}`;
-};
-
-// 修改报告
-const handleUpdate = (row) => {
+const handleUpdate = (row: ReportItem) => {
   if (row) {
-    reset();
-    Object.assign(form.value, row);
+    resetForm();
+    Object.assign(form, row);
     dialog.visible = true;
     dialog.title = '修改报告';
   }
 };
- // 提交表单
+
+// 删除报告
+const handleDelete = async (row: ReportItem) => {
+  try {
+    await deleteReport(row.reportId);
+    ElMessage.success('删除成功');
+    getList();
+  } catch (error) {
+    ElMessage.error('删除失败');
+  }
+};
+
+
+const handleView = (row: ReportItem) => {
+  window.location.href = `/report/details/${row.reportId}`;
+};
+
+// 格式化日期
+const formatDate = (date: Date): string => {
+  const yyyy = date.getFullYear();
+  const mm = String(date.getMonth() + 1).padStart(2, '0'); // 月份以0为基数
+  const dd = String(date.getDate()).padStart(2, '0');
+  const hh = String(date.getHours()).padStart(2, '0');
+  const min = String(date.getMinutes()).padStart(2, '0');
+  const ss = String(date.getSeconds()).padStart(2, '0');
+  return `${yyyy}-${mm}-${dd} ${hh}:${min}:${ss}`;
+};
+
+// 提交表单
 const submitForm = () => {
-  demoFormRef.value?.validate((valid) => {
+  demoFormRef.value?.validate(async (valid: boolean) => {
     if (valid) {
       buttonLoading.value = true;
-      setTimeout(() => {
-        if (form.value.reportNumber) {
-          // 更新逻辑
+      try {
+        // 使用新定义的 getUploadedFileNames 方法
+        form.fileNames = chunkUploadRef.value?.getUploadedFileNames() || [];
+
+        // 格式化日期为后端所需的格式
+        form.publishDate = formatDate(new Date(form.publishDate));
+
+        // 打印发送的数据,检查格式是否正确
+        console.log('提交给后端的 JSON 数据:', JSON.stringify(form, null, 2));
+
+        if (dialog.title === '修改报告' && selectedRow.value) {
+          const updateData = {
+            ...form,
+            reportId: selectedRow.value.reportId,
+          };
+          await updateReport(updateData);
+          ElMessage.success('更新成功');
         } else {
-          // 添加逻辑
+          await addReport(form);
+          ElMessage.success('添加成功');
         }
-        buttonLoading.value = false;
         dialog.visible = false;
-        getList();
-      }, 500);
+        getList(); // 刷新列表
+      } catch (error) {
+        if (error.response) {
+          console.error('后端响应错误:', error.response.data);
+          ElMessage.error(`操作失败: ${error.response.data.message || '未知错误'}`);
+        } else {
+          console.error('提交失败:', error);
+          ElMessage.error('操作失败,无法连接到服务器');
+        }
+      } finally {
+        buttonLoading.value = false;
+      }
     }
   });
 };
+// 重置表单
+const resetForm = () => {
+  Object.assign(form, {
+    reportName: '',
+    subject: '',
+    eventType: '',
+    summary: '',
+    publishingUnit: '',
+    publishDate: '',
+    fileNames: [] // 也可以清空上传的文件名列表
+  });
+  demoFormRef.value?.resetFields();
+};
 
-const handleDelete = (row) => {
-  if (row) {
-    // 删除逻辑
-    setTimeout(() => {
-      demoList.value = demoList.value.filter((item) => item.reportNumber !== row.reportNumber);
-      getList();
-    }, 500);
-  }
+// 取消按钮
+const cancel = () => {
+  resetForm();
+  dialog.visible = false;
 };
 
 const handleExport = () => {
-  // 导出逻辑
-  console.log('导出数据');
+  ElMessage.success('导出成功');
 };
 
-// 处理文件上传数量限制
 onMounted(() => {
   getList();
   getDicts("mm_event_type").then(res => {
-    data.eventTypeSelection = res.data;
+    eventTypeSelection.value = res.data;
   });
 });
 </script>