|
@@ -4,14 +4,14 @@
|
|
<div v-show="showSearch" class="mb-[10px]">
|
|
<div v-show="showSearch" class="mb-[10px]">
|
|
<el-card shadow="hover">
|
|
<el-card shadow="hover">
|
|
<el-form ref="queryFormRef" :model="queryParams" :inline="true" :label-width="85">
|
|
<el-form ref="queryFormRef" :model="queryParams" :inline="true" :label-width="85">
|
|
- <el-form-item label="开单时间:" prop="orderTimeRange">
|
|
|
|
- <el-date-picker clearable v-model="queryParams.orderTimeRange" type="date" value-format="YYYY-MM-DD" placeholder="请选择开单时间" />
|
|
|
|
|
|
+ <el-form-item label="开单时间:" prop="orderTime">
|
|
|
|
+ <el-date-picker v-model="orderTime" value-format="YYYY-MM-DD HH:mm:ss" type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]"></el-date-picker>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
- <el-form-item label="付款时间:" prop="orderTime">
|
|
|
|
- <el-date-picker clearable v-model="queryParams.createTimeRange" type="date" value-format="YYYY-MM-DD" placeholder="请选择开单时间" />
|
|
|
|
|
|
+ <el-form-item label="付款时间:" prop="createTime">
|
|
|
|
+ <el-date-picker v-model="createTime" value-format="YYYY-MM-DD HH:mm:ss" type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]"></el-date-picker>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="退费时间:" prop="refundTime">
|
|
<el-form-item label="退费时间:" prop="refundTime">
|
|
- <el-date-picker clearable v-model="queryParams.refundTimeRange" type="date" value-format="YYYY-MM-DD" placeholder="请选择开单时间" />
|
|
|
|
|
|
+ <el-date-picker v-model="refundTime" value-format="YYYY-MM-DD HH:mm:ss" type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]"></el-date-picker>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="收费类型:" prop="chargeType">
|
|
<el-form-item label="收费类型:" prop="chargeType">
|
|
<el-select v-model="queryParams.chargeType">
|
|
<el-select v-model="queryParams.chargeType">
|
|
@@ -27,12 +27,12 @@
|
|
</el-select>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="支付方式:">
|
|
<el-form-item label="支付方式:">
|
|
- <el-select v-model="queryParams.visitType">
|
|
|
|
|
|
+ <el-select v-model="queryParams.paymentMethod">
|
|
<el-option v-for="dict in charge_way" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
<el-option v-for="dict in charge_way" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
</el-select>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="支付状态:">
|
|
<el-form-item label="支付状态:">
|
|
- <el-select v-model="queryParams.visitType">
|
|
|
|
|
|
+ <el-select v-model="queryParams.paymentStatus">
|
|
<el-option v-for="dict in payment_status" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
<el-option v-for="dict in payment_status" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
</el-select>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
@@ -52,7 +52,7 @@
|
|
|
|
|
|
<el-card shadow="never">
|
|
<el-card shadow="never">
|
|
<template #header>
|
|
<template #header>
|
|
- <el-row :gutter="10" class="mb8">
|
|
|
|
|
|
+ <!-- <el-row :gutter="10" class="mb8">
|
|
<el-col :span="1.5">
|
|
<el-col :span="1.5">
|
|
<el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['system:record:add']">新增</el-button>
|
|
<el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['system:record:add']">新增</el-button>
|
|
</el-col>
|
|
</el-col>
|
|
@@ -66,12 +66,12 @@
|
|
<el-button type="warning" plain icon="Download" @click="handleExport" v-hasPermi="['system:record:export']">导出</el-button>
|
|
<el-button type="warning" plain icon="Download" @click="handleExport" v-hasPermi="['system:record:export']">导出</el-button>
|
|
</el-col>
|
|
</el-col>
|
|
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
|
|
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
|
|
- </el-row>
|
|
|
|
|
|
+ </el-row> -->
|
|
</template>
|
|
</template>
|
|
|
|
|
|
<el-table v-loading="loading" border :data="recordList" @selection-change="handleSelectionChange">
|
|
<el-table v-loading="loading" border :data="recordList" @selection-change="handleSelectionChange">
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
- <el-table-column label="主键ID" align="center" prop="id" v-if="false" />
|
|
|
|
|
|
+ <el-table-column label="主键ID" align="center" prop="chargeId" v-if="false" />
|
|
<el-table-column label="处方id" align="center" prop="settlementId" v-if="false" />
|
|
<el-table-column label="处方id" align="center" prop="settlementId" v-if="false" />
|
|
<el-table-column label="开单时间" align="center" prop="orderTime" width="180">
|
|
<el-table-column label="开单时间" align="center" prop="orderTime" width="180">
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
@@ -100,29 +100,33 @@
|
|
<el-table-column label="身份证号" align="center" prop="idCard" />
|
|
<el-table-column label="身份证号" align="center" prop="idCard" />
|
|
<el-table-column label="订单金额(元)" align="center" prop="receivableAmount" />
|
|
<el-table-column label="订单金额(元)" align="center" prop="receivableAmount" />
|
|
<el-table-column label="实收金额(元)" align="center" prop="fundsReceived" />
|
|
<el-table-column label="实收金额(元)" align="center" prop="fundsReceived" />
|
|
- <el-table-column label="退费金额(元)" align="center" prop="refundAmount" />
|
|
|
|
- <el-table-column label="支付状态" align="center" prop="paymentStatus" >
|
|
|
|
|
|
+ <el-table-column label="退费金额(元)" align="center" prop="refundAmount">
|
|
|
|
+ <template #default="scope">
|
|
|
|
+ <span>{{ scope.row.refundAmount||'--' }}</span>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column label="支付状态" align="center" prop="paymentStatus">
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
<span>{{getDictLabel(payment_status,scope.row.paymentStatus)||'--' }}</span>
|
|
<span>{{getDictLabel(payment_status,scope.row.paymentStatus)||'--' }}</span>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="支付方式" align="center" prop="paymentMethod" >
|
|
|
|
|
|
+ <el-table-column label="支付方式" align="center" prop="paymentMethod">
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
<span>{{getDictLabel(charge_way,scope.row.paymentMethod)||'--' }}</span>
|
|
<span>{{getDictLabel(charge_way,scope.row.paymentMethod)||'--' }}</span>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
<el-table-column label="退费时间" align="center" prop="refundTime" width="180">
|
|
<el-table-column label="退费时间" align="center" prop="refundTime" width="180">
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
- <span>{{ scope.row.refundTime }}</span>
|
|
|
|
|
|
+ <span>{{ scope.row.refundTime||'--' }}</span>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
|
|
+ <el-table-column label="操作" align="center" width="150" class-name="small-padding fixed-width">
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
- <el-tooltip content="修改" placement="top">
|
|
|
|
- <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['system:record:edit']"></el-button>
|
|
|
|
|
|
+ <el-tooltip content="详情" placement="top">
|
|
|
|
+ <el-button link type="primary" icon="Edit" @click="handleDetail(scope.row)" v-hasPermi="['settlement:chargeRecord:edit']">详情</el-button>
|
|
</el-tooltip>
|
|
</el-tooltip>
|
|
<el-tooltip content="删除" placement="top">
|
|
<el-tooltip content="删除" placement="top">
|
|
- <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['system:record:remove']"></el-button>
|
|
|
|
|
|
+ <el-button link type="primary" icon="Delete" >打印</el-button>
|
|
</el-tooltip>
|
|
</el-tooltip>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
@@ -130,11 +134,220 @@
|
|
|
|
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
</el-card>
|
|
</el-card>
|
|
- <!-- 添加或修改收费记录对话框 -->
|
|
|
|
- <el-dialog :title="dialog.title" v-model="dialog.visible" width="500px" append-to-body>
|
|
|
|
- <el-form ref="ChrageRecordFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
|
|
|
+ <!-- 详情对话框 -->
|
|
|
|
+ <el-dialog :title="dialog.title" v-model="dialog.visible" width="65%" append-to-body>
|
|
|
|
+ <!-- 患者信息 -->
|
|
|
|
+ <div class="patient-info">
|
|
|
|
+ <el-row :gutter="20">
|
|
|
|
+ <el-col :span="4">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">开方日期:</span>
|
|
|
|
+ <span class="value">{{ parseTime(form.orderTime, '{y}-{m}-{d}') || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">患者姓名:</span>
|
|
|
|
+ <span class="value">{{ rowData.patientName || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">身份证号:</span>
|
|
|
|
+ <span class="value">{{ rowData.idCard || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">门诊/住院号:</span>
|
|
|
|
+ <span class="value">{{ rowData.patientNo || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">看诊类型:</span>
|
|
|
|
+ <span class="value">{{ getDictLabel(treatment_user_type, rowData.visitType) || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+
|
|
|
|
+ <el-row :gutter="20">
|
|
|
|
+ <el-col :span="4">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">联系电话:</span>
|
|
|
|
+ <span class="value">{{ rowData.phone || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">诊疗卡号:</span>
|
|
|
|
+ <span class="value">{{ rowData.treatNum || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">病区:</span>
|
|
|
|
+ <span class="value">{{ rowData.wardName || '--' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">患者科室:</span>
|
|
|
|
+ <span class="value">{{ rowData.patientDepartment || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="5">
|
|
|
|
+ <div class="info-item">
|
|
|
|
+ <span class="label">处方Id:</span>
|
|
|
|
+ <span class="value">{{ rowData.id || '' }}</span>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <!-- 处方明细表格 -->
|
|
|
|
+ <!-- 处方表格 -->
|
|
|
|
+ <div class="prescription-table-wrapper">
|
|
|
|
+ <!-- 处方数据表格 -->
|
|
|
|
+ <table v-if="recipeDetailData.length > 0" class="prescription-table">
|
|
|
|
+ <thead>
|
|
|
|
+ <tr>
|
|
|
|
+ <th>组号</th>
|
|
|
|
+ <th>产品名称</th>
|
|
|
|
+ <th>规格</th>
|
|
|
|
+ <th>销售价格(元)</th>
|
|
|
|
+ <th>用量/次</th>
|
|
|
|
+ <th>频次</th>
|
|
|
|
+ <th>使用天数</th>
|
|
|
|
+ <th>首日</th>
|
|
|
|
+ <th>用量/总</th>
|
|
|
|
+ <th>应收金额(元)</th>
|
|
|
|
+ <th>操作人</th>
|
|
|
|
+ </tr>
|
|
|
|
+ </thead>
|
|
|
|
+ <tbody>
|
|
|
|
+ <tr v-for="(product, index) in recipeDetailData" :key="index">
|
|
|
|
+ <td>{{ Number(product.groupNo) + 1 || '--' }}</td>
|
|
|
|
+ <td>{{ product.nutritionProduct || '--' }}</td>
|
|
|
|
+ <td>{{ product.specification || '--' }}</td>
|
|
|
|
+ <td>{{ product.salePrice || '--' }}</td>
|
|
|
|
+ <td>{{ product.dosePerTime || '--' }}</td>
|
|
|
|
+ <td>{{ product.frequency || '--' }}</td>
|
|
|
|
+ <td>{{ product.usageDays || '--' }}</td>
|
|
|
|
+ <td>{{ product.firstDay || '--' }}</td>
|
|
|
|
+ <td>{{ product.totalDose || '--' }}</td>
|
|
|
|
+ <td>{{ product.amount || '--' }}</td>
|
|
|
|
+ <td>{{ product.createByName || '--' }}</td>
|
|
|
|
+ </tr>
|
|
|
|
+ </tbody>
|
|
|
|
+ </table>
|
|
|
|
+
|
|
|
|
+ <!-- 筛查数据表格 -->
|
|
|
|
+ <table v-if="screeningData.length > 0" class="prescription-table" style="margin-top: 10px;">
|
|
|
|
+ <thead>
|
|
|
|
+ <tr>
|
|
|
|
+ <th>项目名称</th>
|
|
|
|
+ <th>销售单位</th>
|
|
|
|
+ <th>销售价格</th>
|
|
|
|
+ <th>数量</th>
|
|
|
|
+ <th>应收金额(元)</th>
|
|
|
|
+ <th>操作人</th>
|
|
|
|
+ </tr>
|
|
|
|
+ </thead>
|
|
|
|
+ <tbody>
|
|
|
|
+ <tr v-for="(item, index) in screeningData" :key="index">
|
|
|
|
+ <td>{{ getDictLabel(fee_type,rowData.chargeType) || '--' }}</td>
|
|
|
|
+ <td>次</td>
|
|
|
|
+ <td>{{ rowData.receivableAmount || '--' }}</td>
|
|
|
|
+ <td>1</td>
|
|
|
|
+ <td>{{ rowData.receivableAmount || '--' }}</td>
|
|
|
|
+ <td>{{ item.createByName || '--' }}</td>
|
|
|
|
+ </tr>
|
|
|
|
+ </tbody>
|
|
|
|
+ </table>
|
|
|
|
+
|
|
|
|
+ <!-- 评估数据表格 -->
|
|
|
|
+ <table v-if="evaluationData.length > 0" class="prescription-table" style="margin-top: 10px;">
|
|
|
|
+ <thead>
|
|
|
|
+ <tr>
|
|
|
|
+ <th>项目名称</th>
|
|
|
|
+ <th>销售单位</th>
|
|
|
|
+ <th>销售价格</th>
|
|
|
|
+ <th>数量</th>
|
|
|
|
+ <th>应收金额(元)</th>
|
|
|
|
+ <th>操作人</th>
|
|
|
|
+ </tr>
|
|
|
|
+ </thead>
|
|
|
|
+ <tbody>
|
|
|
|
+ <tr v-for="(item, index) in evaluationData" :key="index">
|
|
|
|
+ <td>{{ getDictLabel(fee_type,rowData.chargeType) || '--' }}</td>
|
|
|
|
+ <td>次</td>
|
|
|
|
+ <td>{{ rowData.receivableAmount || '--' }}</td>
|
|
|
|
+ <td>1</td>
|
|
|
|
+ <td>{{ rowData.receivableAmount || '--' }}</td>
|
|
|
|
+ <td>{{ item.createByName || '--' }}</td>
|
|
|
|
+ </tr>
|
|
|
|
+ </tbody>
|
|
|
|
+ </table>
|
|
|
|
+
|
|
|
|
+ <!-- 无数据提示 -->
|
|
|
|
+ <div v-if="recipeDetailData.length === 0 && screeningData.length === 0 && evaluationData.length === 0" style="text-align: center; color: #909399; padding: 40px 0;">
|
|
|
|
+ 暂无数据
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <!-- 金额统计 -->
|
|
|
|
+ <div style="margin-top:10px;" v-if="rowData.chargeType=='0'||rowData.chargeType=='1'">
|
|
|
|
+ <el-row :gutter="20">
|
|
|
|
+ <el-col :span="4">
|
|
|
|
+ <span>项目总金额:<span style="color: #f56c6c;">¥{{rowData.receivableAmount}}</span></span>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="4">
|
|
|
|
+ <span>实收金额:<span style="color: #f56c6c;">¥{{rowData.fundsReceived}}</span></span><span style="margin-left:5px"> 退费金额:<span style="color: #f56c6c;">¥{{ rowData.refundAmount||'0.00' }}</span></span>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ </div>
|
|
|
|
+ <div style="margin-top:10px;" v-else>
|
|
|
|
+ <el-row :gutter="20">
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <span>处方总金额:<span style="color: #f56c6c;">¥{{rowData.receivableAmount}}</span></span><span>(营养配置费:<span>¥{{ prescriptionFee||'0' }}</span>)</span>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="4">
|
|
|
|
+ <span>实收金额:<span style="color: #f56c6c;">¥{{rowData.fundsReceived}}</span></span><span style="margin-left:5px"> 退费金额:<span style="color: #f56c6c;">¥{{ rowData.refundAmount||'0.00' }}</span></span>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <!-- 筛查数据表格 -->
|
|
|
|
+ <span>操作记录</span>
|
|
|
|
+ <table v-if="recordLogData.length > 0" class="prescription-table" style="margin-top: 10px;">
|
|
|
|
+ <thead>
|
|
|
|
+ <tr>
|
|
|
|
+ <th>操作日期</th>
|
|
|
|
+ <th>交易单号</th>
|
|
|
|
+ <th>产品名称</th>
|
|
|
|
+ <th>操作</th>
|
|
|
|
+ <th>交易金额(元)</th>
|
|
|
|
+ <th>交易状态</th>
|
|
|
|
+ <th>备注</th>
|
|
|
|
+ <th>操作人</th>
|
|
|
|
+ </tr>
|
|
|
|
+ </thead>
|
|
|
|
+ <tbody>
|
|
|
|
+ <tr v-for="(item, index) in recordLogData" :key="index">
|
|
|
|
+ <td>{{ item.createTime || '--' }}</td>
|
|
|
|
+ <td>{{item.settlementId}}</td>
|
|
|
|
+ <td>{{ item.productName || '--' }}</td>
|
|
|
|
+ <td>{{getDictLabel(charge_way,item.paymentMethod) || '--' }}</td>
|
|
|
|
+ <td>{{ rowData.receivableAmount || '--' }}</td>
|
|
|
|
+ <td>{{getDictLabel(action_status,item.status) || '--' }}</td>
|
|
|
|
+ <td>{{ rowData.remark || '--' }}</td>
|
|
|
|
+ <td>{{ item.createByName || '--' }}</td>
|
|
|
|
+ </tr>
|
|
|
|
+ </tbody>
|
|
|
|
+ </table>
|
|
|
|
+ </div>
|
|
|
|
|
|
- </el-form>
|
|
|
|
<template #footer>
|
|
<template #footer>
|
|
<div class="dialog-footer">
|
|
<div class="dialog-footer">
|
|
<el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
|
|
<el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
|
|
@@ -150,8 +363,11 @@
|
|
import { ChrageRecordVO, ChrageRecordQuery, ChrageRecordForm } from '@/api/settlement/chargeRecord/types';
|
|
import { ChrageRecordVO, ChrageRecordQuery, ChrageRecordForm } from '@/api/settlement/chargeRecord/types';
|
|
import { listDept } from '@/api/system/dept'; // 部门列表
|
|
import { listDept } from '@/api/system/dept'; // 部门列表
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
- const { treatment_user_type, check_status, recipe_type, fee_type, charge_way, payment_status } = toRefs < any > (proxy ?.useDict('treatment_user_type', 'check_status', 'recipe_type', 'fee_type', 'charge_way', 'payment_status'));
|
|
|
|
|
|
+ const { treatment_user_type, check_status, recipe_type, fee_type, charge_way, payment_status,action_status } = toRefs < any > (proxy ?.useDict('treatment_user_type', 'check_status', 'recipe_type', 'fee_type', 'charge_way', 'payment_status','action_status'));
|
|
|
|
|
|
|
|
+ const orderTime = ref < [DateModelType, DateModelType] > (['', '']);
|
|
|
|
+ const createTime = ref < [DateModelType, DateModelType] > (['', '']);
|
|
|
|
+ const refundTime = ref < [DateModelType, DateModelType] > (['', '']);
|
|
const recordList = ref < ChrageRecordVO[] > ([]);
|
|
const recordList = ref < ChrageRecordVO[] > ([]);
|
|
const buttonLoading = ref(false);
|
|
const buttonLoading = ref(false);
|
|
const loading = ref(true);
|
|
const loading = ref(true);
|
|
@@ -160,7 +376,12 @@
|
|
const single = ref(true);
|
|
const single = ref(true);
|
|
const multiple = ref(true);
|
|
const multiple = ref(true);
|
|
const total = ref(0);
|
|
const total = ref(0);
|
|
-
|
|
|
|
|
|
+ // 处方明细数据
|
|
|
|
+ const recipeDetailData = ref([]);
|
|
|
|
+ const evaluationData = ref([]);
|
|
|
|
+ const screeningData = ref([]);
|
|
|
|
+ const recordLogData = ref([]);
|
|
|
|
+ const prescriptionFee = ref(0)
|
|
const queryFormRef = ref < ElFormInstance > ();
|
|
const queryFormRef = ref < ElFormInstance > ();
|
|
const ChrageRecordFormRef = ref < ElFormInstance > ();
|
|
const ChrageRecordFormRef = ref < ElFormInstance > ();
|
|
const treeData = ref([]); // 定义 treeData
|
|
const treeData = ref([]); // 定义 treeData
|
|
@@ -173,7 +394,7 @@
|
|
visible: false,
|
|
visible: false,
|
|
title: ''
|
|
title: ''
|
|
});
|
|
});
|
|
-
|
|
|
|
|
|
+ const rowData = ref < ChrageRecordVO > ({})
|
|
const initFormData: ChrageRecordForm = {
|
|
const initFormData: ChrageRecordForm = {
|
|
id: undefined,
|
|
id: undefined,
|
|
settlementId: undefined,
|
|
settlementId: undefined,
|
|
@@ -205,27 +426,20 @@
|
|
queryParams: {
|
|
queryParams: {
|
|
pageNum: 1,
|
|
pageNum: 1,
|
|
pageSize: 10,
|
|
pageSize: 10,
|
|
- settlementId: undefined,
|
|
|
|
orderTime: undefined,
|
|
orderTime: undefined,
|
|
|
|
+ createTime: undefined,
|
|
visitType: undefined,
|
|
visitType: undefined,
|
|
chargeType: undefined,
|
|
chargeType: undefined,
|
|
- patientId: undefined,
|
|
|
|
- patientName: undefined,
|
|
|
|
doorId: undefined,
|
|
doorId: undefined,
|
|
|
|
+ patientId:undefined,
|
|
patientNo: undefined,
|
|
patientNo: undefined,
|
|
- phone: undefined,
|
|
|
|
- idCard: undefined,
|
|
|
|
receivableAmount: undefined,
|
|
receivableAmount: undefined,
|
|
fundsReceived: undefined,
|
|
fundsReceived: undefined,
|
|
refundAmount: undefined,
|
|
refundAmount: undefined,
|
|
paymentStatus: undefined,
|
|
paymentStatus: undefined,
|
|
paymentMethod: undefined,
|
|
paymentMethod: undefined,
|
|
- bedNo: undefined,
|
|
|
|
refundTime: undefined,
|
|
refundTime: undefined,
|
|
- status: undefined,
|
|
|
|
- wardId: undefined,
|
|
|
|
- wardName: undefined,
|
|
|
|
- treatNum: undefined,
|
|
|
|
|
|
+ searchValue: undefined,
|
|
params: {}
|
|
params: {}
|
|
},
|
|
},
|
|
rules: {
|
|
rules: {
|
|
@@ -247,10 +461,37 @@
|
|
return found ? found.label : value || '--';
|
|
return found ? found.label : value || '--';
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /** 添加多个日期范围 */
|
|
|
|
+ const addMultipleDateRanges = (params: any, dateRanges: {
|
|
|
|
+ [key: string]: any[]
|
|
|
|
+ }) => {
|
|
|
|
+ const search = { ...params };
|
|
|
|
+ search.params = typeof search.params === 'object' && search.params !== null && !Array.isArray(search.params) ? search.params : {};
|
|
|
|
+
|
|
|
|
+ // 添加各个时间范围
|
|
|
|
+ Object.keys(dateRanges).forEach(propName => {
|
|
|
|
+ const dateRange = Array.isArray(dateRanges[propName]) ? dateRanges[propName] : [];
|
|
|
|
+ if (dateRange.length >= 2 && dateRange[0] && dateRange[1]) {
|
|
|
|
+ search.params['beginTime'] = dateRange[0];
|
|
|
|
+ search.params['endTime'] = dateRange[1];
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+
|
|
|
|
+ return search;
|
|
|
|
+ };
|
|
|
|
+
|
|
/** 查询收费记录列表 */
|
|
/** 查询收费记录列表 */
|
|
const getList = async () => {
|
|
const getList = async () => {
|
|
loading.value = true;
|
|
loading.value = true;
|
|
- const res = await listRecord(queryParams.value);
|
|
|
|
|
|
+
|
|
|
|
+ // 构建多个时间范围参数
|
|
|
|
+ const dateRanges = {
|
|
|
|
+ OrderTime: orderTime.value,
|
|
|
|
+ CreateTime: createTime.value,
|
|
|
|
+ RefundTime: refundTime.value
|
|
|
|
+ };
|
|
|
|
+
|
|
|
|
+ const res = await listRecord(addMultipleDateRanges(queryParams.value, dateRanges));
|
|
recordList.value = res.rows;
|
|
recordList.value = res.rows;
|
|
total.value = res.total;
|
|
total.value = res.total;
|
|
loading.value = false;
|
|
loading.value = false;
|
|
@@ -304,6 +545,12 @@
|
|
/** 重置按钮操作 */
|
|
/** 重置按钮操作 */
|
|
const resetQuery = () => {
|
|
const resetQuery = () => {
|
|
queryFormRef.value ?.resetFields();
|
|
queryFormRef.value ?.resetFields();
|
|
|
|
+ queryParams.value.searchValue = undefined;
|
|
|
|
+ queryParams.value.visitType = undefined;
|
|
|
|
+ queryParams.value.chargeType = undefined;
|
|
|
|
+ queryParams.value.doorId = undefined;
|
|
|
|
+ queryParams.value.paymentMethod = undefined;
|
|
|
|
+ queryParams.value.paymentStatus = undefined;
|
|
handleQuery();
|
|
handleQuery();
|
|
}
|
|
}
|
|
|
|
|
|
@@ -322,13 +569,21 @@
|
|
}
|
|
}
|
|
|
|
|
|
/** 修改按钮操作 */
|
|
/** 修改按钮操作 */
|
|
- const handleUpdate = async (row ? : ChrageRecordVO) => {
|
|
|
|
|
|
+ const handleDetail = async (row ? : ChrageRecordVO) => {
|
|
reset();
|
|
reset();
|
|
- const _id = row ?.id || ids.value[0]
|
|
|
|
|
|
+ rowData.value = row || {} as ChrageRecordVO;
|
|
|
|
+ console.log(JSON.stringify(row));
|
|
|
|
+ const _id = row ?.id
|
|
const res = await getRecord(_id);
|
|
const res = await getRecord(_id);
|
|
|
|
+ recipeDetailData.value = res.data.enteralNutritionList
|
|
|
|
+ evaluationData.value = res.data.nutritionEvaluationList
|
|
|
|
+ screeningData.value = res.data.nutritionScreeningList
|
|
|
|
+ recordLogData.value = res.data.recordLogList
|
|
|
|
+
|
|
|
|
+ prescriptionFee.value = res.data.prescriptionFee
|
|
Object.assign(form.value, res.data);
|
|
Object.assign(form.value, res.data);
|
|
dialog.visible = true;
|
|
dialog.visible = true;
|
|
- dialog.title = "修改收费记录";
|
|
|
|
|
|
+ dialog.title = "收费详情";
|
|
}
|
|
}
|
|
|
|
|
|
/** 提交按钮 */
|
|
/** 提交按钮 */
|
|
@@ -364,8 +619,135 @@
|
|
}, `record_${new Date().getTime()}.xlsx`)
|
|
}, `record_${new Date().getTime()}.xlsx`)
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ function formatDate(date) {
|
|
|
|
+ const pad = (n) => (n < 10 ? '0' + n : n);
|
|
|
|
+ return date.getFullYear() + '-' + pad(date.getMonth() + 1) + '-' + pad(date.getDate());
|
|
|
|
+ }
|
|
|
|
+
|
|
onMounted(() => {
|
|
onMounted(() => {
|
|
getList();
|
|
getList();
|
|
getDeptList()
|
|
getDeptList()
|
|
|
|
+ let now = new Date();
|
|
|
|
+ let start = formatDate(now);
|
|
|
|
+ let end = formatDate(new Date(now.getTime() - 24 * 60 * 60 * 1000 * 30));
|
|
|
|
+ // orderTime.value = [end + ' 00:00:00', start + ' 23:59:59'];
|
|
|
|
+ // createTime.value = [end + ' 00:00:00', start + ' 23:59:59'];
|
|
});
|
|
});
|
|
-</script>
|
|
|
|
|
|
+</script>
|
|
|
|
+<style lang="scss" scoped>
|
|
|
|
+ .patient-info {
|
|
|
|
+ background-color: #f5f7fa;
|
|
|
|
+ padding: 16px;
|
|
|
|
+ border-radius: 4px;
|
|
|
|
+ margin-bottom: 20px;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .info-item {
|
|
|
|
+ display: flex;
|
|
|
|
+ margin-bottom: 12px;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .info-item .label {
|
|
|
|
+ font-weight: bold;
|
|
|
|
+ color: #606266;
|
|
|
|
+ min-width: 100px;
|
|
|
|
+ flex-shrink: 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .info-item .value {
|
|
|
|
+ color: #303133;
|
|
|
|
+ flex: 1;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .recipe-detail {
|
|
|
|
+ margin-top: 20px;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .dialog-footer {
|
|
|
|
+ text-align: center;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .dialog-footer .el-button {
|
|
|
|
+ margin: 0 10px;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .prescription-table-wrapper {
|
|
|
|
+ overflow-x: auto;
|
|
|
|
+
|
|
|
|
+ .prescription-table {
|
|
|
|
+ width: 100%;
|
|
|
|
+ border-collapse: collapse;
|
|
|
|
+ border: 1px solid #ddd;
|
|
|
|
+ background: white;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+
|
|
|
|
+ th,
|
|
|
|
+ td {
|
|
|
|
+ border: 1px solid #ddd;
|
|
|
|
+ padding: 10px 12px;
|
|
|
|
+ text-align: center;
|
|
|
|
+ vertical-align: middle;
|
|
|
|
+ min-width: 90px;
|
|
|
|
+ white-space: nowrap;
|
|
|
|
+ overflow: hidden;
|
|
|
|
+ text-overflow: ellipsis;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ th {
|
|
|
|
+ background: #e8f4fd !important;
|
|
|
|
+ color: #303133 !important;
|
|
|
|
+ font-weight: 600 !important;
|
|
|
|
+ font-size: 14px !important;
|
|
|
|
+ height: 40px !important;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ td {
|
|
|
|
+ color: #303133;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+ height: 36px;
|
|
|
|
+
|
|
|
|
+ &:first-child {
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 斑马纹
|
|
|
|
+ tbody tr:nth-child(even) {
|
|
|
|
+ background: #fafbfc;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 悬停效果
|
|
|
|
+ tbody tr:hover {
|
|
|
|
+ background: #f0f9ff;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .setting-group {
|
|
|
|
+ display: flex;
|
|
|
|
+ align-items: center;
|
|
|
|
+ margin-bottom: 20px;
|
|
|
|
+
|
|
|
|
+ .setting-label {
|
|
|
|
+ width: 180px;
|
|
|
|
+ color: #606266;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+ flex-shrink: 0;
|
|
|
|
+ text-align: right;
|
|
|
|
+
|
|
|
|
+ .required {
|
|
|
|
+ color: #f56c6c;
|
|
|
|
+ margin-right: 4px;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ .amount-value {
|
|
|
|
+ color: #303133;
|
|
|
|
+ font-size: 14px;
|
|
|
|
+ font-weight: 500;
|
|
|
|
+ min-width: 80px;
|
|
|
|
+ text-align: left;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+</style>
|