eight
2024-11-07 9e188fa816e204f8a02d032e55e2bd63168a77ec
src/views/ecg/queue/index.vue
@@ -49,7 +49,7 @@
          class="!w-240px"
        >
          <el-option
            v-for="dict in getIntDictOptions(DICT_TYPE.ECG_CHECK_TYPE)"
            v-for="dict in checkTypeStore.getCheckTypeOptions()"
            :key="dict.value"
            :label="dict.label"
            :value="dict.value"
@@ -98,20 +98,10 @@
          class="!w-240px"
        />
      </el-form-item>
      <el-form-item label="创建时间" prop="createTime">
        <el-date-picker
          v-model="queryParams.createTime"
          value-format="YYYY-MM-DD HH:mm:ss"
          type="daterange"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          :default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
          class="!w-220px"
        />
      </el-form-item>
      <el-form-item>
        <el-button @click="handleQuery"><Icon icon="ep:search" class="mr-5px" /> 搜索</el-button>
        <el-button @click="resetQuery"><Icon icon="ep:refresh" class="mr-5px" /> 重置</el-button>
<!--
        <el-button
          type="primary"
          plain
@@ -120,6 +110,8 @@
        >
          <Icon icon="ep:plus" class="mr-5px" /> 新增
        </el-button>
-->
<!--
        <el-button
          type="success"
          plain
@@ -129,6 +121,7 @@
        >
          <Icon icon="ep:download" class="mr-5px" /> 导出
        </el-button>
-->
      </el-form-item>
    </el-form>
  </ContentWrap>
@@ -136,21 +129,27 @@
  <!-- 列表 -->
  <ContentWrap>
    <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
      <el-table-column label="id" align="center" prop="id" />
<!--      <el-table-column label="id" align="center" prop="id" />-->
      <el-table-column label="患者编号" align="center" prop="patId" />
      <el-table-column label="患者姓名" align="center" prop="patName" />
      <el-table-column label="患者性别" align="center" prop="patGender" />
      <el-table-column label="患者姓名" align="center" min-width="120px">
        <template #default="scope">
          {{scope.row.patName}} ({{genderFormat(scope.row.patGender)}})
        </template>
      </el-table-column>
      <el-table-column label="检查类型" align="center" prop="bookCheckType" >
        <template #default="scope">
          {{checkTypeStore.getCheckTypeName(scope.row.bookCheckType)}}
        </template>
      </el-table-column>
      <el-table-column label="患者详情" align="center" prop="patDetails" />
      <el-table-column label="预约时段" align="center" prop="bookTimeslot" >
        <template #default="scope">
          <dict-tag :type="DICT_TYPE.ECG_BOOK_TIMESLOT" :value="scope.row.bookTimeslot" />
        </template>
      </el-table-column>
      <el-table-column label="检查类型" align="center" prop="bookCheckType" >
        <template #default="scope">
          <dict-tag :type="DICT_TYPE.ECG_CHECK_TYPE" :value="scope.row.bookCheckType" />
        </template>
      </el-table-column>
        <el-table-column label="排队序号" align="center" prop="seqNum" />
      <el-table-column label="排队序号" align="center" prop="bookSeqNum" />
      <el-table-column label="排队序号" align="center" prop="seqNum" />
      <el-table-column label="VIP" align="center" prop="isVip" />
      <el-table-column label="状态" align="center" prop="status" >
        <template #default="scope">
          <dict-tag :type="DICT_TYPE.ECG_QUEUE_STATUS" :value="scope.row.status" />
@@ -173,11 +172,12 @@
          <el-button
            link
            type="primary"
            @click="openForm('update', scope.row.id)"
            v-hasPermi="['ecg:queue:update']"
            @click="openAppointmentForm('preview', scope.row.patId)"
            v-hasPermi="['ecg:appointment:preview']"
          >
            编辑
            查看
          </el-button>
<!--
          <el-button
            link
            type="danger"
@@ -186,6 +186,7 @@
          >
            删除
          </el-button>
-->
          <el-button
            link
            type="danger"
