ykt-wxapp/pages/message/components/message-card/refill-medicine-card.vue

102 lines
2.6 KiB
Vue
Raw Normal View History

2026-01-20 13:21:50 +08:00
<template>
<view v-if="data" class="card-detail">
<view class="card-row">
<text class="label-text">患者</text>
<text class="content-text">{{ data.patient }}</text>
</view>
<view class="card-row">
<text class="label-text">诊断</text>
<text class="content-text">{{ data.diseases }}</text>
</view>
<view v-if="data.medicines.length && data.type === 'western'" class="card-row card-row--flex">
<view class="row-label label-text">RP</view>
<view class="row-content">
<view v-for="i in data.medicines" :key="i._id">
<view class="content-text"> {{ i.info }}</view>
<view class="label-text"> {{ i.useInfo }}</view>
</view>
</view>
</view>
<view v-else-if="data.type === 'chinese'" class="card-row card-row--flex">
<view class="row-label label-text">RP </view>
<view class="row-content">
<view class="content-text">中药处方</view>
<view class="label-text">
{{ data.doseNum }}, 每日{{ data.dailyDoseNum }},1剂分{{ data.timesPerDosage }}服用, {{ data.administrationTime
}},
{{ data.instructions || '' }}
</view>
</view>
</view>
</view>
</template>
<script setup>
import { computed } from 'vue';
const props = defineProps({
payload: {
type: Object,
default: () => ({})
}
});
const data = computed(() => {
try {
const extension = JSON.parse(props.payload.extension);
return {
...extension,
patient: typeof extension.patient === 'string' ? extension.patient : '',
diseases: typeof extension.diseases === 'string' ? extension.diseases : '',
medicines: Array.isArray(extension.medicines) ? formatWesternMedicine(extension.medicines) : [],
type: typeof extension.type === 'string' ? extension.type : '',
}
} catch (e) { }
return null
})
function formatWesternMedicine(medicines) {
return medicines.map(med => {
const info = `${med.name} ${med.specification || ''} x${med.quantity || ''}${med.unit || ''}`;
const useInfo = `${med.administrationTime || ''} ${med.usageName || ''}, ${med.frequencyName}, 每次${med.dosage || ''} ${med.dosageUnit || ''} `
return { info, useInfo }
});
}
</script>
<style scpoed>
/* 病情描述样式 */
.card-detail {
min-width: 360rpx;
max-width: 600rpx;
}
.card-row {
padding: 4rpx 0;
line-height: 42rpx;
}
.card-row--flex {
display: flex;
}
.card-row--flex .row-label {
flex-shrink: 0;
}
.card-row--flex .row-content {
width: 0;
flex-grow: 1;
}
.label-text {
color: #999;
font-size: 28rpx;
}
.content-text {
color: #333;
font-size: 28rpx;
}
</style>