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
70 lines (62 loc) • 1.87 kB
JavaScript
import { extend, mergeData } from '../../vue'
import { NAME_CARD_BODY } from '../../constants/components'
import { PROP_TYPE_ARRAY_OBJECT_STRING, PROP_TYPE_BOOLEAN } from '../../constants/props'
import { sortKeys } from '../../utils/object'
import {
copyProps,
makeProp,
makePropsConfigurable,
pluckProps,
prefixPropName
} from '../../utils/props'
import { props as cardProps } from '../../mixins/card'
import { BCardTitle, props as titleProps } from './card-title'
import { BCardSubTitle, props as subTitleProps } from './card-sub-title'
// --- Props ---
export const props = makePropsConfigurable(
sortKeys({
...titleProps,
...subTitleProps,
...copyProps(cardProps, prefixPropName.bind(null, 'body')),
bodyClass: makeProp(PROP_TYPE_ARRAY_OBJECT_STRING),
overlay: makeProp(PROP_TYPE_BOOLEAN, false)
}),
NAME_CARD_BODY
)
// --- Main component ---
// @vue/component
export const BCardBody = /*#__PURE__*/ extend({
name: NAME_CARD_BODY,
functional: true,
props,
render(h, { props, data, children }) {
const { bodyBgVariant, bodyBorderVariant, bodyTextVariant } = props
let $title = h()
if (props.title) {
$title = h(BCardTitle, { props: pluckProps(titleProps, props) })
}
let $subTitle = h()
if (props.subTitle) {
$subTitle = h(BCardSubTitle, {
props: pluckProps(subTitleProps, props),
class: ['mb-2']
})
}
return h(
props.bodyTag,
mergeData(data, {
staticClass: 'card-body',
class: [
{
'card-img-overlay': props.overlay,
[`bg-${bodyBgVariant}`]: bodyBgVariant,
[`border-${bodyBorderVariant}`]: bodyBorderVariant,
[`text-${bodyTextVariant}`]: bodyTextVariant
},
props.bodyClass
]
}),
[$title, $subTitle, children]
)
}
})