UNPKG

bootstrap-vue

Version:

BootstrapVue provides one of the most comprehensive implementations of Bootstrap 4 components and grid system for Vue.js and with extensive and automated WAI-ARIA accessibility markup.

140 lines (128 loc) 4.54 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 { mergeData } from 'vue-functional-data-merge'; import memoize from '../../utils/memoize'; import suffixPropName from '../../utils/suffix-prop-name'; import { keys, assign, create } from '../../utils/object'; import { arrayIncludes } from '../../utils/array'; /** * Generates a prop object with a type of * [Boolean, String, Number] */ function boolStrNum() { return { type: [Boolean, String, Number], default: false }; } /** * Generates a prop object with a type of * [String, Number] */ function strNum() { return { type: [String, Number], default: null }; } export var computeBkPtClass = memoize(function computeBkPt(type, breakpoint, val) { var className = type; if (val === false || val === null || val === undefined) { return undefined; } if (breakpoint) { className += '-' + breakpoint; } // Handling the boolean style prop when accepting [Boolean, String, Number] // means Vue will not convert <b-col sm /> to sm: true for us. // Since the default is false, an empty string indicates the prop's presence. if (type === 'col' && (val === '' || val === true)) { // .col-md return className.toLowerCase(); } // .order-md-6 className += '-' + val; return className.toLowerCase(); }); var BREAKPOINTS = ['sm', 'md', 'lg', 'xl']; // Supports classes like: .col-sm, .col-md-6, .col-lg-auto var breakpointCol = BREAKPOINTS.reduce( // eslint-disable-next-line no-sequences function (propMap, breakpoint) { return propMap[breakpoint] = boolStrNum(), propMap; }, create(null)); // Supports classes like: .offset-md-1, .offset-lg-12 var breakpointOffset = BREAKPOINTS.reduce( // eslint-disable-next-line no-sequences function (propMap, breakpoint) { return propMap[suffixPropName(breakpoint, 'offset')] = strNum(), propMap; }, create(null)); // Supports classes like: .order-md-1, .order-lg-12 var breakpointOrder = BREAKPOINTS.reduce( // eslint-disable-next-line no-sequences function (propMap, breakpoint) { return propMap[suffixPropName(breakpoint, 'order')] = strNum(), propMap; }, create(null)); // For loop doesn't need to check hasOwnProperty // when using an object created from null var breakpointPropMap = assign(create(null), { col: keys(breakpointCol), offset: keys(breakpointOffset), order: keys(breakpointOrder) }); export var props = assign({}, breakpointCol, breakpointOffset, breakpointOrder, { tag: { type: String, default: 'div' }, // Generic flexbox .col col: { type: Boolean, default: false }, // .col-[1-12]|auto cols: strNum(), // .offset-[1-12] offset: strNum(), // Flex ordering utility .order-[1-12] order: strNum(), alignSelf: { type: String, default: null, validator: function validator(str) { return arrayIncludes(['auto', 'start', 'end', 'center', 'baseline', 'stretch'], str); } } }); /** * We need ".col" to default in when no other props are passed, * but always render when col=true. */ export default { functional: true, props: props, render: function render(h, _ref) { var _classList$push; var props = _ref.props, data = _ref.data, children = _ref.children; var classList = []; // Loop through `col`, `offset`, `order` breakpoint props for (var type in breakpointPropMap) { // Returns colSm, offset, offsetSm, orderMd, etc. var _keys = breakpointPropMap[type]; for (var i = 0; i < _keys.length; i++) { // computeBkPt(col, colSm => Sm, value=[String, Number, Boolean]) var c = computeBkPtClass(type, _keys[i].replace(type, ''), props[_keys[i]]); // If a class is returned, push it onto the array. if (c) { classList.push(c); } } } classList.push((_classList$push = { // Default to .col if no other classes generated nor `cols` specified. col: props.col || classList.length === 0 && !props.cols }, _defineProperty(_classList$push, 'col-' + props.cols, props.cols), _defineProperty(_classList$push, 'offset-' + props.offset, props.offset), _defineProperty(_classList$push, 'order-' + props.order, props.order), _defineProperty(_classList$push, 'align-self-' + props.alignSelf, props.alignSelf), _classList$push)); return h(props.tag, mergeData(data, { class: classList }), children); } };