paradiego
This commit is contained in:
39
node_modules/@mui/system/createStyled/createStyled.d.ts
generated
vendored
Normal file
39
node_modules/@mui/system/createStyled/createStyled.d.ts
generated
vendored
Normal file
@@ -0,0 +1,39 @@
|
||||
import * as React from 'react';
|
||||
import {
|
||||
CreateMUIStyled as CreateMUIStyledStyledEngine,
|
||||
CSSInterpolation,
|
||||
} from '@mui/styled-engine';
|
||||
import styleFunctionSx, { SxProps } from '../styleFunctionSx';
|
||||
import { Theme as DefaultTheme } from '../createTheme';
|
||||
|
||||
export function shouldForwardProp(propName: PropertyKey): boolean;
|
||||
|
||||
export interface MUIStyledCommonProps<Theme extends object = DefaultTheme> {
|
||||
theme?: Theme;
|
||||
as?: React.ElementType;
|
||||
sx?: SxProps<Theme>;
|
||||
}
|
||||
|
||||
export interface MuiStyledOptions {
|
||||
name?: string;
|
||||
slot?: string;
|
||||
// The difference between Interpolation and CSSInterpolation is that the former supports functions based on props
|
||||
// If we want to support props in the overrides, we will need to change the CSSInterpolation to Interpolation<Props>
|
||||
overridesResolver?: (props: any, styles: Record<string, CSSInterpolation>) => CSSInterpolation;
|
||||
skipVariantsResolver?: boolean;
|
||||
skipSx?: boolean;
|
||||
}
|
||||
|
||||
export type CreateMUIStyled<Theme extends object = DefaultTheme> = CreateMUIStyledStyledEngine<
|
||||
MUIStyledCommonProps<Theme>,
|
||||
MuiStyledOptions,
|
||||
Theme
|
||||
>;
|
||||
|
||||
export default function createStyled<Theme extends object = DefaultTheme>(options?: {
|
||||
themeId?: string;
|
||||
defaultTheme?: Theme;
|
||||
rootShouldForwardProp?: (prop: PropertyKey) => boolean;
|
||||
slotShouldForwardProp?: (prop: PropertyKey) => boolean;
|
||||
styleFunctionSx?: typeof styleFunctionSx;
|
||||
}): CreateMUIStyled<Theme>;
|
||||
241
node_modules/@mui/system/createStyled/createStyled.js
generated
vendored
Normal file
241
node_modules/@mui/system/createStyled/createStyled.js
generated
vendored
Normal file
@@ -0,0 +1,241 @@
|
||||
/* eslint-disable no-underscore-dangle */
|
||||
import styledEngineStyled, { internal_processStyles as processStyles } from '@mui/styled-engine';
|
||||
import { isPlainObject } from '@mui/utils/deepmerge';
|
||||
import capitalize from '@mui/utils/capitalize';
|
||||
import getDisplayName from '@mui/utils/getDisplayName';
|
||||
import createTheme from "../createTheme/index.js";
|
||||
import styleFunctionSx from "../styleFunctionSx/index.js";
|
||||
export const systemDefaultTheme = createTheme();
|
||||
|
||||
// Update /system/styled/#api in case if this changes
|
||||
export function shouldForwardProp(prop) {
|
||||
return prop !== 'ownerState' && prop !== 'theme' && prop !== 'sx' && prop !== 'as';
|
||||
}
|
||||
function resolveTheme(themeId, theme, defaultTheme) {
|
||||
return isObjectEmpty(theme) ? defaultTheme : theme[themeId] || theme;
|
||||
}
|
||||
const PROCESSED_PROPS = Symbol('mui.processed_props');
|
||||
function attachTheme(props, themeId, defaultTheme) {
|
||||
if (PROCESSED_PROPS in props) {
|
||||
return props[PROCESSED_PROPS];
|
||||
}
|
||||
const processedProps = {
|
||||
...props,
|
||||
theme: resolveTheme(themeId, props.theme, defaultTheme)
|
||||
};
|
||||
props[PROCESSED_PROPS] = processedProps;
|
||||
processedProps[PROCESSED_PROPS] = processedProps;
|
||||
return processedProps;
|
||||
}
|
||||
function defaultOverridesResolver(slot) {
|
||||
if (!slot) {
|
||||
return null;
|
||||
}
|
||||
return (_props, styles) => styles[slot];
|
||||
}
|
||||
function processStyle(style, props) {
|
||||
const resolvedStyle = typeof style === 'function' ? style(props) : style;
|
||||
if (Array.isArray(resolvedStyle)) {
|
||||
return resolvedStyle.flatMap(subStyle => processStyle(subStyle, props));
|
||||
}
|
||||
if (Array.isArray(resolvedStyle?.variants)) {
|
||||
const {
|
||||
variants,
|
||||
...otherStyles
|
||||
} = resolvedStyle;
|
||||
let result = otherStyles;
|
||||
let mergedState; // We might not need it, initalized lazily
|
||||
|
||||
/* eslint-disable no-labels */
|
||||
variantLoop: for (let i = 0; i < variants.length; i += 1) {
|
||||
const variant = variants[i];
|
||||
if (typeof variant.props === 'function') {
|
||||
mergedState ??= {
|
||||
...props,
|
||||
...props.ownerState,
|
||||
ownerState: props.ownerState
|
||||
};
|
||||
if (!variant.props(mergedState)) {
|
||||
continue;
|
||||
}
|
||||
} else {
|
||||
for (const key in variant.props) {
|
||||
if (props[key] !== variant.props[key] && props.ownerState?.[key] !== variant.props[key]) {
|
||||
continue variantLoop;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (!Array.isArray(result)) {
|
||||
result = [result];
|
||||
}
|
||||
if (typeof variant.style === 'function') {
|
||||
mergedState ??= {
|
||||
...props,
|
||||
...props.ownerState,
|
||||
ownerState: props.ownerState
|
||||
};
|
||||
result.push(variant.style(mergedState));
|
||||
} else {
|
||||
result.push(variant.style);
|
||||
}
|
||||
}
|
||||
/* eslint-enable no-labels */
|
||||
|
||||
return result;
|
||||
}
|
||||
return resolvedStyle;
|
||||
}
|
||||
export default function createStyled(input = {}) {
|
||||
const {
|
||||
themeId,
|
||||
defaultTheme = systemDefaultTheme,
|
||||
rootShouldForwardProp = shouldForwardProp,
|
||||
slotShouldForwardProp = shouldForwardProp
|
||||
} = input;
|
||||
const systemSx = props => {
|
||||
return styleFunctionSx(attachTheme(props, themeId, defaultTheme));
|
||||
};
|
||||
systemSx.__mui_systemSx = true;
|
||||
const styled = (tag, inputOptions = {}) => {
|
||||
// Filter out the `sx` style function from the previous styled component to prevent unnecessary styles generated by the composite components.
|
||||
processStyles(tag, styles => styles.filter(style => !style?.__mui_systemSx));
|
||||
const {
|
||||
name: componentName,
|
||||
slot: componentSlot,
|
||||
skipVariantsResolver: inputSkipVariantsResolver,
|
||||
skipSx: inputSkipSx,
|
||||
// TODO v6: remove `lowercaseFirstLetter()` in the next major release
|
||||
// For more details: https://github.com/mui/material-ui/pull/37908
|
||||
overridesResolver = defaultOverridesResolver(lowercaseFirstLetter(componentSlot)),
|
||||
...options
|
||||
} = inputOptions;
|
||||
|
||||
// if skipVariantsResolver option is defined, take the value, otherwise, true for root and false for other slots.
|
||||
const skipVariantsResolver = inputSkipVariantsResolver !== undefined ? inputSkipVariantsResolver :
|
||||
// TODO v6: remove `Root` in the next major release
|
||||
// For more details: https://github.com/mui/material-ui/pull/37908
|
||||
componentSlot && componentSlot !== 'Root' && componentSlot !== 'root' || false;
|
||||
const skipSx = inputSkipSx || false;
|
||||
let label;
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
if (componentName) {
|
||||
// TODO v6: remove `lowercaseFirstLetter()` in the next major release
|
||||
// For more details: https://github.com/mui/material-ui/pull/37908
|
||||
label = `${componentName}-${lowercaseFirstLetter(componentSlot || 'Root')}`;
|
||||
}
|
||||
}
|
||||
let shouldForwardPropOption = shouldForwardProp;
|
||||
|
||||
// TODO v6: remove `Root` in the next major release
|
||||
// For more details: https://github.com/mui/material-ui/pull/37908
|
||||
if (componentSlot === 'Root' || componentSlot === 'root') {
|
||||
shouldForwardPropOption = rootShouldForwardProp;
|
||||
} else if (componentSlot) {
|
||||
// any other slot specified
|
||||
shouldForwardPropOption = slotShouldForwardProp;
|
||||
} else if (isStringTag(tag)) {
|
||||
// for string (html) tag, preserve the behavior in emotion & styled-components.
|
||||
shouldForwardPropOption = undefined;
|
||||
}
|
||||
const defaultStyledResolver = styledEngineStyled(tag, {
|
||||
shouldForwardProp: shouldForwardPropOption,
|
||||
label,
|
||||
...options
|
||||
});
|
||||
const transformStyleArg = style => {
|
||||
// On the server Emotion doesn't use React.forwardRef for creating components, so the created
|
||||
// component stays as a function. This condition makes sure that we do not interpolate functions
|
||||
// which are basically components used as a selectors.
|
||||
if (typeof style === 'function' && style.__emotion_real !== style || isPlainObject(style)) {
|
||||
return props => processStyle(style, attachTheme(props, themeId, defaultTheme));
|
||||
}
|
||||
return style;
|
||||
};
|
||||
const muiStyledResolver = (style, ...expressions) => {
|
||||
let transformedStyle = transformStyleArg(style);
|
||||
const expressionsWithDefaultTheme = expressions ? expressions.map(transformStyleArg) : [];
|
||||
if (componentName && overridesResolver) {
|
||||
expressionsWithDefaultTheme.push(props => {
|
||||
const theme = resolveTheme(themeId, props.theme, defaultTheme);
|
||||
if (!theme.components || !theme.components[componentName] || !theme.components[componentName].styleOverrides) {
|
||||
return null;
|
||||
}
|
||||
const styleOverrides = theme.components[componentName].styleOverrides;
|
||||
const resolvedStyleOverrides = {};
|
||||
const propsWithTheme = attachTheme(props, themeId, defaultTheme);
|
||||
|
||||
// TODO: v7 remove iteration and use `resolveStyleArg(styleOverrides[slot])` directly
|
||||
// eslint-disable-next-line guard-for-in
|
||||
for (const slotKey in styleOverrides) {
|
||||
resolvedStyleOverrides[slotKey] = processStyle(styleOverrides[slotKey], propsWithTheme);
|
||||
}
|
||||
return overridesResolver(props, resolvedStyleOverrides);
|
||||
});
|
||||
}
|
||||
if (componentName && !skipVariantsResolver) {
|
||||
expressionsWithDefaultTheme.push(props => {
|
||||
const theme = resolveTheme(themeId, props.theme, defaultTheme);
|
||||
const themeVariants = theme?.components?.[componentName]?.variants;
|
||||
if (!themeVariants) {
|
||||
return null;
|
||||
}
|
||||
return processStyle({
|
||||
variants: themeVariants
|
||||
}, attachTheme(props, themeId, defaultTheme));
|
||||
});
|
||||
}
|
||||
if (!skipSx) {
|
||||
expressionsWithDefaultTheme.push(systemSx);
|
||||
}
|
||||
const numOfCustomFnsApplied = expressionsWithDefaultTheme.length - expressions.length;
|
||||
if (Array.isArray(style) && numOfCustomFnsApplied > 0) {
|
||||
const placeholders = new Array(numOfCustomFnsApplied).fill('');
|
||||
// If the type is array, than we need to add placeholders in the template for the overrides, variants and the sx styles.
|
||||
transformedStyle = [...style, ...placeholders];
|
||||
transformedStyle.raw = [...style.raw, ...placeholders];
|
||||
}
|
||||
const Component = defaultStyledResolver(transformedStyle, ...expressionsWithDefaultTheme);
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
let displayName;
|
||||
if (componentName) {
|
||||
displayName = `${componentName}${capitalize(componentSlot || '')}`;
|
||||
}
|
||||
if (displayName === undefined) {
|
||||
displayName = `Styled(${getDisplayName(tag)})`;
|
||||
}
|
||||
Component.displayName = displayName;
|
||||
}
|
||||
if (tag.muiName) {
|
||||
Component.muiName = tag.muiName;
|
||||
}
|
||||
return Component;
|
||||
};
|
||||
if (defaultStyledResolver.withConfig) {
|
||||
muiStyledResolver.withConfig = defaultStyledResolver.withConfig;
|
||||
}
|
||||
return muiStyledResolver;
|
||||
};
|
||||
return styled;
|
||||
}
|
||||
function isObjectEmpty(object) {
|
||||
// eslint-disable-next-line
|
||||
for (const _ in object) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
// https://github.com/emotion-js/emotion/blob/26ded6109fcd8ca9875cc2ce4564fee678a3f3c5/packages/styled/src/utils.js#L40
|
||||
function isStringTag(tag) {
|
||||
return typeof tag === 'string' &&
|
||||
// 96 is one less than the char code
|
||||
// for "a" so this is checking that
|
||||
// it's a lowercase character
|
||||
tag.charCodeAt(0) > 96;
|
||||
}
|
||||
function lowercaseFirstLetter(string) {
|
||||
if (!string) {
|
||||
return string;
|
||||
}
|
||||
return string.charAt(0).toLowerCase() + string.slice(1);
|
||||
}
|
||||
2
node_modules/@mui/system/createStyled/index.d.ts
generated
vendored
Normal file
2
node_modules/@mui/system/createStyled/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
export { default } from './createStyled';
|
||||
export * from './createStyled';
|
||||
2
node_modules/@mui/system/createStyled/index.js
generated
vendored
Normal file
2
node_modules/@mui/system/createStyled/index.js
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
export { default } from "./createStyled.js";
|
||||
export * from "./createStyled.js";
|
||||
6
node_modules/@mui/system/createStyled/package.json
generated
vendored
Normal file
6
node_modules/@mui/system/createStyled/package.json
generated
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"sideEffects": false,
|
||||
"module": "./index.js",
|
||||
"main": "../node/createStyled/index.js",
|
||||
"types": "./index.d.ts"
|
||||
}
|
||||
Reference in New Issue
Block a user