UNPKG

bootstrap-vue

Version:

BootstrapVue provides one of the most comprehensive implementations of Bootstrap 4 components and grid system for Vue.js and with extensive and automated WAI-ARIA accessibility markup.

27 lines (24 loc) 852 B
import { bindTargets, unbindTargets } from '../../utils/target' import { setAttr, removeAttr } from '../../utils/dom' const listenTypes = {click: true} export default { // eslint-disable-next-line no-shadow-restricted-names bind (el, binding, vnode) { bindTargets(vnode, binding, listenTypes, ({targets, vnode}) => { targets.forEach(target => { vnode.context.$root.$emit('bv::show::modal', target, vnode.elm) }) }) if (el.tagName !== 'BUTTON') { // If element is not a button, we add `role="button"` for accessibility setAttr(el, 'role', 'button') } }, unbind (el, binding, vnode) { unbindTargets(vnode, binding, listenTypes) if (el.tagName !== 'BUTTON') { // If element is not a button, we add `role="button"` for accessibility removeAttr(el, 'role', 'button') } } }