车间能级提升-智能设备管理系统
朱桂飞
2025-01-09 3e8f7f239bedae0b4f04a1ac6bd443ba6298f73c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
<script lang="ts" setup>
import { Page, useVbenModal } from '@vben/common-ui';
 
import { Button, Card } from 'ant-design-vue';
 
import DocButton from '../doc-button.vue';
import AutoHeightDemo from './auto-height-demo.vue';
import BaseDemo from './base-demo.vue';
import DragDemo from './drag-demo.vue';
import DynamicDemo from './dynamic-demo.vue';
import FormModalDemo from './form-modal-demo.vue';
import InContentModalDemo from './in-content-demo.vue';
import SharedDataDemo from './shared-data-demo.vue';
 
const [BaseModal, baseModalApi] = useVbenModal({
  // 连接抽离的组件
  connectedComponent: BaseDemo,
});
 
const [InContentModal, inContentModalApi] = useVbenModal({
  // 连接抽离的组件
  connectedComponent: InContentModalDemo,
});
 
const [AutoHeightModal, autoHeightModalApi] = useVbenModal({
  connectedComponent: AutoHeightDemo,
});
 
const [DragModal, dragModalApi] = useVbenModal({
  connectedComponent: DragDemo,
});
 
const [DynamicModal, dynamicModalApi] = useVbenModal({
  connectedComponent: DynamicDemo,
});
 
const [SharedDataModal, sharedModalApi] = useVbenModal({
  connectedComponent: SharedDataDemo,
});
 
const [FormModal, formModalApi] = useVbenModal({
  connectedComponent: FormModalDemo,
});
 
function openBaseModal() {
  baseModalApi.open();
}
 
function openInContentModal() {
  inContentModalApi.open();
}
 
function openAutoHeightModal() {
  autoHeightModalApi.open();
}
 
function openDragModal() {
  dragModalApi.open();
}
 
function openDynamicModal() {
  dynamicModalApi.open();
}
 
function openSharedModal() {
  sharedModalApi.setData({
    content: '外部传递的数据 content',
    payload: '外部传递的数据 payload',
  });
  sharedModalApi.open();
}
 
function handleUpdateTitle() {
  dynamicModalApi.setState({ title: '外部动态标题' });
  dynamicModalApi.open();
}
 
function openFormModal() {
  formModalApi.setData({
    // 表单值
    values: { field1: 'abc' },
  });
  formModalApi.open();
}
</script>
 
<template>
  <Page
    auto-content-height
    description="弹窗组件常用于在不离开当前页面的情况下,显示额外的信息、表单或操作提示,更多api请查看组件文档。"
    title="弹窗组件示例"
  >
    <template #extra>
      <DocButton path="/components/common-ui/vben-modal" />
    </template>
    <BaseModal />
    <InContentModal />
    <AutoHeightModal />
    <DragModal />
    <DynamicModal />
    <SharedDataModal />
    <FormModal />
    <Card class="mb-4" title="基本使用">
      <p class="mb-3">一个基础的弹窗示例</p>
      <Button type="primary" @click="openBaseModal">打开弹窗</Button>
    </Card>
 
    <Card class="mb-4" title="指定容器">
      <p class="mb-3">在内容区域打开弹窗的示例</p>
      <Button type="primary" @click="openInContentModal">打开弹窗</Button>
    </Card>
 
    <Card class="mb-4" title="内容高度自适应">
      <p class="mb-3">可根据内容并自动调整高度</p>
      <Button type="primary" @click="openAutoHeightModal">打开弹窗</Button>
    </Card>
 
    <Card class="mb-4" title="可拖拽示例">
      <p class="mb-3">配置 draggable 可开启拖拽功能</p>
      <Button type="primary" @click="openDragModal">打开弹窗</Button>
    </Card>
 
    <Card class="mb-4" title="动态配置示例">
      <p class="mb-3">通过 setState 动态调整弹窗数据</p>
      <Button type="primary" @click="openDynamicModal">打开弹窗</Button>
      <Button class="ml-2" type="primary" @click="handleUpdateTitle">
        从外部修改标题并打开
      </Button>
    </Card>
 
    <Card class="mb-4" title="内外数据共享示例">
      <p class="mb-3">通过共享 sharedData 来进行数据交互</p>
      <Button type="primary" @click="openSharedModal">
        打开弹窗并传递数据
      </Button>
    </Card>
 
    <Card class="mb-4" title="表单弹窗示例">
      <p class="mb-3">弹窗与表单结合</p>
      <Button type="primary" @click="openFormModal"> 打开弹窗 </Button>
    </Card>
  </Page>
</template>