@ag.ds-next/box
Advanced tools
Comparing version 4.1.0 to 4.1.1
# @ag.ds-next/box | ||
## 4.1.1 | ||
### Patch Changes | ||
- 3e2abfe3: Added responsive type scale | ||
- Updated dependencies [3e2abfe3] | ||
- @ag.ds-next/core@2.1.5 | ||
## 4.1.0 | ||
@@ -4,0 +12,0 @@ |
@@ -288,3 +288,3 @@ 'use strict'; | ||
...(focus ? focusStyles : undefined) | ||
})], process.env.NODE_ENV === "production" ? "" : ";label:boxStyles;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAkXE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<keyof typeof tokens.fontWeight>;\n\tfontFamily: ResponsiveProp<keyof typeof tokens.font>;\n\tfontSize: ResponsiveProp<keyof typeof tokens.fontSize>;\n\tlineHeight: keyof typeof tokens.lineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderLeft: boolean;\n\tborderLeftWidth: BorderWidth;\n\tborderRight: boolean;\n\tborderRightWidth: BorderWidth;\n\tborderTop: boolean;\n\tborderTopWidth: BorderWidth;\n\tborderBottom: boolean;\n\tborderBottomWidth: BorderWidth;\n\tborderX: boolean;\n\tborderY: boolean;\n\trounded: boolean;\n}>;\n\nfunction borderStyles({\n\tborder,\n\tborderWidth = 'sm',\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n}: BorderProps) {\n\tconst anyBorder =\n\t\tborder ||\n\t\tborderLeft ||\n\t\tborderRight ||\n\t\tborderTop ||\n\t\tborderBottom ||\n\t\tborderX ||\n\t\tborderY;\n\treturn {\n\t\tborderWidth: 0,\n\t\tborderLeftWidth:\n\t\t\tborder ?? borderX ?? borderLeft\n\t\t\t\t? tokens.borderWidth[borderLeftWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderRightWidth:\n\t\t\tborder ?? borderX ?? borderRight\n\t\t\t\t? tokens.borderWidth[borderRightWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderTopWidth:\n\t\t\tborder ?? borderY ?? borderTop\n\t\t\t\t? tokens.borderWidth[borderTopWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderBottomWidth:\n\t\t\tborder ?? borderY ?? borderBottom\n\t\t\t\t? tokens.borderWidth[borderBottomWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderColor: anyBorder ? boxPalette.border : undefined,\n\t\tborderStyle: anyBorder ? 'solid' : undefined,\n\t\tborderRadius: rounded ? tokens.borderRadius : undefined,\n\t};\n}\n\ntype PaddingProps = Partial<{\n\tpaddingTop: ResponsiveProp<Spacing>;\n\tpaddingBottom: ResponsiveProp<Spacing>;\n\tpaddingRight: ResponsiveProp<Spacing>;\n\tpaddingLeft: ResponsiveProp<Spacing>;\n\tpaddingX: ResponsiveProp<Spacing>;\n\tpaddingY: ResponsiveProp<Spacing>;\n\tpadding: ResponsiveProp<Spacing>;\n}>;\n\n// TODO: Explain how overlapping shorthands padding is applied.\nfunction paddingStyles({\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n}: PaddingProps) {\n\treturn {\n\t\tpaddingTop: mapResponsiveProp(\n\t\t\tpaddingTop ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingBottom: mapResponsiveProp(\n\t\t\tpaddingBottom ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingRight: mapResponsiveProp(\n\t\t\tpaddingRight ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingLeft: mapResponsiveProp(\n\t\t\tpaddingLeft ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t};\n}\n\ntype LinkProps = Partial<{ link: boolean }>;\nexport const linkStyles = {\n\t...packs.underline,\n\tcolor: boxPalette.foregroundAction,\n\tcursor: 'pointer',\n\n\t'&:hover': {\n\t\tcolor: boxPalette.foregroundText,\n\t\ttextDecoration: 'none',\n\t},\n};\n\ntype FocusProps = Partial<{ focus: boolean }>;\nexport const focusStyles = {\n\t':focus': packs.outline,\n\t'&::-moz-focus-inner': {\n\t\tborder: 0,\n\t},\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tTypographyProps &\n\tLayoutProps &\n\tLinkProps &\n\tPaddingProps;\n\nexport function boxStyles({\n\tpalette,\n\tdark,\n\tlight,\n\tcolor,\n\tbackground,\n\tborder,\n\tborderWidth,\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tfontWeight,\n\tfontFamily,\n\tfontSize,\n\tfocus,\n\tlink,\n\tlineHeight,\n\t...restProps\n}: BoxProps) {\n\treturn [\n\t\tcss([\n\t\t\tpaletteStyles({ palette, dark, light }),\n\n\t\t\t// common resets\n\t\t\t{\n\t\t\t\tboxSizing: 'border-box',\n\t\t\t\tlistStyle: 'none',\n\t\t\t\tmargin: 0,\n\t\t\t\tpadding: 0,\n\t\t\t},\n\n\t\t\tmq({\n\t\t\t\t...colorStyles({ background, color }),\n\n\t\t\t\t...borderStyles({\n\t\t\t\t\tborder,\n\t\t\t\t\tborderWidth,\n\t\t\t\t\tborderLeft,\n\t\t\t\t\tborderLeftWidth,\n\t\t\t\t\tborderRight,\n\t\t\t\t\tborderRightWidth,\n\t\t\t\t\tborderTop,\n\t\t\t\t\tborderTopWidth,\n\t\t\t\t\tborderBottom,\n\t\t\t\t\tborderBottomWidth,\n\t\t\t\t\tborderX,\n\t\t\t\t\tborderY,\n\t\t\t\t\trounded,\n\t\t\t\t}),\n\n\t\t\t\t...layoutStyles({\n\t\t\t\t\tdisplay,\n\t\t\t\t\tflexDirection,\n\t\t\t\t\tflexWrap,\n\t\t\t\t\tflexGrow,\n\t\t\t\t\tflexShrink,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\twidth,\n\t\t\t\t\tminWidth,\n\t\t\t\t\tmaxWidth,\n\t\t\t\t\theight,\n\t\t\t\t\tminHeight,\n\t\t\t\t\tmaxHeight,\n\t\t\t\t}),\n\n\t\t\t\t...paddingStyles({\n\t\t\t\t\tpaddingTop,\n\t\t\t\t\tpaddingBottom,\n\t\t\t\t\tpaddingRight,\n\t\t\t\t\tpaddingLeft,\n\t\t\t\t\tpaddingX,\n\t\t\t\t\tpaddingY,\n\t\t\t\t\tpadding,\n\t\t\t\t}),\n\n\t\t\t\t...typographyStyles({\n\t\t\t\t\tfontWeight,\n\t\t\t\t\tfontFamily,\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight,\n\t\t\t\t}),\n\n\t\t\t\t...(link ? linkStyles : undefined),\n\t\t\t\t...(focus ? focusStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps]; | ||
})], process.env.NODE_ENV === "production" ? "" : ";label:boxStyles;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsXE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderLeft: boolean;\n\tborderLeftWidth: BorderWidth;\n\tborderRight: boolean;\n\tborderRightWidth: BorderWidth;\n\tborderTop: boolean;\n\tborderTopWidth: BorderWidth;\n\tborderBottom: boolean;\n\tborderBottomWidth: BorderWidth;\n\tborderX: boolean;\n\tborderY: boolean;\n\trounded: boolean;\n}>;\n\nfunction borderStyles({\n\tborder,\n\tborderWidth = 'sm',\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n}: BorderProps) {\n\tconst anyBorder =\n\t\tborder ||\n\t\tborderLeft ||\n\t\tborderRight ||\n\t\tborderTop ||\n\t\tborderBottom ||\n\t\tborderX ||\n\t\tborderY;\n\treturn {\n\t\tborderWidth: 0,\n\t\tborderLeftWidth:\n\t\t\tborder ?? borderX ?? borderLeft\n\t\t\t\t? tokens.borderWidth[borderLeftWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderRightWidth:\n\t\t\tborder ?? borderX ?? borderRight\n\t\t\t\t? tokens.borderWidth[borderRightWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderTopWidth:\n\t\t\tborder ?? borderY ?? borderTop\n\t\t\t\t? tokens.borderWidth[borderTopWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderBottomWidth:\n\t\t\tborder ?? borderY ?? borderBottom\n\t\t\t\t? tokens.borderWidth[borderBottomWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderColor: anyBorder ? boxPalette.border : undefined,\n\t\tborderStyle: anyBorder ? 'solid' : undefined,\n\t\tborderRadius: rounded ? tokens.borderRadius : undefined,\n\t};\n}\n\ntype PaddingProps = Partial<{\n\tpaddingTop: ResponsiveProp<Spacing>;\n\tpaddingBottom: ResponsiveProp<Spacing>;\n\tpaddingRight: ResponsiveProp<Spacing>;\n\tpaddingLeft: ResponsiveProp<Spacing>;\n\tpaddingX: ResponsiveProp<Spacing>;\n\tpaddingY: ResponsiveProp<Spacing>;\n\tpadding: ResponsiveProp<Spacing>;\n}>;\n\n// TODO: Explain how overlapping shorthands padding is applied.\nfunction paddingStyles({\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n}: PaddingProps) {\n\treturn {\n\t\tpaddingTop: mapResponsiveProp(\n\t\t\tpaddingTop ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingBottom: mapResponsiveProp(\n\t\t\tpaddingBottom ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingRight: mapResponsiveProp(\n\t\t\tpaddingRight ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingLeft: mapResponsiveProp(\n\t\t\tpaddingLeft ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t};\n}\n\ntype LinkProps = Partial<{ link: boolean }>;\nexport const linkStyles = {\n\t...packs.underline,\n\tcolor: boxPalette.foregroundAction,\n\tcursor: 'pointer',\n\n\t'&:hover': {\n\t\tcolor: boxPalette.foregroundText,\n\t\ttextDecoration: 'none',\n\t},\n};\n\ntype FocusProps = Partial<{ focus: boolean }>;\nexport const focusStyles = {\n\t':focus': packs.outline,\n\t'&::-moz-focus-inner': {\n\t\tborder: 0,\n\t},\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tTypographyProps &\n\tLayoutProps &\n\tLinkProps &\n\tPaddingProps;\n\nexport function boxStyles({\n\tpalette,\n\tdark,\n\tlight,\n\tcolor,\n\tbackground,\n\tborder,\n\tborderWidth,\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tfontWeight,\n\tfontFamily,\n\tfontSize,\n\tfocus,\n\tlink,\n\tlineHeight,\n\t...restProps\n}: BoxProps) {\n\treturn [\n\t\tcss([\n\t\t\tpaletteStyles({ palette, dark, light }),\n\n\t\t\t// common resets\n\t\t\t{\n\t\t\t\tboxSizing: 'border-box',\n\t\t\t\tlistStyle: 'none',\n\t\t\t\tmargin: 0,\n\t\t\t\tpadding: 0,\n\t\t\t},\n\n\t\t\tmq({\n\t\t\t\t...colorStyles({ background, color }),\n\n\t\t\t\t...borderStyles({\n\t\t\t\t\tborder,\n\t\t\t\t\tborderWidth,\n\t\t\t\t\tborderLeft,\n\t\t\t\t\tborderLeftWidth,\n\t\t\t\t\tborderRight,\n\t\t\t\t\tborderRightWidth,\n\t\t\t\t\tborderTop,\n\t\t\t\t\tborderTopWidth,\n\t\t\t\t\tborderBottom,\n\t\t\t\t\tborderBottomWidth,\n\t\t\t\t\tborderX,\n\t\t\t\t\tborderY,\n\t\t\t\t\trounded,\n\t\t\t\t}),\n\n\t\t\t\t...layoutStyles({\n\t\t\t\t\tdisplay,\n\t\t\t\t\tflexDirection,\n\t\t\t\t\tflexWrap,\n\t\t\t\t\tflexGrow,\n\t\t\t\t\tflexShrink,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\twidth,\n\t\t\t\t\tminWidth,\n\t\t\t\t\tmaxWidth,\n\t\t\t\t\theight,\n\t\t\t\t\tminHeight,\n\t\t\t\t\tmaxHeight,\n\t\t\t\t}),\n\n\t\t\t\t...paddingStyles({\n\t\t\t\t\tpaddingTop,\n\t\t\t\t\tpaddingBottom,\n\t\t\t\t\tpaddingRight,\n\t\t\t\t\tpaddingLeft,\n\t\t\t\t\tpaddingX,\n\t\t\t\t\tpaddingY,\n\t\t\t\t\tpadding,\n\t\t\t\t}),\n\n\t\t\t\t...typographyStyles({\n\t\t\t\t\tfontWeight,\n\t\t\t\t\tfontFamily,\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight,\n\t\t\t\t}),\n\n\t\t\t\t...(link ? linkStyles : undefined),\n\t\t\t\t...(focus ? focusStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps]; | ||
} | ||
@@ -291,0 +291,0 @@ |
@@ -284,3 +284,3 @@ import { css, jsx } from '@emotion/react'; | ||
...(focus ? focusStyles : undefined) | ||
})], process.env.NODE_ENV === "production" ? "" : ";label:boxStyles;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAkXE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<keyof typeof tokens.fontWeight>;\n\tfontFamily: ResponsiveProp<keyof typeof tokens.font>;\n\tfontSize: ResponsiveProp<keyof typeof tokens.fontSize>;\n\tlineHeight: keyof typeof tokens.lineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderLeft: boolean;\n\tborderLeftWidth: BorderWidth;\n\tborderRight: boolean;\n\tborderRightWidth: BorderWidth;\n\tborderTop: boolean;\n\tborderTopWidth: BorderWidth;\n\tborderBottom: boolean;\n\tborderBottomWidth: BorderWidth;\n\tborderX: boolean;\n\tborderY: boolean;\n\trounded: boolean;\n}>;\n\nfunction borderStyles({\n\tborder,\n\tborderWidth = 'sm',\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n}: BorderProps) {\n\tconst anyBorder =\n\t\tborder ||\n\t\tborderLeft ||\n\t\tborderRight ||\n\t\tborderTop ||\n\t\tborderBottom ||\n\t\tborderX ||\n\t\tborderY;\n\treturn {\n\t\tborderWidth: 0,\n\t\tborderLeftWidth:\n\t\t\tborder ?? borderX ?? borderLeft\n\t\t\t\t? tokens.borderWidth[borderLeftWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderRightWidth:\n\t\t\tborder ?? borderX ?? borderRight\n\t\t\t\t? tokens.borderWidth[borderRightWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderTopWidth:\n\t\t\tborder ?? borderY ?? borderTop\n\t\t\t\t? tokens.borderWidth[borderTopWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderBottomWidth:\n\t\t\tborder ?? borderY ?? borderBottom\n\t\t\t\t? tokens.borderWidth[borderBottomWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderColor: anyBorder ? boxPalette.border : undefined,\n\t\tborderStyle: anyBorder ? 'solid' : undefined,\n\t\tborderRadius: rounded ? tokens.borderRadius : undefined,\n\t};\n}\n\ntype PaddingProps = Partial<{\n\tpaddingTop: ResponsiveProp<Spacing>;\n\tpaddingBottom: ResponsiveProp<Spacing>;\n\tpaddingRight: ResponsiveProp<Spacing>;\n\tpaddingLeft: ResponsiveProp<Spacing>;\n\tpaddingX: ResponsiveProp<Spacing>;\n\tpaddingY: ResponsiveProp<Spacing>;\n\tpadding: ResponsiveProp<Spacing>;\n}>;\n\n// TODO: Explain how overlapping shorthands padding is applied.\nfunction paddingStyles({\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n}: PaddingProps) {\n\treturn {\n\t\tpaddingTop: mapResponsiveProp(\n\t\t\tpaddingTop ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingBottom: mapResponsiveProp(\n\t\t\tpaddingBottom ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingRight: mapResponsiveProp(\n\t\t\tpaddingRight ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingLeft: mapResponsiveProp(\n\t\t\tpaddingLeft ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t};\n}\n\ntype LinkProps = Partial<{ link: boolean }>;\nexport const linkStyles = {\n\t...packs.underline,\n\tcolor: boxPalette.foregroundAction,\n\tcursor: 'pointer',\n\n\t'&:hover': {\n\t\tcolor: boxPalette.foregroundText,\n\t\ttextDecoration: 'none',\n\t},\n};\n\ntype FocusProps = Partial<{ focus: boolean }>;\nexport const focusStyles = {\n\t':focus': packs.outline,\n\t'&::-moz-focus-inner': {\n\t\tborder: 0,\n\t},\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tTypographyProps &\n\tLayoutProps &\n\tLinkProps &\n\tPaddingProps;\n\nexport function boxStyles({\n\tpalette,\n\tdark,\n\tlight,\n\tcolor,\n\tbackground,\n\tborder,\n\tborderWidth,\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tfontWeight,\n\tfontFamily,\n\tfontSize,\n\tfocus,\n\tlink,\n\tlineHeight,\n\t...restProps\n}: BoxProps) {\n\treturn [\n\t\tcss([\n\t\t\tpaletteStyles({ palette, dark, light }),\n\n\t\t\t// common resets\n\t\t\t{\n\t\t\t\tboxSizing: 'border-box',\n\t\t\t\tlistStyle: 'none',\n\t\t\t\tmargin: 0,\n\t\t\t\tpadding: 0,\n\t\t\t},\n\n\t\t\tmq({\n\t\t\t\t...colorStyles({ background, color }),\n\n\t\t\t\t...borderStyles({\n\t\t\t\t\tborder,\n\t\t\t\t\tborderWidth,\n\t\t\t\t\tborderLeft,\n\t\t\t\t\tborderLeftWidth,\n\t\t\t\t\tborderRight,\n\t\t\t\t\tborderRightWidth,\n\t\t\t\t\tborderTop,\n\t\t\t\t\tborderTopWidth,\n\t\t\t\t\tborderBottom,\n\t\t\t\t\tborderBottomWidth,\n\t\t\t\t\tborderX,\n\t\t\t\t\tborderY,\n\t\t\t\t\trounded,\n\t\t\t\t}),\n\n\t\t\t\t...layoutStyles({\n\t\t\t\t\tdisplay,\n\t\t\t\t\tflexDirection,\n\t\t\t\t\tflexWrap,\n\t\t\t\t\tflexGrow,\n\t\t\t\t\tflexShrink,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\twidth,\n\t\t\t\t\tminWidth,\n\t\t\t\t\tmaxWidth,\n\t\t\t\t\theight,\n\t\t\t\t\tminHeight,\n\t\t\t\t\tmaxHeight,\n\t\t\t\t}),\n\n\t\t\t\t...paddingStyles({\n\t\t\t\t\tpaddingTop,\n\t\t\t\t\tpaddingBottom,\n\t\t\t\t\tpaddingRight,\n\t\t\t\t\tpaddingLeft,\n\t\t\t\t\tpaddingX,\n\t\t\t\t\tpaddingY,\n\t\t\t\t\tpadding,\n\t\t\t\t}),\n\n\t\t\t\t...typographyStyles({\n\t\t\t\t\tfontWeight,\n\t\t\t\t\tfontFamily,\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight,\n\t\t\t\t}),\n\n\t\t\t\t...(link ? linkStyles : undefined),\n\t\t\t\t...(focus ? focusStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps]; | ||
})], process.env.NODE_ENV === "production" ? "" : ";label:boxStyles;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsXE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderLeft: boolean;\n\tborderLeftWidth: BorderWidth;\n\tborderRight: boolean;\n\tborderRightWidth: BorderWidth;\n\tborderTop: boolean;\n\tborderTopWidth: BorderWidth;\n\tborderBottom: boolean;\n\tborderBottomWidth: BorderWidth;\n\tborderX: boolean;\n\tborderY: boolean;\n\trounded: boolean;\n}>;\n\nfunction borderStyles({\n\tborder,\n\tborderWidth = 'sm',\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n}: BorderProps) {\n\tconst anyBorder =\n\t\tborder ||\n\t\tborderLeft ||\n\t\tborderRight ||\n\t\tborderTop ||\n\t\tborderBottom ||\n\t\tborderX ||\n\t\tborderY;\n\treturn {\n\t\tborderWidth: 0,\n\t\tborderLeftWidth:\n\t\t\tborder ?? borderX ?? borderLeft\n\t\t\t\t? tokens.borderWidth[borderLeftWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderRightWidth:\n\t\t\tborder ?? borderX ?? borderRight\n\t\t\t\t? tokens.borderWidth[borderRightWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderTopWidth:\n\t\t\tborder ?? borderY ?? borderTop\n\t\t\t\t? tokens.borderWidth[borderTopWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderBottomWidth:\n\t\t\tborder ?? borderY ?? borderBottom\n\t\t\t\t? tokens.borderWidth[borderBottomWidth || borderWidth]\n\t\t\t\t: undefined,\n\t\tborderColor: anyBorder ? boxPalette.border : undefined,\n\t\tborderStyle: anyBorder ? 'solid' : undefined,\n\t\tborderRadius: rounded ? tokens.borderRadius : undefined,\n\t};\n}\n\ntype PaddingProps = Partial<{\n\tpaddingTop: ResponsiveProp<Spacing>;\n\tpaddingBottom: ResponsiveProp<Spacing>;\n\tpaddingRight: ResponsiveProp<Spacing>;\n\tpaddingLeft: ResponsiveProp<Spacing>;\n\tpaddingX: ResponsiveProp<Spacing>;\n\tpaddingY: ResponsiveProp<Spacing>;\n\tpadding: ResponsiveProp<Spacing>;\n}>;\n\n// TODO: Explain how overlapping shorthands padding is applied.\nfunction paddingStyles({\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n}: PaddingProps) {\n\treturn {\n\t\tpaddingTop: mapResponsiveProp(\n\t\t\tpaddingTop ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingBottom: mapResponsiveProp(\n\t\t\tpaddingBottom ?? paddingY ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingRight: mapResponsiveProp(\n\t\t\tpaddingRight ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t\tpaddingLeft: mapResponsiveProp(\n\t\t\tpaddingLeft ?? paddingX ?? padding,\n\t\t\tmapSpacing\n\t\t),\n\t};\n}\n\ntype LinkProps = Partial<{ link: boolean }>;\nexport const linkStyles = {\n\t...packs.underline,\n\tcolor: boxPalette.foregroundAction,\n\tcursor: 'pointer',\n\n\t'&:hover': {\n\t\tcolor: boxPalette.foregroundText,\n\t\ttextDecoration: 'none',\n\t},\n};\n\ntype FocusProps = Partial<{ focus: boolean }>;\nexport const focusStyles = {\n\t':focus': packs.outline,\n\t'&::-moz-focus-inner': {\n\t\tborder: 0,\n\t},\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tTypographyProps &\n\tLayoutProps &\n\tLinkProps &\n\tPaddingProps;\n\nexport function boxStyles({\n\tpalette,\n\tdark,\n\tlight,\n\tcolor,\n\tbackground,\n\tborder,\n\tborderWidth,\n\tborderLeft,\n\tborderLeftWidth,\n\tborderRight,\n\tborderRightWidth,\n\tborderTop,\n\tborderTopWidth,\n\tborderBottom,\n\tborderBottomWidth,\n\tborderX,\n\tborderY,\n\trounded,\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n\tpaddingTop,\n\tpaddingBottom,\n\tpaddingRight,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tfontWeight,\n\tfontFamily,\n\tfontSize,\n\tfocus,\n\tlink,\n\tlineHeight,\n\t...restProps\n}: BoxProps) {\n\treturn [\n\t\tcss([\n\t\t\tpaletteStyles({ palette, dark, light }),\n\n\t\t\t// common resets\n\t\t\t{\n\t\t\t\tboxSizing: 'border-box',\n\t\t\t\tlistStyle: 'none',\n\t\t\t\tmargin: 0,\n\t\t\t\tpadding: 0,\n\t\t\t},\n\n\t\t\tmq({\n\t\t\t\t...colorStyles({ background, color }),\n\n\t\t\t\t...borderStyles({\n\t\t\t\t\tborder,\n\t\t\t\t\tborderWidth,\n\t\t\t\t\tborderLeft,\n\t\t\t\t\tborderLeftWidth,\n\t\t\t\t\tborderRight,\n\t\t\t\t\tborderRightWidth,\n\t\t\t\t\tborderTop,\n\t\t\t\t\tborderTopWidth,\n\t\t\t\t\tborderBottom,\n\t\t\t\t\tborderBottomWidth,\n\t\t\t\t\tborderX,\n\t\t\t\t\tborderY,\n\t\t\t\t\trounded,\n\t\t\t\t}),\n\n\t\t\t\t...layoutStyles({\n\t\t\t\t\tdisplay,\n\t\t\t\t\tflexDirection,\n\t\t\t\t\tflexWrap,\n\t\t\t\t\tflexGrow,\n\t\t\t\t\tflexShrink,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\twidth,\n\t\t\t\t\tminWidth,\n\t\t\t\t\tmaxWidth,\n\t\t\t\t\theight,\n\t\t\t\t\tminHeight,\n\t\t\t\t\tmaxHeight,\n\t\t\t\t}),\n\n\t\t\t\t...paddingStyles({\n\t\t\t\t\tpaddingTop,\n\t\t\t\t\tpaddingBottom,\n\t\t\t\t\tpaddingRight,\n\t\t\t\t\tpaddingLeft,\n\t\t\t\t\tpaddingX,\n\t\t\t\t\tpaddingY,\n\t\t\t\t\tpadding,\n\t\t\t\t}),\n\n\t\t\t\t...typographyStyles({\n\t\t\t\t\tfontWeight,\n\t\t\t\t\tfontFamily,\n\t\t\t\t\tfontSize,\n\t\t\t\t\tlineHeight,\n\t\t\t\t}),\n\n\t\t\t\t...(link ? linkStyles : undefined),\n\t\t\t\t...(focus ? focusStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps]; | ||
} | ||
@@ -287,0 +287,0 @@ |
@@ -1,2 +0,2 @@ | ||
import { tokens, BoxPalette, ResponsiveProp, Spacing, BorderWidth } from '@ag.ds-next/core'; | ||
import { BoxPalette, ResponsiveProp, Spacing, BorderWidth, FontWeight, FontSize, LineHeight, Font } from '@ag.ds-next/core'; | ||
declare type PaletteProps = Partial<{ | ||
@@ -30,6 +30,6 @@ palette: BoxPalette; | ||
declare type TypographyProps = Partial<{ | ||
fontWeight: ResponsiveProp<keyof typeof tokens.fontWeight>; | ||
fontFamily: ResponsiveProp<keyof typeof tokens.font>; | ||
fontSize: ResponsiveProp<keyof typeof tokens.fontSize>; | ||
lineHeight: keyof typeof tokens.lineHeight; | ||
fontWeight: ResponsiveProp<FontWeight>; | ||
fontFamily: ResponsiveProp<Font>; | ||
fontSize: ResponsiveProp<FontSize>; | ||
lineHeight: LineHeight; | ||
}>; | ||
@@ -36,0 +36,0 @@ declare type LayoutProps = Partial<{ |
{ | ||
"name": "@ag.ds-next/box", | ||
"version": "4.1.0", | ||
"version": "4.1.1", | ||
"main": "dist/ag.ds-next-box.cjs.js", | ||
@@ -8,3 +8,3 @@ "module": "dist/ag.ds-next-box.esm.js", | ||
"peerDependencies": { | ||
"@ag.ds-next/core": "2.1.4", | ||
"@ag.ds-next/core": "2.1.5", | ||
"@emotion/react": "^11.7.0" | ||
@@ -11,0 +11,0 @@ }, |
@@ -16,2 +16,6 @@ import { css } from '@emotion/react'; | ||
BorderWidth, | ||
FontWeight, | ||
FontSize, | ||
LineHeight, | ||
Font, | ||
} from '@ag.ds-next/core'; | ||
@@ -68,6 +72,6 @@ | ||
type TypographyProps = Partial<{ | ||
fontWeight: ResponsiveProp<keyof typeof tokens.fontWeight>; | ||
fontFamily: ResponsiveProp<keyof typeof tokens.font>; | ||
fontSize: ResponsiveProp<keyof typeof tokens.fontSize>; | ||
lineHeight: keyof typeof tokens.lineHeight; | ||
fontWeight: ResponsiveProp<FontWeight>; | ||
fontFamily: ResponsiveProp<Font>; | ||
fontSize: ResponsiveProp<FontSize>; | ||
lineHeight: LineHeight; | ||
}>; | ||
@@ -74,0 +78,0 @@ |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
1986
81945