@ultraviolet/ui 1.82.0 → 1.82.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.
- package/dist/components/Checkbox/index.cjs +14 -20
- package/dist/components/Checkbox/index.d.ts +1 -1
- package/dist/components/Checkbox/index.js +15 -21
- package/dist/components/Chip/index.d.ts +1 -1
- package/dist/components/List/Cell.cjs +1 -1
- package/dist/components/List/Cell.js +1 -1
- package/dist/components/List/HeaderRow.cjs +4 -5
- package/dist/components/List/HeaderRow.js +4 -5
- package/dist/components/List/ListContext.cjs +105 -104
- package/dist/components/List/ListContext.d.ts +14 -11
- package/dist/components/List/ListContext.js +105 -104
- package/dist/components/List/Row.cjs +33 -26
- package/dist/components/List/Row.js +33 -26
- package/dist/components/List/index.cjs +2 -2
- package/dist/components/List/index.d.ts +1 -22
- package/dist/components/List/index.js +2 -2
- package/dist/components/Radio/index.cjs +11 -11
- package/dist/components/Radio/index.d.ts +1 -2
- package/dist/components/Radio/index.js +11 -11
- package/dist/components/SearchInput/index.cjs +2 -2
- package/dist/components/SearchInput/index.js +2 -2
- package/dist/components/SwitchButton/index.cjs +3 -3
- package/dist/components/SwitchButton/index.js +3 -3
- package/dist/components/Table/HeaderRow.cjs +2 -3
- package/dist/components/Table/HeaderRow.js +2 -3
- package/dist/components/Table/Row.cjs +29 -22
- package/dist/components/Table/Row.js +29 -22
- package/dist/components/Table/TableContext.cjs +20 -158
- package/dist/components/Table/TableContext.d.ts +5 -30
- package/dist/components/Table/TableContext.js +21 -159
- package/dist/components/Table/index.cjs +2 -2
- package/dist/components/Table/index.d.ts +26 -33
- package/dist/components/Table/index.js +2 -2
- package/package.json +4 -4
|
@@ -27,7 +27,7 @@ const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("tr", process
|
|
|
27
27
|
theme
|
|
28
28
|
}) => theme.radii.default, " ", ({
|
|
29
29
|
theme
|
|
30
|
-
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAamC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
30
|
+
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAamC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n\n  ${({ theme, inRange }) =>\n    inRange\n      ? `svg {\n          padding: ${theme.space[0.25]};\n          outline: 1px inset ${theme.colors.primary.backgroundStrong};\n          box-shadow: ${theme.shadows.focusPrimary};\n          transition:\n            box-shadow 250ms ease,\n            outline 250ms ease,\n            padding 250ms ease;\n          rect {\n            fill: ${theme.colors.primary.backgroundHover};\n            stroke: ${theme.colors.primary.borderHover};\n          }\n      }\n  `\n      : ''}\n\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    expandButton,\n    mapCheckbox,\n    inRange,\n    columns,\n  } = useTableContext()\n\n  const checkboxRowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const { current } = checkboxRowRef\n\n    if (current) {\n      mapCheckbox.set(id, current)\n    }\n\n    return () => {\n      mapCheckbox.delete(id)\n    }\n  }, [mapCheckbox, id])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  inRange={inRange?.has(id)}\n                  disabled={selectDisabled !== undefined}\n                  ref={checkboxRowRef}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
31
31
|
const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
32
32
|
target: "e1qvrbgq3"
|
|
33
33
|
} : {
|
|
@@ -35,7 +35,7 @@ const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div",
|
|
|
35
35
|
label: "StyledCheckboxContainer"
|
|
36
36
|
})("display:flex;width:", ({
|
|
37
37
|
theme
|
|
38
|
-
}) => theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
38
|
+
}) => theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n\n  ${({ theme, inRange }) =>\n    inRange\n      ? `svg {\n          padding: ${theme.space[0.25]};\n          outline: 1px inset ${theme.colors.primary.backgroundStrong};\n          box-shadow: ${theme.shadows.focusPrimary};\n          transition:\n            box-shadow 250ms ease,\n            outline 250ms ease,\n            padding 250ms ease;\n          rect {\n            fill: ${theme.colors.primary.backgroundHover};\n            stroke: ${theme.colors.primary.borderHover};\n          }\n      }\n  `\n      : ''}\n\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    expandButton,\n    mapCheckbox,\n    inRange,\n    columns,\n  } = useTableContext()\n\n  const checkboxRowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const { current } = checkboxRowRef\n\n    if (current) {\n      mapCheckbox.set(id, current)\n    }\n\n    return () => {\n      mapCheckbox.delete(id)\n    }\n  }, [mapCheckbox, id])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  inRange={inRange?.has(id)}\n                  disabled={selectDisabled !== undefined}\n                  ref={checkboxRowRef}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
39
39
|
const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index.Checkbox, process.env.NODE_ENV === "production" ? {
|
|
40
40
|
shouldForwardProp: (prop) => !["inRange"].includes(prop),
|
|
41
41
|
target: "e1qvrbgq2"
|
|
@@ -43,10 +43,23 @@ const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index.Checkbox,
|
|
|
43
43
|
shouldForwardProp: (prop) => !["inRange"].includes(prop),
|
|
44
44
|
target: "e1qvrbgq2",
|
|
45
45
|
label: "StyledCheckbox"
|
|
46
|
-
})(
|
|
46
|
+
})(({
|
|
47
47
|
theme,
|
|
48
48
|
inRange
|
|
49
|
-
}) => inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : "", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA+BwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
49
|
+
}) => inRange ? `svg {
|
|
50
|
+
padding: ${theme.space[0.25]};
|
|
51
|
+
outline: 1px inset ${theme.colors.primary.backgroundStrong};
|
|
52
|
+
box-shadow: ${theme.shadows.focusPrimary};
|
|
53
|
+
transition:
|
|
54
|
+
box-shadow 250ms ease,
|
|
55
|
+
outline 250ms ease,
|
|
56
|
+
padding 250ms ease;
|
|
57
|
+
rect {
|
|
58
|
+
fill: ${theme.colors.primary.backgroundHover};
|
|
59
|
+
stroke: ${theme.colors.primary.borderHover};
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA+BwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n\n  ${({ theme, inRange }) =>\n    inRange\n      ? `svg {\n          padding: ${theme.space[0.25]};\n          outline: 1px inset ${theme.colors.primary.backgroundStrong};\n          box-shadow: ${theme.shadows.focusPrimary};\n          transition:\n            box-shadow 250ms ease,\n            outline 250ms ease,\n            padding 250ms ease;\n          rect {\n            fill: ${theme.colors.primary.backgroundHover};\n            stroke: ${theme.colors.primary.borderHover};\n          }\n      }\n  `\n      : ''}\n\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    expandButton,\n    mapCheckbox,\n    inRange,\n    columns,\n  } = useTableContext()\n\n  const checkboxRowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const { current } = checkboxRowRef\n\n    if (current) {\n      mapCheckbox.set(id, current)\n    }\n\n    return () => {\n      mapCheckbox.delete(id)\n    }\n  }, [mapCheckbox, id])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  inRange={inRange?.has(id)}\n                  disabled={selectDisabled !== undefined}\n                  ref={checkboxRowRef}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
50
63
|
const colorChange = (theme) => react.keyframes`
|
|
51
64
|
5% {
|
|
52
65
|
background-color: ${theme.colors.primary.background};
|
|
@@ -74,7 +87,7 @@ const StyledTr = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE
|
|
|
74
87
|
${column.minWidth ? `min-width: ${column.minWidth};` : ""}
|
|
75
88
|
${column.maxWidth ? `max-width: ${column.maxWidth};` : ""}
|
|
76
89
|
}
|
|
77
|
-
`), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
90
|
+
`), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwEE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n\n  ${({ theme, inRange }) =>\n    inRange\n      ? `svg {\n          padding: ${theme.space[0.25]};\n          outline: 1px inset ${theme.colors.primary.backgroundStrong};\n          box-shadow: ${theme.shadows.focusPrimary};\n          transition:\n            box-shadow 250ms ease,\n            outline 250ms ease,\n            padding 250ms ease;\n          rect {\n            fill: ${theme.colors.primary.backgroundHover};\n            stroke: ${theme.colors.primary.borderHover};\n          }\n      }\n  `\n      : ''}\n\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    expandButton,\n    mapCheckbox,\n    inRange,\n    columns,\n  } = useTableContext()\n\n  const checkboxRowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const { current } = checkboxRowRef\n\n    if (current) {\n      mapCheckbox.set(id, current)\n    }\n\n    return () => {\n      mapCheckbox.delete(id)\n    }\n  }, [mapCheckbox, id])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  inRange={inRange?.has(id)}\n                  disabled={selectDisabled !== undefined}\n                  ref={checkboxRowRef}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
78
91
|
const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
|
|
79
92
|
shouldForwardProp: (prop) => !["maxWidth"].includes(prop),
|
|
80
93
|
target: "e1qvrbgq0"
|
|
@@ -86,7 +99,7 @@ const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, proces
|
|
|
86
99
|
theme
|
|
87
100
|
}) => theme.space["2"], ";}max-width:", ({
|
|
88
101
|
maxWidth
|
|
89
|
-
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA2EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
102
|
+
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA2FyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n\n  ${({ theme, inRange }) =>\n    inRange\n      ? `svg {\n          padding: ${theme.space[0.25]};\n          outline: 1px inset ${theme.colors.primary.backgroundStrong};\n          box-shadow: ${theme.shadows.focusPrimary};\n          transition:\n            box-shadow 250ms ease,\n            outline 250ms ease,\n            padding 250ms ease;\n          rect {\n            fill: ${theme.colors.primary.backgroundHover};\n            stroke: ${theme.colors.primary.borderHover};\n          }\n      }\n  `\n      : ''}\n\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    expandButton,\n    mapCheckbox,\n    inRange,\n    columns,\n  } = useTableContext()\n\n  const checkboxRowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const { current } = checkboxRowRef\n\n    if (current) {\n      mapCheckbox.set(id, current)\n    }\n\n    return () => {\n      mapCheckbox.delete(id)\n    }\n  }, [mapCheckbox, id])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  inRange={inRange?.has(id)}\n                  disabled={selectDisabled !== undefined}\n                  ref={checkboxRowRef}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
90
103
|
const Row = ({
|
|
91
104
|
children,
|
|
92
105
|
className,
|
|
@@ -105,14 +118,12 @@ const Row = ({
|
|
|
105
118
|
collapseRow,
|
|
106
119
|
registerSelectableRow,
|
|
107
120
|
selectedRowIds,
|
|
108
|
-
selectRow,
|
|
109
|
-
unselectRow,
|
|
110
121
|
expandButton,
|
|
111
|
-
|
|
122
|
+
mapCheckbox,
|
|
112
123
|
inRange,
|
|
113
124
|
columns
|
|
114
125
|
} = TableContext.useTableContext();
|
|
115
|
-
const
|
|
126
|
+
const checkboxRowRef = React.useRef(null);
|
|
116
127
|
const hasExpandable = !!expandable;
|
|
117
128
|
React.useEffect(() => {
|
|
118
129
|
if (hasExpandable) {
|
|
@@ -137,25 +148,21 @@ const Row = ({
|
|
|
137
148
|
}, [collapseRow, expandRow, expandedRowIds, id]);
|
|
138
149
|
const canClickRowToExpand = hasExpandable && !expandButton;
|
|
139
150
|
React.useEffect(() => {
|
|
140
|
-
const refAtEffectStart = ref.current;
|
|
141
151
|
const {
|
|
142
152
|
current
|
|
143
|
-
} =
|
|
144
|
-
if (
|
|
145
|
-
|
|
153
|
+
} = checkboxRowRef;
|
|
154
|
+
if (current) {
|
|
155
|
+
mapCheckbox.set(id, current);
|
|
146
156
|
}
|
|
147
|
-
|
|
157
|
+
return () => {
|
|
158
|
+
mapCheckbox.delete(id);
|
|
159
|
+
};
|
|
160
|
+
}, [mapCheckbox, id]);
|
|
148
161
|
const theme = react.useTheme();
|
|
149
162
|
const childrenLength = React.Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0);
|
|
150
163
|
return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
151
164
|
/* @__PURE__ */ jsxRuntime.jsxs(StyledTr, { className, "data-testid": dataTestid, highlightAnimation, role: canClickRowToExpand ? "button row" : "row", columns, columnsStartAt: (selectable ? 1 : 0) + (expandButton ? 1 : 0), children: [
|
|
152
|
-
selectable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { maxWidth: theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { name: "table-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id,
|
|
153
|
-
if (selectedRowIds[id]) {
|
|
154
|
-
unselectRow(id);
|
|
155
|
-
} else {
|
|
156
|
-
selectRow(id);
|
|
157
|
-
}
|
|
158
|
-
}, disabled: selectDisabled !== void 0, ref: rowRef, inRange: inRange.includes(id) }) }) }) }) : null,
|
|
165
|
+
selectable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { maxWidth: theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { name: "table-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id, inRange: inRange?.has(id), disabled: selectDisabled !== void 0, ref: checkboxRowRef }) }) }) }) : null,
|
|
159
166
|
expandButton ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { disabled: !expandable, icon: expandedRowIds[id] ? "arrow-up" : "arrow-down", onClick: toggleRowExpand, size: "xsmall", sentiment: "neutral", variant: "ghost", "aria-label": "expand", "data-testid": "list-expand-button" }) }) : null,
|
|
160
167
|
children
|
|
161
168
|
] }),
|