import Vue from '../../utils/vue' import normalizeSlotMixin from '../../mixins/normalize-slot' export const props = { variant: { type: String, default: null } } const LIGHT = 'light' const DARK = 'dark' // @vue/component export const BTr = /*#__PURE__*/ Vue.extend({ name: 'BTr', mixins: [normalizeSlotMixin], inheritAttrs: false, provide() { return { bvTableTr: this } }, inject: { bvTableRowGroup: { default() /* istanbul ignore next */ { return {} } } }, props, computed: { inTbody() { // Sniffed by / return this.bvTableRowGroup.isTbody }, inThead() { // Sniffed by / return this.bvTableRowGroup.isThead }, inTfoot() { // Sniffed by / return this.bvTableRowGroup.isTfoot }, isDark() { // Sniffed by / return this.bvTableRowGroup.isDark }, isStacked() { // Sniffed by / return this.bvTableRowGroup.isStacked }, isResponsive() { // Sniffed by / return this.bvTableRowGroup.isResponsive }, isStickyHeader() { // Sniffed by / // Sticky headers are only supported in thead return this.bvTableRowGroup.isStickyHeader }, 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.bvTableRowGroup.hasStickyHeader }, tableVariant() { // Sniffed by / return this.bvTableRowGroup.tableVariant }, headVariant() { // Sniffed by / return this.inThead ? this.bvTableRowGroup.headVariant : null }, footVariant() { // Sniffed by / return this.inTfoot ? this.bvTableRowGroup.footVariant : null }, isRowDark() { return this.headVariant === LIGHT || this.footVariant === LIGHT ? false : this.headVariant === DARK || this.footVariant === DARK ? true : this.isDark }, trClasses() { return [this.variant ? `${this.isRowDark ? 'bg' : 'table'}-${this.variant}` : null] }, trAttrs() { return { role: 'row', ...this.$attrs } } }, render(h) { return h( 'tr', { class: this.trClasses, attrs: this.trAttrs, // Pass native listeners to child on: this.$listeners }, this.normalizeSlot('default') ) } })