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

69 lines (62 loc) 2.42 kB
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } import { extend } from '../../vue'; import { NAME_NAVBAR } from '../../constants/components'; import { PROP_TYPE_BOOLEAN, PROP_TYPE_BOOLEAN_STRING, PROP_TYPE_STRING } from '../../constants/props'; import { getBreakpoints } from '../../utils/config'; import { isTag } from '../../utils/dom'; import { isString } from '../../utils/inspect'; import { makeProp, makePropsConfigurable } from '../../utils/props'; import { normalizeSlotMixin } from '../../mixins/normalize-slot'; // --- Props --- export var props = makePropsConfigurable({ fixed: makeProp(PROP_TYPE_STRING), print: makeProp(PROP_TYPE_BOOLEAN, false), sticky: makeProp(PROP_TYPE_BOOLEAN, false), tag: makeProp(PROP_TYPE_STRING, 'nav'), toggleable: makeProp(PROP_TYPE_BOOLEAN_STRING, false), type: makeProp(PROP_TYPE_STRING, 'light'), variant: makeProp(PROP_TYPE_STRING) }, NAME_NAVBAR); // --- Main component --- // @vue/component export var BNavbar = /*#__PURE__*/extend({ name: NAME_NAVBAR, mixins: [normalizeSlotMixin], provide: function provide() { var _this = this; return { getBvNavbar: function getBvNavbar() { return _this; } }; }, props: props, computed: { breakpointClass: function breakpointClass() { var toggleable = this.toggleable; var xs = getBreakpoints()[0]; var breakpoint = null; if (toggleable && isString(toggleable) && toggleable !== xs) { breakpoint = "navbar-expand-".concat(toggleable); } else if (toggleable === false) { breakpoint = 'navbar-expand'; } return breakpoint; } }, render: function render(h) { var _ref; var tag = this.tag, type = this.type, variant = this.variant, fixed = this.fixed; return h(tag, { staticClass: 'navbar', class: [(_ref = { 'd-print': this.print, 'sticky-top': this.sticky }, _defineProperty(_ref, "navbar-".concat(type), type), _defineProperty(_ref, "bg-".concat(variant), variant), _defineProperty(_ref, "fixed-".concat(fixed), fixed), _ref), this.breakpointClass], attrs: { role: isTag(tag, 'nav') ? null : 'navigation' } }, [this.normalizeSlot()]); } });