This repository has been archived by the owner on Nov 30, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 44
/
Dialog.vue
91 lines (85 loc) · 2.79 KB
/
Dialog.vue
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
<template>
<aside class="mdc-dialog" role="alertdialog" :id="id">
<div class="mdc-dialog__surface">
<header class="mdc-dialog__header" v-if="$slots['dialogHeader']">
<h1 v-if="heading === 1" class="mdc-dialog__header__title">
<slot name="dialogHeader" />
</h1>
<h2 v-else-if="heading === 2" class="mdc-dialog__header__title">
<slot name="dialogHeader" />
</h2>
<h3 v-else-if="heading === 3" class="mdc-dialog__header__title">
<slot name="dialogHeader" />
</h3>
</header>
<section class="mdc-dialog__body" v-if="$slots['dialogBody']">
<slot name="dialogBody" />
</section>
<footer class="mdc-dialog__footer" v-if="$slots['dialogAcceptButton'] || $slots['dialogCancelButton'] || $slots['dialogButton']">
<slot name="dialogAcceptButton" />
<slot name="dialogCancelButton" />
<slot name="dialogButton" />
</footer>
</div>
<div class="mdc-dialog__backdrop"></div>
</aside>
</template>
<script>
import { MDCDialog } from '@material/dialog';
export default {
props: {
show: {
type: Boolean,
required: false
},
id: {
type: String,
required: false
},
heading: {
type: Number,
required: true
}
},
data() {
return {
mdcDialog: null
}
},
mounted() {
let vm = this;
vm.mdcDialog = new MDCDialog(this.$el)
vm.mdcDialog.listen('MDCDialog:accept', function() {
vm.$emit('accept')
})
vm.mdcDialog.listen('MDCDialog:cancel', function() {
vm.$emit('cancel')
})
if (vm.$slots.dialogAcceptButton)
vm.$slots.dialogAcceptButton.map((n) => {
n.elm.classList.add('mdc-dialog__footer__button')
n.elm.classList.add('mdc-dialog__footer__button--accept')
})
if (vm.$slots.dialogCancelButton)
vm.$slots.dialogCancelButton.map((n) => {
n.elm.classList.add('mdc-dialog__footer__button')
n.elm.classList.add('mdc-dialog__footer__button--cancel')
})
if (vm.$slots.dialogButton)
vm.$slots.dialogButton.map((n) => {
n.elm.classList.add('mdc-dialog__footer__button')
})
},
destroyed() {
this.mdcDialog.destroy()
},
watch: {
show() {
this.show ? this.mdcDialog.show() : this.mdcDialog.close()
}
}
}
</script>
<style lang="scss">
@import "@material/dialog/mdc-dialog";
</style>