Files
admin-vben5/apps/web-antd/src/views/property/roomBooking/conferenceAddServices/conferenceAddServices-detail.vue
FLL e28ddabf57
Some checks are pending
Gitea Actions Demo / Explore-Gitea-Actions (push) Waiting to run
会议管理
2025-07-04 17:56:14 +08:00

60 lines
2.1 KiB
Vue

<script setup lang="ts">
import type {conferenceAddServices} from '#/api/property/roomBooking/conferenceAddServices/model';
import {shallowRef} from 'vue';
import {useVbenModal} from '@vben/common-ui';
import {Descriptions, DescriptionsItem} from 'ant-design-vue';
import dayjs from 'dayjs';
import duration from 'dayjs/plugin/duration';
import relativeTime from 'dayjs/plugin/relativeTime';
import {attachInfo} from '#/api/property/roomBooking/conferenceAddServices';
import {renderDict} from "#/utils/render";
dayjs.extend(duration);
dayjs.extend(relativeTime);
const [BasicModal, modalApi] = useVbenModal({
onOpenChange: handleOpenChange,
onClosed() {
conferenceAddServicesDetail.value = null;
},
});
const conferenceAddServicesDetail = shallowRef<null | conferenceAddServices>(null);
async function handleOpenChange(open: boolean) {
if (!open) {
return null;
}
modalApi.modalLoading(true);
const {id} = modalApi.getData() as { id: number | string };
const response = await attachInfo(id);
conferenceAddServicesDetail.value = response;
modalApi.modalLoading(false);
}
</script>
<template>
<BasicModal :footer="false" :fullscreen-button="false" title="访客管理信息" class="w-[70%]">
<Descriptions v-if="conferenceAddServicesDetail" size="small" :column="2" bordered :labelStyle="{width:'100px'}">
<DescriptionsItem label="产品名称">
{{ conferenceAddServicesDetail.projectName}}
</DescriptionsItem>
<DescriptionsItem label="单价(元)">
{{ conferenceAddServicesDetail.price }}
</DescriptionsItem>
<DescriptionsItem label="单位">
{{ conferenceAddServicesDetail.unit }}
</DescriptionsItem>
<DescriptionsItem label="类型" v-if="conferenceAddServicesDetail.type!=null">
<component
:is="renderDict(conferenceAddServicesDetail.type,'wy_parking_spot')"
/>
</DescriptionsItem>
<DescriptionsItem label="状态" v-if="conferenceAddServicesDetail.state!=null">
<component
:is="renderDict(conferenceAddServicesDetail.state,'wy_appointment_tatus')"
/>
</DescriptionsItem>
</Descriptions>
</BasicModal>
</template>