Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@ag.ds-next/box

Package Overview
Dependencies
Maintainers
3
Versions
17
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ag.ds-next/box - npm Package Compare versions

Comparing version 7.0.0 to 8.0.0

src/__snapshots__/Box.test.tsx.snap

15

CHANGELOG.md
# @ag.ds-next/box
## 8.0.0
### Patch Changes
- 0ba460044: Add gridColumnSpan, gridColumnStart and gridColumnEnd props
- 30726c674: Added new prop `highContrastOutline`
- def4b6687: Sort package.json files
- 70aa65c52: Add 'table', 'grid' and 'inline-grid' display types
- Updated dependencies [e4c7ceb5f]
- Updated dependencies [def4b6687]
- Updated dependencies [c128d8632]
- Updated dependencies [74ca5f4c6]
- Updated dependencies [355806633]
- @ag.ds-next/core@4.1.0
## 7.0.0

@@ -4,0 +19,0 @@

27

dist/ag.ds-next-box.cjs.dev.js

@@ -12,3 +12,3 @@ 'use strict';

var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "focus", "link", "lineHeight"];
var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "gridColumnSpan", "gridColumnStart", "gridColumnEnd", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "lineHeight", "focus", "link", "highContrastOutline"];

@@ -113,2 +113,5 @@ function ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }

flexShrink = _ref5.flexShrink,
gridColumnSpan = _ref5.gridColumnSpan,
gridColumnStart = _ref5.gridColumnStart,
gridColumnEnd = _ref5.gridColumnEnd,
justifyContent = _ref5.justifyContent,

@@ -131,2 +134,7 @@ alignItems = _ref5.alignItems,

flexShrink: core.mapResponsiveProp(flexShrink),
gridColumn: core.mapResponsiveProp(gridColumnSpan, function (v) {
return "span ".concat(v, "/span ").concat(v);
}),
gridColumnStart: core.mapResponsiveProp(gridColumnStart),
gridColumnEnd: core.mapResponsiveProp(gridColumnEnd),
justifyContent: core.mapResponsiveProp(justifyContent),