@@ -193,7 +194,16 @@
            v-if="scope.row.status === 10"
            v-hasPermi="['ecg:queue:jump']"
          >
            {{scope.row.jumpFlag === 0? "插队" : "取消插队"}}
            {{scope.row.jumpFlag === 0? "加急" : "取消加急"}}
          </el-button>
          <el-button
            link
            type="danger"
            @click="recall(scope.row)"
            v-if="scope.row.status === 5"
            v-hasPermi="['ecg:queue:recall']"
          >
            召回
          </el-button>
        </template>
      </el-table-column>
@@ -208,15 +218,21 @@
  </ContentWrap>
  <!-- 表单弹窗:添加/修改 -->
  <queueForm ref="formRef" @success="getList" />
  <!--  <queueForm ref="formRef" @success="getList" />-->
  <!-- 表单弹窗:添加/修改 -->
  <AppointmentForm ref="formRef" @event_appointment_success="getList" />
</template>
<script setup lang="ts">
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { queueApi, queueVO } from '@/api/ecg/queue'
import queueForm from './queueForm.vue'
import { QueueApi, QueueVO } from '@/api/ecg/queue'
import {DICT_TYPE, getIntDictOptions} from '@/utils/dict'
import {DoctorApi, PatientVO} from "@/api/ecg/doctor";
import {useCheckTypeStore} from "@/store/modules/checkType";
import AppointmentForm from "@/views/ecg/appointment/AppointmentForm.vue";
import {genderFormat} from "@/utils/stringUtil";
/** 排队 列表 */
defineOptions({ name: 'queue' })
@@ -224,8 +240,10 @@
const message = useMessage() // 消息弹窗
const { t } = useI18n() // 国际化
const checkTypeStore = useCheckTypeStore();
const loading = ref(true) // 列表的加载中
const list = ref<queueVO[]>([]) // 列表的数据
const list = ref<QueueVO[]>([]) // 列表的数据
const total = ref(0) // 列表的总页数
const queryParams = reactive({
  pageNo: 1,
@@ -233,6 +251,7 @@
  patId: undefined,
  patName: undefined,
  patGender: undefined,
  patDetails: undefined,
  bookTimeslot: undefined,
  bookCheckType: undefined,
  seqNum: undefined,
@@ -241,7 +260,6 @@
  expired: undefined,
  roomId: undefined,
  bedNo: undefined,
  createTime: []
})
const queryFormRef = ref() // 搜索的表单
const exportLoading = ref(false) // 导出的加载中
@@ -250,7 +268,7 @@
const getList = async () => {
  loading.value = true
  try {
    const data = await queueApi.getqueuePage(queryParams)
    const data = await QueueApi.getqueuePage(queryParams)
    list.value = data.list
    total.value = data.total
  } finally {
@@ -275,6 +293,9 @@
const openForm = (type: string, id?: number) => {
  formRef.value.open(type, id)
}
const openAppointmentForm = (type: string, patId: string, status: number) => {
  formRef.value.openByQueue(type, patId, status)
}
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
@@ -282,7 +303,7 @@
    // 删除的二次确认
    await message.delConfirm()
    // 发起删除
    await queueApi.deletequeue(id)
    await QueueApi.deletequeue(id)
    message.success(t('common.delSuccess'))
    // 刷新列表
    await getList()
@@ -290,18 +311,32 @@
}
/** 插队按钮操作 */
const handleJump = async (item: queueVO ) => {
const handleJump = async (item: QueueVO ) => {
  try {
    if (item.jumpFlag === 0)
      item.jumpFlag = 1
    else
      item.jumpFlag = 0
    const data = await queueApi.jumpQueue(item)
    const data = await QueueApi.jumpQueue(item)
    message.success(data)
    // 刷新列表
    await getList()
  } catch {}
}
const recall = async (item: QueueVO) => {
  const patientVO: PatientVO = {
    roomId: item.roomId,
    bedNo: item.bedNo,
    patId: item.patId,
    jumpFlag: 0
  }
  const data = await DoctorApi.recallPatient(patientVO);
  message.info(data)
  // 刷新列表
  await getList()
}
/** 导出按钮操作 */
@@ -311,7 +346,7 @@
    await message.exportConfirm()
    // 发起导出
    exportLoading.value = true
    const data = await queueApi.exportqueue(queryParams)
    const data = await QueueApi.exportqueue(queryParams)
    download.excel(data, '排队.xls')
  } catch {
  } finally {