- Updated all component headers and documentation
- Changed navbar and footer branding
- Updated homepage hero badge
- Modified page title in index.html
- Simplified footer text to 'Built with ❤️'
- Consistent V2 capitalization across all references
57 lines
1.4 KiB
JavaScript
57 lines
1.4 KiB
JavaScript
'use strict';
|
|
|
|
var is = require('./is.cjs');
|
|
|
|
const breakpoints = Object.freeze([
|
|
"base",
|
|
"sm",
|
|
"md",
|
|
"lg",
|
|
"xl",
|
|
"2xl"
|
|
]);
|
|
function mapResponsive(prop, mapper) {
|
|
if (Array.isArray(prop)) {
|
|
return prop.map((item) => item === null ? null : mapper(item));
|
|
}
|
|
if (is.isObject(prop)) {
|
|
return Object.keys(prop).reduce((result, key) => {
|
|
result[key] = mapper(prop[key]);
|
|
return result;
|
|
}, {});
|
|
}
|
|
if (prop != null) {
|
|
return mapper(prop);
|
|
}
|
|
return null;
|
|
}
|
|
function objectToArrayNotation(obj, bps = breakpoints) {
|
|
const result = bps.map((br) => obj[br] ?? null);
|
|
const lastItem = result[result.length - 1];
|
|
while (lastItem === null)
|
|
result.pop();
|
|
return result;
|
|
}
|
|
function arrayToObjectNotation(values, bps = breakpoints) {
|
|
const result = {};
|
|
values.forEach((value, index) => {
|
|
const key = bps[index];
|
|
if (value == null)
|
|
return;
|
|
result[key] = value;
|
|
});
|
|
return result;
|
|
}
|
|
function isResponsiveObjectLike(obj, bps = breakpoints) {
|
|
const keys = Object.keys(obj);
|
|
return keys.length > 0 && keys.every((key) => bps.includes(key));
|
|
}
|
|
const isCustomBreakpoint = (v) => Number.isNaN(Number(v));
|
|
|
|
exports.arrayToObjectNotation = arrayToObjectNotation;
|
|
exports.breakpoints = breakpoints;
|
|
exports.isCustomBreakpoint = isCustomBreakpoint;
|
|
exports.isResponsiveObjectLike = isResponsiveObjectLike;
|
|
exports.mapResponsive = mapResponsive;
|
|
exports.objectToArrayNotation = objectToArrayNotation;
|