@gitlab/ui
Version:
GitLab UI Components
53 lines (47 loc) • 1.26 kB
JavaScript
import { extend, mergeData } from '../../vue';
import { NAME_DROPDOWN_HEADER } from '../../constants/components';
import { PROP_TYPE_STRING } from '../../constants/props';
import { isTag } from '../../utils/dom';
import { omit } from '../../utils/object';
import { makePropsConfigurable, makeProp } from '../../utils/props';
// --- Props ---
const props = makePropsConfigurable({
id: makeProp(PROP_TYPE_STRING),
tag: makeProp(PROP_TYPE_STRING, 'header'),
variant: makeProp(PROP_TYPE_STRING)
}, NAME_DROPDOWN_HEADER);
// --- Main component ---
// @vue/component
const BDropdownHeader = /*#__PURE__*/extend({
name: NAME_DROPDOWN_HEADER,
functional: true,
props,
render(h, _ref) {
let {
props,
data,
children
} = _ref;
const {
tag,
variant
} = props;
return h('li', mergeData(omit(data, ['attrs']), {
attrs: {
role: 'presentation'
}
}), [h(tag, {
staticClass: 'dropdown-header',
class: {
[`text-${variant}`]: variant
},
attrs: {
...(data.attrs || {}),
id: props.id || null,
role: isTag(tag, 'header') ? null : 'heading'
},
ref: 'header'
}, children)]);
}
});
export { BDropdownHeader, props };