WXL (wul)
昨天 feb5a669dced68415bc7e32f237f77bf9842fe8b
src/views/sfstatistics/percentage/components/SecondFollowUp.vue
@@ -253,7 +253,6 @@
                  prop="followUpRateAgain"
                />
                <el-table-column
                  v-if="orgname != '丽水市中医院'"
                  label="人工"
                  align="center"
                  key="manualAgain"
@@ -277,7 +276,6 @@
                  </template>
                </el-table-column>
                <el-table-column
                  v-if="orgname != '丽水市中医院'"
                  label="语音"
                  align="center"
                  key="voiceAgain"
@@ -301,7 +299,6 @@
                  </template>
                </el-table-column>
                <el-table-column
                  v-if="orgname != '丽水市中医院'"
                  label="短信"
                  align="center"
                  key="smsAgain"
@@ -325,7 +322,6 @@
                  </template>
                </el-table-column>
                <el-table-column
                  v-if="orgname != '丽水市中医院'"
                  label="微信"
                  align="center"
                  key="weChatAgain"
@@ -552,7 +548,6 @@
            prop="followUpRateAgain"
          />
          <el-table-column
            v-if="orgname != '丽水市中医院'"
            label="人工"
            align="center"
            key="manualAgain"
@@ -575,7 +570,6 @@
            </template>
          </el-table-column>
          <el-table-column
            v-if="orgname != '丽水市中医院'"
            label="语音"
            align="center"
            key="voiceAgain"
@@ -594,7 +588,6 @@
            </template>
          </el-table-column>
          <el-table-column
            v-if="orgname != '丽水市中医院'"
            label="短信"
            align="center"
            key="smsAgain"
@@ -617,7 +610,6 @@
            </template>
          </el-table-column>
          <el-table-column
            v-if="orgname != '丽水市中医院'"
            label="微信"
            align="center"
            key="weChatAgain"
@@ -649,6 +641,7 @@
import { getSfStatistics } from "@/api/system/user";
import ExcelJS from "exceljs";
import { saveAs } from "file-saver";
import store from "@/store";
export default {
  name: "SecondFollowUp",
@@ -680,6 +673,7 @@
      loading: false,
      expands: [],
      ids: [],
      tasktypes: store.getters.tasktypes,
    };
  },
  methods: {
@@ -1117,12 +1111,30 @@
        let dateRangeString = "";
        let sheetNameSuffix = "";
    // 判断是否是丽水市中医院
    const isLishuiHospital = this.orgname == "丽水市中医院";
        if (
          this.queryParams.dateRange &&
          this.queryParams.dateRange.length === 2
        ) {
          const startDateStr = this.queryParams.dateRange[0];
          const endDateStr = this.queryParams.dateRange[1];
      if (isLishuiHospital) {
        // 丽水市中医院:只显示年月
        const formatMonthOnly = (dateTimeStr) => {
          const date = new Date(dateTimeStr);
          const year = date.getFullYear();
          const month = date.getMonth() + 1;
          return `${year}年${month}月`;
        };
        const startDateFormatted = formatMonthOnly(startDateStr);
        const endDateFormatted = formatMonthOnly(endDateStr);
        dateRangeString = `${startDateFormatted}至${endDateFormatted}`;
        sheetNameSuffix = `${startDateFormatted}至${endDateFormatted}`;
      } else {
        // 其他医院:显示年月日
          const formatDateForDisplay = (dateTimeStr) => {
            return dateTimeStr.split(" ")[0];
          };
@@ -1130,18 +1142,85 @@
          const endDateFormatted = formatDateForDisplay(endDateStr);
          dateRangeString = `${startDateFormatted}至${endDateFormatted}`;
          sheetNameSuffix = `${startDateFormatted}至${endDateFormatted}`;
      }
        } else {
          const now = new Date();
          const currentMonth = now.getMonth() + 1;
      const currentYear = now.getFullYear();
      if (isLishuiHospital) {
        // 丽水市中医院:显示年月
        dateRangeString = `${currentYear}年${currentMonth}月`;
        sheetNameSuffix = `${currentYear}年${currentMonth}月`;
      } else {
        // 其他医院:显示月份
          dateRangeString = `${currentMonth}月`;
          sheetNameSuffix = `${currentMonth}月`;
        }
    }
        const excelName = `再次出院随访统计表_${dateRangeString}.xlsx`;
        const worksheetName = `再次随访统计_${sheetNameSuffix}`;
    // 根据 serviceType 生成随访类型名称
    let serviceTypeName = "出院随访"; // 文件名使用的名称
    let sheetTypeName = "再次随访"; // 工作表使用的名称(简化版)
    console.log(this.queryParams.serviceType);
    if (
      this.queryParams.serviceType &&
      Array.isArray(this.queryParams.serviceType) &&
      this.queryParams.serviceType.length > 0
    ) {
      if (this.tasktypes && Array.isArray(this.tasktypes)) {
        // 过滤出匹配的随访类型
        const matchedTypes = this.tasktypes.filter((task) =>
          this.queryParams.serviceType.includes(task.value)
        );
        if (matchedTypes.length === 1) {
          // 单个类型
          const label = matchedTypes[0].label;
          serviceTypeName = label;
          sheetTypeName = label;
        } else if (matchedTypes.length > 1) {
          // 多个类型
          const typeNames = matchedTypes.map((task) => task.label);
          // 文件名:用斜杠分隔
          serviceTypeName = typeNames.join("/");
          // 工作表名:使用第一个类型或简化名称
          if (matchedTypes.length <= 2) {
            // 如果只有2个类型,都显示
            sheetTypeName = `${typeNames[0]}等`;
          } else {
            // 如果超过2个类型,只显示第一个
            sheetTypeName = `${typeNames[0]}等`;
          }
        } else if (this.queryParams.serviceType.length > 0) {
          // 如果没有匹配的,使用原始值
          const typeStr = this.queryParams.serviceType.join("/");
          serviceTypeName = typeStr;
          sheetTypeName = "再次随访";
        }
      } else if (this.queryParams.serviceType.length > 0) {
        // 如果没有 tasktypes,使用原始值
        const typeStr = this.queryParams.serviceType.join("/");
        serviceTypeName = typeStr;
        sheetTypeName = "再次随访";
      }
    }
    const excelName = `再次${serviceTypeName}统计表_${dateRangeString}.xlsx`;
    // 清理工作表名称,移除非法字符
    const cleanSheetName = (name) => {
      // Excel工作表名不能包含的字符: * ? : \ / [ ]
      return name.replace(/[*?:\\/[\]]/g, ' ');
    };
    const worksheetName = cleanSheetName(`再次${sheetTypeName}统计_${sheetNameSuffix}`);
        if (!this.tableData || this.tableData.length === 0) {
          this.$message.warning("暂无再次随访数据可导出");
      this.$message.warning(`暂无再次${serviceTypeName}数据可导出`);
          return false;
        }