@@ -222,2 +230,5 @@ alignItems: core.mapResponsiveProp(alignItems),

};
var highContrastOutlineStyles = {
outline: '1px solid transparent'
};
function boxStyles(_ref16) {

@@ -248,2 +259,5 @@ var palette = _ref16.palette,

flexShrink = _ref16.flexShrink,
gridColumnSpan = _ref16.gridColumnSpan,
gridColumnStart = _ref16.gridColumnStart,
gridColumnEnd = _ref16.gridColumnEnd,
justifyContent = _ref16.justifyContent,

@@ -270,5 +284,6 @@ alignItems = _ref16.alignItems,

fontSize = _ref16.fontSize,
lineHeight = _ref16.lineHeight,
focus = _ref16.focus,
link = _ref16.link,
lineHeight = _ref16.lineHeight,
highContrastOutline = _ref16.highContrastOutline,
restProps = _objectWithoutProperties(_ref16, _excluded$3);

@@ -290,3 +305,3 @@

padding: 0
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
background: background,

@@ -315,2 +330,5 @@ color: color

flexShrink: flexShrink,
gridColumnSpan: gridColumnSpan,
gridColumnStart: gridColumnStart,
gridColumnEnd: gridColumnEnd,
justifyContent: justifyContent,

@@ -340,3 +358,3 @@ alignItems: alignItems,

lineHeight: lineHeight
})), link ? linkStyles : undefined), 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":"AAgZE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tcolumnGap,\n\trowGap,\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\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\tborderColor,\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\tcolumnGap,\n\trowGap,\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\tborderColor,\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\tcolumnGap,\n\t\t\t\t\trowGap,\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"]} */", 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":"AAgZE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tcolumnGap,\n\trowGap,\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\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\tborderColor,\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\tcolumnGap,\n\trowGap,\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\tborderColor,\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\tcolumnGap,\n\t\t\t\t\trowGap,\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];
})), link ? linkStyles : undefined), focus ? focusStyles : undefined), highContrastOutline ? highContrastOutlineStyles : 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":"AAyaE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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'\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\t| 'grid'\n\t\t| 'inline-grid'\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\tgridColumnSpan: ResponsiveProp<number>;\n\tgridColumnStart: ResponsiveProp<number>;\n\tgridColumnEnd: 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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tgridColumn: mapResponsiveProp(gridColumnSpan, (v) => `span ${v}/span ${v}`),\n\t\tgridColumnStart: mapResponsiveProp(gridColumnStart),\n\t\tgridColumnEnd: mapResponsiveProp(gridColumnEnd),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\ntype HighContrastProps = Partial<{\n\t/** If true, a solid outline will be visible in windows high contrast mode. */\n\thighContrastOutline: boolean;\n}>;\nexport const highContrastOutlineStyles = {\n\toutline: '1px solid transparent',\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tHighContrastProps &\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\tborderColor,\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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tlineHeight,\n\tfocus,\n\tlink,\n\thighContrastOutline,\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\tborderColor,\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\tgridColumnSpan,\n\t\t\t\t\tgridColumnStart,\n\t\t\t\t\tgridColumnEnd,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\tcolumnGap,\n\t\t\t\t\trowGap,\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\t...(highContrastOutline ? highContrastOutlineStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */", 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":"AAyaE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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'\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\t| 'grid'\n\t\t| 'inline-grid'\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\tgridColumnSpan: ResponsiveProp<number>;\n\tgridColumnStart: ResponsiveProp<number>;\n\tgridColumnEnd: 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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tgridColumn: mapResponsiveProp(gridColumnSpan, (v) => `span ${v}/span ${v}`),\n\t\tgridColumnStart: mapResponsiveProp(gridColumnStart),\n\t\tgridColumnEnd: mapResponsiveProp(gridColumnEnd),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\ntype HighContrastProps = Partial<{\n\t/** If true, a solid outline will be visible in windows high contrast mode. */\n\thighContrastOutline: boolean;\n}>;\nexport const highContrastOutlineStyles = {\n\toutline: '1px solid transparent',\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tHighContrastProps &\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\tborderColor,\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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tlineHeight,\n\tfocus,\n\tlink,\n\thighContrastOutline,\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\tborderColor,\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\tgridColumnSpan,\n\t\t\t\t\tgridColumnStart,\n\t\t\t\t\tgridColumnEnd,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\tcolumnGap,\n\t\t\t\t\trowGap,\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\t...(highContrastOutline ? highContrastOutlineStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps];
}

@@ -421,2 +439,3 @@

exports.foregroundColorMap = foregroundColorMap;
exports.highContrastOutlineStyles = highContrastOutlineStyles;
exports.linkStyles = linkStyles;

@@ -12,3 +12,3 @@ 'use strict';

var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "focus", "link", "lineHeight"];
var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "gridColumnSpan", "gridColumnStart", "gridColumnEnd", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "lineHeight", "focus", "link", "highContrastOutline"];

@@ -113,2 +113,5 @@ function ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }

flexShrink = _ref5.flexShrink,
gridColumnSpan = _ref5.gridColumnSpan,
gridColumnStart = _ref5.gridColumnStart,
gridColumnEnd = _ref5.gridColumnEnd,
justifyContent = _ref5.justifyContent,

@@ -131,2 +134,7 @@ alignItems = _ref5.alignItems,

flexShrink: core.mapResponsiveProp(flexShrink),
gridColumn: core.mapResponsiveProp(gridColumnSpan, function (v) {
return "span ".concat(v, "/span ").concat(v);
}),
gridColumnStart: core.mapResponsiveProp(gridColumnStart),
gridColumnEnd: core.mapResponsiveProp(gridColumnEnd),
justifyContent: core.mapResponsiveProp(justifyContent),

