@cloudscape-design/components 3.0.154 → 3.0.155

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.
Files changed (82) hide show
  1. package/button/internal.d.ts +0 -1
  2. package/button/internal.d.ts.map +1 -1
  3. package/button/internal.js +2 -2
  4. package/button/internal.js.map +1 -1
  5. package/form-field/interfaces.d.ts +0 -10
  6. package/form-field/interfaces.d.ts.map +1 -1
  7. package/form-field/interfaces.js.map +1 -1
  8. package/form-field/internal.d.ts +1 -1
  9. package/form-field/internal.d.ts.map +1 -1
  10. package/form-field/internal.js +4 -5
  11. package/form-field/internal.js.map +1 -1
  12. package/input/internal.d.ts.map +1 -1
  13. package/input/internal.js +4 -16
  14. package/input/internal.js.map +1 -1
  15. package/internal/context/form-field-context.d.ts +2 -6
  16. package/internal/context/form-field-context.d.ts.map +1 -1
  17. package/internal/context/form-field-context.js +1 -7
  18. package/internal/context/form-field-context.js.map +1 -1
  19. package/internal/environment.js +1 -1
  20. package/internal/manifest.json +1 -1
  21. package/internal/types.d.ts +0 -9
  22. package/internal/types.d.ts.map +1 -1
  23. package/internal/types.js +2 -0
  24. package/internal/types.js.map +1 -1
  25. package/package.json +1 -1
  26. package/select/parts/styles.css.js +9 -9
  27. package/select/parts/styles.scoped.css +9 -27
  28. package/select/parts/styles.selectors.js +9 -9
  29. package/table/body-cell/index.d.ts +20 -11
  30. package/table/body-cell/index.d.ts.map +1 -1
  31. package/table/body-cell/index.js +9 -48
  32. package/table/body-cell/index.js.map +1 -1
  33. package/table/body-cell/styles.css.js +12 -18
  34. package/table/body-cell/styles.scoped.css +46 -229
  35. package/table/body-cell/styles.selectors.js +12 -18
  36. package/table/header-cell/index.d.ts +7 -8
  37. package/table/header-cell/index.d.ts.map +1 -1
  38. package/table/header-cell/index.js +2 -6
  39. package/table/header-cell/index.js.map +1 -1
  40. package/table/header-cell/styles.css.js +18 -19
  41. package/table/header-cell/styles.scoped.css +35 -40
  42. package/table/header-cell/styles.selectors.js +18 -19
  43. package/table/header-cell/utils.d.ts +1 -1
  44. package/table/header-cell/utils.d.ts.map +1 -1
  45. package/table/interfaces.d.ts +10 -85
  46. package/table/interfaces.d.ts.map +1 -1
  47. package/table/interfaces.js.map +1 -1
  48. package/table/internal.d.ts.map +1 -1
  49. package/table/internal.js +18 -68
  50. package/table/internal.js.map +1 -1
  51. package/table/thead.d.ts.map +1 -1
  52. package/table/thead.js +1 -1
  53. package/table/thead.js.map +1 -1
  54. package/table/utils.d.ts +1 -1
  55. package/table/utils.d.ts.map +1 -1
  56. package/test-utils/dom/table/index.d.ts +0 -4
  57. package/test-utils/dom/table/index.js +5 -21
  58. package/test-utils/dom/table/index.js.map +1 -1
  59. package/test-utils/selectors/table/index.d.ts +0 -4
  60. package/test-utils/selectors/table/index.js +5 -21
  61. package/test-utils/selectors/table/index.js.map +1 -1
  62. package/test-utils/tsconfig.tsbuildinfo +1 -1
  63. package/table/body-cell/click-away.d.ts +0 -9
  64. package/table/body-cell/click-away.d.ts.map +0 -1
  65. package/table/body-cell/click-away.js +0 -38
  66. package/table/body-cell/click-away.js.map +0 -1
  67. package/table/body-cell/inline-editor.d.ts +0 -12
  68. package/table/body-cell/inline-editor.d.ts.map +0 -1
  69. package/table/body-cell/inline-editor.js +0 -88
  70. package/table/body-cell/inline-editor.js.map +0 -1
  71. package/table/body-cell/td-element.d.ts +0 -21
  72. package/table/body-cell/td-element.d.ts.map +0 -1
  73. package/table/body-cell/td-element.js +0 -11
  74. package/table/body-cell/td-element.js.map +0 -1
  75. package/table/body-cell/use-stable-scroll-position.d.ts +0 -17
  76. package/table/body-cell/use-stable-scroll-position.d.ts.map +0 -1
  77. package/table/body-cell/use-stable-scroll-position.js +0 -48
  78. package/table/body-cell/use-stable-scroll-position.js.map +0 -1
  79. package/table/use-table-focus-navigation.d.ts +0 -16
  80. package/table/use-table-focus-navigation.d.ts.map +0 -1
  81. package/table/use-table-focus-navigation.js +0 -131
  82. package/table/use-table-focus-navigation.js.map +0 -1
@@ -1,16 +1,25 @@
1
+ import React from 'react';
1
2
  import { TableProps } from '../interfaces';
