@cloudscape-design/components 3.0.274 → 3.0.276
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/collection-preferences/content-display/content-display-option.d.ts +13 -0
- package/collection-preferences/content-display/content-display-option.d.ts.map +1 -0
- package/collection-preferences/content-display/content-display-option.js +23 -0
- package/collection-preferences/content-display/content-display-option.js.map +1 -0
- package/collection-preferences/content-display/{sortable-item.d.ts → draggable-option.d.ts} +2 -2
- package/collection-preferences/content-display/draggable-option.d.ts.map +1 -0
- package/collection-preferences/content-display/draggable-option.js +27 -0
- package/collection-preferences/content-display/draggable-option.js.map +1 -0
- package/collection-preferences/content-display/index.d.ts.map +1 -1
- package/collection-preferences/content-display/index.js +10 -3
- package/collection-preferences/content-display/index.js.map +1 -1
- package/collection-preferences/content-display/styles.css.js +11 -15
- package/collection-preferences/content-display/styles.scoped.css +80 -62
- package/collection-preferences/content-display/styles.selectors.js +11 -15
- package/collection-preferences/styles.css.js +32 -36
- package/collection-preferences/styles.scoped.css +102 -84
- package/collection-preferences/styles.selectors.js +32 -36
- package/internal/components/options-list/index.d.ts.map +1 -1
- package/internal/components/options-list/index.js +4 -3
- package/internal/components/options-list/index.js.map +1 -1
- package/internal/environment.js +1 -1
- package/internal/hooks/use-scroll-sync/index.d.ts +1 -1
- package/internal/hooks/use-scroll-sync/index.d.ts.map +1 -1
- package/internal/hooks/use-scroll-sync/index.js +3 -2
- package/internal/hooks/use-scroll-sync/index.js.map +1 -1
- package/internal/manifest.json +1 -1
- package/package.json +1 -1
- package/table/internal.d.ts.map +1 -1
- package/table/internal.js +1 -1
- package/table/internal.js.map +1 -1
- package/table/use-sticky-scrollbar.d.ts.map +1 -1
- package/table/use-sticky-scrollbar.js +8 -3
- package/table/use-sticky-scrollbar.js.map +1 -1
- package/test-utils/dom/collection-preferences/content-display-preference.js +2 -2
- package/test-utils/dom/collection-preferences/content-display-preference.js.map +1 -1
- package/test-utils/selectors/collection-preferences/content-display-preference.js +2 -2
- package/test-utils/selectors/collection-preferences/content-display-preference.js.map +1 -1
- package/test-utils/tsconfig.tsbuildinfo +1 -1
- package/collection-preferences/content-display/sortable-item.d.ts.map +0 -1
- package/collection-preferences/content-display/sortable-item.js +0 -52
- package/collection-preferences/content-display/sortable-item.js.map +0 -1
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import { useSortable } from '@dnd-kit/sortable';
|
|
5
|
-
import { CSS } from '@dnd-kit/utilities';
|
|
6
|
-
import clsx from 'clsx';
|
|
7
|
-
import styles from '../styles.css.js';
|
|
8
|
-
import DragHandle from '../../internal/drag-handle';
|
|
9
|
-
import InternalToggle from '../../toggle/internal';
|
|
10
|
-
import { useUniqueId } from '../../internal/hooks/use-unique-id';
|
|
11
|
-
const componentPrefix = 'sortable-item';
|
|
12
|
-
const getClassName = (suffix) => styles[`${componentPrefix}-${suffix}`];
|
|
13
|
-
export function SortableItem({ dragHandleAriaLabel, onKeyDown, onToggle, option, }) {
|
|
14
|
-
var _a, _b, _c, _d, _e;
|
|
15
|
-
const { isDragging, isSorting, listeners, over, rect, setNodeRef, transform } = useSortable({
|
|
16
|
-
id: option.id,
|
|
17
|
-
});
|
|
18
|
-
const style = {
|
|
19
|
-
transform: CSS.Translate.toString(transform),
|
|
20
|
-
};
|
|
21
|
-
const idPrefix = useUniqueId(componentPrefix);
|
|
22
|
-
const controlId = `${idPrefix}-control-${option.id}`;
|
|
23
|
-
const dragHandleAttributes = {
|
|
24
|
-
['aria-label']: [dragHandleAriaLabel, option.label].join(', '),
|
|
25
|
-
};
|
|
26
|
-
const combinedListeners = Object.assign(Object.assign({}, listeners), { onKeyDown: (event) => {
|
|
27
|
-
if (onKeyDown) {
|
|
28
|
-
onKeyDown(event);
|
|
29
|
-
}
|
|
30
|
-
if (listeners === null || listeners === void 0 ? void 0 : listeners.onKeyDown) {
|
|
31
|
-
listeners.onKeyDown(event);
|
|
32
|
-
}
|
|
33
|
-
} });
|
|
34
|
-
// The placeholder is rendered from within the dragged item, but is shown at the position of the displaced item.
|
|
35
|
-
// Therefore, we need to translate it by the right amount.
|
|
36
|
-
// Unfortunately we can't use dnd-kit's recommended approach of using a drag overlay
|
|
37
|
-
// because it renders out of place when drag and drop is used in our modal.
|
|
38
|
-
const placeholderOffsetY = isDragging && ((_a = over === null || over === void 0 ? void 0 : over.rect) === null || _a === void 0 ? void 0 : _a.top) !== undefined && ((_b = rect.current) === null || _b === void 0 ? void 0 : _b.top) !== undefined
|
|
39
|
-
? over.rect.top > ((_c = rect.current) === null || _c === void 0 ? void 0 : _c.top)
|
|
40
|
-
? over.rect.bottom - ((_d = rect.current) === null || _d === void 0 ? void 0 : _d.bottom)
|
|
41
|
-
: over.rect.top - ((_e = rect.current) === null || _e === void 0 ? void 0 : _e.top)
|
|
42
|
-
: undefined;
|
|
43
|
-
const placeholderStyle = placeholderOffsetY ? { transform: `translateY(${placeholderOffsetY}px)` } : undefined;
|
|
44
|
-
return (React.createElement("li", { className: clsx(styles['content-display-option'], styles['sortable-item']) },
|
|
45
|
-
isDragging && React.createElement("div", { className: getClassName('placeholder'), style: placeholderStyle }),
|
|
46
|
-
React.createElement("div", { ref: setNodeRef, className: clsx(getClassName('content'), styles.draggable, isDragging && styles.active, isSorting && styles.sorting), style: style },
|
|
47
|
-
React.createElement(DragHandle, { attributes: dragHandleAttributes, hideFocus: isDragging, listeners: combinedListeners }),
|
|
48
|
-
React.createElement("label", { className: getClassName('label'), htmlFor: controlId }, option.label),
|
|
49
|
-
React.createElement("div", { className: getClassName('toggle') },
|
|
50
|
-
React.createElement(InternalToggle, { checked: !!option.visible, onChange: () => onToggle(option), disabled: option.alwaysVisible === true, controlId: controlId })))));
|
|
51
|
-
}
|
|
52
|
-
//# sourceMappingURL=sortable-item.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sortable-item.js","sourceRoot":"lib/default/","sources":["collection-preferences/content-display/sortable-item.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 React from 'react';\nimport { useSortable } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport clsx from 'clsx';\nimport styles from '../styles.css.js';\nimport DragHandle from '../../internal/drag-handle';\nimport InternalToggle from '../../toggle/internal';\nimport { useUniqueId } from '../../internal/hooks/use-unique-id';\nimport { OptionWithVisibility } from './utils';\n\nconst componentPrefix = 'sortable-item';\nconst getClassName = (suffix: string) => styles[`${componentPrefix}-${suffix}`];\n\nexport function SortableItem({\n dragHandleAriaLabel,\n onKeyDown,\n onToggle,\n option,\n}: {\n dragHandleAriaLabel?: string;\n onKeyDown?: (event: React.KeyboardEvent) => void;\n onToggle: (option: OptionWithVisibility) => void;\n option: OptionWithVisibility;\n}) {\n const { isDragging, isSorting, listeners, over, rect, setNodeRef, transform } = useSortable({\n id: option.id,\n });\n const style = {\n transform: CSS.Translate.toString(transform),\n };\n\n const idPrefix = useUniqueId(componentPrefix);\n const controlId = `${idPrefix}-control-${option.id}`;\n\n const dragHandleAttributes = {\n ['aria-label']: [dragHandleAriaLabel, option.label].join(', '),\n };\n\n const combinedListeners = {\n ...listeners,\n onKeyDown: (event: React.KeyboardEvent) => {\n if (onKeyDown) {\n onKeyDown(event);\n }\n if (listeners?.onKeyDown) {\n listeners.onKeyDown(event);\n }\n },\n };\n\n // The placeholder is rendered from within the dragged item, but is shown at the position of the displaced item.\n // Therefore, we need to translate it by the right amount.\n // Unfortunately we can't use dnd-kit's recommended approach of using a drag overlay\n // because it renders out of place when drag and drop is used in our modal.\n const placeholderOffsetY =\n isDragging && over?.rect?.top !== undefined && rect.current?.top !== undefined\n ? over.rect.top > rect.current?.top\n ? over.rect.bottom - rect.current?.bottom\n : over.rect.top - rect.current?.top\n : undefined;\n\n const placeholderStyle = placeholderOffsetY ? { transform: `translateY(${placeholderOffsetY}px)` } : undefined;\n\n return (\n <li className={clsx(styles['content-display-option'], styles['sortable-item'])}>\n {isDragging && <div className={getClassName('placeholder')} style={placeholderStyle} />}\n <div\n ref={setNodeRef}\n className={clsx(\n getClassName('content'),\n styles.draggable,\n isDragging && styles.active,\n isSorting && styles.sorting\n )}\n style={style}\n >\n <DragHandle attributes={dragHandleAttributes} hideFocus={isDragging} listeners={combinedListeners} />\n\n <label className={getClassName('label')} htmlFor={controlId}>\n {option.label}\n </label>\n <div className={getClassName('toggle')}>\n <InternalToggle\n checked={!!option.visible}\n onChange={() => onToggle(option)}\n disabled={option.alwaysVisible === true}\n controlId={controlId}\n />\n </div>\n </div>\n </li>\n );\n}\n"]}
|