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

77 lines (73 loc) 1.93 kB
import { stopEvent } from '../../../utils/events' import { isFunction } from '../../../utils/inspect' import { BTr } from '../tr' import { BTd } from '../td' const busySlotName = 'table-busy' export default { props: { busy: { type: Boolean, default: false } }, data() { return { localBusy: false } }, computed: { computedBusy() { return this.busy || this.localBusy } }, watch: { localBusy(newVal, oldVal) { if (newVal !== oldVal) { this.$emit('update:busy', newVal) } } }, methods: { // Event handler helper stopIfBusy(evt) { if (this.computedBusy) { // If table is busy (via provider) then don't propagate stopEvent(evt) return true } return false }, // Render the busy indicator or return `null` if not busy renderBusy() { const h = this.$createElement // Return a busy indicator row, or `null` if not busy if (this.computedBusy && this.hasNormalizedSlot(busySlotName)) { // Show the busy slot return h( BTr, { key: 'table-busy-slot', staticClass: 'b-table-busy-slot', class: [ isFunction(this.tbodyTrClass) ? /* istanbul ignore next */ this.tbodyTrClass(null, busySlotName) : this.tbodyTrClass ], attrs: isFunction(this.tbodyTrAttr) ? /* istanbul ignore next */ this.tbodyTrAttr(null, busySlotName) : this.tbodyTrAttr }, [ h(BTd, { props: { colspan: this.computedFields.length || null } }, [ this.normalizeSlot(busySlotName) ]) ] ) } else { // We return `null` here so that we can determine if we need to // render the table items rows or not return null } } } }