UNPKG

bootstrap-vue

Version:

With more than 85 components, over 45 available plugins, several directives, and 1000+ icons, BootstrapVue provides one of the most comprehensive implementations of the Bootstrap v4 component and grid system available for Vue.js v2.6, complete with extens

48 lines (43 loc) 1.37 kB
/* Form control contextual state class computation * * Returned class is either 'is-valid' or 'is-invalid' based on the 'state' prop * state can be one of five values: * - true for is-valid * - false for is-invalid * - null for no contextual state */ import { extend } from '../vue' import { PROP_TYPE_BOOLEAN } from '../constants/props' import { isBoolean } from '../utils/inspect' import { makeProp, makePropsConfigurable } from '../utils/props' import { safeVueInstance } from '../utils/safe-vue-instance' // --- Props --- export const props = makePropsConfigurable( { // Tri-state prop: true, false, null (or undefined) state: makeProp(PROP_TYPE_BOOLEAN, null) }, 'formState' ) // --- Mixin --- // @vue/component export const formStateMixin = extend({ props, computed: { computedState() { // If not a boolean, ensure that value is null return isBoolean(this.state) ? this.state : null }, stateClass() { const state = this.computedState return state === true ? 'is-valid' : state === false ? 'is-invalid' : null }, computedAriaInvalid() { const ariaInvalid = safeVueInstance(this).ariaInvalid if (ariaInvalid === true || ariaInvalid === 'true' || ariaInvalid === '') { return 'true' } return this.computedState === false ? 'true' : ariaInvalid } } })