vuetify
Version:
Vue.js 2 Semantic Component Framework
108 lines (93 loc) • 2.51 kB
text/typescript
// Styles
import '../../stylus/components/_alerts.styl'
// Components
import VIcon from '../VIcon'
// Mixins
import Colorable from '../../mixins/colorable'
import Toggleable from '../../mixins/toggleable'
import Transitionable from '../../mixins/transitionable'
// Types
import { VNode } from 'vue/types'
import mixins from '../../util/mixins'
/* @vue/component */
export default mixins(Colorable, Toggleable, Transitionable).extend({
name: 'v-alert',
props: {
dismissible: Boolean,
icon: String,
outline: Boolean,
type: {
type: String,
validator (val: string) {
return [
'info',
'error',
'success',
'warning'
].includes(val)
}
}
},
computed: {
computedColor (): string {
return (this.type && !this.color) ? this.type : (this.color || 'error')
},
computedIcon (): string | void {
if (this.icon || !this.type) return this.icon
switch (this.type) {
case 'info': return '$vuetify.icons.info'
case 'error': return '$vuetify.icons.error'
case 'success': return '$vuetify.icons.success'
case 'warning': return '$vuetify.icons.warning'
}
}
},
methods: {
genIcon (): VNode | null {
if (!this.computedIcon) return null
return this.$createElement(VIcon, {
'class': 'v-alert__icon'
}, this.computedIcon)
},
genDismissible (): VNode | null {
if (!this.dismissible) return null
return this.$createElement('a', {
'class': 'v-alert__dismissible',
on: { click: () => { this.isActive = false } }
}, [
this.$createElement(VIcon, {
props: {
right: true
}
}, '$vuetify.icons.cancel')
])
}
},
render (h): VNode {
const children = [
this.genIcon(),
h('div', this.$slots.default),
this.genDismissible()
] as any
const setColor = this.outline ? this.setTextColor : this.setBackgroundColor
const alert = h('div', setColor(this.computedColor, {
staticClass: 'v-alert',
'class': {
'v-alert--outline': this.outline
},
directives: [{
name: 'show',
value: this.isActive
}] as any,
on: this.$listeners
}), children)
if (!this.transition) return alert
return h('transition', {
props: {
name: this.transition,
origin: this.origin,
mode: this.mode
}
}, [alert])
}
})