@@ -222,2 +230,5 @@ alignItems: core.mapResponsiveProp(alignItems),

};
var highContrastOutlineStyles = {
outline: '1px solid transparent'
};
function boxStyles(_ref16) {

@@ -248,2 +259,5 @@ var palette = _ref16.palette,

flexShrink = _ref16.flexShrink,
gridColumnSpan = _ref16.gridColumnSpan,
gridColumnStart = _ref16.gridColumnStart,
gridColumnEnd = _ref16.gridColumnEnd,
justifyContent = _ref16.justifyContent,

@@ -270,5 +284,6 @@ alignItems = _ref16.alignItems,

fontSize = _ref16.fontSize,
lineHeight = _ref16.lineHeight,
focus = _ref16.focus,
link = _ref16.link,
lineHeight = _ref16.lineHeight,
highContrastOutline = _ref16.highContrastOutline,
restProps = _objectWithoutProperties(_ref16, _excluded$3);

@@ -290,3 +305,3 @@

padding: 0
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
background: background,

@@ -315,2 +330,5 @@ color: color

flexShrink: flexShrink,
gridColumnSpan: gridColumnSpan,
gridColumnStart: gridColumnStart,
gridColumnEnd: gridColumnEnd,
justifyContent: justifyContent,

@@ -340,3 +358,3 @@ alignItems: alignItems,

lineHeight: lineHeight
})), link ? linkStyles : undefined), focus ? focusStyles : undefined))], "" , "" , "" , "" ), restProps];
})), link ? linkStyles : undefined), focus ? focusStyles : undefined), highContrastOutline ? highContrastOutlineStyles : undefined))], "" , "" , "" , "" ), restProps];
}

@@ -421,2 +439,3 @@

exports.foregroundColorMap = foregroundColorMap;
exports.highContrastOutlineStyles = highContrastOutlineStyles;
exports.linkStyles = linkStyles;

@@ -8,3 +8,3 @@ import _objectWithoutProperties from '@babel/runtime/helpers/esm/objectWithoutProperties';

var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "focus", "link", "lineHeight"];
var _excluded$3 = ["palette", "dark", "light", "color", "background", "border", "borderWidth", "borderColor", "borderLeft", "borderLeftWidth", "borderRight", "borderRightWidth", "borderTop", "borderTopWidth", "borderBottom", "borderBottomWidth", "borderX", "borderY", "rounded", "display", "flexDirection", "flexWrap", "flexGrow", "flexShrink", "gridColumnSpan", "gridColumnStart", "gridColumnEnd", "justifyContent", "alignItems", "gap", "columnGap", "rowGap", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "paddingTop", "paddingBottom", "paddingRight", "paddingLeft", "paddingX", "paddingY", "padding", "fontWeight", "fontFamily", "fontSize", "lineHeight", "focus", "link", "highContrastOutline"];

@@ -109,2 +109,5 @@ function ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }

flexShrink = _ref5.flexShrink,
gridColumnSpan = _ref5.gridColumnSpan,
gridColumnStart = _ref5.gridColumnStart,
gridColumnEnd = _ref5.gridColumnEnd,
justifyContent = _ref5.justifyContent,

@@ -127,2 +130,7 @@ alignItems = _ref5.alignItems,

flexShrink: mapResponsiveProp(flexShrink),
gridColumn: mapResponsiveProp(gridColumnSpan, function (v) {
return "span ".concat(v, "/span ").concat(v);
}),
gridColumnStart: mapResponsiveProp(gridColumnStart),
gridColumnEnd: mapResponsiveProp(gridColumnEnd),
justifyContent: mapResponsiveProp(justifyContent),

