@mantine/core
Version:
React components library focused on usability, accessibility and developer experience
51 lines (48 loc) • 1.97 kB
JavaScript
import { getResponsiveValue } from '../get-responsive-value/get-responsive-value.js';
import { valueGetters } from '../value-getters/value-getters.js';
import { SYSTEM_PROPS } from '../system-props/system-props.js';
var __defProp = Object.defineProperty;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
function getSystemStyles(systemStyles, theme, systemProps = SYSTEM_PROPS) {
const styles = Object.keys(systemProps).reduce((acc, systemProp) => {
if (systemProp in systemStyles && systemStyles[systemProp] !== void 0) {
acc.push(getResponsiveValue({
value: systemStyles[systemProp],
getValue: valueGetters[systemProps[systemProp].type],
property: systemProps[systemProp].property,
theme
}));
}
return acc;
}, []);
return styles.reduce((acc, stylesPartial) => {
Object.keys(stylesPartial).forEach((property) => {
if (typeof stylesPartial[property] === "object" && stylesPartial[property] !== null) {
if (!(property in acc)) {
acc[property] = stylesPartial[property];
} else {
acc[property] = __spreadValues(__spreadValues({}, acc[property]), stylesPartial[property]);
}
} else {
acc[property] = stylesPartial[property];
}
});
return acc;
}, {});
}
export { getSystemStyles };
//# sourceMappingURL=get-system-styles.js.map