@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(() => {
|
package/dist/List/ListCol.js
CHANGED
|
@@ -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
|
package/dist/List/elements.d.ts
CHANGED
|
@@ -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;
|
package/dist/List/elements.js
CHANGED
|
@@ -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.
|
|
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": "
|
|
62
|
+
"gitHead": "7cb8c520b1cc4477d1361ee802c6e0d05ec1748e"
|
|
63
63
|
}
|