@@ -218,2 +226,5 @@ alignItems: mapResponsiveProp(alignItems),

};
var highContrastOutlineStyles = {
outline: '1px solid transparent'
};
function boxStyles(_ref16) {

@@ -244,2 +255,5 @@ var palette = _ref16.palette,

flexShrink = _ref16.flexShrink,
gridColumnSpan = _ref16.gridColumnSpan,
gridColumnStart = _ref16.gridColumnStart,
gridColumnEnd = _ref16.gridColumnEnd,
justifyContent = _ref16.justifyContent,

@@ -266,5 +280,6 @@ alignItems = _ref16.alignItems,

fontSize = _ref16.fontSize,
lineHeight = _ref16.lineHeight,
focus = _ref16.focus,
link = _ref16.link,
lineHeight = _ref16.lineHeight,
highContrastOutline = _ref16.highContrastOutline,
restProps = _objectWithoutProperties(_ref16, _excluded$3);

@@ -286,3 +301,3 @@

padding: 0
}, mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
}, mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({
background: background,

@@ -311,2 +326,5 @@ color: color

flexShrink: flexShrink,
gridColumnSpan: gridColumnSpan,
gridColumnStart: gridColumnStart,
gridColumnEnd: gridColumnEnd,
justifyContent: justifyContent,

@@ -336,3 +354,3 @@ alignItems: alignItems,

lineHeight: lineHeight
})), link ? linkStyles : undefined), 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":"AAgZE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tcolumnGap,\n\trowGap,\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\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\tborderColor,\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\tcolumnGap,\n\trowGap,\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\tborderColor,\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\tcolumnGap,\n\t\t\t\t\trowGap,\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"]} */", 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":"AAgZE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tcolumnGap,\n\trowGap,\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\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\tborderColor,\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\tcolumnGap,\n\trowGap,\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\tborderColor,\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\tcolumnGap,\n\t\t\t\t\trowGap,\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];
})), link ? linkStyles : undefined), focus ? focusStyles : undefined), highContrastOutline ? highContrastOutlineStyles : 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":"AAyaE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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'\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\t| 'grid'\n\t\t| 'inline-grid'\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\tgridColumnSpan: ResponsiveProp<number>;\n\tgridColumnStart: ResponsiveProp<number>;\n\tgridColumnEnd: 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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tgridColumn: mapResponsiveProp(gridColumnSpan, (v) => `span ${v}/span ${v}`),\n\t\tgridColumnStart: mapResponsiveProp(gridColumnStart),\n\t\tgridColumnEnd: mapResponsiveProp(gridColumnEnd),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\ntype HighContrastProps = Partial<{\n\t/** If true, a solid outline will be visible in windows high contrast mode. */\n\thighContrastOutline: boolean;\n}>;\nexport const highContrastOutlineStyles = {\n\toutline: '1px solid transparent',\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tHighContrastProps &\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\tborderColor,\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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tlineHeight,\n\tfocus,\n\tlink,\n\thighContrastOutline,\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\tborderColor,\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\tgridColumnSpan,\n\t\t\t\t\tgridColumnStart,\n\t\t\t\t\tgridColumnEnd,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\tcolumnGap,\n\t\t\t\t\trowGap,\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\t...(highContrastOutline ? highContrastOutlineStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */", 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":"AAyaE","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\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: boxPalette.accent,\n\terror: boxPalette.systemError,\n\tsuccess: boxPalette.systemSuccess,\n\twarning: boxPalette.systemWarning,\n\tinfo: boxPalette.systemInfo,\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'\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\t| 'grid'\n\t\t| 'inline-grid'\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\tgridColumnSpan: ResponsiveProp<number>;\n\tgridColumnStart: ResponsiveProp<number>;\n\tgridColumnEnd: 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\tcolumnGap: ResponsiveProp<Spacing>;\n\trowGap: 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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tgridColumn: mapResponsiveProp(gridColumnSpan, (v) => `span ${v}/span ${v}`),\n\t\tgridColumnStart: mapResponsiveProp(gridColumnStart),\n\t\tgridColumnEnd: mapResponsiveProp(gridColumnEnd),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\tcolumnGap: mapResponsiveProp(columnGap, mapSpacing),\n\t\trowGap: mapResponsiveProp(rowGap, 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\nconst borderColorMap = {\n\tborder: 'border',\n\tmuted: 'borderMuted',\n} as const;\n\ntype BorderColor = keyof typeof borderColorMap;\n\ntype BorderProps = Partial<{\n\tborder: boolean;\n\tborderWidth: BorderWidth;\n\tborderColor: BorderColor;\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\tborderColor = 'border',\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\n\t\t\t? boxPalette[borderColorMap[borderColor]]\n\t\t\t: 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\t// Display link URLs\n\t'@media print': {\n\t\t'&[href]:after': {\n\t\t\tcontent: '\" (\" attr(href) \")\" !important',\n\t\t},\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\ntype HighContrastProps = Partial<{\n\t/** If true, a solid outline will be visible in windows high contrast mode. */\n\thighContrastOutline: boolean;\n}>;\nexport const highContrastOutlineStyles = {\n\toutline: '1px solid transparent',\n};\n\nexport type BoxProps = PaletteProps &\n\tColorProps &\n\tBorderProps &\n\tFocusProps &\n\tHighContrastProps &\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\tborderColor,\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\tgridColumnSpan,\n\tgridColumnStart,\n\tgridColumnEnd,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\tcolumnGap,\n\trowGap,\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\tlineHeight,\n\tfocus,\n\tlink,\n\thighContrastOutline,\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\tborderColor,\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\tgridColumnSpan,\n\t\t\t\t\tgridColumnStart,\n\t\t\t\t\tgridColumnEnd,\n\t\t\t\t\tjustifyContent,\n\t\t\t\t\talignItems,\n\t\t\t\t\tgap,\n\t\t\t\t\tcolumnGap,\n\t\t\t\t\trowGap,\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\t...(highContrastOutline ? highContrastOutlineStyles : undefined),\n\t\t\t}),\n\t\t]),\n\t\trestProps,\n\t];\n}\n"]} */"), restProps];
}

@@ -410,2 +428,2 @@

export { Box, Flex, Stack, backgroundColorMap, boxStyles, focusStyles, foregroundColorMap, linkStyles };
export { Box, Flex, Stack, backgroundColorMap, boxStyles, focusStyles, foregroundColorMap, highContrastOutlineStyles, linkStyles };

@@ -36,3 +36,3 @@ import { BoxPalette, ResponsiveProp, Spacing, BorderWidth, FontWeight, FontSize, LineHeight, Font } from '@ag.ds-next/core';

declare type LayoutProps = Partial<{
display: ResponsiveProp<'block' | 'flex' | 'inline' | 'inline-block' | 'inline-flex' | 'none' | 'table-row-group' | 'table-header-group' | 'table-footer-group' | 'table-row' | 'table-cell' | 'table-column-group' | 'table-column' | 'table-caption'>;
display: ResponsiveProp<'block' | 'flex' | 'inline' | 'inline-block' | 'inline-flex' | 'none' | 'table' | 'table-row-group' | 'table-header-group' | 'table-footer-group' | 'table-row' | 'table-cell' | 'table-column-group' | 'table-column' | 'table-caption' | 'grid' | 'inline-grid'>;
flexDirection: ResponsiveProp<'row' | 'column' | 'row-reverse' | 'column-reverse'>;

@@ -42,2 +42,5 @@ flexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;

flexShrink: ResponsiveProp<number>;
gridColumnSpan: ResponsiveProp<number>;
gridColumnStart: ResponsiveProp<number>;
gridColumnEnd: ResponsiveProp<number>;
justifyContent: ResponsiveProp<'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly'>;

@@ -117,4 +120,11 @@ alignItems: ResponsiveProp<'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'>;

};
export declare type BoxProps = PaletteProps & ColorProps & BorderProps & FocusProps & TypographyProps & LayoutProps & LinkProps & PaddingProps;
export declare function boxStyles({ palette, dark, light, color, background, border, borderWidth, borderColor, borderLeft, borderLeftWidth, borderRight, borderRightWidth, borderTop, borderTopWidth, borderBottom, borderBottomWidth, borderX, borderY, rounded, display, flexDirection, flexWrap, flexGrow, flexShrink, justifyContent, alignItems, gap, columnGap, rowGap, width, minWidth, maxWidth, height, minHeight, maxHeight, paddingTop, paddingBottom, paddingRight, paddingLeft, paddingX, paddingY, padding, fontWeight, fontFamily, fontSize, focus, link, lineHeight, ...restProps }: BoxProps): {}[];
declare type HighContrastProps = Partial<{
/** If true, a solid outline will be visible in windows high contrast mode. */
highContrastOutline: boolean;
}>;
export declare const highContrastOutlineStyles: {
outline: string;
};
export declare type BoxProps = PaletteProps & ColorProps & BorderProps & FocusProps & HighContrastProps & TypographyProps & LayoutProps & LinkProps & PaddingProps;
export declare function boxStyles({ palette, dark, light, color, background, border, borderWidth, borderColor, borderLeft, borderLeftWidth, borderRight, borderRightWidth, borderTop, borderTopWidth, borderBottom, borderBottomWidth, borderX, borderY, rounded, display, flexDirection, flexWrap, flexGrow, flexShrink, gridColumnSpan, gridColumnStart, gridColumnEnd, justifyContent, alignItems, gap, columnGap, rowGap, width, minWidth, maxWidth, height, minHeight, maxHeight, paddingTop, paddingBottom, paddingRight, paddingLeft, paddingX, paddingY, padding, fontWeight, fontFamily, fontSize, lineHeight, focus, link, highContrastOutline, ...restProps }: BoxProps): {}[];
export {};

12

package.json
{
"name": "@ag.ds-next/box",
"version": "7.0.0",
"version": "8.0.0",
"license": "MIT",
"main": "dist/ag.ds-next-box.cjs.js",
"module": "dist/ag.ds-next-box.esm.js",
"license": "MIT",
"dependencies": {
"@babel/runtime": "^7.4.5"
},
"peerDependencies": {
"@ag.ds-next/core": "4.0.0",
"@emotion/react": "^11.7.0"
},
"devDependencies": {
"@ag.ds-next/core": "*",
"@emotion/react": "^11.7.0"
},
"peerDependencies": {
"@ag.ds-next/core": "4.1.0",
"@emotion/react": "^11.7.0"
}
}

@@ -124,2 +124,3 @@ import { css } from '@emotion/react';

| 'none'
| 'table'
| 'table-row-group'

@@ -133,2 +134,4 @@ | 'table-header-group'

| 'table-caption'
| 'grid'
| 'inline-grid'
>;

@@ -141,2 +144,5 @@ flexDirection: ResponsiveProp<

flexShrink: ResponsiveProp<number>;
gridColumnSpan: ResponsiveProp<number>;
gridColumnStart: ResponsiveProp<number>;
gridColumnEnd: ResponsiveProp<number>;
justifyContent: ResponsiveProp<

@@ -170,2 +176,5 @@ | 'flex-start'

flexShrink,
gridColumnSpan,
gridColumnStart,
gridColumnEnd,
justifyContent,

@@ -189,2 +198,5 @@ alignItems,

flexShrink: mapResponsiveProp(flexShrink),
gridColumn: mapResponsiveProp(gridColumnSpan, (v) => `span ${v}/span ${v}`),
gridColumnStart: mapResponsiveProp(gridColumnStart),
gridColumnEnd: mapResponsiveProp(gridColumnEnd),
justifyContent: mapResponsiveProp(justifyContent),

@@ -345,2 +357,10 @@ alignItems: mapResponsiveProp(alignItems),

type HighContrastProps = Partial<{
/** If true, a solid outline will be visible in windows high contrast mode. */
highContrastOutline: boolean;
}>;
export const highContrastOutlineStyles = {
outline: '1px solid transparent',
};
export type BoxProps = PaletteProps &

@@ -350,2 +370,3 @@ ColorProps &

FocusProps &
HighContrastProps &
TypographyProps &

@@ -381,2 +402,5 @@ LayoutProps &

flexShrink,
gridColumnSpan,
gridColumnStart,
gridColumnEnd,
justifyContent,

@@ -403,5 +427,6 @@ alignItems,

fontSize,
lineHeight,
focus,
link,
lineHeight,
highContrastOutline,
...restProps

@@ -447,2 +472,5 @@ }: BoxProps) {

flexShrink,
gridColumnSpan,
gridColumnStart,
gridColumnEnd,
justifyContent,

@@ -480,2 +508,3 @@ alignItems,

...(focus ? focusStyles : undefined),
...(highContrastOutline ? highContrastOutlineStyles : undefined),
}),

@@ -482,0 +511,0 @@ ]),

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc