dpzvc3-ui 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/LICENSE +20 -0
  2. package/README.md +175 -0
  3. package/build-style.js +58 -0
  4. package/dist/dpzvc3.esm.js +17676 -0
  5. package/dist/dpzvc3.esm.js.map +1 -0
  6. package/dist/dpzvc3.esm.min.js +2 -0
  7. package/dist/dpzvc3.esm.min.js.map +1 -0
  8. package/dist/dpzvc3.js +15200 -0
  9. package/dist/dpzvc3.js.map +1 -0
  10. package/dist/dpzvc3.min.js +2 -0
  11. package/dist/dpzvc3.min.js.map +1 -0
  12. package/dist/styles/base/font.css +1 -0
  13. package/dist/styles/base/reset.css +1 -0
  14. package/dist/styles/base/variable.css +0 -0
  15. package/dist/styles/components/actionSheet.css +1 -0
  16. package/dist/styles/components/badge.css +1 -0
  17. package/dist/styles/components/button.css +1 -0
  18. package/dist/styles/components/card.css +1 -0
  19. package/dist/styles/components/cell-swipe.css +1 -0
  20. package/dist/styles/components/cell.css +1 -0
  21. package/dist/styles/components/checkBox.css +1 -0
  22. package/dist/styles/components/editor.css +1 -0
  23. package/dist/styles/components/header.css +1 -0
  24. package/dist/styles/components/indicator.css +1 -0
  25. package/dist/styles/components/loadmore.css +1 -0
  26. package/dist/styles/components/message.css +1 -0
  27. package/dist/styles/components/modal.css +1 -0
  28. package/dist/styles/components/number.css +1 -0
  29. package/dist/styles/components/picker.css +1 -0
  30. package/dist/styles/components/popup.css +1 -0
  31. package/dist/styles/components/progress.css +1 -0
  32. package/dist/styles/components/prompt.css +1 -0
  33. package/dist/styles/components/radioBox.css +1 -0
  34. package/dist/styles/components/slide-Bar.css +1 -0
  35. package/dist/styles/components/spinner.css +1 -0
  36. package/dist/styles/components/swipe.css +1 -0
  37. package/dist/styles/components/switchBar.css +1 -0
  38. package/dist/styles/components/tab.css +1 -0
  39. package/dist/styles/components/text.css +1 -0
  40. package/dist/styles/components/toTop.css +1 -0
  41. package/dist/styles/components/upload.css +1 -0
  42. package/dist/styles/dpzvc3.css +1 -0
  43. package/dist/styles/utils/1px.css +1 -0
  44. package/dist/styles/utils/animation.css +1 -0
  45. package/dist/styles/utils/nowrap.css +1 -0
  46. package/dist-prod/91.9d79b442ec3131707419.js +3 -0
  47. package/dist-prod/91.9d79b442ec3131707419.js.LICENSE.txt +25 -0
  48. package/dist-prod/91.9d79b442ec3131707419.js.map +1 -0
  49. package/dist-prod/actionsheet.e2f7c32d0120f5147a4f.chunk.js +2 -0
  50. package/dist-prod/actionsheet.e2f7c32d0120f5147a4f.chunk.js.map +1 -0
  51. package/dist-prod/badge.6038c4ccc54ffb56a645.chunk.js +2 -0
  52. package/dist-prod/badge.6038c4ccc54ffb56a645.chunk.js.map +1 -0
  53. package/dist-prod/button.28b491339fbba29c3f16.chunk.js +2 -0
  54. package/dist-prod/button.28b491339fbba29c3f16.chunk.js.map +1 -0
  55. package/dist-prod/card.3ad847f07bebc1391125.chunk.js +2 -0
  56. package/dist-prod/card.3ad847f07bebc1391125.chunk.js.map +1 -0
  57. package/dist-prod/cell.8920796a9ebd2d84bbd3.chunk.js +2 -0
  58. package/dist-prod/cell.8920796a9ebd2d84bbd3.chunk.js.map +1 -0
  59. package/dist-prod/cellswipe.53b0178e4638c201dcf1.chunk.js +2 -0
  60. package/dist-prod/cellswipe.53b0178e4638c201dcf1.chunk.js.map +1 -0
  61. package/dist-prod/checkbox.87403976981ee0f64f4a.chunk.js +2 -0
  62. package/dist-prod/checkbox.87403976981ee0f64f4a.chunk.js.map +1 -0
  63. package/dist-prod/guide.5195c74796a7a0e37f7b.chunk.js +2 -0
  64. package/dist-prod/guide.5195c74796a7a0e37f7b.chunk.js.map +1 -0
  65. package/dist-prod/header.e3cecc6d60f801c1c105.chunk.js +2 -0
  66. package/dist-prod/header.e3cecc6d60f801c1c105.chunk.js.map +1 -0
  67. package/dist-prod/index.html +19 -0
  68. package/dist-prod/indicator.6b0c7a91ca254c3586e8.chunk.js +2 -0
  69. package/dist-prod/indicator.6b0c7a91ca254c3586e8.chunk.js.map +1 -0
  70. package/dist-prod/loadmore.ba86c35311fc68ee215b.chunk.js +2 -0
  71. package/dist-prod/loadmore.ba86c35311fc68ee215b.chunk.js.map +1 -0
  72. package/dist-prod/main.2e9aaa9095e329ea2d7b.js +2 -0
  73. package/dist-prod/main.2e9aaa9095e329ea2d7b.js.map +1 -0
  74. package/dist-prod/message.e57fa263a214006f7191.chunk.js +2 -0
  75. package/dist-prod/message.e57fa263a214006f7191.chunk.js.map +1 -0
  76. package/dist-prod/modal.1172c8ba7d90503fc8e8.chunk.js +2 -0
  77. package/dist-prod/modal.1172c8ba7d90503fc8e8.chunk.js.map +1 -0
  78. package/dist-prod/picker.4ff114161c5c3f8df57a.chunk.js +2 -0
  79. package/dist-prod/picker.4ff114161c5c3f8df57a.chunk.js.map +1 -0
  80. package/dist-prod/popup.8f92c027932e4d47fa59.chunk.js +2 -0
  81. package/dist-prod/popup.8f92c027932e4d47fa59.chunk.js.map +1 -0
  82. package/dist-prod/progress.1e0d785044aecadc5615.chunk.js +2 -0
  83. package/dist-prod/progress.1e0d785044aecadc5615.chunk.js.map +1 -0
  84. package/dist-prod/prompt.c2b442c3dd0e6d8319bc.chunk.js +2 -0
  85. package/dist-prod/prompt.c2b442c3dd0e6d8319bc.chunk.js.map +1 -0
  86. package/dist-prod/radiobox.479703c69b75d473e85d.chunk.js +2 -0
  87. package/dist-prod/radiobox.479703c69b75d473e85d.chunk.js.map +1 -0
  88. package/dist-prod/rater.939e0e7e770728f684c3.chunk.js +2 -0
  89. package/dist-prod/rater.939e0e7e770728f684c3.chunk.js.map +1 -0
  90. package/dist-prod/slidebar.3d3f48a631f03a2210c9.chunk.js +2 -0
  91. package/dist-prod/slidebar.3d3f48a631f03a2210c9.chunk.js.map +1 -0
  92. package/dist-prod/spinner.f20e3bd8cec27d26afe0.chunk.js +2 -0
  93. package/dist-prod/spinner.f20e3bd8cec27d26afe0.chunk.js.map +1 -0
  94. package/dist-prod/swipe.2e5b0acc3bbb2bf49dd5.chunk.js +2 -0
  95. package/dist-prod/swipe.2e5b0acc3bbb2bf49dd5.chunk.js.map +1 -0
  96. package/dist-prod/switchbar.56d03d96c275ff4c65a1.chunk.js +2 -0
  97. package/dist-prod/switchbar.56d03d96c275ff4c65a1.chunk.js.map +1 -0
  98. package/dist-prod/tab.4c391211c41b7d12b585.chunk.js +2 -0
  99. package/dist-prod/tab.4c391211c41b7d12b585.chunk.js.map +1 -0
  100. package/dist-prod/text.ee2804ba87e6a460aa7d.chunk.js +2 -0
  101. package/dist-prod/text.ee2804ba87e6a460aa7d.chunk.js.map +1 -0
  102. package/dist-prod/totop.c6f9dce152bb6abe5cb2.chunk.js +2 -0
  103. package/dist-prod/totop.c6f9dce152bb6abe5cb2.chunk.js.map +1 -0
  104. package/dist-prod/upload.ec7a954970889869d93e.chunk.js +2 -0
  105. package/dist-prod/upload.ec7a954970889869d93e.chunk.js.map +1 -0
  106. package/images/IMG_2614 2 2.JPG +0 -0
  107. package/images/IMG_2614.JPG +0 -0
  108. package/images/IMG_2615 2.JPG +0 -0
  109. package/images/IMG_2615.JPG +0 -0
  110. package/package.json +113 -0
  111. package/postcss.config.js +5 -0
  112. package/src/components/Indicator/Indicator.vue +82 -0
  113. package/src/components/Indicator/index.js +86 -0
  114. package/src/components/Text/Number.vue +167 -0
  115. package/src/components/Text/index.js +7 -0
  116. package/src/components/Text/textBar.vue +122 -0
  117. package/src/components/action-sheet/actionSheet.vue +93 -0
  118. package/src/components/action-sheet/index.js +5 -0
  119. package/src/components/app.vue +61 -0
  120. package/src/components/badge/badge.vue +80 -0
  121. package/src/components/badge/index.js +5 -0
  122. package/src/components/button/button.vue +111 -0
  123. package/src/components/button/index.js +5 -0
  124. package/src/components/card/card.vue +49 -0
  125. package/src/components/card/index.js +5 -0
  126. package/src/components/cell/cell.vue +93 -0
  127. package/src/components/cell/index.js +5 -0
  128. package/src/components/cell-swipe/cell-swipe.vue +169 -0
  129. package/src/components/cell-swipe/index.js +5 -0
  130. package/src/components/checkBox/checkbox-group.vue +74 -0
  131. package/src/components/checkBox/checkbox.vue +117 -0
  132. package/src/components/checkBox/index.js +8 -0
  133. package/src/components/header/header.vue +130 -0
  134. package/src/components/header/index.js +5 -0
  135. package/src/components/loadMore/index.js +5 -0
  136. package/src/components/loadMore/loadmore.vue +258 -0
  137. package/src/components/message/confirm.js +60 -0
  138. package/src/components/message/index.js +111 -0
  139. package/src/components/message/message.vue +137 -0
  140. package/src/components/message/messageGroup.vue +82 -0
  141. package/src/components/modal/confirm.js +122 -0
  142. package/src/components/modal/index.js +52 -0
  143. package/src/components/modal/modal.vue +138 -0
  144. package/src/components/picker/area-picker/area-picker.vue +230 -0
  145. package/src/components/picker/area-picker/props.js +17 -0
  146. package/src/components/picker/date-picker/date-picker.vue +191 -0
  147. package/src/components/picker/date-picker/props.js +24 -0
  148. package/src/components/picker/index.js +5 -0
  149. package/src/components/picker/normal-picker/normal-picker.vue +120 -0
  150. package/src/components/picker/normal-picker/props.js +20 -0
  151. package/src/components/picker/picker-slot.vue +217 -0
  152. package/src/components/picker/picker.vue +111 -0
  153. package/src/components/popup/index.js +5 -0
  154. package/src/components/popup/popup.vue +91 -0
  155. package/src/components/progress/index.js +5 -0
  156. package/src/components/progress/progress.vue +86 -0
  157. package/src/components/prompt/confirm.js +91 -0
  158. package/src/components/prompt/index.js +53 -0
  159. package/src/components/prompt/prompt.vue +125 -0
  160. package/src/components/radioBox/index.js +8 -0
  161. package/src/components/radioBox/radiobox-group.vue +66 -0
  162. package/src/components/radioBox/radiobox.vue +88 -0
  163. package/src/components/rater/index.js +5 -0
  164. package/src/components/rater/rater.vue +118 -0
  165. package/src/components/slideBar/index.js +6 -0
  166. package/src/components/slideBar/slideBar.vue +207 -0
  167. package/src/components/spinner/behavior/blade.vue +42 -0
  168. package/src/components/spinner/behavior/double-bounce.vue +38 -0
  169. package/src/components/spinner/behavior/fading-circle.vue +55 -0
  170. package/src/components/spinner/behavior/snake.vue +41 -0
  171. package/src/components/spinner/behavior/triple-bounce.vue +52 -0
  172. package/src/components/spinner/index.js +5 -0
  173. package/src/components/spinner/props.js +28 -0
  174. package/src/components/spinner/spinner.vue +78 -0
  175. package/src/components/swipe/index.js +5 -0
  176. package/src/components/swipe/swipe.vue +281 -0
  177. package/src/components/switchbar/index.js +5 -0
  178. package/src/components/switchbar/switchbar.vue +79 -0
  179. package/src/components/tab/index.js +6 -0
  180. package/src/components/tab/tab.vue +89 -0
  181. package/src/components/toTop/index.js +5 -0
  182. package/src/components/toTop/topTop.vue +78 -0
  183. package/src/components/upload/index.js +5 -0
  184. package/src/components/upload/upload.vue +166 -0
  185. package/src/config/config.js +16 -0
  186. package/src/directives/clickoutside.js +42 -0
  187. package/src/directives/tranferDom.js +66 -0
  188. package/src/index.js +149 -0
  189. package/src/lib/MegaPixImage.js +163 -0
  190. package/src/lib/MegaPixImageOld.js +153 -0
  191. package/src/lib/exif-js.js +235 -0
  192. package/src/lib/exif.js +789 -0
  193. package/src/main.js +31 -0
  194. package/src/mixin/emitter.js +72 -0
  195. package/src/mixin/input.js +41 -0
  196. package/src/router.js +36 -0
  197. package/src/styles/base/font.less +99 -0
  198. package/src/styles/base/reset.less +135 -0
  199. package/src/styles/base/variable.less +108 -0
  200. package/src/styles/components/actionSheet.less +43 -0
  201. package/src/styles/components/badge.less +81 -0
  202. package/src/styles/components/button.less +124 -0
  203. package/src/styles/components/card.less +31 -0
  204. package/src/styles/components/cell-swipe.less +20 -0
  205. package/src/styles/components/cell.less +75 -0
  206. package/src/styles/components/checkBox.less +113 -0
  207. package/src/styles/components/editor.less +3 -0
  208. package/src/styles/components/header.less +72 -0
  209. package/src/styles/components/indicator.less +39 -0
  210. package/src/styles/components/loadmore.less +48 -0
  211. package/src/styles/components/message.less +57 -0
  212. package/src/styles/components/modal.less +84 -0
  213. package/src/styles/components/number.less +60 -0
  214. package/src/styles/components/picker.less +152 -0
  215. package/src/styles/components/popup.less +46 -0
  216. package/src/styles/components/progress.less +52 -0
  217. package/src/styles/components/prompt.less +37 -0
  218. package/src/styles/components/radioBox.less +138 -0
  219. package/src/styles/components/slide-Bar.less +149 -0
  220. package/src/styles/components/spinner.less +329 -0
  221. package/src/styles/components/swipe.less +125 -0
  222. package/src/styles/components/switchBar.less +88 -0
  223. package/src/styles/components/tab.less +71 -0
  224. package/src/styles/components/text.less +82 -0
  225. package/src/styles/components/toTop.less +28 -0
  226. package/src/styles/components/upload.less +23 -0
  227. package/src/styles/index.less +38 -0
  228. package/src/styles/utils/1px.less +206 -0
  229. package/src/styles/utils/animation.less +165 -0
  230. package/src/styles/utils/nowrap.less +19 -0
  231. package/src/template/index.ejs +40 -0
  232. package/src/utils/util.js +202 -0
  233. package/src/vconsole-resources.min.js +6 -0
  234. package/src/vconsole-sources.min.js +6 -0
  235. package/src/vconsole.min.js +7 -0
  236. package/src/views/ActionSheet.vue +46 -0
  237. package/src/views/Badge.vue +51 -0
  238. package/src/views/Button.vue +69 -0
  239. package/src/views/Card.vue +88 -0
  240. package/src/views/Cell.vue +30 -0
  241. package/src/views/CellSwipe.vue +68 -0
  242. package/src/views/CheckBox.vue +77 -0
  243. package/src/views/Header.vue +70 -0
  244. package/src/views/Indicator.vue +82 -0
  245. package/src/views/LoadMore.vue +73 -0
  246. package/src/views/Message.vue +61 -0
  247. package/src/views/Modal.vue +69 -0
  248. package/src/views/Picker.vue +140 -0
  249. package/src/views/Popup.vue +97 -0
  250. package/src/views/Progress.vue +47 -0
  251. package/src/views/Prompt.vue +43 -0
  252. package/src/views/RadioBox.vue +68 -0
  253. package/src/views/Rater.vue +49 -0
  254. package/src/views/SlideBar.vue +55 -0
  255. package/src/views/Spinner.vue +15 -0
  256. package/src/views/Swipe.vue +59 -0
  257. package/src/views/SwitchBar.vue +47 -0
  258. package/src/views/Tab.vue +53 -0
  259. package/src/views/Text.vue +93 -0
  260. package/src/views/ToTop.vue +17 -0
  261. package/src/views/Upload.vue +61 -0
  262. package/src/views/guide.vue +164 -0
  263. package/src/views/index.vue +554 -0
  264. package/webpack.base.config.js +65 -0
  265. package/webpack.dev.config.js +42 -0
  266. package/webpack.dist.dev.config.js +75 -0
  267. package/webpack.dist.prod.config.js +89 -0
  268. package/webpack.prod.config.js +51 -0