2
- import { TableTdElementProps } from './td-element';
3
- interface TableBodyCellProps<ItemType, ValueType> extends TableTdElementProps {
4
- column: TableProps.EditableColumnDefinition<ItemType, ValueType>;
3
+ interface TableBodyCellProps {
4
+ className?: string;
5
+ style?: React.CSSProperties;
6
+ wrapLines: boolean | undefined;
7
+ isFirstRow: boolean;
8
+ isLastRow: boolean;
9
+ isEvenRow?: boolean;
10
+ stripedRows?: boolean;
11
+ isSelected: boolean;
12
+ isNextSelected: boolean;
13
+ isPrevSelected: boolean;
14
+ children?: React.ReactNode;
15
+ hasSelection?: boolean;
16
+ hasFooter?: boolean;
17
+ }
18
+ export declare function TableBodyCell({ className, style, children, wrapLines, isFirstRow, isLastRow, isSelected, isNextSelected, isPrevSelected, isEvenRow, stripedRows, hasSelection, hasFooter, }: TableBodyCellProps): JSX.Element;
19
+ interface TableBodyCellContentProps<ItemType> extends TableBodyCellProps {
20
+ column: TableProps.ColumnDefinition<ItemType>;
5
21
  item: ItemType;
6
- isEditing: boolean;
7
- onEditStart: () => void;
8
- onEditEnd: () => void;
9
- submitEdit?: TableProps.SubmitEditFunction<ItemType, ValueType>;
10
- ariaLabels: TableProps['ariaLabels'];
11
22
  }
12
- export declare function TableBodyCell<ItemType, ValueType>({ isEditable, ...rest }: TableBodyCellProps<ItemType, ValueType> & {
13
- isEditable: boolean;
14
- }): JSX.Element;
23
+ export declare function TableBodyCellContent<ItemType>({ item, column, ...rest }: TableBodyCellContentProps<ItemType>): JSX.Element;
15
24
  export {};
16
25
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/table/body-cell/index.tsx"],"names":[],"mappings":"AASA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAkB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAcnE,UAAU,kBAAkB,CAAC,QAAQ,EAAE,SAAS,CAAE,SAAQ,mBAAmB;IAC3E,MAAM,EAAE,UAAU,CAAC,wBAAwB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IACjE,IAAI,EAAE,QAAQ,CAAC;IACf,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,MAAM,IAAI,CAAC;IACxB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,UAAU,CAAC,EAAE,UAAU,CAAC,kBAAkB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IAChE,UAAU,EAAE,UAAU,CAAC,YAAY,CAAC,CAAC;CACtC;AAsFD,wBAAgB,aAAa,CAAC,QAAQ,EAAE,SAAS,EAAE,EACjD,UAAU,EACV,GAAG,IAAI,EACR,EAAE,kBAAkB,CAAC,QAAQ,EAAE,SAAS,CAAC,GAAG;IAAE,UAAU,EAAE,OAAO,CAAA;CAAE,eAMnE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/table/body-cell/index.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,UAAU,kBAAkB;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,SAAS,EAAE,OAAO,GAAG,SAAS,CAAC;IAC/B,UAAU,EAAE,OAAO,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,OAAO,CAAC;IACxB,cAAc,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,wBAAgB,aAAa,CAAC,EAC5B,SAAS,EACT,KAAK,EACL,QAAQ,EACR,SAAS,EACT,UAAU,EACV,SAAS,EACT,UAAU,EACV,cAAc,EACd,cAAc,EACd,SAAS,EACT,WAAW,EACX,YAAY,EACZ,SAAS,GACV,EAAE,kBAAkB,eAyBpB;AAED,UAAU,yBAAyB,CAAC,QAAQ,CAAE,SAAQ,kBAAkB;IACtE,MAAM,EAAE,UAAU,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IAC9C,IAAI,EAAE,QAAQ,CAAC;CAChB;AAED,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,EAAE,yBAAyB,CAAC,QAAQ,CAAC,eAE5G"}
@@ -3,54 +3,15 @@ import { __assign, __rest } from "tslib";
3
3
  // SPDX-License-Identifier: Apache-2.0
4
4
  import clsx from 'clsx';
5
5
  import styles from './styles.css.js';
6
- import React, { useCallback, useRef } from 'react';
7
- import useFocusVisible from '../../internal/hooks/focus-visible';
8
- import { useEffectOnUpdate } from '../../internal/hooks/use-effect-on-update';
9
- import Button from '../../button/internal';
10
- import { TableTdElement } from './td-element';
11
- import { InlineEditor } from './inline-editor';
12
- import { useStableScrollPosition } from './use-stable-scroll-position';
13
- var readonlyState = Object.freeze({
14
- isEditing: false,
15
- currentValue: undefined,
16
- setValue: function () { }
17
- });
18
- var submitHandlerFallback = function () {
19
- throw new Error('The function `handleSubmit` is required for editable columns');
20
- };
21
- function TableCellEditable(_a) {
22
- var _b;
23
- var className = _a.className, item = _a.item, column = _a.column, isEditing = _a.isEditing, onEditStart = _a.onEditStart, onEditEnd = _a.onEditEnd, submitEdit = _a.submitEdit, ariaLabels = _a.ariaLabels, isVisualRefresh = _a.isVisualRefresh, rest = __rest(_a, ["className", "item", "column", "isEditing", "onEditStart", "onEditEnd", "submitEdit", "ariaLabels", "isVisualRefresh"]);
24
- var editActivateRef = useRef(null);
25
- var cellRef = useRef(null);
26
- var focusVisible = useFocusVisible();
27
- var _c = useStableScrollPosition(cellRef), storeScrollPosition = _c.storeScrollPosition, restoreScrollPosition = _c.restoreScrollPosition;
28
- var handleEditStart = function () {
29
- storeScrollPosition();
30
- if (!isEditing) {
31
- onEditStart();
32
- }
33
- };
34
- var scheduleRestoreScrollPosition = useCallback(function () { return setTimeout(restoreScrollPosition, 0); }, [restoreScrollPosition]);
35
- var tdNativeAttributes = __assign(__assign({}, focusVisible), { onFocus: scheduleRestoreScrollPosition, 'data-inline-editing-active': isEditing.toString() });
36
- useEffectOnUpdate(function () {
37
- if (!isEditing && editActivateRef.current) {
38
- editActivateRef.current.focus({ preventScroll: true });
39
- }
40
- var timer = scheduleRestoreScrollPosition();
41
- return function () { return clearTimeout(timer); };
42
- }, [isEditing, scheduleRestoreScrollPosition]);
43
- return (React.createElement(TableTdElement, __assign({}, rest, { nativeAttributes: tdNativeAttributes, className: clsx(className, styles['body-cell-editable'], isEditing && styles['body-cell-edit-active'], isVisualRefresh && styles['is-visual-refresh']), onClick: handleEditStart, ref: cellRef }), isEditing ? (React.createElement(InlineEditor, { ariaLabels: ariaLabels, column: column, item: item, onEditEnd: onEditEnd, submitEdit: submitEdit !== null && submitEdit !== void 0 ? submitEdit : submitHandlerFallback, __onRender: restoreScrollPosition })) : (React.createElement(React.Fragment, null,
44
- column.cell(item, readonlyState),
45
- React.createElement("span", { className: styles['body-cell-editor'] },
46
- React.createElement(Button, { __hideFocusOutline: true, __internalRootRef: editActivateRef, ariaLabel: (_b = ariaLabels === null || ariaLabels === void 0 ? void 0 : ariaLabels.activateEditLabel) === null || _b === void 0 ? void 0 : _b.call(ariaLabels, column), formAction: "none", iconName: "edit", variant: "inline-icon" }))))));
47
- }
6
+ import React from 'react';
7
+ import { useVisualRefresh } from '../../internal/hooks/use-visual-mode';
48
8
  export function TableBodyCell(_a) {
49
- var isEditable = _a.isEditable, rest = __rest(_a, ["isEditable"]);
50
- if (isEditable || rest.isEditing) {
51
- return React.createElement(TableCellEditable, __assign({}, rest));
52
- }
53
- var column = rest.column, item = rest.item;
54
- return React.createElement(TableTdElement, __assign({}, rest), column.cell(item, readonlyState));
9
+ var className = _a.className, style = _a.style, children = _a.children, wrapLines = _a.wrapLines, isFirstRow = _a.isFirstRow, isLastRow = _a.isLastRow, isSelected = _a.isSelected, isNextSelected = _a.isNextSelected, isPrevSelected = _a.isPrevSelected, isEvenRow = _a.isEvenRow, stripedRows = _a.stripedRows, hasSelection = _a.hasSelection, hasFooter = _a.hasFooter;
10
+ var isVisualRefresh = useVisualRefresh();
11
+ return (React.createElement("td", { style: style, className: clsx(className, styles['body-cell'], wrapLines && styles['body-cell-wrap'], isFirstRow && styles['body-cell-first-row'], isLastRow && styles['body-cell-last-row'], isSelected && styles['body-cell-selected'], isNextSelected && styles['body-cell-next-selected'], isPrevSelected && styles['body-cell-prev-selected'], !isEvenRow && stripedRows && styles['body-cell-shaded'], stripedRows && styles['has-striped-rows'], isVisualRefresh && styles['is-visual-refresh'], hasSelection && styles['has-selection'], hasFooter && styles['has-footer']) }, children));
12
+ }
13
+ export function TableBodyCellContent(_a) {
14
+ var item = _a.item, column = _a.column, rest = __rest(_a, ["item", "column"]);
15
+ return React.createElement(TableBodyCell, __assign({}, rest), column.cell(item));
55
16
  }
56
17
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/table/body-cell/index.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport clsx from 'clsx';\nimport styles from './styles.css.js';\nimport React, { useCallback, useRef } from 'react';\nimport useFocusVisible from '../../internal/hooks/focus-visible';\nimport { useEffectOnUpdate } from '../../internal/hooks/use-effect-on-update';\nimport Button from '../../button/internal';\nimport { ButtonProps } from '../../button/interfaces';\nimport { TableProps } from '../interfaces';\nimport { TableTdElement, TableTdElementProps } from './td-element';\nimport { InlineEditor } from './inline-editor';\nimport { useStableScrollPosition } from './use-stable-scroll-position';\n\nconst readonlyState = Object.freeze({\n isEditing: false,\n currentValue: undefined,\n setValue: () => {},\n});\n\nconst submitHandlerFallback = () => {\n throw new Error('The function `handleSubmit` is required for editable columns');\n};\n\ninterface TableBodyCellProps<ItemType, ValueType> extends TableTdElementProps {\n column: TableProps.EditableColumnDefinition<ItemType, ValueType>;\n item: ItemType;\n isEditing: boolean;\n onEditStart: () => void;\n onEditEnd: () => void;\n submitEdit?: TableProps.SubmitEditFunction<ItemType, ValueType>;\n ariaLabels: TableProps['ariaLabels'];\n}\n\nfunction TableCellEditable<ItemType, ValueType>({\n className,\n item,\n column,\n isEditing,\n onEditStart,\n onEditEnd,\n submitEdit,\n ariaLabels,\n isVisualRefresh,\n ...rest\n}: TableBodyCellProps<ItemType, ValueType>) {\n const editActivateRef = useRef<ButtonProps.Ref>(null);\n const cellRef = useRef<HTMLTableCellElement>(null);\n const focusVisible = useFocusVisible();\n const { storeScrollPosition, restoreScrollPosition } = useStableScrollPosition(cellRef);\n\n const handleEditStart = () => {\n storeScrollPosition();\n if (!isEditing) {\n onEditStart();\n }\n };\n\n const scheduleRestoreScrollPosition = useCallback(\n () => setTimeout(restoreScrollPosition, 0),\n [restoreScrollPosition]\n );\n\n const tdNativeAttributes = {\n ...(focusVisible as Record<string, string>),\n onFocus: scheduleRestoreScrollPosition,\n 'data-inline-editing-active': isEditing.toString(),\n };\n\n useEffectOnUpdate(() => {\n if (!isEditing && editActivateRef.current) {\n editActivateRef.current.focus({ preventScroll: true });\n }\n const timer = scheduleRestoreScrollPosition();\n return () => clearTimeout(timer);\n }, [isEditing, scheduleRestoreScrollPosition]);\n\n return (\n <TableTdElement\n {...rest}\n nativeAttributes={tdNativeAttributes as TableTdElementProps['nativeAttributes']}\n className={clsx(\n className,\n styles['body-cell-editable'],\n isEditing && styles['body-cell-edit-active'],\n isVisualRefresh && styles['is-visual-refresh']\n )}\n onClick={handleEditStart}\n ref={cellRef}\n >\n {isEditing ? (\n <InlineEditor\n ariaLabels={ariaLabels}\n column={column}\n item={item}\n onEditEnd={onEditEnd}\n submitEdit={submitEdit ?? submitHandlerFallback}\n __onRender={restoreScrollPosition}\n />\n ) : (\n <>\n {column.cell(item, readonlyState)}\n <span className={styles['body-cell-editor']}>\n <Button\n __hideFocusOutline={true}\n __internalRootRef={editActivateRef}\n ariaLabel={ariaLabels?.activateEditLabel?.(column)}\n formAction=\"none\"\n iconName=\"edit\"\n variant=\"inline-icon\"\n />\n </span>\n </>\n )}\n </TableTdElement>\n );\n}\n\nexport function TableBodyCell<ItemType, ValueType>({\n isEditable,\n ...rest\n}: TableBodyCellProps<ItemType, ValueType> & { isEditable: boolean }) {\n if (isEditable || rest.isEditing) {\n return <TableCellEditable {...rest} />;\n }\n const { column, item } = rest;\n return <TableTdElement {...rest}>{column.cell(item, readonlyState)}</TableTdElement>;\n}\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/table/body-cell/index.tsx"],"names":[],"mappings":";AAAA,qEAAqE;AACrE,sCAAsC;AACtC,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,MAAM,MAAM,iBAAiB,CAAC;AACrC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AAkBxE,MAAM,UAAU,aAAa,CAAC,EAcT;QAbnB,SAAS,eAAA,EACT,KAAK,WAAA,EACL,QAAQ,cAAA,EACR,SAAS,eAAA,EACT,UAAU,gBAAA,EACV,SAAS,eAAA,EACT,UAAU,gBAAA,EACV,cAAc,oBAAA,EACd,cAAc,oBAAA,EACd,SAAS,eAAA,EACT,WAAW,iBAAA,EACX,YAAY,kBAAA,EACZ,SAAS,eAAA;IAET,IAAM,eAAe,GAAG,gBAAgB,EAAE,CAAC;IAE3C,OAAO,CACL,4BACE,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,IAAI,CACb,SAAS,EACT,MAAM,CAAC,WAAW,CAAC,EACnB,SAAS,IAAI,MAAM,CAAC,gBAAgB,CAAC,EACrC,UAAU,IAAI,MAAM,CAAC,qBAAqB,CAAC,EAC3C,SAAS,IAAI,MAAM,CAAC,oBAAoB,CAAC,EACzC,UAAU,IAAI,MAAM,CAAC,oBAAoB,CAAC,EAC1C,cAAc,IAAI,MAAM,CAAC,yBAAyB,CAAC,EACnD,cAAc,IAAI,MAAM,CAAC,yBAAyB,CAAC,EACnD,CAAC,SAAS,IAAI,WAAW,IAAI,MAAM,CAAC,kBAAkB,CAAC,EACvD,WAAW,IAAI,MAAM,CAAC,kBAAkB,CAAC,EACzC,eAAe,IAAI,MAAM,CAAC,mBAAmB,CAAC,EAC9C,YAAY,IAAI,MAAM,CAAC,eAAe,CAAC,EACvC,SAAS,IAAI,MAAM,CAAC,YAAY,CAAC,CAClC,IAEA,QAAQ,CACN,CACN,CAAC;AACJ,CAAC;AAOD,MAAM,UAAU,oBAAoB,CAAW,EAA8D;IAA5D,IAAA,IAAI,UAAA,EAAE,MAAM,YAAA,EAAK,IAAI,cAAvB,kBAAyB,CAAF;IACpE,OAAO,oBAAC,aAAa,eAAK,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAiB,CAAC;AACtE,CAAC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport clsx from 'clsx';\nimport styles from './styles.css.js';\nimport React from 'react';\nimport { TableProps } from '../interfaces';\nimport { useVisualRefresh } from '../../internal/hooks/use-visual-mode';\n\ninterface TableBodyCellProps {\n className?: string;\n style?: React.CSSProperties;\n wrapLines: boolean | undefined;\n isFirstRow: boolean;\n isLastRow: boolean;\n isEvenRow?: boolean;\n stripedRows?: boolean;\n isSelected: boolean;\n isNextSelected: boolean;\n isPrevSelected: boolean;\n children?: React.ReactNode;\n hasSelection?: boolean;\n hasFooter?: boolean;\n}\n\nexport function TableBodyCell({\n className,\n style,\n children,\n wrapLines,\n isFirstRow,\n isLastRow,\n isSelected,\n isNextSelected,\n isPrevSelected,\n isEvenRow,\n stripedRows,\n hasSelection,\n hasFooter,\n}: TableBodyCellProps) {\n const isVisualRefresh = useVisualRefresh();\n\n return (\n <td\n style={style}\n className={clsx(\n className,\n styles['body-cell'],\n wrapLines && styles['body-cell-wrap'],\n isFirstRow && styles['body-cell-first-row'],\n isLastRow && styles['body-cell-last-row'],\n isSelected && styles['body-cell-selected'],\n isNextSelected && styles['body-cell-next-selected'],\n isPrevSelected && styles['body-cell-prev-selected'],\n !isEvenRow && stripedRows && styles['body-cell-shaded'],\n stripedRows && styles['has-striped-rows'],\n isVisualRefresh && styles['is-visual-refresh'],\n hasSelection && styles['has-selection'],\n hasFooter && styles['has-footer']\n )}\n >\n {children}\n </td>\n );\n}\n\ninterface TableBodyCellContentProps<ItemType> extends TableBodyCellProps {\n column: TableProps.ColumnDefinition<ItemType>;\n item: ItemType;\n}\n\nexport function TableBodyCellContent<ItemType>({ item, column, ...rest }: TableBodyCellContentProps<ItemType>) {\n return <TableBodyCell {...rest}>{column.cell(item)}</TableBodyCell>;\n}\n"]}
@@ -1,23 +1,17 @@
1
1
 
2
2
  import './styles.scoped.css';
3
3
  export default {
4
- "body-cell": "awsui_body-cell_c6tup_17cg6_93",
5
- "body-cell-wrap": "awsui_body-cell-wrap_c6tup_17cg6_102",
6
- "is-visual-refresh": "awsui_is-visual-refresh_c6tup_17cg6_114",
7
- "has-striped-rows": "awsui_has-striped-rows_c6tup_17cg6_126",
8
- "body-cell-edit-active": "awsui_body-cell-edit-active_c6tup_17cg6_129",
9
- "body-cell-editable": "awsui_body-cell-editable_c6tup_17cg6_129",
10
- "has-selection": "awsui_has-selection_c6tup_17cg6_135",
11
- "body-cell-first-row": "awsui_body-cell-first-row_c6tup_17cg6_141",
12
- "body-cell-last-row": "awsui_body-cell-last-row_c6tup_17cg6_144",
13
- "body-cell-selected": "awsui_body-cell-selected_c6tup_17cg6_144",
14
- "has-footer": "awsui_has-footer_c6tup_17cg6_144",
15
- "body-cell-shaded": "awsui_body-cell-shaded_c6tup_17cg6_154",
16
- "body-cell-next-selected": "awsui_body-cell-next-selected_c6tup_17cg6_176",
17
- "body-cell-prev-selected": "awsui_body-cell-prev-selected_c6tup_17cg6_180",
18
- "body-cell-editor": "awsui_body-cell-editor_c6tup_17cg6_204",
19
- "body-cell-editor-form": "awsui_body-cell-editor-form_c6tup_17cg6_214",
20
- "body-cell-editor-row": "awsui_body-cell-editor-row_c6tup_17cg6_223",
21
- "body-cell-editor-controls": "awsui_body-cell-editor-controls_c6tup_17cg6_233"
4
+ "body-cell": "awsui_body-cell_c6tup_9o7yk_9",
5
+ "body-cell-wrap": "awsui_body-cell-wrap_c6tup_9o7yk_18",
6
+ "body-cell-first-row": "awsui_body-cell-first-row_c6tup_9o7yk_30",
7
+ "body-cell-last-row": "awsui_body-cell-last-row_c6tup_9o7yk_33",
8
+ "body-cell-selected": "awsui_body-cell-selected_c6tup_9o7yk_33",
9
+ "has-footer": "awsui_has-footer_c6tup_9o7yk_33",
10
+ "body-cell-shaded": "awsui_body-cell-shaded_c6tup_9o7yk_43",
11
+ "body-cell-next-selected": "awsui_body-cell-next-selected_c6tup_9o7yk_65",
12
+ "body-cell-prev-selected": "awsui_body-cell-prev-selected_c6tup_9o7yk_69",
13
+ "is-visual-refresh": "awsui_is-visual-refresh_c6tup_9o7yk_98",
14
+ "has-selection": "awsui_has-selection_c6tup_9o7yk_114",
15
+ "has-striped-rows": "awsui_has-striped-rows_c6tup_9o7yk_117"
22
16
  };
23
17
 
@@ -6,91 +6,7 @@
6
6
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
7
7
  SPDX-License-Identifier: Apache-2.0
8
8
  */
9
- /*
10
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
11
- SPDX-License-Identifier: Apache-2.0
12
- */
13
- /*
14
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
15
- SPDX-License-Identifier: Apache-2.0
16
- */
17
- /*
18
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
19
- SPDX-License-Identifier: Apache-2.0
20
- */
21
- /*
22
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
23
- SPDX-License-Identifier: Apache-2.0
24
- */
25
- /*
26
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
27
- SPDX-License-Identifier: Apache-2.0
28
- */
29
- /*
30
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
31
- SPDX-License-Identifier: Apache-2.0
32
- */
33
- /*
34
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
35
- SPDX-License-Identifier: Apache-2.0
36
- */
37
- /*
38
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
39
- SPDX-License-Identifier: Apache-2.0
40
- */
41
- /*
42
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
43
- SPDX-License-Identifier: Apache-2.0
44
- */
45
- /*
46
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
47
- SPDX-License-Identifier: Apache-2.0
48
- */
49
- /*
50
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
51
- SPDX-License-Identifier: Apache-2.0
52
- */
53
- /* stylelint-disable @cloudscape-design/no-motion-outside-of-mixin, selector-combinator-disallowed-list, selector-pseudo-class-no-unknown, selector-class-pattern */
54
- /* stylelint-enable @cloudscape-design/no-motion-outside-of-mixin, selector-combinator-disallowed-list, selector-pseudo-class-no-unknown, selector-class-pattern */
55
- /*
56
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
57
- SPDX-License-Identifier: Apache-2.0
58
- */
59
- /*
60
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
61
- SPDX-License-Identifier: Apache-2.0
62
- */
63
- /*
64
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
65
- SPDX-License-Identifier: Apache-2.0
66
- */
67
- /*
68
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
69
- SPDX-License-Identifier: Apache-2.0
70
- */
71
- /*
72
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
73
- SPDX-License-Identifier: Apache-2.0
74
- */
75
- /*
76
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
77
- SPDX-License-Identifier: Apache-2.0
78
- */
79
- /*
80
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
81
- SPDX-License-Identifier: Apache-2.0
82
- */
83
- /* Style used for links in slots/components that are text heavy, to help links stand out among
84
- surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F73#description */
85
- /*
86
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
87
- SPDX-License-Identifier: Apache-2.0
88
- */
89
- /*
90
- Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
91
- SPDX-License-Identifier: Apache-2.0
92
- */
93
- .awsui_body-cell_c6tup_17cg6_93:not(#\9) {
9
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9) {
94
10
  box-sizing: border-box;
95
11
  padding: var(--space-scaled-xs-6859qs, 8px) var(--space-scaled-l-t03y3z, 20px) calc(
96
12
  var(--space-scaled-xs-6859qs, 8px) + (var(--border-item-width-qbbbsa, 2px) - var(--border-divider-list-width-hacikr, 1px))
@@ -99,207 +15,108 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
99
15
  word-wrap: break-word;
100
16
  border-bottom: var(--border-divider-list-width-hacikr, 1px) solid var(--color-border-divider-default-7s2wjw, #e9ebed);
101
17
  }
102
- .awsui_body-cell_c6tup_17cg6_93:not(#\9):not(.awsui_body-cell-wrap_c6tup_17cg6_102) {
18
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9):not(.awsui_body-cell-wrap_c6tup_9o7yk_18) {
103
19
  white-space: nowrap;
104
20
  overflow: hidden;
105
21
  text-overflow: ellipsis;
106
22
  }
107
- .awsui_body-cell_c6tup_17cg6_93:not(#\9):first-child {
23
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9):first-child {
108
24
  border-left: var(--border-item-width-qbbbsa, 2px) solid transparent;
109
25
  }
110
- .awsui_body-cell_c6tup_17cg6_93:not(#\9):last-child {
26
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9):last-child {
111
27
  border-right: var(--border-item-width-qbbbsa, 2px) solid transparent;
112
28
  padding-right: calc(var(--space-l-4vl6xu, 20px) - var(--border-item-width-qbbbsa, 2px));
113
29
  }
114
- .awsui_body-cell_c6tup_17cg6_93.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):first-child {
115
- /*
116
- Striped rows requires additional left padding because the
117
- shaded background makes the child content appear too close
118
- to the table edge.
119
- */
120
- /*
121
- Remove the placeholder border if the row is not selectable.
122
- Rows that are not selectable will reserve the horizontal space
123
- that the placeholder border would consume.
124
- */
125
- }
126
- .awsui_body-cell_c6tup_17cg6_93.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):first-child:not(.awsui_has-striped-rows_c6tup_17cg6_126) {
127
- padding-left: var(--space-xxxs-k2w98v, 2px);
128
- }
129
- .awsui_body-cell_c6tup_17cg6_93.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):first-child:not(.awsui_has-striped-rows_c6tup_17cg6_126):not(.awsui_body-cell-edit-active_c6tup_17cg6_129).awsui_body-cell-editable_c6tup_17cg6_129:hover {
130
- padding-left: calc(var(--space-xxxs-k2w98v, 2px) + var(--border-divider-list-width-hacikr, 1px));
131
- }
132
- .awsui_body-cell_c6tup_17cg6_93.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):first-child:first-child.awsui_has-striped-rows_c6tup_17cg6_126 {
133
- padding-left: var(--space-xxs-ynfts5, 4px);
134
- }
135
- .awsui_body-cell_c6tup_17cg6_93.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):first-child:not(.awsui_has-selection_c6tup_17cg6_135):not(.awsui_body-cell-editable_c6tup_17cg6_129) {
136
- border-left: none;
137
- }
138
- .awsui_body-cell_c6tup_17cg6_93:not(#\9):first-child:not(.awsui_is-visual-refresh_c6tup_17cg6_114) {
139
- padding-left: calc(var(--space-l-4vl6xu, 20px) - var(--border-item-width-qbbbsa, 2px));
140
- }
141
- .awsui_body-cell-first-row_c6tup_17cg6_141:not(#\9) {
30
+ .awsui_body-cell-first-row_c6tup_9o7yk_30:not(#\9) {
142
31
  border-top: var(--border-item-width-qbbbsa, 2px) solid transparent;
143
32
  }
144
- .awsui_body-cell-last-row_c6tup_17cg6_144:not(#\9):not(.awsui_body-cell-selected_c6tup_17cg6_144):not(.awsui_has-footer_c6tup_17cg6_144) {
33
+ .awsui_body-cell-last-row_c6tup_9o7yk_33:not(#\9):not(.awsui_body-cell-selected_c6tup_9o7yk_33):not(.awsui_has-footer_c6tup_9o7yk_33) {
145
34
  border-bottom: var(--border-item-width-qbbbsa, 2px) solid transparent;
146
35
  }
147
- .awsui_body-cell-last-row_c6tup_17cg6_144:not(#\9):not(.awsui_body-cell-selected_c6tup_17cg6_144).awsui_has-footer_c6tup_17cg6_144 {
36
+ .awsui_body-cell-last-row_c6tup_9o7yk_33:not(#\9):not(.awsui_body-cell-selected_c6tup_9o7yk_33).awsui_has-footer_c6tup_9o7yk_33 {
148
37
  /*
149
- Add a bottom border to the body cells of the last row as a separator between the
38
+ Add a bottom border to the body cells of the last row as a separator between the
150
39
  table and the footer
151
40
  */
152
41
  border-bottom: var(--border-divider-section-width-4wm2it, 2px) solid var(--color-border-divider-default-7s2wjw, #e9ebed);
153
42
  }
154
- .awsui_body-cell-shaded_c6tup_17cg6_154:not(#\9) {
43
+ .awsui_body-cell-shaded_c6tup_9o7yk_43:not(#\9) {
155
44
  background: var(--color-background-cell-shaded-26ubfj, #f8f8f8);
156
45
  }
157
- .awsui_body-cell-selected_c6tup_17cg6_144:not(#\9) {
46
+ .awsui_body-cell-selected_c6tup_9o7yk_33:not(#\9) {
158
47
  background-color: var(--color-background-item-selected-ebt4bi, #f2f8fd);
159
48
  border-top: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-item-selected-ppkssz, #0972d3);
160
49
  border-bottom: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-item-selected-ppkssz, #0972d3);
161
50
  padding-bottom: var(--space-scaled-xs-6859qs, 8px);
162
51
  }
163
- .awsui_body-cell-selected_c6tup_17cg6_144:not(#\9):first-child {
52
+ .awsui_body-cell-selected_c6tup_9o7yk_33:not(#\9):first-child {
164
53
  border-left: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-item-selected-ppkssz, #0972d3);
165
54
  border-radius: var(--border-radius-item-u2ibpi, 8px) 0 0 var(--border-radius-item-u2ibpi, 8px);
166
55
  }
167
- .awsui_body-cell-selected_c6tup_17cg6_144:not(#\9):last-child {
56
+ .awsui_body-cell-selected_c6tup_9o7yk_33:not(#\9):last-child {
168
57
  border-right: var(--border-item-width-qbbbsa, 2px) solid var(--color-border-item-selected-ppkssz, #0972d3);
169
58
  border-radius: 0 var(--border-radius-item-u2ibpi, 8px) var(--border-radius-item-u2ibpi, 8px) 0;
170
59
  }
171
- .awsui_body-cell-selected_c6tup_17cg6_144:not(#\9):not(:first-child) {
60
+ .awsui_body-cell-selected_c6tup_9o7yk_33:not(#\9):not(:first-child) {
172
61
  padding-top: calc(
173
62
  var(--space-scaled-xs-6859qs, 8px) + (var(--border-item-width-qbbbsa, 2px) - var(--border-divider-list-width-hacikr, 1px))
174
63
  );
175
64
  }
176
- .awsui_body-cell_c6tup_17cg6_93:not(#\9):not(.awsui_body-cell-selected_c6tup_17cg6_144).awsui_body-cell-next-selected_c6tup_17cg6_176 {
65
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9):not(.awsui_body-cell-selected_c6tup_9o7yk_33).awsui_body-cell-next-selected_c6tup_9o7yk_65 {
177
66
  border-bottom: 0;
178
67
  padding-bottom: calc(var(--space-scaled-xs-6859qs, 8px) + var(--border-divider-list-width-hacikr, 1px));
179
68
  }
180
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-prev-selected_c6tup_17cg6_180:not(#\9) {
69
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-prev-selected_c6tup_9o7yk_69:not(#\9) {
181
70
  padding-top: calc(
182
71
  var(--space-scaled-xs-6859qs, 8px) + (var(--border-item-width-qbbbsa, 2px) - var(--border-divider-list-width-hacikr, 1px))
183
72
  );
184
73
  border-top: var(--border-divider-list-width-hacikr, 1px) solid var(--color-border-item-placeholder-jgzhnb, #0972d3);
185
74
  }
186
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-next-selected_c6tup_17cg6_176:not(#\9) {
75
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-next-selected_c6tup_9o7yk_65:not(#\9) {
187
76
  border-bottom-width: var(--border-divider-list-width-hacikr, 1px);
188
77
  }
189
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-next-selected_c6tup_17cg6_176:not(#\9):first-child {
78
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-next-selected_c6tup_9o7yk_65:not(#\9):first-child {
190
79
  border-bottom-left-radius: 0;
191
80
  }
192
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-next-selected_c6tup_17cg6_176:not(#\9):last-child {
81
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-next-selected_c6tup_9o7yk_65:not(#\9):last-child {
193
82
  border-bottom-right-radius: 0;
194
83
  }
195
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-prev-selected_c6tup_17cg6_180:not(#\9):first-child {
84
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-prev-selected_c6tup_9o7yk_69:not(#\9):first-child {
196
85
  border-top-left-radius: 0;
197
86
  }
198
- .awsui_body-cell-selected_c6tup_17cg6_144.awsui_body-cell-prev-selected_c6tup_17cg6_180:not(#\9):last-child {
87
+ .awsui_body-cell-selected_c6tup_9o7yk_33.awsui_body-cell-prev-selected_c6tup_9o7yk_69:not(#\9):last-child {
199
88
  border-top-right-radius: 0;
200
89
  }
201
- .awsui_body-cell-selected_c6tup_17cg6_144:not(#\9):not(.awsui_body-cell-prev-selected_c6tup_17cg6_180) {
90
+ .awsui_body-cell-selected_c6tup_9o7yk_33:not(#\9):not(.awsui_body-cell-prev-selected_c6tup_9o7yk_69) {
202
91
  padding-top: var(--space-scaled-xs-6859qs, 8px);
203
92
  }
204
- .awsui_body-cell-editor_c6tup_17cg6_204:not(#\9) {
205
- top: 0;
206
- right: 0;
207
- bottom: 0;
208
- position: absolute;
209
- display: flex;
210
- align-items: center;
211
- justify-content: flex-end;
212
- padding-right: var(--space-xs-rsr2qu, 8px);
213
- }
214
- .awsui_body-cell-editor-form_c6tup_17cg6_214:not(#\9) {
215
- margin: calc(-1 * var(--space-xs-rsr2qu, 8px)) calc(-1.5 * var(--space-xs-rsr2qu, 8px));
216
- }
217
- .awsui_is-visual-refresh_c6tup_17cg6_114.awsui_body-cell_c6tup_17cg6_93:not(#\9):first-child.awsui_has-striped-rows_c6tup_17cg6_126 > .awsui_body-cell-editor-form_c6tup_17cg6_214 {
218
- margin-left: calc(-1 * var(--space-xxs-ynfts5, 4px));
219
- }
220
- .awsui_is-visual-refresh_c6tup_17cg6_114.awsui_body-cell_c6tup_17cg6_93:not(#\9):first-child:not(.awsui_has-striped-rows_c6tup_17cg6_126) > .awsui_body-cell-editor-form_c6tup_17cg6_214 {
221
- margin-left: calc(-1 * var(--space-xxxs-k2w98v, 2px));
222
- }
223
- .awsui_body-cell-editor-row_c6tup_17cg6_223:not(#\9) {
224
- display: flex;
225
- flex-flow: row nowrap;
226
- align-items: center;
227
- justify-content: space-between;
228
- column-gap: var(--space-xxs-ynfts5, 4px);
229
- }
230
- .awsui_body-cell-editor-row_c6tup_17cg6_223 > :not(#\9):not(:last-child) {
231
- flex-grow: 1;
232
- }
233
- .awsui_body-cell-editor-controls_c6tup_17cg6_233:not(#\9) {
234
- flex-shrink: 0;
235
- }
236
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9) {
237
- position: relative;
238
- cursor: pointer;
239
- }
240
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129.awsui_body-cell-edit-active_c6tup_17cg6_129:not(#\9) {
241
- overflow: visible;
242
- }
243
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129) > .awsui_body-cell-editor_c6tup_17cg6_204 {
244
- opacity: 0;
245
- }
246
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover {
247
- position: relative;
248
- background-color: var(--color-background-dropdown-item-hover-mqsxkv, #f4f4f4);
249
- border: var(--border-divider-list-width-hacikr, 1px) solid var(--color-border-control-default-m3lmsh, #7d8998);
250
- left: calc(-1 * var(--border-divider-list-width-hacikr, 1px));
251
- right: calc(-1 * var(--border-divider-list-width-hacikr, 1px));
252
- }
253
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover > .awsui_body-cell-editor_c6tup_17cg6_204 {
254
- padding-right: calc(var(--space-xs-rsr2qu, 8px) - (2 * var(--border-divider-list-width-hacikr, 1px)));
255
- }
256
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover.awsui_body-cell-last-row_c6tup_17cg6_144.awsui_body-cell-selected_c6tup_17cg6_144, .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover.awsui_body-cell-next-selected_c6tup_17cg6_176 {
257
- padding-top: calc(var(--space-scaled-xs-6859qs, 8px) - calc(var(--border-divider-list-width-hacikr, 1px) / 2));
258
- padding-bottom: calc(var(--space-scaled-xs-6859qs, 8px) - calc(var(--border-divider-list-width-hacikr, 1px) / 2));
259
- }
260
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover.awsui_body-cell-last-row_c6tup_17cg6_144:not(.awsui_body-cell-selected_c6tup_17cg6_144) {
261
- padding-top: calc(var(--space-scaled-xs-6859qs, 8px) - calc(var(--border-divider-list-width-hacikr, 1px)));
262
- }
263
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover.awsui_body-cell-first-row_c6tup_17cg6_141:not(.awsui_body-cell-selected_c6tup_17cg6_144) {
264
- padding-top: calc(var(--space-scaled-xs-6859qs, 8px) - calc(var(--border-divider-list-width-hacikr, 1px)));
265
- padding-bottom: calc(var(--space-scaled-xs-6859qs, 8px) - calc(var(--border-divider-list-width-hacikr, 1px)));
266
- }
267
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover, .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129)[data-awsui-focus-visible=true]:focus-within {
268
- padding-right: calc(var(--space-scaled-l-t03y3z, 20px) + var(--space-l-4vl6xu, 20px));
269
- }
270
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover > .awsui_body-cell-editor_c6tup_17cg6_204, .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129)[data-awsui-focus-visible=true]:focus-within > .awsui_body-cell-editor_c6tup_17cg6_204 {
271
- opacity: 1;
272
- }
273
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover:first-child {
274
- left: 0;
275
- right: 0;
276
- }
277
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129)[data-awsui-focus-visible=true]:not(:hover):focus-within {
278
- position: relative;
279
- }
280
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129)[data-awsui-focus-visible=true]:not(:hover):focus-within {
281
- outline: 2px dotted transparent;
282
- outline-offset: calc(calc(-1 * var(--space-scaled-xxs-95dhkm, 4px)) - 1px);
93
+
94
+ /*
95
+ In Visual Refresh the first cell of each row should align with the
96
+ left edge of the table as closely as possible.
97
+ */
98
+ .awsui_body-cell_c6tup_9o7yk_9:not(#\9):not(.awsui_is-visual-refresh_c6tup_9o7yk_98):first-child {
99
+ padding-left: calc(var(--space-l-4vl6xu, 20px) - var(--border-item-width-qbbbsa, 2px));
283
100
  }
284
- .awsui_body-cell_c6tup_17cg6_93.awsui_body-cell-editable_c6tup_17cg6_129:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129)[data-awsui-focus-visible=true]:not(:hover):focus-within::before {
285
- content: " ";
286
- display: block;
287
- position: absolute;
288
- left: calc(-1 * calc(-1 * var(--space-scaled-xxs-95dhkm, 4px)));
289
- top: calc(-1 * calc(-1 * var(--space-scaled-xxs-95dhkm, 4px)));
290
- width: calc(100% + 2 * calc(-1 * var(--space-scaled-xxs-95dhkm, 4px)));
291
- height: calc(100% + 2 * calc(-1 * var(--space-scaled-xxs-95dhkm, 4px)));
292
- border-radius: var(--border-radius-control-default-focus-ring-7661kz, 4px);
293
- box-shadow: 0 0 0 2px var(--color-border-item-focused-ap3b6s, #0972d3);
101
+
102
+ .awsui_body-cell_c6tup_9o7yk_9.awsui_is-visual-refresh_c6tup_9o7yk_98:not(#\9) {
103
+ /*
104
+ Remove the placeholder border if the row is not selectable.
105
+ Rows that are not selectable will reserve the horizontal space
106
+ that the placeholder border would consume.
107
+ */
108
+ /*
109
+ Striped rows requires additional left padding because the
110
+ shaded background makes the child content appear too close
111
+ to the table edge.
112
+ */
294
113
  }
295
- .awsui_body-cell-editable_c6tup_17cg6_129.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover:first-child {
296
- border-top-left-radius: var(--border-radius-control-default-focus-ring-7661kz, 4px);
297
- border-bottom-left-radius: var(--border-radius-control-default-focus-ring-7661kz, 4px);
114
+ .awsui_body-cell_c6tup_9o7yk_9.awsui_is-visual-refresh_c6tup_9o7yk_98:not(#\9):first-child:not(.awsui_has-selection_c6tup_9o7yk_114) {
115
+ border-left: none;
298
116
  }
299
- .awsui_body-cell-editable_c6tup_17cg6_129.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover:last-child {
300
- border-top-right-radius: var(--border-radius-control-default-focus-ring-7661kz, 4px);
301
- border-bottom-right-radius: var(--border-radius-control-default-focus-ring-7661kz, 4px);
117
+ .awsui_body-cell_c6tup_9o7yk_9.awsui_is-visual-refresh_c6tup_9o7yk_98:not(#\9):first-child:not(.awsui_has-striped-rows_c6tup_9o7yk_117) {
118
+ padding-left: var(--space-xxxs-k2w98v, 2px);
302
119
  }
303
- .awsui_body-cell-editable_c6tup_17cg6_129.awsui_is-visual-refresh_c6tup_17cg6_114:not(#\9):not(.awsui_body-cell-edit-active_c6tup_17cg6_129):hover.awsui_body-cell-first-row_c6tup_17cg6_141 > .awsui_body-cell-editor_c6tup_17cg6_204 {
304
- padding-top: var(--border-divider-list-width-hacikr, 1px);
120
+ .awsui_body-cell_c6tup_9o7yk_9.awsui_is-visual-refresh_c6tup_9o7yk_98:not(#\9):first-child.awsui_has-striped-rows_c6tup_9o7yk_117 {
121
+ padding-left: var(--space-xxs-ynfts5, 4px);
305
122
  }
@@ -2,23 +2,17 @@
2
2
  // es-module interop with Babel and Typescript
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  module.exports.default = {
5
- "body-cell": "awsui_body-cell_c6tup_17cg6_93",
6
- "body-cell-wrap": "awsui_body-cell-wrap_c6tup_17cg6_102",
7
- "is-visual-refresh": "awsui_is-visual-refresh_c6tup_17cg6_114",
8
- "has-striped-rows": "awsui_has-striped-rows_c6tup_17cg6_126",
9
- "body-cell-edit-active": "awsui_body-cell-edit-active_c6tup_17cg6_129",
10
- "body-cell-editable": "awsui_body-cell-editable_c6tup_17cg6_129",
11
- "has-selection": "awsui_has-selection_c6tup_17cg6_135",
12
- "body-cell-first-row": "awsui_body-cell-first-row_c6tup_17cg6_141",
13
- "body-cell-last-row": "awsui_body-cell-last-row_c6tup_17cg6_144",
14
- "body-cell-selected": "awsui_body-cell-selected_c6tup_17cg6_144",
15
- "has-footer": "awsui_has-footer_c6tup_17cg6_144",
16
- "body-cell-shaded": "awsui_body-cell-shaded_c6tup_17cg6_154",
17
- "body-cell-next-selected": "awsui_body-cell-next-selected_c6tup_17cg6_176",
18
- "body-cell-prev-selected": "awsui_body-cell-prev-selected_c6tup_17cg6_180",
19
- "body-cell-editor": "awsui_body-cell-editor_c6tup_17cg6_204",
20
- "body-cell-editor-form": "awsui_body-cell-editor-form_c6tup_17cg6_214",
21
- "body-cell-editor-row": "awsui_body-cell-editor-row_c6tup_17cg6_223",
22
- "body-cell-editor-controls": "awsui_body-cell-editor-controls_c6tup_17cg6_233"
5
+ "body-cell": "awsui_body-cell_c6tup_9o7yk_9",
6
+ "body-cell-wrap": "awsui_body-cell-wrap_c6tup_9o7yk_18",
7
+ "body-cell-first-row": "awsui_body-cell-first-row_c6tup_9o7yk_30",
8
+ "body-cell-last-row": "awsui_body-cell-last-row_c6tup_9o7yk_33",
9
+ "body-cell-selected": "awsui_body-cell-selected_c6tup_9o7yk_33",
10
+ "has-footer": "awsui_has-footer_c6tup_9o7yk_33",
11
+ "body-cell-shaded": "awsui_body-cell-shaded_c6tup_9o7yk_43",
12
+ "body-cell-next-selected": "awsui_body-cell-next-selected_c6tup_9o7yk_65",
13
+ "body-cell-prev-selected": "awsui_body-cell-prev-selected_c6tup_9o7yk_69",
14
+ "is-visual-refresh": "awsui_is-visual-refresh_c6tup_9o7yk_98",
15
+ "has-selection": "awsui_has-selection_c6tup_9o7yk_114",
16
+ "has-striped-rows": "awsui_has-striped-rows_c6tup_9o7yk_117"
23
17
  };
24
18
 
@@ -1,14 +1,14 @@
1
1
  import React from 'react';
2
2
  import { TableProps } from '../interfaces';
3
- interface TableHeaderCellProps<ItemType, ValueType> {
3
+ interface TableHeaderCellProps {
4
4
  className?: string;
5
5
  style?: React.CSSProperties;
6
6
  tabIndex: number;
7
- column: TableProps.ColumnDefinition<ItemType, ValueType>;
8
- activeSortingColumn?: TableProps.SortingColumn<ItemType>;
9
- sortingDescending?: boolean;
10
- sortingDisabled?: boolean;
11
- wrapLines?: boolean;
7
+ column: TableProps.ColumnDefinition<any>;
8
+ activeSortingColumn: TableProps.SortingColumn<any> | undefined;
9
+ sortingDescending: boolean | undefined;
10
+ sortingDisabled: boolean | undefined;
11
+ wrapLines: boolean | undefined;
12
12
  showFocusRing: boolean;
13
13
  hidden?: boolean;
14
14
  onClick(detail: TableProps.SortingState<any>): void;
@@ -18,8 +18,7 @@ interface TableHeaderCellProps<ItemType, ValueType> {
18
18
  onFocus?: () => void;
19
19
  onBlur?: () => void;
20
20
  resizableColumns?: boolean;
21
- isEditable?: boolean;
22
21
  }
23
- export declare function TableHeaderCell<ItemType, ValueType>({ className, style, tabIndex, column, activeSortingColumn, sortingDescending, sortingDisabled, wrapLines, showFocusRing, hidden, onClick, colIndex, onFocus, onBlur, updateColumn, resizableColumns, onResizeFinish, isEditable, }: TableHeaderCellProps<ItemType, ValueType>): JSX.Element;
22
+ export declare function TableHeaderCell({ className, style, tabIndex, column, activeSortingColumn, sortingDescending, sortingDisabled, wrapLines, showFocusRing, hidden, onClick, colIndex, onFocus, onBlur, updateColumn, resizableColumns, onResizeFinish, }: TableHeaderCellProps): JSX.Element;
24
23
  export {};
25
24
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/table/header-cell/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAM3C,UAAU,oBAAoB,CAAC,QAAQ,EAAE,SAAS;IAChD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,UAAU,CAAC,gBAAgB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IACzD,mBAAmB,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACzD,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,EAAE,OAAO,CAAC;IACvB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,MAAM,EAAE,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACpD,cAAc,EAAE,MAAM,IAAI,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3D,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,SAAS,EAAE,EACnD,SAAS,EACT,KAAK,EACL,QAAQ,EACR,MAAM,EACN,mBAAmB,EACnB,iBAAiB,EACjB,eAAe,EACf,SAAS,EACT,aAAa,EACb,MAAM,EACN,OAAO,EACP,QAAQ,EACR,OAAO,EACP,MAAM,EACN,YAAY,EACZ,gBAAgB,EAChB,cAAc,EACd,UAAU,GACX,EAAE,oBAAoB,CAAC,QAAQ,EAAE,SAAS,CAAC,eA0F3C"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/table/header-cell/index.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAM3C,UAAU,oBAAoB;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACzC,mBAAmB,EAAE,UAAU,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;IAC/D,iBAAiB,EAAE,OAAO,GAAG,SAAS,CAAC;IACvC,eAAe,EAAE,OAAO,GAAG,SAAS,CAAC;IACrC,SAAS,EAAE,OAAO,GAAG,SAAS,CAAC;IAC/B,aAAa,EAAE,OAAO,CAAC;IACvB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,MAAM,EAAE,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACpD,cAAc,EAAE,MAAM,IAAI,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3D,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED,wBAAgB,eAAe,CAAC,EAC9B,SAAS,EACT,KAAK,EACL,QAAQ,EACR,MAAM,EACN,mBAAmB,EACnB,iBAAiB,EACjB,eAAe,EACf,SAAS,EACT,aAAa,EACb,MAAM,EACN,OAAO,EACP,QAAQ,EACR,OAAO,EACP,MAAM,EACN,YAAY,EACZ,gBAAgB,EAChB,cAAc,GACf,EAAE,oBAAoB,eAqFtB"}