@ag.ds-next/box
Advanced tools
Comparing version 6.0.0 to 6.1.0
# @ag.ds-next/box | ||
## 6.1.0 | ||
### Minor Changes | ||
- 46eea44f4: Add support for `columnGap` and `rowGap` props | ||
### Patch Changes | ||
- 0f76d269a: Update documentation | ||
- 042fb9e8c: Added `@babel/runtime` as a package dependency. | ||
- Updated dependencies [d43864f0e] | ||
- Updated dependencies [27b6ef36b] | ||
- Updated dependencies [b67fa1685] | ||
- Updated dependencies [042fb9e8c] | ||
- @ag.ds-next/core@3.0.1 | ||
## 6.0.0 | ||
@@ -4,0 +20,0 @@ |
@@ -5,10 +5,19 @@ 'use strict'; | ||
var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); | ||
var _defineProperty = require('@babel/runtime/helpers/defineProperty'); | ||
var react = require('@emotion/react'); | ||
var core = require('@ag.ds-next/core'); | ||
var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); | ||
var jsxRuntime = require('@emotion/react/jsx-runtime'); | ||
function paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
}) { | ||
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"]; | ||
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; } | ||
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$3(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
function paletteStyles(_ref) { | ||
var palette = _ref.palette, | ||
dark = _ref.dark, | ||
light = _ref.light; | ||
if (palette) return core.boxPalettes[palette]; | ||
@@ -19,3 +28,3 @@ if (dark) return core.boxPalettes.dark; | ||
const foregroundColorMap = { | ||
var foregroundColorMap = { | ||
text: core.boxPalette.foregroundText, | ||
@@ -32,3 +41,3 @@ action: core.boxPalette.foregroundAction, | ||
}; | ||
const backgroundColorMap = { | ||
var backgroundColorMap = { | ||
body: core.boxPalette.backgroundBody, | ||
@@ -40,23 +49,29 @@ shade: core.boxPalette.backgroundShade, | ||
function colorStyles({ | ||
color, | ||
background | ||
}) { | ||
function colorStyles(_ref2) { | ||
var color = _ref2.color, | ||
background = _ref2.background; | ||
return { | ||
color: color ? core.mapResponsiveProp(color, t => foregroundColorMap[t]) : undefined, | ||
backgroundColor: background ? core.mapResponsiveProp(background, t => backgroundColorMap[t]) : undefined | ||
color: color ? core.mapResponsiveProp(color, function (t) { | ||
return foregroundColorMap[t]; | ||
}) : undefined, | ||
backgroundColor: background ? core.mapResponsiveProp(background, function (t) { | ||
return backgroundColorMap[t]; | ||
}) : undefined | ||
}; | ||
} | ||
function typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize: _fontSize, | ||
lineHeight: _lineHeight = 'default' | ||
}) { | ||
const responsiveFontGrid = core.mapResponsiveProp(_fontSize, t => core.fontGrid(t, _lineHeight)); | ||
const { | ||
fontSize, | ||
lineHeight | ||
} = responsiveFontGrid?.reduce((acc, entry, index) => { | ||
function typographyStyles(_ref3) { | ||
var _responsiveFontGrid$r; | ||
var fontWeight = _ref3.fontWeight, | ||
fontFamily = _ref3.fontFamily, | ||
_fontSize = _ref3.fontSize, | ||
_ref3$lineHeight = _ref3.lineHeight, | ||
_lineHeight = _ref3$lineHeight === void 0 ? 'default' : _ref3$lineHeight; | ||
var responsiveFontGrid = core.mapResponsiveProp(_fontSize, function (t) { | ||
return core.fontGrid(t, _lineHeight); | ||
}); | ||
var _ref4 = (_responsiveFontGrid$r = responsiveFontGrid === null || responsiveFontGrid === void 0 ? void 0 : responsiveFontGrid.reduce(function (acc, entry, index) { | ||
acc.fontSize[index] = isEntry(entry) ? entry.fontSize : null; | ||
@@ -68,11 +83,18 @@ acc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null; | ||
lineHeight: [] | ||
}) ?? { | ||
})) !== null && _responsiveFontGrid$r !== void 0 ? _responsiveFontGrid$r : { | ||
fontSize: undefined, | ||
lineHeight: undefined | ||
}; | ||
}, | ||
fontSize = _ref4.fontSize, | ||
lineHeight = _ref4.lineHeight; | ||
return { | ||
fontWeight: core.mapResponsiveProp(fontWeight, t => core.tokens.fontWeight[t]), | ||
fontFamily: core.mapResponsiveProp(fontFamily, t => core.tokens.font[t]), | ||
fontSize, | ||
lineHeight, | ||
fontWeight: core.mapResponsiveProp(fontWeight, function (t) { | ||
return core.tokens.fontWeight[t]; | ||
}), | ||
fontFamily: core.mapResponsiveProp(fontFamily, function (t) { | ||
return core.tokens.font[t]; | ||
}), | ||
fontSize: fontSize, | ||
lineHeight: lineHeight, | ||
'& ::selection': { | ||
@@ -89,18 +111,19 @@ color: core.boxPalette.backgroundBody, | ||
function layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}) { | ||
function layoutStyles(_ref5) { | ||
var display = _ref5.display, | ||
flexDirection = _ref5.flexDirection, | ||
flexWrap = _ref5.flexWrap, | ||
flexGrow = _ref5.flexGrow, | ||
flexShrink = _ref5.flexShrink, | ||
justifyContent = _ref5.justifyContent, | ||
alignItems = _ref5.alignItems, | ||
gap = _ref5.gap, | ||
columnGap = _ref5.columnGap, | ||
rowGap = _ref5.rowGap, | ||
width = _ref5.width, | ||
minWidth = _ref5.minWidth, | ||
maxWidth = _ref5.maxWidth, | ||
height = _ref5.height, | ||
minHeight = _ref5.minHeight, | ||
maxHeight = _ref5.maxHeight; | ||
return { | ||
@@ -115,2 +138,4 @@ display: core.mapResponsiveProp(display), | ||
gap: core.mapResponsiveProp(gap, core.mapSpacing), | ||
columnGap: core.mapResponsiveProp(columnGap, core.mapSpacing), | ||
rowGap: core.mapResponsiveProp(rowGap, core.mapSpacing), | ||
width: core.mapResponsiveProp(width), | ||
@@ -125,3 +150,3 @@ minWidth: core.mapResponsiveProp(minWidth), | ||
const borderColorMap = { | ||
var borderColorMap = { | ||
border: 'border', | ||
@@ -131,25 +156,28 @@ muted: 'borderMuted' | ||
function borderStyles({ | ||
border, | ||
borderWidth = 'sm', | ||
borderColor = 'border', | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}) { | ||
const anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
function borderStyles(_ref6) { | ||
var _ref7, _ref8, _ref9, _ref10; | ||
var border = _ref6.border, | ||
_ref6$borderWidth = _ref6.borderWidth, | ||
borderWidth = _ref6$borderWidth === void 0 ? 'sm' : _ref6$borderWidth, | ||
_ref6$borderColor = _ref6.borderColor, | ||
borderColor = _ref6$borderColor === void 0 ? 'border' : _ref6$borderColor, | ||
borderLeft = _ref6.borderLeft, | ||
borderLeftWidth = _ref6.borderLeftWidth, | ||
borderRight = _ref6.borderRight, | ||
borderRightWidth = _ref6.borderRightWidth, | ||
borderTop = _ref6.borderTop, | ||
borderTopWidth = _ref6.borderTopWidth, | ||
borderBottom = _ref6.borderBottom, | ||
borderBottomWidth = _ref6.borderBottomWidth, | ||
borderX = _ref6.borderX, | ||
borderY = _ref6.borderY, | ||
rounded = _ref6.rounded; | ||
var anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
return { | ||
borderWidth: 0, | ||
borderLeftWidth: border ?? borderX ?? borderLeft ? core.tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: border ?? borderX ?? borderRight ? core.tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: border ?? borderY ?? borderTop ? core.tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: border ?? borderY ?? borderBottom ? core.tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderLeftWidth: ((_ref7 = border !== null && border !== void 0 ? border : borderX) !== null && _ref7 !== void 0 ? _ref7 : borderLeft) ? core.tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: ((_ref8 = border !== null && border !== void 0 ? border : borderX) !== null && _ref8 !== void 0 ? _ref8 : borderRight) ? core.tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: ((_ref9 = border !== null && border !== void 0 ? border : borderY) !== null && _ref9 !== void 0 ? _ref9 : borderTop) ? core.tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: ((_ref10 = border !== null && border !== void 0 ? border : borderY) !== null && _ref10 !== void 0 ? _ref10 : borderBottom) ? core.tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderColor: anyBorder ? core.boxPalette[borderColorMap[borderColor]] : undefined, | ||
@@ -162,20 +190,21 @@ borderStyle: anyBorder ? 'solid' : undefined, | ||
// TODO: Explain how overlapping shorthands padding is applied. | ||
function paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}) { | ||
function paddingStyles(_ref11) { | ||
var _ref12, _ref13, _ref14, _ref15; | ||
var paddingTop = _ref11.paddingTop, | ||
paddingBottom = _ref11.paddingBottom, | ||
paddingRight = _ref11.paddingRight, | ||
paddingLeft = _ref11.paddingLeft, | ||
paddingX = _ref11.paddingX, | ||
paddingY = _ref11.paddingY, | ||
padding = _ref11.padding; | ||
return { | ||
paddingTop: core.mapResponsiveProp(paddingTop ?? paddingY ?? padding, core.mapSpacing), | ||
paddingBottom: core.mapResponsiveProp(paddingBottom ?? paddingY ?? padding, core.mapSpacing), | ||
paddingRight: core.mapResponsiveProp(paddingRight ?? paddingX ?? padding, core.mapSpacing), | ||
paddingLeft: core.mapResponsiveProp(paddingLeft ?? paddingX ?? padding, core.mapSpacing) | ||
paddingTop: core.mapResponsiveProp((_ref12 = paddingTop !== null && paddingTop !== void 0 ? paddingTop : paddingY) !== null && _ref12 !== void 0 ? _ref12 : padding, core.mapSpacing), | ||
paddingBottom: core.mapResponsiveProp((_ref13 = paddingBottom !== null && paddingBottom !== void 0 ? paddingBottom : paddingY) !== null && _ref13 !== void 0 ? _ref13 : padding, core.mapSpacing), | ||
paddingRight: core.mapResponsiveProp((_ref14 = paddingRight !== null && paddingRight !== void 0 ? paddingRight : paddingX) !== null && _ref14 !== void 0 ? _ref14 : padding, core.mapSpacing), | ||
paddingLeft: core.mapResponsiveProp((_ref15 = paddingLeft !== null && paddingLeft !== void 0 ? paddingLeft : paddingX) !== null && _ref15 !== void 0 ? _ref15 : padding, core.mapSpacing) | ||
}; | ||
} | ||
const linkStyles = { ...core.packs.underline, | ||
var linkStyles = _objectSpread$3(_objectSpread$3({}, core.packs.underline), {}, { | ||
color: core.boxPalette.foregroundAction, | ||
@@ -193,4 +222,4 @@ cursor: 'pointer', | ||
} | ||
}; | ||
const focusStyles = { | ||
}); | ||
var focusStyles = { | ||
':focus': core.packs.outline, | ||
@@ -201,55 +230,61 @@ '&::-moz-focus-inner': { | ||
}; | ||
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, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight, | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding, | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
focus, | ||
link, | ||
lineHeight, | ||
...restProps | ||
}) { | ||
return [/*#__PURE__*/react.css([paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
function boxStyles(_ref16) { | ||
var palette = _ref16.palette, | ||
dark = _ref16.dark, | ||
light = _ref16.light, | ||
color = _ref16.color, | ||
background = _ref16.background, | ||
border = _ref16.border, | ||
borderWidth = _ref16.borderWidth, | ||
borderColor = _ref16.borderColor, | ||
borderLeft = _ref16.borderLeft, | ||
borderLeftWidth = _ref16.borderLeftWidth, | ||
borderRight = _ref16.borderRight, | ||
borderRightWidth = _ref16.borderRightWidth, | ||
borderTop = _ref16.borderTop, | ||
borderTopWidth = _ref16.borderTopWidth, | ||
borderBottom = _ref16.borderBottom, | ||
borderBottomWidth = _ref16.borderBottomWidth, | ||
borderX = _ref16.borderX, | ||
borderY = _ref16.borderY, | ||
rounded = _ref16.rounded, | ||
display = _ref16.display, | ||
flexDirection = _ref16.flexDirection, | ||
flexWrap = _ref16.flexWrap, | ||
flexGrow = _ref16.flexGrow, | ||
flexShrink = _ref16.flexShrink, | ||
justifyContent = _ref16.justifyContent, | ||
alignItems = _ref16.alignItems, | ||
gap = _ref16.gap, | ||
columnGap = _ref16.columnGap, | ||
rowGap = _ref16.rowGap, | ||
width = _ref16.width, | ||
minWidth = _ref16.minWidth, | ||
maxWidth = _ref16.maxWidth, | ||
height = _ref16.height, | ||
minHeight = _ref16.minHeight, | ||
maxHeight = _ref16.maxHeight, | ||
paddingTop = _ref16.paddingTop, | ||
paddingBottom = _ref16.paddingBottom, | ||
paddingRight = _ref16.paddingRight, | ||
paddingLeft = _ref16.paddingLeft, | ||
paddingX = _ref16.paddingX, | ||
paddingY = _ref16.paddingY, | ||
padding = _ref16.padding, | ||
fontWeight = _ref16.fontWeight, | ||
fontFamily = _ref16.fontFamily, | ||
fontSize = _ref16.fontSize, | ||
focus = _ref16.focus, | ||
link = _ref16.link, | ||
lineHeight = _ref16.lineHeight, | ||
restProps = _objectWithoutProperties(_ref16, _excluded$3); | ||
return [ | ||
/*#__PURE__*/ | ||
/*#__PURE__*/ | ||
react.css([paletteStyles({ | ||
palette: palette, | ||
dark: dark, | ||
light: light | ||
}), // common resets | ||
@@ -261,82 +296,69 @@ { | ||
padding: 0 | ||
}, core.mq({ ...colorStyles({ | ||
background, | ||
color | ||
}), | ||
...borderStyles({ | ||
border, | ||
borderWidth, | ||
borderColor, | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}), | ||
...layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}), | ||
...paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}), | ||
...typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
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":"AAyYE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\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\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\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]; | ||
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({ | ||
background: background, | ||
color: color | ||
})), borderStyles({ | ||
border: border, | ||
borderWidth: borderWidth, | ||
borderColor: borderColor, | ||
borderLeft: borderLeft, | ||
borderLeftWidth: borderLeftWidth, | ||
borderRight: borderRight, | ||
borderRightWidth: borderRightWidth, | ||
borderTop: borderTop, | ||
borderTopWidth: borderTopWidth, | ||
borderBottom: borderBottom, | ||
borderBottomWidth: borderBottomWidth, | ||
borderX: borderX, | ||
borderY: borderY, | ||
rounded: rounded | ||
})), layoutStyles({ | ||
display: display, | ||
flexDirection: flexDirection, | ||
flexWrap: flexWrap, | ||
flexGrow: flexGrow, | ||
flexShrink: flexShrink, | ||
justifyContent: justifyContent, | ||
alignItems: alignItems, | ||
gap: gap, | ||
columnGap: columnGap, | ||
rowGap: rowGap, | ||
width: width, | ||
minWidth: minWidth, | ||
maxWidth: maxWidth, | ||
height: height, | ||
minHeight: minHeight, | ||
maxHeight: maxHeight | ||
})), paddingStyles({ | ||
paddingTop: paddingTop, | ||
paddingBottom: paddingBottom, | ||
paddingRight: paddingRight, | ||
paddingLeft: paddingLeft, | ||
paddingX: paddingX, | ||
paddingY: paddingY, | ||
padding: padding | ||
})), typographyStyles({ | ||
fontWeight: fontWeight, | ||
fontFamily: fontFamily, | ||
fontSize: fontSize, | ||
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":"AAiZE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\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":"AAiZE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\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]; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
var _excluded$2 = ["as"]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
function ownKeys$2(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; } | ||
return target; | ||
}; | ||
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Box = core.forwardRefWithAs(function Box(_ref, ref) { | ||
var _ref$as = _ref.as, | ||
Tag = _ref$as === void 0 ? 'div' : _ref$as, | ||
props = _objectWithoutProperties(_ref, _excluded$2); | ||
return _extends.apply(this, arguments); | ||
} | ||
var _boxStyles = boxStyles(props), | ||
_boxStyles2 = _slicedToArray(_boxStyles, 2), | ||
styles = _boxStyles2[0], | ||
attrs = _boxStyles2[1]; | ||
const Box = core.forwardRefWithAs(function Box({ | ||
as: Tag = 'div', | ||
...props | ||
}, ref) { | ||
const [styles, attrs] = boxStyles(props); | ||
return react.jsx(Tag, _extends({ | ||
return jsxRuntime.jsx(Tag, _objectSpread$2({ | ||
ref: ref, | ||
@@ -347,13 +369,22 @@ css: styles | ||
const Flex = core.forwardRefWithAs(function Flex({ | ||
inline = false, | ||
flexDirection = 'row', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
display, | ||
...props | ||
}, ref) { | ||
return react.jsx(Box, _extends({ | ||
var _excluded$1 = ["inline", "flexDirection", "justifyContent", "alignItems", "display"]; | ||
function ownKeys$1(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; } | ||
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Flex = core.forwardRefWithAs(function Flex(_ref, ref) { | ||
var _ref$inline = _ref.inline, | ||
inline = _ref$inline === void 0 ? false : _ref$inline, | ||
_ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'row' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
display = _ref.display, | ||
props = _objectWithoutProperties(_ref, _excluded$1); | ||
return jsxRuntime.jsx(Box, _objectSpread$1({ | ||
ref: ref, | ||
display: display ?? (inline ? 'inline-flex' : 'flex'), | ||
display: display !== null && display !== void 0 ? display : inline ? 'inline-flex' : 'flex', | ||
flexDirection: flexDirection, | ||
@@ -365,9 +396,17 @@ justifyContent: justifyContent, | ||
const Stack = core.forwardRefWithAs(function Stack({ | ||
flexDirection = 'column', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
...props | ||
}, ref) { | ||
return react.jsx(Box, _extends({ | ||
var _excluded = ["flexDirection", "justifyContent", "alignItems"]; | ||
function ownKeys(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; } | ||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Stack = core.forwardRefWithAs(function Stack(_ref, ref) { | ||
var _ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'column' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
props = _objectWithoutProperties(_ref, _excluded); | ||
return jsxRuntime.jsx(Box, _objectSpread({ | ||
ref: ref, | ||
@@ -374,0 +413,0 @@ display: "flex", |
@@ -5,10 +5,19 @@ 'use strict'; | ||
var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); | ||
var _defineProperty = require('@babel/runtime/helpers/defineProperty'); | ||
var react = require('@emotion/react'); | ||
var core = require('@ag.ds-next/core'); | ||
var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); | ||
var jsxRuntime = require('@emotion/react/jsx-runtime'); | ||
function paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
}) { | ||
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"]; | ||
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; } | ||
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$3(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
function paletteStyles(_ref) { | ||
var palette = _ref.palette, | ||
dark = _ref.dark, | ||
light = _ref.light; | ||
if (palette) return core.boxPalettes[palette]; | ||
@@ -19,3 +28,3 @@ if (dark) return core.boxPalettes.dark; | ||
const foregroundColorMap = { | ||
var foregroundColorMap = { | ||
text: core.boxPalette.foregroundText, | ||
@@ -32,3 +41,3 @@ action: core.boxPalette.foregroundAction, | ||
}; | ||
const backgroundColorMap = { | ||
var backgroundColorMap = { | ||
body: core.boxPalette.backgroundBody, | ||
@@ -40,23 +49,29 @@ shade: core.boxPalette.backgroundShade, | ||
function colorStyles({ | ||
color, | ||
background | ||
}) { | ||
function colorStyles(_ref2) { | ||
var color = _ref2.color, | ||
background = _ref2.background; | ||
return { | ||
color: color ? core.mapResponsiveProp(color, t => foregroundColorMap[t]) : undefined, | ||
backgroundColor: background ? core.mapResponsiveProp(background, t => backgroundColorMap[t]) : undefined | ||
color: color ? core.mapResponsiveProp(color, function (t) { | ||
return foregroundColorMap[t]; | ||
}) : undefined, | ||
backgroundColor: background ? core.mapResponsiveProp(background, function (t) { | ||
return backgroundColorMap[t]; | ||
}) : undefined | ||
}; | ||
} | ||
function typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize: _fontSize, | ||
lineHeight: _lineHeight = 'default' | ||
}) { | ||
const responsiveFontGrid = core.mapResponsiveProp(_fontSize, t => core.fontGrid(t, _lineHeight)); | ||
const { | ||
fontSize, | ||
lineHeight | ||
} = responsiveFontGrid?.reduce((acc, entry, index) => { | ||
function typographyStyles(_ref3) { | ||
var _responsiveFontGrid$r; | ||
var fontWeight = _ref3.fontWeight, | ||
fontFamily = _ref3.fontFamily, | ||
_fontSize = _ref3.fontSize, | ||
_ref3$lineHeight = _ref3.lineHeight, | ||
_lineHeight = _ref3$lineHeight === void 0 ? 'default' : _ref3$lineHeight; | ||
var responsiveFontGrid = core.mapResponsiveProp(_fontSize, function (t) { | ||
return core.fontGrid(t, _lineHeight); | ||
}); | ||
var _ref4 = (_responsiveFontGrid$r = responsiveFontGrid === null || responsiveFontGrid === void 0 ? void 0 : responsiveFontGrid.reduce(function (acc, entry, index) { | ||
acc.fontSize[index] = isEntry(entry) ? entry.fontSize : null; | ||
@@ -68,11 +83,18 @@ acc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null; | ||
lineHeight: [] | ||
}) ?? { | ||
})) !== null && _responsiveFontGrid$r !== void 0 ? _responsiveFontGrid$r : { | ||
fontSize: undefined, | ||
lineHeight: undefined | ||
}; | ||
}, | ||
fontSize = _ref4.fontSize, | ||
lineHeight = _ref4.lineHeight; | ||
return { | ||
fontWeight: core.mapResponsiveProp(fontWeight, t => core.tokens.fontWeight[t]), | ||
fontFamily: core.mapResponsiveProp(fontFamily, t => core.tokens.font[t]), | ||
fontSize, | ||
lineHeight, | ||
fontWeight: core.mapResponsiveProp(fontWeight, function (t) { | ||
return core.tokens.fontWeight[t]; | ||
}), | ||
fontFamily: core.mapResponsiveProp(fontFamily, function (t) { | ||
return core.tokens.font[t]; | ||
}), | ||
fontSize: fontSize, | ||
lineHeight: lineHeight, | ||
'& ::selection': { | ||
@@ -89,18 +111,19 @@ color: core.boxPalette.backgroundBody, | ||
function layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}) { | ||
function layoutStyles(_ref5) { | ||
var display = _ref5.display, | ||
flexDirection = _ref5.flexDirection, | ||
flexWrap = _ref5.flexWrap, | ||
flexGrow = _ref5.flexGrow, | ||
flexShrink = _ref5.flexShrink, | ||
justifyContent = _ref5.justifyContent, | ||
alignItems = _ref5.alignItems, | ||
gap = _ref5.gap, | ||
columnGap = _ref5.columnGap, | ||
rowGap = _ref5.rowGap, | ||
width = _ref5.width, | ||
minWidth = _ref5.minWidth, | ||
maxWidth = _ref5.maxWidth, | ||
height = _ref5.height, | ||
minHeight = _ref5.minHeight, | ||
maxHeight = _ref5.maxHeight; | ||
return { | ||
@@ -115,2 +138,4 @@ display: core.mapResponsiveProp(display), | ||
gap: core.mapResponsiveProp(gap, core.mapSpacing), | ||
columnGap: core.mapResponsiveProp(columnGap, core.mapSpacing), | ||
rowGap: core.mapResponsiveProp(rowGap, core.mapSpacing), | ||
width: core.mapResponsiveProp(width), | ||
@@ -125,3 +150,3 @@ minWidth: core.mapResponsiveProp(minWidth), | ||
const borderColorMap = { | ||
var borderColorMap = { | ||
border: 'border', | ||
@@ -131,25 +156,28 @@ muted: 'borderMuted' | ||
function borderStyles({ | ||
border, | ||
borderWidth = 'sm', | ||
borderColor = 'border', | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}) { | ||
const anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
function borderStyles(_ref6) { | ||
var _ref7, _ref8, _ref9, _ref10; | ||
var border = _ref6.border, | ||
_ref6$borderWidth = _ref6.borderWidth, | ||
borderWidth = _ref6$borderWidth === void 0 ? 'sm' : _ref6$borderWidth, | ||
_ref6$borderColor = _ref6.borderColor, | ||
borderColor = _ref6$borderColor === void 0 ? 'border' : _ref6$borderColor, | ||
borderLeft = _ref6.borderLeft, | ||
borderLeftWidth = _ref6.borderLeftWidth, | ||
borderRight = _ref6.borderRight, | ||
borderRightWidth = _ref6.borderRightWidth, | ||
borderTop = _ref6.borderTop, | ||
borderTopWidth = _ref6.borderTopWidth, | ||
borderBottom = _ref6.borderBottom, | ||
borderBottomWidth = _ref6.borderBottomWidth, | ||
borderX = _ref6.borderX, | ||
borderY = _ref6.borderY, | ||
rounded = _ref6.rounded; | ||
var anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
return { | ||
borderWidth: 0, | ||
borderLeftWidth: border ?? borderX ?? borderLeft ? core.tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: border ?? borderX ?? borderRight ? core.tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: border ?? borderY ?? borderTop ? core.tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: border ?? borderY ?? borderBottom ? core.tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderLeftWidth: ((_ref7 = border !== null && border !== void 0 ? border : borderX) !== null && _ref7 !== void 0 ? _ref7 : borderLeft) ? core.tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: ((_ref8 = border !== null && border !== void 0 ? border : borderX) !== null && _ref8 !== void 0 ? _ref8 : borderRight) ? core.tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: ((_ref9 = border !== null && border !== void 0 ? border : borderY) !== null && _ref9 !== void 0 ? _ref9 : borderTop) ? core.tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: ((_ref10 = border !== null && border !== void 0 ? border : borderY) !== null && _ref10 !== void 0 ? _ref10 : borderBottom) ? core.tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderColor: anyBorder ? core.boxPalette[borderColorMap[borderColor]] : undefined, | ||
@@ -162,20 +190,21 @@ borderStyle: anyBorder ? 'solid' : undefined, | ||
// TODO: Explain how overlapping shorthands padding is applied. | ||
function paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}) { | ||
function paddingStyles(_ref11) { | ||
var _ref12, _ref13, _ref14, _ref15; | ||
var paddingTop = _ref11.paddingTop, | ||
paddingBottom = _ref11.paddingBottom, | ||
paddingRight = _ref11.paddingRight, | ||
paddingLeft = _ref11.paddingLeft, | ||
paddingX = _ref11.paddingX, | ||
paddingY = _ref11.paddingY, | ||
padding = _ref11.padding; | ||
return { | ||
paddingTop: core.mapResponsiveProp(paddingTop ?? paddingY ?? padding, core.mapSpacing), | ||
paddingBottom: core.mapResponsiveProp(paddingBottom ?? paddingY ?? padding, core.mapSpacing), | ||
paddingRight: core.mapResponsiveProp(paddingRight ?? paddingX ?? padding, core.mapSpacing), | ||
paddingLeft: core.mapResponsiveProp(paddingLeft ?? paddingX ?? padding, core.mapSpacing) | ||
paddingTop: core.mapResponsiveProp((_ref12 = paddingTop !== null && paddingTop !== void 0 ? paddingTop : paddingY) !== null && _ref12 !== void 0 ? _ref12 : padding, core.mapSpacing), | ||
paddingBottom: core.mapResponsiveProp((_ref13 = paddingBottom !== null && paddingBottom !== void 0 ? paddingBottom : paddingY) !== null && _ref13 !== void 0 ? _ref13 : padding, core.mapSpacing), | ||
paddingRight: core.mapResponsiveProp((_ref14 = paddingRight !== null && paddingRight !== void 0 ? paddingRight : paddingX) !== null && _ref14 !== void 0 ? _ref14 : padding, core.mapSpacing), | ||
paddingLeft: core.mapResponsiveProp((_ref15 = paddingLeft !== null && paddingLeft !== void 0 ? paddingLeft : paddingX) !== null && _ref15 !== void 0 ? _ref15 : padding, core.mapSpacing) | ||
}; | ||
} | ||
const linkStyles = { ...core.packs.underline, | ||
var linkStyles = _objectSpread$3(_objectSpread$3({}, core.packs.underline), {}, { | ||
color: core.boxPalette.foregroundAction, | ||
@@ -193,4 +222,4 @@ cursor: 'pointer', | ||
} | ||
}; | ||
const focusStyles = { | ||
}); | ||
var focusStyles = { | ||
':focus': core.packs.outline, | ||
@@ -201,55 +230,61 @@ '&::-moz-focus-inner': { | ||
}; | ||
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, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight, | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding, | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
focus, | ||
link, | ||
lineHeight, | ||
...restProps | ||
}) { | ||
return [/*#__PURE__*/react.css([paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
function boxStyles(_ref16) { | ||
var palette = _ref16.palette, | ||
dark = _ref16.dark, | ||
light = _ref16.light, | ||
color = _ref16.color, | ||
background = _ref16.background, | ||
border = _ref16.border, | ||
borderWidth = _ref16.borderWidth, | ||
borderColor = _ref16.borderColor, | ||
borderLeft = _ref16.borderLeft, | ||
borderLeftWidth = _ref16.borderLeftWidth, | ||
borderRight = _ref16.borderRight, | ||
borderRightWidth = _ref16.borderRightWidth, | ||
borderTop = _ref16.borderTop, | ||
borderTopWidth = _ref16.borderTopWidth, | ||
borderBottom = _ref16.borderBottom, | ||
borderBottomWidth = _ref16.borderBottomWidth, | ||
borderX = _ref16.borderX, | ||
borderY = _ref16.borderY, | ||
rounded = _ref16.rounded, | ||
display = _ref16.display, | ||
flexDirection = _ref16.flexDirection, | ||
flexWrap = _ref16.flexWrap, | ||
flexGrow = _ref16.flexGrow, | ||
flexShrink = _ref16.flexShrink, | ||
justifyContent = _ref16.justifyContent, | ||
alignItems = _ref16.alignItems, | ||
gap = _ref16.gap, | ||
columnGap = _ref16.columnGap, | ||
rowGap = _ref16.rowGap, | ||
width = _ref16.width, | ||
minWidth = _ref16.minWidth, | ||
maxWidth = _ref16.maxWidth, | ||
height = _ref16.height, | ||
minHeight = _ref16.minHeight, | ||
maxHeight = _ref16.maxHeight, | ||
paddingTop = _ref16.paddingTop, | ||
paddingBottom = _ref16.paddingBottom, | ||
paddingRight = _ref16.paddingRight, | ||
paddingLeft = _ref16.paddingLeft, | ||
paddingX = _ref16.paddingX, | ||
paddingY = _ref16.paddingY, | ||
padding = _ref16.padding, | ||
fontWeight = _ref16.fontWeight, | ||
fontFamily = _ref16.fontFamily, | ||
fontSize = _ref16.fontSize, | ||
focus = _ref16.focus, | ||
link = _ref16.link, | ||
lineHeight = _ref16.lineHeight, | ||
restProps = _objectWithoutProperties(_ref16, _excluded$3); | ||
return [ | ||
/*#__PURE__*/ | ||
/*#__PURE__*/ | ||
react.css([paletteStyles({ | ||
palette: palette, | ||
dark: dark, | ||
light: light | ||
}), // common resets | ||
@@ -261,82 +296,69 @@ { | ||
padding: 0 | ||
}, core.mq({ ...colorStyles({ | ||
background, | ||
color | ||
}), | ||
...borderStyles({ | ||
border, | ||
borderWidth, | ||
borderColor, | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}), | ||
...layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}), | ||
...paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}), | ||
...typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
lineHeight | ||
}), | ||
...(link ? linkStyles : undefined), | ||
...(focus ? focusStyles : undefined) | ||
})], "" , "" ), restProps]; | ||
}, core.mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({ | ||
background: background, | ||
color: color | ||
})), borderStyles({ | ||
border: border, | ||
borderWidth: borderWidth, | ||
borderColor: borderColor, | ||
borderLeft: borderLeft, | ||
borderLeftWidth: borderLeftWidth, | ||
borderRight: borderRight, | ||
borderRightWidth: borderRightWidth, | ||
borderTop: borderTop, | ||
borderTopWidth: borderTopWidth, | ||
borderBottom: borderBottom, | ||
borderBottomWidth: borderBottomWidth, | ||
borderX: borderX, | ||
borderY: borderY, | ||
rounded: rounded | ||
})), layoutStyles({ | ||
display: display, | ||
flexDirection: flexDirection, | ||
flexWrap: flexWrap, | ||
flexGrow: flexGrow, | ||
flexShrink: flexShrink, | ||
justifyContent: justifyContent, | ||
alignItems: alignItems, | ||
gap: gap, | ||
columnGap: columnGap, | ||
rowGap: rowGap, | ||
width: width, | ||
minWidth: minWidth, | ||
maxWidth: maxWidth, | ||
height: height, | ||
minHeight: minHeight, | ||
maxHeight: maxHeight | ||
})), paddingStyles({ | ||
paddingTop: paddingTop, | ||
paddingBottom: paddingBottom, | ||
paddingRight: paddingRight, | ||
paddingLeft: paddingLeft, | ||
paddingX: paddingX, | ||
paddingY: paddingY, | ||
padding: padding | ||
})), typographyStyles({ | ||
fontWeight: fontWeight, | ||
fontFamily: fontFamily, | ||
fontSize: fontSize, | ||
lineHeight: lineHeight | ||
})), link ? linkStyles : undefined), focus ? focusStyles : undefined))], "" , "" , "" , "" ), restProps]; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
var _excluded$2 = ["as"]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
function ownKeys$2(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; } | ||
return target; | ||
}; | ||
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Box = core.forwardRefWithAs(function Box(_ref, ref) { | ||
var _ref$as = _ref.as, | ||
Tag = _ref$as === void 0 ? 'div' : _ref$as, | ||
props = _objectWithoutProperties(_ref, _excluded$2); | ||
return _extends.apply(this, arguments); | ||
} | ||
var _boxStyles = boxStyles(props), | ||
_boxStyles2 = _slicedToArray(_boxStyles, 2), | ||
styles = _boxStyles2[0], | ||
attrs = _boxStyles2[1]; | ||
const Box = core.forwardRefWithAs(function Box({ | ||
as: Tag = 'div', | ||
...props | ||
}, ref) { | ||
const [styles, attrs] = boxStyles(props); | ||
return react.jsx(Tag, _extends({ | ||
return jsxRuntime.jsx(Tag, _objectSpread$2({ | ||
ref: ref, | ||
@@ -347,13 +369,22 @@ css: styles | ||
const Flex = core.forwardRefWithAs(function Flex({ | ||
inline = false, | ||
flexDirection = 'row', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
display, | ||
...props | ||
}, ref) { | ||
return react.jsx(Box, _extends({ | ||
var _excluded$1 = ["inline", "flexDirection", "justifyContent", "alignItems", "display"]; | ||
function ownKeys$1(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; } | ||
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Flex = core.forwardRefWithAs(function Flex(_ref, ref) { | ||
var _ref$inline = _ref.inline, | ||
inline = _ref$inline === void 0 ? false : _ref$inline, | ||
_ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'row' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
display = _ref.display, | ||
props = _objectWithoutProperties(_ref, _excluded$1); | ||
return jsxRuntime.jsx(Box, _objectSpread$1({ | ||
ref: ref, | ||
display: display ?? (inline ? 'inline-flex' : 'flex'), | ||
display: display !== null && display !== void 0 ? display : inline ? 'inline-flex' : 'flex', | ||
flexDirection: flexDirection, | ||
@@ -365,9 +396,17 @@ justifyContent: justifyContent, | ||
const Stack = core.forwardRefWithAs(function Stack({ | ||
flexDirection = 'column', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
...props | ||
}, ref) { | ||
return react.jsx(Box, _extends({ | ||
var _excluded = ["flexDirection", "justifyContent", "alignItems"]; | ||
function ownKeys(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; } | ||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Stack = core.forwardRefWithAs(function Stack(_ref, ref) { | ||
var _ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'column' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
props = _objectWithoutProperties(_ref, _excluded); | ||
return jsxRuntime.jsx(Box, _objectSpread({ | ||
ref: ref, | ||
@@ -374,0 +413,0 @@ display: "flex", |
@@ -1,9 +0,18 @@ | ||
import { css, jsx } from '@emotion/react'; | ||
import _objectWithoutProperties from '@babel/runtime/helpers/esm/objectWithoutProperties'; | ||
import _defineProperty from '@babel/runtime/helpers/esm/defineProperty'; | ||
import { css } from '@emotion/react'; | ||
import { boxPalette, globalPalette, packs, mq, mapResponsiveProp, tokens, mapSpacing, boxPalettes, fontGrid, forwardRefWithAs } from '@ag.ds-next/core'; | ||
import _slicedToArray from '@babel/runtime/helpers/esm/slicedToArray'; | ||
import { jsx } from '@emotion/react/jsx-runtime'; | ||
function paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
}) { | ||
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"]; | ||
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; } | ||
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$3(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
function paletteStyles(_ref) { | ||
var palette = _ref.palette, | ||
dark = _ref.dark, | ||
light = _ref.light; | ||
if (palette) return boxPalettes[palette]; | ||
@@ -14,3 +23,3 @@ if (dark) return boxPalettes.dark; | ||
const foregroundColorMap = { | ||
var foregroundColorMap = { | ||
text: boxPalette.foregroundText, | ||
@@ -27,3 +36,3 @@ action: boxPalette.foregroundAction, | ||
}; | ||
const backgroundColorMap = { | ||
var backgroundColorMap = { | ||
body: boxPalette.backgroundBody, | ||
@@ -35,23 +44,29 @@ shade: boxPalette.backgroundShade, | ||
function colorStyles({ | ||
color, | ||
background | ||
}) { | ||
function colorStyles(_ref2) { | ||
var color = _ref2.color, | ||
background = _ref2.background; | ||
return { | ||
color: color ? mapResponsiveProp(color, t => foregroundColorMap[t]) : undefined, | ||
backgroundColor: background ? mapResponsiveProp(background, t => backgroundColorMap[t]) : undefined | ||
color: color ? mapResponsiveProp(color, function (t) { | ||
return foregroundColorMap[t]; | ||
}) : undefined, | ||
backgroundColor: background ? mapResponsiveProp(background, function (t) { | ||
return backgroundColorMap[t]; | ||
}) : undefined | ||
}; | ||
} | ||
function typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize: _fontSize, | ||
lineHeight: _lineHeight = 'default' | ||
}) { | ||
const responsiveFontGrid = mapResponsiveProp(_fontSize, t => fontGrid(t, _lineHeight)); | ||
const { | ||
fontSize, | ||
lineHeight | ||
} = responsiveFontGrid?.reduce((acc, entry, index) => { | ||
function typographyStyles(_ref3) { | ||
var _responsiveFontGrid$r; | ||
var fontWeight = _ref3.fontWeight, | ||
fontFamily = _ref3.fontFamily, | ||
_fontSize = _ref3.fontSize, | ||
_ref3$lineHeight = _ref3.lineHeight, | ||
_lineHeight = _ref3$lineHeight === void 0 ? 'default' : _ref3$lineHeight; | ||
var responsiveFontGrid = mapResponsiveProp(_fontSize, function (t) { | ||
return fontGrid(t, _lineHeight); | ||
}); | ||
var _ref4 = (_responsiveFontGrid$r = responsiveFontGrid === null || responsiveFontGrid === void 0 ? void 0 : responsiveFontGrid.reduce(function (acc, entry, index) { | ||
acc.fontSize[index] = isEntry(entry) ? entry.fontSize : null; | ||
@@ -63,11 +78,18 @@ acc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null; | ||
lineHeight: [] | ||
}) ?? { | ||
})) !== null && _responsiveFontGrid$r !== void 0 ? _responsiveFontGrid$r : { | ||
fontSize: undefined, | ||
lineHeight: undefined | ||
}; | ||
}, | ||
fontSize = _ref4.fontSize, | ||
lineHeight = _ref4.lineHeight; | ||
return { | ||
fontWeight: mapResponsiveProp(fontWeight, t => tokens.fontWeight[t]), | ||
fontFamily: mapResponsiveProp(fontFamily, t => tokens.font[t]), | ||
fontSize, | ||
lineHeight, | ||
fontWeight: mapResponsiveProp(fontWeight, function (t) { | ||
return tokens.fontWeight[t]; | ||
}), | ||
fontFamily: mapResponsiveProp(fontFamily, function (t) { | ||
return tokens.font[t]; | ||
}), | ||
fontSize: fontSize, | ||
lineHeight: lineHeight, | ||
'& ::selection': { | ||
@@ -84,18 +106,19 @@ color: boxPalette.backgroundBody, | ||
function layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}) { | ||
function layoutStyles(_ref5) { | ||
var display = _ref5.display, | ||
flexDirection = _ref5.flexDirection, | ||
flexWrap = _ref5.flexWrap, | ||
flexGrow = _ref5.flexGrow, | ||
flexShrink = _ref5.flexShrink, | ||
justifyContent = _ref5.justifyContent, | ||
alignItems = _ref5.alignItems, | ||
gap = _ref5.gap, | ||
columnGap = _ref5.columnGap, | ||
rowGap = _ref5.rowGap, | ||
width = _ref5.width, | ||
minWidth = _ref5.minWidth, | ||
maxWidth = _ref5.maxWidth, | ||
height = _ref5.height, | ||
minHeight = _ref5.minHeight, | ||
maxHeight = _ref5.maxHeight; | ||
return { | ||
@@ -110,2 +133,4 @@ display: mapResponsiveProp(display), | ||
gap: mapResponsiveProp(gap, mapSpacing), | ||
columnGap: mapResponsiveProp(columnGap, mapSpacing), | ||
rowGap: mapResponsiveProp(rowGap, mapSpacing), | ||
width: mapResponsiveProp(width), | ||
@@ -120,3 +145,3 @@ minWidth: mapResponsiveProp(minWidth), | ||
const borderColorMap = { | ||
var borderColorMap = { | ||
border: 'border', | ||
@@ -126,25 +151,28 @@ muted: 'borderMuted' | ||
function borderStyles({ | ||
border, | ||
borderWidth = 'sm', | ||
borderColor = 'border', | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}) { | ||
const anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
function borderStyles(_ref6) { | ||
var _ref7, _ref8, _ref9, _ref10; | ||
var border = _ref6.border, | ||
_ref6$borderWidth = _ref6.borderWidth, | ||
borderWidth = _ref6$borderWidth === void 0 ? 'sm' : _ref6$borderWidth, | ||
_ref6$borderColor = _ref6.borderColor, | ||
borderColor = _ref6$borderColor === void 0 ? 'border' : _ref6$borderColor, | ||
borderLeft = _ref6.borderLeft, | ||
borderLeftWidth = _ref6.borderLeftWidth, | ||
borderRight = _ref6.borderRight, | ||
borderRightWidth = _ref6.borderRightWidth, | ||
borderTop = _ref6.borderTop, | ||
borderTopWidth = _ref6.borderTopWidth, | ||
borderBottom = _ref6.borderBottom, | ||
borderBottomWidth = _ref6.borderBottomWidth, | ||
borderX = _ref6.borderX, | ||
borderY = _ref6.borderY, | ||
rounded = _ref6.rounded; | ||
var anyBorder = border || borderLeft || borderRight || borderTop || borderBottom || borderX || borderY; | ||
return { | ||
borderWidth: 0, | ||
borderLeftWidth: border ?? borderX ?? borderLeft ? tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: border ?? borderX ?? borderRight ? tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: border ?? borderY ?? borderTop ? tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: border ?? borderY ?? borderBottom ? tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderLeftWidth: ((_ref7 = border !== null && border !== void 0 ? border : borderX) !== null && _ref7 !== void 0 ? _ref7 : borderLeft) ? tokens.borderWidth[borderLeftWidth || borderWidth] : undefined, | ||
borderRightWidth: ((_ref8 = border !== null && border !== void 0 ? border : borderX) !== null && _ref8 !== void 0 ? _ref8 : borderRight) ? tokens.borderWidth[borderRightWidth || borderWidth] : undefined, | ||
borderTopWidth: ((_ref9 = border !== null && border !== void 0 ? border : borderY) !== null && _ref9 !== void 0 ? _ref9 : borderTop) ? tokens.borderWidth[borderTopWidth || borderWidth] : undefined, | ||
borderBottomWidth: ((_ref10 = border !== null && border !== void 0 ? border : borderY) !== null && _ref10 !== void 0 ? _ref10 : borderBottom) ? tokens.borderWidth[borderBottomWidth || borderWidth] : undefined, | ||
borderColor: anyBorder ? boxPalette[borderColorMap[borderColor]] : undefined, | ||
@@ -157,20 +185,21 @@ borderStyle: anyBorder ? 'solid' : undefined, | ||
// TODO: Explain how overlapping shorthands padding is applied. | ||
function paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}) { | ||
function paddingStyles(_ref11) { | ||
var _ref12, _ref13, _ref14, _ref15; | ||
var paddingTop = _ref11.paddingTop, | ||
paddingBottom = _ref11.paddingBottom, | ||
paddingRight = _ref11.paddingRight, | ||
paddingLeft = _ref11.paddingLeft, | ||
paddingX = _ref11.paddingX, | ||
paddingY = _ref11.paddingY, | ||
padding = _ref11.padding; | ||
return { | ||
paddingTop: mapResponsiveProp(paddingTop ?? paddingY ?? padding, mapSpacing), | ||
paddingBottom: mapResponsiveProp(paddingBottom ?? paddingY ?? padding, mapSpacing), | ||
paddingRight: mapResponsiveProp(paddingRight ?? paddingX ?? padding, mapSpacing), | ||
paddingLeft: mapResponsiveProp(paddingLeft ?? paddingX ?? padding, mapSpacing) | ||
paddingTop: mapResponsiveProp((_ref12 = paddingTop !== null && paddingTop !== void 0 ? paddingTop : paddingY) !== null && _ref12 !== void 0 ? _ref12 : padding, mapSpacing), | ||
paddingBottom: mapResponsiveProp((_ref13 = paddingBottom !== null && paddingBottom !== void 0 ? paddingBottom : paddingY) !== null && _ref13 !== void 0 ? _ref13 : padding, mapSpacing), | ||
paddingRight: mapResponsiveProp((_ref14 = paddingRight !== null && paddingRight !== void 0 ? paddingRight : paddingX) !== null && _ref14 !== void 0 ? _ref14 : padding, mapSpacing), | ||
paddingLeft: mapResponsiveProp((_ref15 = paddingLeft !== null && paddingLeft !== void 0 ? paddingLeft : paddingX) !== null && _ref15 !== void 0 ? _ref15 : padding, mapSpacing) | ||
}; | ||
} | ||
const linkStyles = { ...packs.underline, | ||
var linkStyles = _objectSpread$3(_objectSpread$3({}, packs.underline), {}, { | ||
color: boxPalette.foregroundAction, | ||
@@ -188,4 +217,4 @@ cursor: 'pointer', | ||
} | ||
}; | ||
const focusStyles = { | ||
}); | ||
var focusStyles = { | ||
':focus': packs.outline, | ||
@@ -196,55 +225,61 @@ '&::-moz-focus-inner': { | ||
}; | ||
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, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight, | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding, | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
focus, | ||
link, | ||
lineHeight, | ||
...restProps | ||
}) { | ||
return [/*#__PURE__*/css([paletteStyles({ | ||
palette, | ||
dark, | ||
light | ||
function boxStyles(_ref16) { | ||
var palette = _ref16.palette, | ||
dark = _ref16.dark, | ||
light = _ref16.light, | ||
color = _ref16.color, | ||
background = _ref16.background, | ||
border = _ref16.border, | ||
borderWidth = _ref16.borderWidth, | ||
borderColor = _ref16.borderColor, | ||
borderLeft = _ref16.borderLeft, | ||
borderLeftWidth = _ref16.borderLeftWidth, | ||
borderRight = _ref16.borderRight, | ||
borderRightWidth = _ref16.borderRightWidth, | ||
borderTop = _ref16.borderTop, | ||
borderTopWidth = _ref16.borderTopWidth, | ||
borderBottom = _ref16.borderBottom, | ||
borderBottomWidth = _ref16.borderBottomWidth, | ||
borderX = _ref16.borderX, | ||
borderY = _ref16.borderY, | ||
rounded = _ref16.rounded, | ||
display = _ref16.display, | ||
flexDirection = _ref16.flexDirection, | ||
flexWrap = _ref16.flexWrap, | ||
flexGrow = _ref16.flexGrow, | ||
flexShrink = _ref16.flexShrink, | ||
justifyContent = _ref16.justifyContent, | ||
alignItems = _ref16.alignItems, | ||
gap = _ref16.gap, | ||
columnGap = _ref16.columnGap, | ||
rowGap = _ref16.rowGap, | ||
width = _ref16.width, | ||
minWidth = _ref16.minWidth, | ||
maxWidth = _ref16.maxWidth, | ||
height = _ref16.height, | ||
minHeight = _ref16.minHeight, | ||
maxHeight = _ref16.maxHeight, | ||
paddingTop = _ref16.paddingTop, | ||
paddingBottom = _ref16.paddingBottom, | ||
paddingRight = _ref16.paddingRight, | ||
paddingLeft = _ref16.paddingLeft, | ||
paddingX = _ref16.paddingX, | ||
paddingY = _ref16.paddingY, | ||
padding = _ref16.padding, | ||
fontWeight = _ref16.fontWeight, | ||
fontFamily = _ref16.fontFamily, | ||
fontSize = _ref16.fontSize, | ||
focus = _ref16.focus, | ||
link = _ref16.link, | ||
lineHeight = _ref16.lineHeight, | ||
restProps = _objectWithoutProperties(_ref16, _excluded$3); | ||
return [ | ||
/*#__PURE__*/ | ||
/*#__PURE__*/ | ||
css([paletteStyles({ | ||
palette: palette, | ||
dark: dark, | ||
light: light | ||
}), // common resets | ||
@@ -256,82 +291,69 @@ { | ||
padding: 0 | ||
}, mq({ ...colorStyles({ | ||
background, | ||
color | ||
}), | ||
...borderStyles({ | ||
border, | ||
borderWidth, | ||
borderColor, | ||
borderLeft, | ||
borderLeftWidth, | ||
borderRight, | ||
borderRightWidth, | ||
borderTop, | ||
borderTopWidth, | ||
borderBottom, | ||
borderBottomWidth, | ||
borderX, | ||
borderY, | ||
rounded | ||
}), | ||
...layoutStyles({ | ||
display, | ||
flexDirection, | ||
flexWrap, | ||
flexGrow, | ||
flexShrink, | ||
justifyContent, | ||
alignItems, | ||
gap, | ||
width, | ||
minWidth, | ||
maxWidth, | ||
height, | ||
minHeight, | ||
maxHeight | ||
}), | ||
...paddingStyles({ | ||
paddingTop, | ||
paddingBottom, | ||
paddingRight, | ||
paddingLeft, | ||
paddingX, | ||
paddingY, | ||
padding | ||
}), | ||
...typographyStyles({ | ||
fontWeight, | ||
fontFamily, | ||
fontSize, | ||
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":"AAyYE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\twidth: ResponsiveProp<number | string>;\n\tminWidth: ResponsiveProp<number | string>;\n\tmaxWidth: ResponsiveProp<number | string>;\n\theight: ResponsiveProp<number | string>;\n\tminHeight: ResponsiveProp<number | string>;\n\tmaxHeight: ResponsiveProp<number | string>;\n}>;\n\nfunction layoutStyles({\n\tdisplay,\n\tflexDirection,\n\tflexWrap,\n\tflexGrow,\n\tflexShrink,\n\tjustifyContent,\n\talignItems,\n\tgap,\n\twidth,\n\tminWidth,\n\tmaxWidth,\n\theight,\n\tminHeight,\n\tmaxHeight,\n}: LayoutProps) {\n\treturn {\n\t\tdisplay: mapResponsiveProp(display),\n\t\tflexDirection: mapResponsiveProp(flexDirection),\n\t\tflexWrap: mapResponsiveProp(flexWrap),\n\t\tflexGrow: mapResponsiveProp(flexGrow),\n\t\tflexShrink: mapResponsiveProp(flexShrink),\n\t\tjustifyContent: mapResponsiveProp(justifyContent),\n\t\talignItems: mapResponsiveProp(alignItems),\n\t\tgap: mapResponsiveProp(gap, mapSpacing),\n\t\twidth: mapResponsiveProp(width),\n\t\tminWidth: mapResponsiveProp(minWidth),\n\t\tmaxWidth: mapResponsiveProp(maxWidth),\n\t\theight: mapResponsiveProp(height),\n\t\tminHeight: mapResponsiveProp(minHeight),\n\t\tmaxHeight: mapResponsiveProp(maxHeight),\n\t};\n}\n\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\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\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]; | ||
}, mq(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3(_objectSpread$3({}, colorStyles({ | ||
background: background, | ||
color: color | ||
})), borderStyles({ | ||
border: border, | ||
borderWidth: borderWidth, | ||
borderColor: borderColor, | ||
borderLeft: borderLeft, | ||
borderLeftWidth: borderLeftWidth, | ||
borderRight: borderRight, | ||
borderRightWidth: borderRightWidth, | ||
borderTop: borderTop, | ||
borderTopWidth: borderTopWidth, | ||
borderBottom: borderBottom, | ||
borderBottomWidth: borderBottomWidth, | ||
borderX: borderX, | ||
borderY: borderY, | ||
rounded: rounded | ||
})), layoutStyles({ | ||
display: display, | ||
flexDirection: flexDirection, | ||
flexWrap: flexWrap, | ||
flexGrow: flexGrow, | ||
flexShrink: flexShrink, | ||
justifyContent: justifyContent, | ||
alignItems: alignItems, | ||
gap: gap, | ||
columnGap: columnGap, | ||
rowGap: rowGap, | ||
width: width, | ||
minWidth: minWidth, | ||
maxWidth: maxWidth, | ||
height: height, | ||
minHeight: minHeight, | ||
maxHeight: maxHeight | ||
})), paddingStyles({ | ||
paddingTop: paddingTop, | ||
paddingBottom: paddingBottom, | ||
paddingRight: paddingRight, | ||
paddingLeft: paddingLeft, | ||
paddingX: paddingX, | ||
paddingY: paddingY, | ||
padding: padding | ||
})), typographyStyles({ | ||
fontWeight: fontWeight, | ||
fontFamily: fontFamily, | ||
fontSize: fontSize, | ||
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":"AAiZE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\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":"AAiZE","file":"styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport {\n\ttokens,\n\tBoxPalette,\n\tboxPalettes,\n\tboxPalette,\n\tResponsiveProp,\n\tmapResponsiveProp,\n\tmapSpacing,\n\tmq,\n\tfontGrid,\n\tSpacing,\n\tglobalPalette,\n\tpacks,\n\tBorderWidth,\n\tFontWeight,\n\tFontSize,\n\tLineHeight,\n\tFont,\n} from '@ag.ds-next/core';\n\ntype PaletteProps = Partial<{\n\tpalette: BoxPalette;\n\tdark: boolean;\n\tlight: boolean;\n}>;\n\nfunction paletteStyles({ palette, dark, light }: PaletteProps) {\n\tif (palette) return boxPalettes[palette];\n\tif (dark) return boxPalettes.dark;\n\tif (light) return boxPalettes.light;\n}\n\nexport const foregroundColorMap = {\n\ttext: boxPalette.foregroundText,\n\taction: boxPalette.foregroundAction,\n\tfocus: boxPalette.foregroundFocus,\n\tmuted: boxPalette.foregroundMuted,\n\taccent: globalPalette.accent,\n\terror: globalPalette.error,\n\tsuccess: globalPalette.success,\n\twarning: globalPalette.warning,\n\tinfo: globalPalette.info,\n\tinherit: 'inherit',\n};\n\nexport const backgroundColorMap = {\n\tbody: boxPalette.backgroundBody,\n\tshade: boxPalette.backgroundShade,\n\tbodyAlt: boxPalette.backgroundBodyAlt,\n\tshadeAlt: boxPalette.backgroundShadeAlt,\n};\n\ntype ColorProps = Partial<{\n\tcolor: ResponsiveProp<keyof typeof foregroundColorMap>;\n\tbackground: ResponsiveProp<keyof typeof backgroundColorMap>;\n}>;\n\nfunction colorStyles({ color, background }: ColorProps) {\n\treturn {\n\t\tcolor: color\n\t\t\t? mapResponsiveProp(color, (t) => foregroundColorMap[t])\n\t\t\t: undefined,\n\t\tbackgroundColor: background\n\t\t\t? mapResponsiveProp(background, (t) => backgroundColorMap[t])\n\t\t\t: undefined,\n\t};\n}\n\ntype TypographyProps = Partial<{\n\tfontWeight: ResponsiveProp<FontWeight>;\n\tfontFamily: ResponsiveProp<Font>;\n\tfontSize: ResponsiveProp<FontSize>;\n\tlineHeight: LineHeight;\n}>;\n\nfunction typographyStyles({\n\tfontWeight,\n\tfontFamily,\n\tfontSize: _fontSize,\n\tlineHeight: _lineHeight = 'default',\n}: TypographyProps) {\n\tconst responsiveFontGrid = mapResponsiveProp(_fontSize, (t) =>\n\t\tfontGrid(t, _lineHeight)\n\t);\n\n\tconst { fontSize, lineHeight } = responsiveFontGrid?.reduce<{\n\t\tfontSize: (string | null)[];\n\t\tlineHeight: (number | null)[];\n\t}>(\n\t\t(acc, entry, index) => {\n\t\t\tacc.fontSize[index] = isEntry(entry) ? entry.fontSize : null;\n\t\t\tacc.lineHeight[index] = isEntry(entry) ? entry.lineHeight : null;\n\t\t\treturn acc;\n\t\t},\n\t\t{ fontSize: [], lineHeight: [] }\n\t) ?? { fontSize: undefined, lineHeight: undefined };\n\n\treturn {\n\t\tfontWeight: mapResponsiveProp(fontWeight, (t) => tokens.fontWeight[t]),\n\t\tfontFamily: mapResponsiveProp(fontFamily, (t) => tokens.font[t]),\n\t\tfontSize,\n\t\tlineHeight,\n\t\t'& ::selection': {\n\t\t\tcolor: boxPalette.backgroundBody,\n\t\t\tbackgroundColor: boxPalette.foregroundAction,\n\t\t},\n\t};\n}\n\nfunction isEntry(a: unknown): a is {\n\tfontSize: string;\n\tlineHeight: number;\n} {\n\treturn !!a; // ie. not null or undefined\n}\ntype LayoutProps = Partial<{\n\tdisplay: ResponsiveProp<\n\t\t| 'block'\n\t\t| 'flex'\n\t\t| 'inline'\n\t\t| 'inline-block'\n\t\t| 'inline-flex'\n\t\t| 'none'\n\t\t| 'table-row-group'\n\t\t| 'table-header-group'\n\t\t| 'table-footer-group'\n\t\t| 'table-row'\n\t\t| 'table-cell'\n\t\t| 'table-column-group'\n\t\t| 'table-column'\n\t\t| 'table-caption'\n\t>;\n\tflexDirection: ResponsiveProp<\n\t\t'row' | 'column' | 'row-reverse' | 'column-reverse'\n\t>;\n\tflexWrap: ResponsiveProp<'nowrap' | 'wrap' | 'wrap-reverse'>;\n\tflexGrow: ResponsiveProp<number>;\n\tflexShrink: ResponsiveProp<number>;\n\tjustifyContent: ResponsiveProp<\n\t\t| 'flex-start'\n\t\t| 'flex-end'\n\t\t| 'center'\n\t\t| 'space-between'\n\t\t| 'space-around'\n\t\t| 'space-evenly'\n\t>;\n\talignItems: ResponsiveProp<\n\t\t'stretch' | 'flex-start' | 'flex-end' | 'center' | 'baseline'\n\t>;\n\tgap: ResponsiveProp<Spacing>;\n\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]; | ||
} | ||
function _extends() { | ||
_extends = Object.assign || function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
var _excluded$2 = ["as"]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
function ownKeys$2(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; } | ||
return target; | ||
}; | ||
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Box = forwardRefWithAs(function Box(_ref, ref) { | ||
var _ref$as = _ref.as, | ||
Tag = _ref$as === void 0 ? 'div' : _ref$as, | ||
props = _objectWithoutProperties(_ref, _excluded$2); | ||
return _extends.apply(this, arguments); | ||
} | ||
var _boxStyles = boxStyles(props), | ||
_boxStyles2 = _slicedToArray(_boxStyles, 2), | ||
styles = _boxStyles2[0], | ||
attrs = _boxStyles2[1]; | ||
const Box = forwardRefWithAs(function Box({ | ||
as: Tag = 'div', | ||
...props | ||
}, ref) { | ||
const [styles, attrs] = boxStyles(props); | ||
return jsx(Tag, _extends({ | ||
return jsx(Tag, _objectSpread$2({ | ||
ref: ref, | ||
@@ -342,13 +364,22 @@ css: styles | ||
const Flex = forwardRefWithAs(function Flex({ | ||
inline = false, | ||
flexDirection = 'row', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
display, | ||
...props | ||
}, ref) { | ||
return jsx(Box, _extends({ | ||
var _excluded$1 = ["inline", "flexDirection", "justifyContent", "alignItems", "display"]; | ||
function ownKeys$1(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; } | ||
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Flex = forwardRefWithAs(function Flex(_ref, ref) { | ||
var _ref$inline = _ref.inline, | ||
inline = _ref$inline === void 0 ? false : _ref$inline, | ||
_ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'row' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
display = _ref.display, | ||
props = _objectWithoutProperties(_ref, _excluded$1); | ||
return jsx(Box, _objectSpread$1({ | ||
ref: ref, | ||
display: display ?? (inline ? 'inline-flex' : 'flex'), | ||
display: display !== null && display !== void 0 ? display : inline ? 'inline-flex' : 'flex', | ||
flexDirection: flexDirection, | ||
@@ -360,9 +391,17 @@ justifyContent: justifyContent, | ||
const Stack = forwardRefWithAs(function Stack({ | ||
flexDirection = 'column', | ||
justifyContent = 'flex-start', | ||
alignItems = 'stretch', | ||
...props | ||
}, ref) { | ||
return jsx(Box, _extends({ | ||
var _excluded = ["flexDirection", "justifyContent", "alignItems"]; | ||
function ownKeys(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; } | ||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | ||
var Stack = forwardRefWithAs(function Stack(_ref, ref) { | ||
var _ref$flexDirection = _ref.flexDirection, | ||
flexDirection = _ref$flexDirection === void 0 ? 'column' : _ref$flexDirection, | ||
_ref$justifyContent = _ref.justifyContent, | ||
justifyContent = _ref$justifyContent === void 0 ? 'flex-start' : _ref$justifyContent, | ||
_ref$alignItems = _ref.alignItems, | ||
alignItems = _ref$alignItems === void 0 ? 'stretch' : _ref$alignItems, | ||
props = _objectWithoutProperties(_ref, _excluded); | ||
return jsx(Box, _objectSpread({ | ||
ref: ref, | ||
@@ -369,0 +408,0 @@ display: "flex", |
@@ -44,2 +44,4 @@ import { BoxPalette, ResponsiveProp, Spacing, BorderWidth, FontWeight, FontSize, LineHeight, Font } from '@ag.ds-next/core'; | ||
gap: ResponsiveProp<Spacing>; | ||
columnGap: ResponsiveProp<Spacing>; | ||
rowGap: ResponsiveProp<Spacing>; | ||
width: ResponsiveProp<number | string>; | ||
@@ -115,3 +117,3 @@ minWidth: ResponsiveProp<number | string>; | ||
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, width, minWidth, maxWidth, height, minHeight, maxHeight, paddingTop, paddingBottom, paddingRight, paddingLeft, paddingX, paddingY, padding, fontWeight, fontFamily, fontSize, focus, link, lineHeight, ...restProps }: BoxProps): {}[]; | ||
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): {}[]; | ||
export {}; |
{ | ||
"name": "@ag.ds-next/box", | ||
"version": "6.0.0", | ||
"version": "6.1.0", | ||
"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": "3.0.0", | ||
"@ag.ds-next/core": "3.0.1", | ||
"@emotion/react": "^11.7.0" | ||
@@ -10,0 +13,0 @@ }, |
@@ -1,48 +0,3 @@ | ||
--- | ||
title: Box | ||
description: A set of primitive layout components | ||
group: Foundations | ||
storybookPath: /story/foundations-box--light-box | ||
--- | ||
## @ag.ds-next/box | ||
This package includes the components `<Box />`, `<Flex />` and `<Stack />`. | ||
## Box | ||
```jsx live | ||
<Box | ||
palette="dark" | ||
background="body" | ||
color="text" | ||
fontFamily="body" | ||
border | ||
padding={{ xs: 1, xl: 4 }} | ||
rounded | ||
> | ||
A Box example | ||
</Box> | ||
``` | ||
## Flex | ||
Same principles as `Box`, but extended with CSS Flexbox properties. | ||
```jsx live | ||
<Flex gap={1} justifyContent="space-between" alignItems="flex-start"> | ||
<Box background="shade" padding={1} /> | ||
<Box background="shade" height="64px" padding={1} /> | ||
<Box background="shade" padding={1} /> | ||
</Flex> | ||
``` | ||
## Stack | ||
Use to distribute items vertically with even spacing. | ||
```jsx live | ||
<Stack gap={1}> | ||
<Box background="shade" padding={1} /> | ||
<Box background="shade" padding={1} /> | ||
<Box background="shade" padding={1} /> | ||
</Stack> | ||
``` | ||
Documentation for this package can be found here: https://steelthreads.github.io/agds-next/packages/foundations/box |
@@ -152,2 +152,4 @@ import { css } from '@emotion/react'; | ||
gap: ResponsiveProp<Spacing>; | ||
columnGap: ResponsiveProp<Spacing>; | ||
rowGap: ResponsiveProp<Spacing>; | ||
width: ResponsiveProp<number | string>; | ||
@@ -170,2 +172,4 @@ minWidth: ResponsiveProp<number | string>; | ||
gap, | ||
columnGap, | ||
rowGap, | ||
width, | ||
@@ -187,2 +191,4 @@ minWidth, | ||
gap: mapResponsiveProp(gap, mapSpacing), | ||
columnGap: mapResponsiveProp(columnGap, mapSpacing), | ||
rowGap: mapResponsiveProp(rowGap, mapSpacing), | ||
width: mapResponsiveProp(width), | ||
@@ -375,2 +381,4 @@ minWidth: mapResponsiveProp(minWidth), | ||
gap, | ||
columnGap, | ||
rowGap, | ||
width, | ||
@@ -438,2 +446,4 @@ minWidth, | ||
gap, | ||
columnGap, | ||
rowGap, | ||
width, | ||
@@ -440,0 +450,0 @@ minWidth, |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
145597
23
2267
3
4
14
+ Added@babel/runtime@^7.4.5
+ Added@ag.ds-next/core@3.0.1(transitive)
- Removed@ag.ds-next/core@3.0.0(transitive)