| <template> | 
|   <ProDialog :title="title" v-model="visible" destroy-on-close draggable width="800px"> | 
|     <FourStreamsMaterialFileTable v-model:list="form.list" v-bind="props" /> | 
|     <template #footer> | 
|       <span class="dialog-footer"> | 
|         <el-button type="primary" @click="handleConfirm">确 定</el-button> | 
|       </span> | 
|     </template> | 
|   </ProDialog> | 
| </template> | 
|   | 
| <script setup lang="ts" generic="T"> | 
| import { ProDialog } from '@bole-core/components'; | 
| import FourStreamsMaterialFileTable from './FourStreamsMaterialFileTable.vue'; | 
| import { FourStreamsMaterialFileTableProps, BaseMaterialFileTableItem } from './types'; | 
|   | 
| defineOptions({ | 
|   name: 'FourStreamsMaterialFileDialog', | 
| }); | 
|   | 
| type Props = FourStreamsMaterialFileTableProps & { | 
|   title?: string; | 
| }; | 
|   | 
| const props = withDefaults(defineProps<Props>(), { | 
|   showUploadBtn: true, | 
|   showCheckBtn: true, | 
|   showDownloadBtn: true, | 
|   showDeleteBtn: true, | 
|   title: '材料详情', | 
| }); | 
|   | 
| const visible = defineModel({ type: Boolean }); | 
|   | 
| type Form = { | 
|   list: BaseMaterialFileTableItem<T>[]; | 
| }; | 
|   | 
| const form = defineModel<Form>('form'); | 
|   | 
| const emit = defineEmits<{ | 
|   (e: 'onConfirm'): void; | 
|   (e: 'onCancel'): void; | 
| }>(); | 
|   | 
| function handleConfirm() { | 
|   emit('onConfirm'); | 
| } | 
| </script> |