UNPKG

bootstrap-view

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 (66 loc) 3.08 kB
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } 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 tag = this.tag, type = this.type, variant = this.variant, fixed = this.fixed; return h(tag, { staticClass: 'navbar', class: [_defineProperty(_defineProperty(_defineProperty({ 'd-print': this.print, 'sticky-top': this.sticky }, "navbar-".concat(type), type), "bg-".concat(variant), variant), "fixed-".concat(fixed), fixed), this.breakpointClass], attrs: { role: isTag(tag, 'nav') ? null : 'navigation' } }, [this.normalizeSlot()]); } });