@coreui/vue
Version:
UI Components Library for Vue.js
53 lines (48 loc) • 1.31 kB
text/typescript
import { defineComponent, h, inject, resolveComponent } from 'vue'
import { CCloseButton } from '../close-button/CCloseButton'
import type { ComponentProps } from '../../utils/ComponentProps'
interface CCloseButtonProps extends ComponentProps<typeof CCloseButton> {
as?: string
}
const CToastClose = defineComponent({
name: 'CToastClose',
props: {
/**
* Component used for the root node. Either a string to use a HTML element or a component.
*/
as: String,
...CCloseButton.props,
},
emits: [
/**
* Event called before the dissmiss animation has started.
*/
'close',
],
setup(props: CCloseButtonProps, { slots, emit }) {
// eslint-disable-next-line no-unused-vars
const updateVisible = inject('updateVisible') as (visible: boolean) => void
const handleClose = () => {
emit('close')
updateVisible(false)
}
return () =>
props.as
? h(
resolveComponent(props.as),
{
onClick: () => {
handleClose()
},
},
() => slots.default && slots.default(),
)
: h(CCloseButton, {
...props,
onClick: () => {
handleClose()
},
})
},
})
export { CToastClose }