@@ -0,0 +1,137 @@
1
+ <template>
2
+ <transition name="dpzvc3-ani-scale">
3
+ <div :class="classes">
4
+ <div
5
+ v-if="showLeft"
6
+ :class="leftClasses"
7
+ >
8
+ <slot name="message-left">
9
+ <Spinner
10
+ size="65"
11
+ type="blade"
12
+ color="#ffffff"
13
+ />
14
+ </slot>
15
+ </div>
16
+
17
+ <p :class="wrapperClasses">
18
+ {{ text }}
19
+ </p>
20
+
21
+ <div
22
+ v-if="!rightHide"
23
+ :class="rightClasses"
24
+ >
25
+ <slot name="message-right" />
26
+ </div>
27
+ </div>
28
+ </transition>
29
+ </template>
30
+
31
+ <script>
32
+ import { defineComponent, computed, onMounted, onBeforeUnmount, inject } from 'vue'
33
+ import Spinner from '../spinner'
34
+
35
+ const prefixCls = 'dpzvc3-message'
36
+
37
+ export default defineComponent({
38
+ name: 'DpzMessage',
39
+ components: { Spinner },
40
+
41
+ props: {
42
+ name: {
43
+ type: [String, Number],
44
+ required: true
45
+ },
46
+ text: {
47
+ type: [String, Number],
48
+ default: ''
49
+ },
50
+ duration: {
51
+ type: Number,
52
+ default: 1.5
53
+ },
54
+ showLeft: {
55
+ type: Boolean,
56
+ default: false
57
+ },
58
+ rightHide: {
59
+ type: Boolean,
60
+ default: true
61
+ },
62
+ type: {
63
+ type: String,
64
+ default: 'normal',
65
+ validator: val =>
66
+ ['success', 'loading', 'error', 'normal', 'warning', 'danger'].includes(val)
67
+ },
68
+ onClose: {
69
+ type: Function,
70
+ default: () => {}
71
+ },
72
+ position: {
73
+ type: String,
74
+ default: 'top'
75
+ }
76
+ },
77
+
78
+ setup (props) {
79
+ /** 🔑 从 messageGroup 注入 remove 方法 */
80
+ const remove = inject('removeMessage')
81
+
82
+ let timer = null
83
+
84
+ const classes = computed(() => [
85
+ prefixCls,
86
+ `${prefixCls}-position-${props.position}`
87
+ ])
88
+
89
+ const wrapperClasses = computed(() => [
90
+ `${prefixCls}-text`
91
+ ])
92
+
93
+ const leftClasses = computed(() => [
94
+ `${prefixCls}-left`
95
+ ])
96
+
97
+ const rightClasses = computed(() => [
98
+ `${prefixCls}-right`
99
+ ])
100
+
101
+ const closeTimer = () => {
102
+ if (timer) {
103
+ clearTimeout(timer)
104
+ timer = null
105
+ }
106
+ }
107
+
108
+ const close = () => {
109
+ closeTimer()
110
+ remove && remove(props.name)
111
+ props.onClose()
112
+ }
113
+
114
+ onMounted(() => {
115
+ closeTimer()
116
+
117
+ if (props.duration !== 0) {
118
+ timer = setTimeout(() => {
119
+ close()
120
+ }, props.duration * 1000)
121
+ }
122
+ })
123
+
124
+ onBeforeUnmount(() => {
125
+ closeTimer()
126
+ })
127
+
128
+ return {
129
+ classes,
130
+ wrapperClasses,
131
+ leftClasses,
132
+ rightClasses,
133
+ close
134
+ }
135
+ }
136
+ })
137
+ </script>
@@ -0,0 +1,82 @@
1
+ <template>
2
+ <div
3
+ class="dpzvc3-message-group"
4
+ :style="styles"
5
+ >
6
+ <Message
7
+ v-for="message in messages"
8
+ :key="message.name"
9
+ :name="message.name"
10
+ :text="message.text"
11
+ :duration="message.duration"
12
+ :show-left="message.showLeft"
13
+ :right-hide="message.rightHide"
14
+ :type="message.type"
15
+ :position="message.position"
16
+ :on-close="message.onClose"
17
+ />
18
+ </div>
19
+ </template>
20
+
21
+ <script>
22
+ import { defineComponent, ref, provide } from 'vue'
23
+ import Message from './message.vue'
24
+
25
+ export default defineComponent({
26
+ name: 'MessageGroup',
27
+ components: {
28
+ Message
29
+ },
30
+ props: {
31
+ styles: {
32
+ type: Object,
33
+ default: () => ({})
34
+ }
35
+ },
36
+
37
+ setup () {
38
+ const messages = ref([])
39
+
40
+ /** 添加 message */
41
+ const add = (props = {}) => {
42
+ const message = Object.assign(
43
+ {
44
+ name: '',
45
+ text: '',
46
+ duration: 1.5,
47
+ showLeft: false,
48
+ rightHide: true,
49
+ type: 'normal',
50
+ position: 'top',
51
+ onClose: () => {}
52
+ },
53
+ props
54
+ )
55
+
56
+ messages.value.push(message)
57
+ }
58
+
59
+ /** 移除 message(供 message.vue 注入使用) */
60
+ const remove = (name) => {
61
+ messages.value = messages.value.filter(
62
+ item => item.name !== name
63
+ )
64
+ }
65
+
66
+ /** 关闭所有 */
67
+ const closeAll = () => {
68
+ messages.value = []
69
+ }
70
+
71
+ /** 🔑 向子组件注入 remove 方法 */
72
+ provide('removeMessage', remove)
73
+
74
+ return {
75
+ messages,
76
+ add,
77
+ remove,
78
+ closeAll
79
+ }
80
+ }
81
+ })
82
+ </script>
@@ -0,0 +1,122 @@
1
+ /**
2
+ * confirm.js - Vue 3 版本(修复 enter 过渡)
3
+ */
4
+ import { h, createVNode, render } from 'vue'
5
+ import Modal from './modal.vue'
6
+ import VButton from '../button'
7
+
8
+ const prefixCls = 'dpzvc3-modal'
9
+
10
+ function createModalInstance (properties = {}) {
11
+ const container = document.createElement('div')
12
+ document.body.appendChild(container)
13
+
14
+ let vnode = null
15
+
16
+ const defaultProps = {
17
+ visible: false,
18
+ modelValue: false,
19
+ width: '70%',
20
+ body: '',
21
+ title: '',
22
+ okText: '确定',
23
+ cancleText: '取消',
24
+ loading: false,
25
+ buttonLoading: false,
26
+ showCancle: true,
27
+ showHead: true,
28
+ onOk: () => {},
29
+ onCancle: () => {},
30
+ onRemove: () => {}
31
+ }
32
+
33
+ const props = { ...defaultProps, ...properties }
34
+
35
+ const updateVNode = () => {
36
+ const footer = [
37
+ props.showCancle
38
+ ? h(VButton, { type: 'primary', radius: false, onClick: cancle }, () => props.cancleText)
39
+ : null,
40
+ h(
41
+ VButton,
42
+ { type: 'normal', radius: false, loading: props.buttonLoading, onClick: ok },
43
+ () => props.okText
44
+ )
45
+ ]
46
+
47
+ vnode = createVNode(
48
+ Modal,
49
+ {
50
+ modelValue: props.modelValue,
51
+ width: props.width,
52
+ showHead: props.showHead,
53
+ footerHide: false,
54
+ onOk: ok,
55
+ onCancle: cancle
56
+ },
57
+ {
58
+ header: () =>
59
+ h('div', {
60
+ class: `${prefixCls}-header-inner ellipse-fir`,
61
+ innerHTML: props.title
62
+ }),
63
+ body: () =>
64
+ h('div', {
65
+ class: `${prefixCls}-body-inner`,
66
+ innerHTML: props.body
67
+ }),
68
+ footer: () => footer
69
+ }
70
+ )
71
+
72
+ render(vnode, container)
73
+ }
74
+
75
+ const remove = () => {
76
+ props.modelValue = false
77
+ updateVNode()
78
+ setTimeout(destroy, 300)
79
+ }
80
+
81
+ const destroy = () => {
82
+ render(null, container)
83
+ container.parentNode && container.parentNode.removeChild(container)
84
+ props.onRemove()
85
+ }
86
+
87
+ const ok = () => {
88
+ if (props.loading) {
89
+ props.buttonLoading = true
90
+ } else {
91
+ remove()
92
+ }
93
+ props.onOk()
94
+ }
95
+
96
+ const cancle = () => {
97
+ remove()
98
+ props.onCancle()
99
+ }
100
+
101
+ return {
102
+ show (newProps = {}) {
103
+ Object.assign(props, newProps)
104
+
105
+ // 👇 关键:先 render hidden
106
+ props.modelValue = false
107
+ updateVNode()
108
+
109
+ // 👇 下一帧再显示,触发 enter
110
+ requestAnimationFrame(() => {
111
+ props.modelValue = true
112
+ updateVNode()
113
+ })
114
+ },
115
+ remove,
116
+ component: props
117
+ }
118
+ }
119
+
120
+ export default {
121
+ newInstance: createModalInstance
122
+ }
@@ -0,0 +1,52 @@
1
+ /**
2
+ * index.js - Vue 3 版本
3
+ */
4
+ import Modal from './confirm'
5
+
6
+ let modalInstance = null
7
+
8
+ function getModalInstance () {
9
+ if (!modalInstance) {
10
+ modalInstance = Modal.newInstance({
11
+ showHead: true,
12
+ closable: true,
13
+ maskClosable: false,
14
+ footerHide: false
15
+ })
16
+ }
17
+ return modalInstance
18
+ }
19
+
20
+ function confirm (options = {}) {
21
+ const instance = getModalInstance()
22
+
23
+ options.onRemove = () => {
24
+ modalInstance = null
25
+ }
26
+
27
+ instance.show(options)
28
+ return instance
29
+ }
30
+
31
+ // info 模态框,显示取消按钮
32
+ Modal.info = function (props = {}) {
33
+ props.showCancle = true
34
+ props.showHead = false
35
+ return confirm(props)
36
+ }
37
+
38
+ // confirm 模态框,不显示取消按钮
39
+ Modal.confirm = function (props = {}) {
40
+ props.showCancle = false
41
+ props.showHead = false
42
+ return confirm(props)
43
+ }
44
+
45
+ // 移除当前 modal
46
+ Modal.remove = function () {
47
+ if (!modalInstance) return false
48
+ const instance = getModalInstance()
49
+ instance.remove()
50
+ }
51
+
52
+ export default Modal
@@ -0,0 +1,138 @@
1
+ <template>
2
+ <div>
3
+ <!-- 遮罩层 -->
4
+ <transition name="dpzvc3-ani-fade">
5
+ <div
6
+ v-if="visible"
7
+ class="dpzvc3-modal-mask"
8
+ @click="mask"
9
+ @touchstart.prevent
10
+ @touchmove.prevent
11
+ @touchend.prevent
12
+ />
13
+ </transition>
14
+
15
+ <!-- 弹窗内容 -->
16
+ <transition name="dpzvc3-ani-scale">
17
+ <div
18
+ v-if="visible"
19
+ class="dpzvc3-modal"
20
+ :style="getWrapperStyle"
21
+ >
22
+ <!-- 头部 -->
23
+ <div
24
+ v-if="isHead"
25
+ class="dpzvc3-modal-header"
26
+ >
27
+ <slot name="header">
28
+ <div class="dpzvc3-modal-header-inner ellipse-fir">
29
+ {{ title }}
30
+ </div>
31
+ </slot>
32
+ </div>
33
+
34
+ <!-- 内容 -->
35
+ <div class="dpzvc3-modal-body">
36
+ <slot name="body">
37
+ {{ body }}
38
+ </slot>
39
+ </div>
40
+
41
+ <!-- 底部 -->
42
+ <div
43
+ v-if="!footerHide"
44
+ class="dpzvc3-modal-footer"
45
+ >
46
+ <slot name="footer">
47
+ <VButton
48
+ v-if="cancleText"
49
+ type="primary"
50
+ @click="close"
51
+ >
52
+ {{ cancleText }}
53
+ </VButton>
54
+ <VButton
55
+ type="normal"
56
+ :loading="buttonLoading"
57
+ @click="ok"
58
+ >
59
+ {{ okText }}
60
+ </VButton>
61
+ </slot>
62
+ </div>
63
+ </div>
64
+ </transition>
65
+ </div>
66
+ </template>
67
+
68
+ <script>
69
+ import { ref, computed, watch } from 'vue'
70
+ import VButton from '../button'
71
+
72
+ export default {
73
+ name: 'Dpzvc3Modal',
74
+ components: { VButton },
75
+ props: {
76
+ modelValue: { type: Boolean, default: false },
77
+ maskClosable: { type: Boolean, default: true },
78
+ title: String,
79
+ width: { type: String, default: '70%' },
80
+ okText: { type: String, default: '确定' },
81
+ cancleText: { type: String, default: '取消' },
82
+ loading: { type: Boolean, default: false },
83
+ styles: Object,
84
+ showHead: { type: Boolean, default: true },
85
+ footerHide: { type: Boolean, default: false },
86
+ body: String
87
+ },
88
+ setup (props, { emit }) {
89
+ const visible = ref(props.modelValue)
90
+ const isHead = ref(props.showHead)
91
+ const buttonLoading = ref(false)
92
+
93
+ const getWrapperStyle = computed(() => {
94
+ return Object.assign(
95
+ { width: props.width },
96
+ props.styles || {}
97
+ )
98
+ })
99
+
100
+ // watch props changes
101
+ watch(() => props.modelValue, (val) => { visible.value = val })
102
+ watch(() => props.showHead, (val) => { isHead.value = val })
103
+
104
+ // methods
105
+ const close = () => {
106
+ // visible.value = false
107
+ emit('update:modelValue', false)
108
+ emit('on-cancle')
109
+ }
110
+
111
+ const mask = () => {
112
+ if (props.maskClosable && !buttonLoading.value) {
113
+ close()
114
+ }
115
+ }
116
+
117
+ const ok = () => {
118
+ if (props.loading) {
119
+ buttonLoading.value = true
120
+ } else {
121
+ // visible.value = false
122
+ emit('update:modelValue', false)
123
+ }
124
+ emit('on-ok')
125
+ }
126
+
127
+ return {
128
+ visible,
129
+ isHead,
130
+ buttonLoading,
131
+ getWrapperStyle,
132
+ close,
133
+ mask,
134
+ ok
135
+ }
136
+ }
137
+ }
138
+ </script>