import Vue from '../../utils/vue' import normalizeSlotMixin from '../../mixins/normalize-slot' export const props = { tbodyTransitionProps: { type: Object // default: undefined }, tbodyTransitionHandlers: { type: Object // default: undefined } } // @vue/component export const BTbody = /*#__PURE__*/ Vue.extend({ name: 'BTbody', mixins: [normalizeSlotMixin], inheritAttrs: false, provide() { return { bvTableRowGroup: this } }, inject: { bvTable: { // Sniffed by / / default() /* istanbul ignore next */ { return {} } } }, props, computed: { isTbody() { // Sniffed by / / return true }, isDark() { // Sniffed by / / return this.bvTable.dark }, isStacked() { // Sniffed by / / return this.bvTable.isStacked }, isResponsive() { // Sniffed by / / return this.bvTable.isResponsive }, isStickyHeader() { // Sniffed by / / // Sticky headers are only supported in thead return false }, hasStickyHeader() { // Sniffed by / / // Needed to handle header background classes, due to lack of // background color inheritance with Bootstrap v4 table CSS return !this.isStacked && this.bvTable.stickyHeader }, tableVariant() /* istanbul ignore next: Not currently sniffed in tests */ { // Sniffed by / / return this.bvTable.tableVariant }, isTransitionGroup() { return this.tbodyTransitionProps || this.tbodyTransitionHandlers }, tbodyAttrs() { return { role: 'rowgroup', ...this.$attrs } }, tbodyProps() { return this.tbodyTransitionProps ? { ...this.tbodyTransitionProps, tag: 'tbody' } : {} } }, render(h) { const data = { props: this.tbodyProps, attrs: this.tbodyAttrs } if (this.isTransitionGroup) { // We use native listeners if a transition group // for any delegated events data.on = this.tbodyTransitionHandlers || {} data.nativeOn = this.$listeners || {} } else { // Otherwise we place any listeners on the tbody element data.on = this.$listeners || {} } return h( this.isTransitionGroup ? 'transition-group' : 'tbody', data, this.normalizeSlot('default') ) } })