@codecademy/gamut 68.2.0 → 68.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,7 @@
1
1
  import { isValidElement, memo, useCallback, useMemo, createElement as _createElement } from 'react';
2
2
  import { Text } from '../../..';
3
3
  import { ListCol, ListRow } from '../../../List';
4
+ import { useListContext } from '../../../List/ListProvider';
4
5
  import { Shimmer } from '../../../Loading/Shimmer';
5
6
  import { ExpandControl, SelectControl } from '../../Controls';
6
7
  import { useControlContext } from '../../hooks/useListControls';
@@ -22,7 +23,13 @@ export const TableRow = ({
22
23
  onSelect,
23
24
  prefixId
24
25
  } = useControlContext();
26
+ const {
27
+ variant,
28
+ listType
29
+ } = useListContext();
30
+ const dataTablePadding = listType === 'table' && variant === 'table';
25
31
  const listColProps = {
32
+ dataTablePadding,
26
33
  showOverflow
27
34
  };
28
35
  const controlIndices = useMemo(() => {
@@ -26,6 +26,7 @@ export const ListCol = /*#__PURE__*/forwardRef(({
26
26
  as: colEl,
27
27
  columnHeader: columnHeader,
28
28
  delimiter: sticky && activeVariants.variant === 'table',
29
+ lastChildPadding: !(type === 'expandControl'),
29
30
  ref: ref,
30
31
  sticky: sticky,
31
32
  type: isOrderedHeader ? 'orderedHeader' : type
@@ -332,10 +332,6 @@ declare const space: import("@codecademy/variance/dist/types/config").Parser<imp
332
332
  readonly minHeight: {
333
333
  readonly property: {
334
334
  readonly physical: "minHeight";
335
- /**
336
- * Whether the column/cell should allow content to overflow out of it.
337
- * Useful for tooltips and conditionally rendered content that wants to overflow.
338
- */
339
335
  readonly logical: "minBlockSize";
340
336
  };
341
337
  readonly resolveProperty: (useLogicalProperties: boolean) => import("@codecademy/variance/dist/types/properties").PropertyMode;
@@ -343,6 +339,10 @@ declare const space: import("@codecademy/variance/dist/types/config").Parser<imp
343
339
  };
344
340
  readonly maxHeight: {
345
341
  readonly property: {
342
+ /**
343
+ * Whether the column/cell should allow content to overflow out of it.
344
+ * Useful for tooltips and conditionally rendered content that wants to overflow.
345
+ */
346
346
  readonly physical: "maxHeight";
347
347
  readonly logical: "maxBlockSize";
348
348
  };
@@ -401,7 +401,7 @@ declare const columnJustify: (props: import("@codecademy/variance/dist/types/con
401
401
  declare const columnSizes: (props: import("@codecademy/variance/dist/types/config").VariantProps<"size", false | "sm" | "md" | "lg" | "xl" | "content"> & {
402
402
  theme?: import("@emotion/react").Theme | undefined;
403
403
  }) => import("@codecademy/variance").CSSObject;
404
- declare const columnStates: (props: Partial<Record<"fill" | "wrap" | "sticky" | "delimiter" | "ghost" | "columnHeader" | "showOverflow", boolean>> & {
404
+ declare const columnStates: (props: Partial<Record<"fill" | "wrap" | "sticky" | "delimiter" | "ghost" | "columnHeader" | "dataTablePadding" | "lastChildPadding" | "showOverflow", boolean>> & {
405
405
  theme?: import("@emotion/react").Theme | undefined;
406
406
  }) => import("@codecademy/variance").CSSObject;
407
407
  declare const columnSpacing: (props: import("@codecademy/variance/dist/types/config").VariantProps<"spacing", false | "normal" | "condensed" | "compact"> & {
@@ -829,6 +829,10 @@ export declare const AnimatedListWrapper: import("@emotion/styled").StyledCompon
829
829
  }>;
830
830
  maxHeight?: import("@codecademy/variance/dist/types/config").Scale<{
831
831
  readonly property: {
832
+ /**
833
+ * Whether the column/cell should allow content to overflow out of it.
834
+ * Useful for tooltips and conditionally rendered content that wants to overflow.
835
+ */
832
836
  readonly physical: "maxHeight";
833
837
  readonly logical: "maxBlockSize";
834
838
  };
@@ -846,10 +850,6 @@ export declare const AnimatedListWrapper: import("@emotion/styled").StyledCompon
846
850
  minHeight?: import("@codecademy/variance/dist/types/config").Scale<{
847
851
  readonly property: {
848
852
  readonly physical: "minHeight";
849
- /**
850
- * Whether the column/cell should allow content to overflow out of it.
851
- * Useful for tooltips and conditionally rendered content that wants to overflow.
852
- */
853
853
  readonly logical: "minBlockSize";
854
854
  };
855
855
  readonly resolveProperty: (useLogicalProperties: boolean) => import("@codecademy/variance/dist/types/properties").PropertyMode;
@@ -45,7 +45,7 @@ const listVariants = variant({
45
45
  export const ListEl = /*#__PURE__*/_styled('ul', _extends({}, {
46
46
  target: "e3sih596",
47
47
  label: "ListEl"
48
- }, styledOptions()))(listVariants, space, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAuDsB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
48
+ }, styledOptions()))(listVariants, space, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAuDsB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
49
49
  const rowStates = states({
50
50
  isOl: {
51
51
  '&::before': {
@@ -92,13 +92,6 @@ const interactiveState = states({
92
92
  });
93
93
  const spacingVariants = variant({
94
94
  prop: 'spacing',
95
- base: {
96
- px: {
97
- _: 8,
98
- c_base: 0,
99
- c_sm: 8
100
- }
101
- },
102
95
  variants: {
103
96
  normal: {
104
97
  rowGap: {
@@ -222,7 +215,7 @@ export const RowEl = /*#__PURE__*/_styled('li', _extends({}, {
222
215
  c_sm: 0
223
216
  },
224
217
  width: 1
225
- }), variance.compose(grid, flex), rowBreakpointVariants, rowVariants, spacingVariants, interactiveState, rowStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAwLqB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
218
+ }), variance.compose(grid, flex), rowBreakpointVariants, rowVariants, spacingVariants, interactiveState, rowStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAqLqB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
226
219
  const headerVariants = variant({
227
220
  prop: 'variant',
228
221
  variants: {
@@ -259,7 +252,7 @@ export const HeaderRowEl = /*#__PURE__*/_styled('tr', _extends({}, {
259
252
  c_base: 8,
260
253
  c_sm: 0
261
254
  }
262
- }), spacingVariants, rowStates, headerVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAuN2B","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
255
+ }), spacingVariants, rowStates, headerVariants, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAoN2B","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
263
256
  const columnType = variant({
264
257
  prop: 'type',
265
258
  defaultVariant: 'content',
@@ -480,6 +473,23 @@ const columnStates = states({
480
473
  whiteSpace: 'normal',
481
474
  alignItems: 'flex-end'
482
475
  },
476
+ dataTablePadding: {
477
+ '&:first-of-type': {
478
+ pl: 8
479
+ },
480
+ '&:last-of-type': {
481
+ pr: 8
482
+ }
483
+ },
484
+ /**
485
+ * We add this to every RowEl except expandable DataList because it causes a layout shift.
486
+ * In that case, the padding is instead added directly to the Expandable control.
487
+ */
488
+ lastChildPadding: {
489
+ '&:last-of-type': {
490
+ pr: 8
491
+ }
492
+ },
483
493
  wrap: {
484
494
  whiteSpace: 'normal'
485
495
  },
@@ -498,6 +508,9 @@ const columnSpacing = variant({
498
508
  _: 0,
499
509
  c_base: 8,
500
510
  c_sm: 0
511
+ },
512
+ '&:first-of-type': {
513
+ pl: 8
501
514
  }
502
515
  },
503
516
  variants: {
@@ -528,7 +541,7 @@ export const ColEl = /*#__PURE__*/_styled('div', _extends({}, {
528
541
  whiteSpace: 'nowrap',
529
542
  overflow: 'hidden',
530
543
  position: 'relative'
531
- }), columnSpacing, columnSizes, columnType, columnStates, columnJustify, layout, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AA8ZqB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
544
+ }), columnSpacing, columnSizes, columnType, columnStates, columnJustify, layout, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AA+aqB","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
532
545
  export const StickyHeaderColWrapper = /*#__PURE__*/_styled("th", {
533
546
  target: "e3sih592",
534
547
  label: "StickyHeaderColWrapper"
@@ -593,7 +606,7 @@ export const StickyHeaderColWrapper = /*#__PURE__*/_styled("th", {
593
606
  width: 16,
594
607
  position: 'absolute'
595
608
  }
596
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AA2bsC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
609
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AA4csC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
597
610
  const listStyles = css({
598
611
  containerType: 'inline-size'
599
612
  });
@@ -605,11 +618,11 @@ const listStates = states({
605
618
  export const StaticListWrapper = /*#__PURE__*/_styled(Box, {
606
619
  target: "e3sih591",
607
620
  label: "StaticListWrapper"
608
- })(listStyles, listStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAsfiC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
621
+ })(listStyles, listStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAugBiC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
609
622
  export const AnimatedListWrapper = /*#__PURE__*/_styled(motion.create(Box), {
610
623
  target: "e3sih590",
611
624
  label: "AnimatedListWrapper"
612
- })(listStyles, listStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAwfmC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 8, c_base: 0, c_sm: 8 },\n  },\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
625
+ })(listStyles, listStates, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/List/elements.tsx"],"names":[],"mappings":"AAygBmC","file":"../../src/List/elements.tsx","sourcesContent":["import {\n  css,\n  states,\n  styledOptions,\n  system,\n  theme,\n  variant,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\n\nimport { Box } from '../Box';\n\nconst { space, grid, flex, layout } = system;\n\nconst olStyles = {\n  alignItems: 'center',\n  content: 'counters(section, \".\") \".\"',\n  counterIncrement: 'section',\n  fontFamily: 'accent',\n  fontSize: 'inherit',\n} as const;\n\nconst listVariants = variant({\n  prop: 'variant',\n  defaultVariant: 'default',\n  base: {\n    counterReset: 'section',\n    listStyleType: 'none',\n    p: 0,\n    m: 0,\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  variants: {\n    default: {\n      borderRadius: 'sm',\n    },\n    table: {},\n    card: {\n      gap: 24,\n    },\n    block: {\n      gap: 16,\n    },\n    plain: {},\n  },\n});\n\nexport interface ListProps\n  extends StyleProps<typeof listVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof space> {}\n\nexport const ListEl = styled('ul', styledOptions<'ul'>())<ListProps>(\n  listVariants,\n  space\n);\n\nconst rowStates = states({\n  isOl: {\n    '&::before': {\n      ...olStyles,\n      display: { _: 'flex', c_base: 'none', c_sm: 'flex' },\n      pl: 16,\n    },\n  },\n  scrollable: {\n    minWidth: 'min-content',\n    width: '100%',\n  },\n  expanded: {\n    display: 'flex',\n    flexDirection: { _: 'column', c_base: 'row', c_sm: 'column' },\n  },\n  /**\n   * Overrides the background of the element to transparent.\n   */\n  transparentBg: {\n    bg: 'transparent',\n  },\n});\n\nconst interactiveState = states({\n  interactive: {\n    cursor: 'pointer',\n\n    '&:hover': {\n      bg: 'background-hover',\n    },\n    '&:focus-visible, &:focus-within': {\n      outline: `1px solid ${theme.colors.primary}`,\n      boxShadow: `0 0 0 1px ${theme.colors.primary} inset`,\n      bg: 'background-selected',\n    },\n  },\n});\n\nconst spacingVariants = variant({\n  prop: 'spacing',\n  variants: {\n    normal: {\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    condensed: {\n      fontSize: 16,\n      rowGap: { _: 0, c_base: 8, c_sm: 0 },\n      columnGap: { _: 32, c_base: 8, c_sm: 32 },\n      gap: { _: 40, c_base: 8, c_sm: 40 },\n    },\n    compact: {\n      gap: 0,\n      py: 0,\n    },\n  },\n});\n\nconst rowVariants = variant({\n  prop: 'variant',\n  base: {},\n  variants: {\n    default: {\n      bg: 'background',\n      border: 1,\n      borderTop: 'none',\n      '&:first-of-type': {\n        borderTop: 1,\n      },\n    },\n    table: {\n      bg: 'transparent',\n      '&:nth-of-type(2n)': {\n        bg: 'background-selected',\n      },\n    },\n    card: {\n      bg: 'background',\n      border: 1,\n      borderRadius: 'sm',\n    },\n    block: {\n      bg: 'background',\n      border: 'none',\n      borderRadius: 'sm',\n    },\n    plain: {},\n  },\n});\n\nconst rowBreakpointVariants = variant({\n  prop: 'rowBreakpoint',\n  defaultVariant: 'xs',\n\n  variants: {\n    xs: {\n      display: { _: 'flex', c_base: 'grid', c_sm: 'flex' },\n      flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    },\n    sm: {\n      display: { _: 'grid', c_md: 'flex', md: 'flex' },\n      flexDirection: { _: 'column', c_md: 'row', md: 'row' },\n    },\n    md: {\n      display: { _: 'grid', c_lg: 'flex', lg: 'flex' },\n      flexDirection: { _: 'column', c_lg: 'row', lg: 'row' },\n    },\n    grid: { display: 'grid' },\n  },\n});\n\nexport interface RowProps\n  extends StyleProps<typeof rowVariants>,\n    StyleProps<typeof rowBreakpointVariants>,\n    StyleProps<typeof spacingVariants>,\n    StyleProps<typeof interactiveState>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof flex>,\n    StyleProps<typeof grid> {}\n\nexport const RowEl = styled('li', styledOptions<'li'>())<RowProps>(\n  css({\n    py: { _: 0, c_base: 8, c_sm: 0 },\n    width: 1,\n  }),\n  variance.compose(grid, flex),\n  rowBreakpointVariants,\n  rowVariants,\n  spacingVariants,\n  interactiveState,\n  rowStates\n);\n\nconst headerVariants = variant({\n  prop: 'variant',\n  variants: {\n    default: {},\n    card: {},\n    block: {},\n    table: {\n      borderBottom: 2,\n    },\n    plain: {},\n  },\n});\n\nexport interface HeaderProps\n  extends StyleProps<typeof spacingVariants>,\n    StyleProps<typeof rowStates>,\n    StyleProps<typeof listVariants> {}\n\nexport const HeaderRowEl = styled('tr', styledOptions)<HeaderProps>(\n  css({\n    display: 'flex',\n    position: { _: 'sticky', c_base: 'initial', c_sm: 'sticky' },\n    flexDirection: { _: 'row', c_base: 'column', c_sm: 'row' },\n    top: 0,\n    bg: 'background-current',\n    zIndex: 2,\n    fontFamily: 'accent',\n    pb: { _: 0, c_base: 8, c_sm: 0 },\n  }),\n  spacingVariants,\n  rowStates,\n  headerVariants\n);\n\nconst columnType = variant({\n  prop: 'type',\n  defaultVariant: 'content',\n  variants: {\n    // Keeping this within variants for typing purposes, we use this behaviorally despite it not needing specific styling\n    header: {},\n    orderedHeader: {\n      '&::before': {\n        ...olStyles,\n        display: { _: 'none', c_base: 'flex', c_sm: 'none' },\n        pl: 8,\n      },\n    },\n    content: {\n      gridColumn: { _: 'auto', c_base: 1, c_sm: 'auto' },\n      gridColumnEnd: { _: 'auto', c_base: 'span 1', c_sm: 'auto' },\n    },\n    select: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    control: {\n      gridColumn: { _: 1, c_base: 3, c_sm: 1 },\n      gridRow: 1,\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    tableControl: {\n      minWidth: 'min-content',\n      alignItems: {\n        _: 'center',\n        c_base: 'flex-start',\n        c_sm: 'center',\n      },\n      justifyItems: {\n        _: 'auto',\n        c_base: 'end',\n        c_sm: 'auto',\n      },\n    },\n    expand: {\n      minWidth: 'min-content',\n    },\n    expandControl: {\n      gridColumnEnd: { _: 'auto', c_base: 'span 3', c_sm: 'auto' },\n    },\n  },\n});\n\nconst columnJustify = variant({\n  prop: 'justify',\n  defaultVariant: 'left',\n  variants: {\n    left: {\n      justifyContent: {\n        _: 'flex-start',\n        c_base: 'initial',\n        c_sm: 'flex-start',\n      },\n    },\n    right: {\n      justifyContent: { _: 'flex-end', c_base: 'initial', c_sm: 'flex-end' },\n      '& div': {\n        width: { sm: 'fit-content' },\n      },\n    },\n  },\n});\n\nconst columnSizes = variant({\n  prop: 'size',\n  defaultVariant: 'content',\n  base: { minWidth: 0, maxWidth: 1, flexShrink: 1 },\n  variants: {\n    sm: {\n      flexBasis: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n      width: { _: '6rem', c_base: 'auto', c_sm: '6rem' },\n    },\n    md: {\n      flexBasis: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n      width: { _: '10rem', c_base: 'auto', c_sm: '10rem' },\n    },\n    lg: {\n      flexBasis: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n      width: { _: '12rem', c_base: 'auto', c_sm: '12rem' },\n    },\n    xl: {\n      flexBasis: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n      width: { _: '20rem', c_base: 'auto', c_sm: '20rem' },\n    },\n    content: {\n      flexShrink: 0,\n    },\n  },\n});\n\nconst columnStates = states({\n  fill: { flexGrow: { _: 1, c_base: 0, c_sm: 1 } },\n  sticky: {\n    height: '100%',\n    bg: 'inherit',\n  },\n  delimiter: {\n    overflow: 'visible',\n    '&:after': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      bg: 'background-current',\n      right: -4,\n      top: 0,\n      bottom: -3,\n      width: 4,\n      position: 'absolute',\n    },\n  },\n  ghost: {\n    visibility: 'hidden',\n    pointerEvents: 'none',\n    opacity: 0,\n    height: 0,\n  },\n  columnHeader: {\n    fontWeight: 400,\n    overflow: 'visible',\n    whiteSpace: 'normal',\n    alignItems: 'flex-end',\n  },\n  dataTablePadding: {\n    '&:first-of-type': {\n      pl: 8,\n    },\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  /**\n   * We add this to every RowEl except expandable DataList because it causes a layout shift.\n   * In that case, the padding is instead added directly to the Expandable control.\n   */\n  lastChildPadding: {\n    '&:last-of-type': {\n      pr: 8,\n    },\n  },\n  wrap: {\n    whiteSpace: 'normal',\n  },\n  /**\n   * Whether the column/cell should allow content to overflow out of it.\n   * Useful for tooltips and conditionally rendered content that wants to overflow.\n   */\n  showOverflow: {\n    overflow: 'visible',\n  },\n});\n\nconst columnSpacing = variant({\n  prop: 'spacing',\n  base: {\n    px: { _: 0, c_base: 8, c_sm: 0 },\n    '&:first-of-type': {\n      pl: 8,\n    },\n  },\n  variants: {\n    normal: {\n      py: { _: 16, c_base: 0, c_sm: 16 },\n    },\n    condensed: {\n      py: { _: 8, c_base: 0, c_sm: 8 },\n    },\n    compact: {},\n  },\n});\n\nexport interface ColProps\n  extends StyleProps<typeof columnSizes>,\n    StyleProps<typeof columnSpacing>,\n    StyleProps<typeof columnType>,\n    StyleProps<typeof columnStates>,\n    StyleProps<typeof columnJustify>,\n    StyleProps<typeof layout> {}\n\nexport const ColEl = styled(\n  'div',\n  styledOptions([\n    'fill',\n    'ghost',\n    'spacing',\n    'columnHeader',\n    'sticky',\n    'size',\n    'justify',\n    'type',\n  ])\n)<ColProps>(\n  css({\n    fontWeight: 400,\n    display: 'inline-flex',\n    alignItems: 'center',\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n    position: 'relative',\n  }),\n  columnSpacing,\n  columnSizes,\n  columnType,\n  columnStates,\n  columnJustify,\n  layout\n);\n\nexport const StickyHeaderColWrapper = styled.th(\n  css({\n    '&:before': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: { _: 'background', c_base: 'transparent', c_sm: 'background' },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    '&:after': {\n      content: '\"\"',\n      position: 'absolute',\n      bg: {\n        _: 'background-current',\n        c_base: 'inherit',\n        c_sm: 'background-current',\n      },\n      width: '100%',\n      height: '100%',\n      top: 0,\n      left: 0,\n      zIndex: -1,\n    },\n    // p: 0 removes the browser's default padding of 1px\n    p: 0,\n    display: 'flex',\n    flexShrink: 0,\n    position: 'sticky',\n    left: 0,\n    zIndex: 1,\n    bg: { _: 'inherit', c_base: 'transparent', c_sm: 'inherit' },\n    '&:not(:first-of-type)': {\n      left: { _: 16, c_base: 0, c_sm: 16 },\n      overflow: 'visible',\n    },\n    '&:not(:first-of-type):before': {\n      display: { _: 'block', c_base: 'none', c_sm: 'block' },\n      content: '\"\"',\n      left: -16,\n      height: 1,\n      width: 16,\n      position: 'absolute',\n    },\n  })\n);\n\nconst listStyles = css({\n  containerType: 'inline-size',\n});\n\nconst listStates = states({\n  disableContainerQuery: {\n    containerType: 'normal',\n  },\n});\n\nexport const StaticListWrapper = styled(Box)(listStyles, listStates);\n\nexport const AnimatedListWrapper = styled(motion.create(Box))(\n  listStyles,\n  listStates\n);\n\nexport const hiddenVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '0px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n} as const;\n\nexport const shadowVariant = {\n  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,\n  backgroundSize: '124px 100%',\n  backgroundPosition: 'right',\n  backgroundRepeat: 'no-repeat',\n};\n"]} */");
613
626
  export const hiddenVariant = {
614
627
  background: `linear-gradient(90deg, transparent 0%, transparent 40%, ${theme.colors['background-selected']} 50%, ${theme.colors['border-tertiary']} 100%)`,
615
628
  backgroundSize: '0px 100%',
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@codecademy/gamut",
3
3
  "description": "Styleguide & Component library for Codecademy",
4
- "version": "68.2.0",
4
+ "version": "68.2.1",
5
5
  "author": "Codecademy Engineering <dev@codecademy.com>",
6
6
  "dependencies": {
7
7
  "@codecademy/gamut-icons": "9.57.1",
@@ -59,5 +59,5 @@
59
59
  "dist/**/[A-Z]**/[A-Z]*.js",
60
60
  "dist/**/[A-Z]**/index.js"
61
61
  ],
62
- "gitHead": "502f9c61b71cb0479cbe5ff3bcd7301041a3c3bd"
62
+ "gitHead": "7cb8c520b1cc4477d1361ee802c6e0d05ec1748e"
63
63
  }