@cloudscape-design/components 3.0.853 → 3.0.855

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 (90) hide show
  1. package/app-layout/visual-refresh-toolbar/index.d.ts.map +1 -1
  2. package/app-layout/visual-refresh-toolbar/index.js +1 -1
  3. package/app-layout/visual-refresh-toolbar/index.js.map +1 -1
  4. package/app-layout/visual-refresh-toolbar/skeleton/index.d.ts +1 -0
  5. package/app-layout/visual-refresh-toolbar/skeleton/index.d.ts.map +1 -1
  6. package/app-layout/visual-refresh-toolbar/skeleton/index.js +2 -2
  7. package/app-layout/visual-refresh-toolbar/skeleton/index.js.map +1 -1
  8. package/collection-preferences/content-display/content-display-option.d.ts +1 -2
  9. package/collection-preferences/content-display/content-display-option.d.ts.map +1 -1
  10. package/collection-preferences/content-display/content-display-option.js +2 -2
  11. package/collection-preferences/content-display/content-display-option.js.map +1 -1
  12. package/collection-preferences/content-display/index.d.ts.map +1 -1
  13. package/collection-preferences/content-display/index.js +4 -6
  14. package/collection-preferences/content-display/index.js.map +1 -1
  15. package/collection-preferences/content-display/styles.css.js +10 -12
  16. package/collection-preferences/content-display/styles.scoped.css +10 -36
  17. package/collection-preferences/content-display/styles.selectors.js +10 -12
  18. package/collection-preferences/styles.css.js +36 -38
  19. package/collection-preferences/styles.scoped.css +37 -63
  20. package/collection-preferences/styles.selectors.js +36 -38
  21. package/internal/components/dnd-area/index.d.ts +4 -0
  22. package/internal/components/dnd-area/index.d.ts.map +1 -0
  23. package/internal/components/{dnd-container → dnd-area}/index.js +13 -15
  24. package/internal/components/dnd-area/index.js.map +1 -0
  25. package/internal/components/{dnd-container → dnd-area}/interfaces.d.ts +13 -14
  26. package/internal/components/dnd-area/interfaces.d.ts.map +1 -0
  27. package/internal/components/dnd-area/interfaces.js.map +1 -0
  28. package/internal/components/dnd-area/keyboard-sensor/defaults.d.ts.map +1 -0
  29. package/internal/components/dnd-area/keyboard-sensor/defaults.js.map +1 -0
  30. package/internal/components/dnd-area/keyboard-sensor/index.d.ts.map +1 -0
  31. package/internal/components/dnd-area/keyboard-sensor/index.js.map +1 -0
  32. package/internal/components/dnd-area/keyboard-sensor/utilities/events.d.ts.map +1 -0
  33. package/internal/components/dnd-area/keyboard-sensor/utilities/events.js.map +1 -0
  34. package/internal/components/dnd-area/keyboard-sensor/utilities/listeners.d.ts.map +1 -0
  35. package/internal/components/dnd-area/keyboard-sensor/utilities/listeners.js.map +1 -0
  36. package/internal/components/dnd-area/keyboard-sensor/utilities/scroll.d.ts.map +1 -0
  37. package/internal/components/dnd-area/keyboard-sensor/utilities/scroll.js.map +1 -0
  38. package/internal/components/dnd-area/styles.css.js +13 -0
  39. package/internal/components/{dnd-container → dnd-area}/styles.scoped.css +79 -4
  40. package/internal/components/dnd-area/styles.selectors.js +14 -0
  41. package/internal/components/{dnd-container → dnd-area}/use-drag-and-drop-reorder.d.ts +2 -2
  42. package/internal/components/dnd-area/use-drag-and-drop-reorder.d.ts.map +1 -0
  43. package/internal/components/dnd-area/use-drag-and-drop-reorder.js.map +1 -0
  44. package/internal/components/{dnd-container → dnd-area}/use-live-announcements.d.ts +3 -3
  45. package/internal/components/dnd-area/use-live-announcements.d.ts.map +1 -0
  46. package/internal/components/dnd-area/use-live-announcements.js.map +1 -0
  47. package/internal/components/drag-handle/index.d.ts +7 -5
  48. package/internal/components/drag-handle/index.d.ts.map +1 -1
  49. package/internal/components/drag-handle/index.js +2 -3
  50. package/internal/components/drag-handle/index.js.map +1 -1
  51. package/internal/environment.js +1 -1
  52. package/internal/environment.json +1 -1
  53. package/internal/manifest.json +1 -1
  54. package/mixed-line-bar-chart/chart-container.js +7 -7
  55. package/mixed-line-bar-chart/chart-container.js.map +1 -1
  56. package/package.json +1 -1
  57. package/internal/components/dnd-container/index.d.ts +0 -4
  58. package/internal/components/dnd-container/index.d.ts.map +0 -1
  59. package/internal/components/dnd-container/index.js.map +0 -1
  60. package/internal/components/dnd-container/interfaces.d.ts.map +0 -1
  61. package/internal/components/dnd-container/interfaces.js.map +0 -1
  62. package/internal/components/dnd-container/keyboard-sensor/defaults.d.ts.map +0 -1
  63. package/internal/components/dnd-container/keyboard-sensor/defaults.js.map +0 -1
  64. package/internal/components/dnd-container/keyboard-sensor/index.d.ts.map +0 -1
  65. package/internal/components/dnd-container/keyboard-sensor/index.js.map +0 -1
  66. package/internal/components/dnd-container/keyboard-sensor/utilities/events.d.ts.map +0 -1
  67. package/internal/components/dnd-container/keyboard-sensor/utilities/events.js.map +0 -1
  68. package/internal/components/dnd-container/keyboard-sensor/utilities/listeners.d.ts.map +0 -1
  69. package/internal/components/dnd-container/keyboard-sensor/utilities/listeners.js.map +0 -1
  70. package/internal/components/dnd-container/keyboard-sensor/utilities/scroll.d.ts.map +0 -1
  71. package/internal/components/dnd-container/keyboard-sensor/utilities/scroll.js.map +0 -1
  72. package/internal/components/dnd-container/styles.css.js +0 -6
  73. package/internal/components/dnd-container/styles.selectors.js +0 -7
  74. package/internal/components/dnd-container/use-drag-and-drop-reorder.d.ts.map +0 -1
  75. package/internal/components/dnd-container/use-drag-and-drop-reorder.js.map +0 -1
  76. package/internal/components/dnd-container/use-live-announcements.d.ts.map +0 -1
  77. package/internal/components/dnd-container/use-live-announcements.js.map +0 -1
  78. /package/internal/components/{dnd-container → dnd-area}/interfaces.js +0 -0
  79. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/defaults.d.ts +0 -0
  80. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/defaults.js +0 -0
  81. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/index.d.ts +0 -0
  82. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/index.js +0 -0
  83. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/events.d.ts +0 -0
  84. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/events.js +0 -0
  85. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/listeners.d.ts +0 -0
  86. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/listeners.js +0 -0
  87. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/scroll.d.ts +0 -0
  88. /package/internal/components/{dnd-container → dnd-area}/keyboard-sensor/utilities/scroll.js +0 -0
  89. /package/internal/components/{dnd-container → dnd-area}/use-drag-and-drop-reorder.js +0 -0
  90. /package/internal/components/{dnd-container → dnd-area}/use-live-announcements.js +0 -0
@@ -1,43 +1,41 @@
1
1
 
2
2
  import './styles.scoped.css';
3
3
  export default {
4
- "visible-content": "awsui_visible-content_tc96w_1xqaf_289",
5
- "visible-content-toggle": "awsui_visible-content-toggle_tc96w_1xqaf_290",
6
- "visible-content-groups": "awsui_visible-content-groups_tc96w_1xqaf_291",
7
- "visible-content-group": "awsui_visible-content-group_tc96w_1xqaf_291",
8
- "visible-content-title": "awsui_visible-content-title_tc96w_1xqaf_296",
9
- "visible-content-group-label": "awsui_visible-content-group-label_tc96w_1xqaf_306",
10
- "visible-content-option": "awsui_visible-content-option_tc96w_1xqaf_312",
11
- "visible-content-option-label": "awsui_visible-content-option-label_tc96w_1xqaf_325",
12
- "content-display-option-toggle": "awsui_content-display-option-toggle_tc96w_1xqaf_620",
13
- "content-display-option-content": "awsui_content-display-option-content_tc96w_1xqaf_624",
14
- "content-display-option": "awsui_content-display-option_tc96w_1xqaf_620",
15
- "placeholder": "awsui_placeholder_tc96w_1xqaf_671",
16
- "sorting": "awsui_sorting_tc96w_1xqaf_671",
17
- "content-display-option-label": "awsui_content-display-option-label_tc96w_1xqaf_698",
18
- "content-display": "awsui_content-display_tc96w_1xqaf_620",
19
- "content-display-text-filter": "awsui_content-display-text-filter_tc96w_1xqaf_706",
20
- "content-display-no-match": "awsui_content-display-no-match_tc96w_1xqaf_707",
21
- "content-display-title": "awsui_content-display-title_tc96w_1xqaf_711",
22
- "content-display-description": "awsui_content-display-description_tc96w_1xqaf_720",
23
- "content-display-option-list": "awsui_content-display-option-list_tc96w_1xqaf_728",
24
- "root": "awsui_root_tc96w_1xqaf_735",
25
- "modal-root": "awsui_modal-root_tc96w_1xqaf_736",
26
- "trigger-button": "awsui_trigger-button_tc96w_1xqaf_737",
27
- "cancel-button": "awsui_cancel-button_tc96w_1xqaf_738",
28
- "confirm-button": "awsui_confirm-button_tc96w_1xqaf_739",
29
- "custom": "awsui_custom_tc96w_1xqaf_740",
30
- "second-column-small": "awsui_second-column-small_tc96w_1xqaf_744",
31
- "wrap-lines": "awsui_wrap-lines_tc96w_1xqaf_748",
32
- "striped-rows": "awsui_striped-rows_tc96w_1xqaf_749",
33
- "content-density": "awsui_content-density_tc96w_1xqaf_750",
34
- "page-size": "awsui_page-size_tc96w_1xqaf_751",
35
- "page-size-form-field": "awsui_page-size-form-field_tc96w_1xqaf_752",
36
- "page-size-radio-group": "awsui_page-size-radio-group_tc96w_1xqaf_753",
37
- "sticky-columns": "awsui_sticky-columns_tc96w_1xqaf_754",
38
- "sticky-columns-form-field": "awsui_sticky-columns-form-field_tc96w_1xqaf_755",
39
- "sticky-columns-radio-group": "awsui_sticky-columns-radio-group_tc96w_1xqaf_756",
40
- "sticky-columns-first": "awsui_sticky-columns-first_tc96w_1xqaf_757",
41
- "sticky-columns-last": "awsui_sticky-columns-last_tc96w_1xqaf_758"
4
+ "visible-content": "awsui_visible-content_tc96w_356y9_289",
5
+ "visible-content-toggle": "awsui_visible-content-toggle_tc96w_356y9_290",
6
+ "visible-content-groups": "awsui_visible-content-groups_tc96w_356y9_291",
7
+ "visible-content-group": "awsui_visible-content-group_tc96w_356y9_291",
8
+ "visible-content-title": "awsui_visible-content-title_tc96w_356y9_296",
9
+ "visible-content-group-label": "awsui_visible-content-group-label_tc96w_356y9_306",
10
+ "visible-content-option": "awsui_visible-content-option_tc96w_356y9_312",
11
+ "visible-content-option-label": "awsui_visible-content-option-label_tc96w_356y9_325",
12
+ "content-display-option-toggle": "awsui_content-display-option-toggle_tc96w_356y9_620",
13
+ "content-display-option-content": "awsui_content-display-option-content_tc96w_356y9_624",
14
+ "content-display-option": "awsui_content-display-option_tc96w_356y9_620",
15
+ "content-display-option-label": "awsui_content-display-option-label_tc96w_356y9_672",
16
+ "content-display": "awsui_content-display_tc96w_356y9_620",
17
+ "content-display-text-filter": "awsui_content-display-text-filter_tc96w_356y9_680",
18
+ "content-display-no-match": "awsui_content-display-no-match_tc96w_356y9_681",
19
+ "content-display-title": "awsui_content-display-title_tc96w_356y9_685",
20
+ "content-display-description": "awsui_content-display-description_tc96w_356y9_694",
21
+ "content-display-option-list": "awsui_content-display-option-list_tc96w_356y9_702",
22
+ "root": "awsui_root_tc96w_356y9_709",
23
+ "modal-root": "awsui_modal-root_tc96w_356y9_710",
24
+ "trigger-button": "awsui_trigger-button_tc96w_356y9_711",
25
+ "cancel-button": "awsui_cancel-button_tc96w_356y9_712",
26
+ "confirm-button": "awsui_confirm-button_tc96w_356y9_713",
27
+ "custom": "awsui_custom_tc96w_356y9_714",
28
+ "second-column-small": "awsui_second-column-small_tc96w_356y9_718",
29
+ "wrap-lines": "awsui_wrap-lines_tc96w_356y9_722",
30
+ "striped-rows": "awsui_striped-rows_tc96w_356y9_723",
31
+ "content-density": "awsui_content-density_tc96w_356y9_724",
32
+ "page-size": "awsui_page-size_tc96w_356y9_725",
33
+ "page-size-form-field": "awsui_page-size-form-field_tc96w_356y9_726",
34
+ "page-size-radio-group": "awsui_page-size-radio-group_tc96w_356y9_727",
35
+ "sticky-columns": "awsui_sticky-columns_tc96w_356y9_728",
36
+ "sticky-columns-form-field": "awsui_sticky-columns-form-field_tc96w_356y9_729",
37
+ "sticky-columns-radio-group": "awsui_sticky-columns-radio-group_tc96w_356y9_730",
38
+ "sticky-columns-first": "awsui_sticky-columns-first_tc96w_356y9_731",
39
+ "sticky-columns-last": "awsui_sticky-columns-last_tc96w_356y9_732"
42
40
  };
43
41
 
@@ -286,14 +286,14 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
286
286
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
287
287
  SPDX-License-Identifier: Apache-2.0
288
288
  */
289
- .awsui_visible-content_tc96w_1xqaf_289:not(#\9),
290
- .awsui_visible-content-toggle_tc96w_1xqaf_290:not(#\9),
291
- .awsui_visible-content-groups_tc96w_1xqaf_291:not(#\9),
292
- .awsui_visible-content-group_tc96w_1xqaf_291:not(#\9) {
289
+ .awsui_visible-content_tc96w_356y9_289:not(#\9),
290
+ .awsui_visible-content-toggle_tc96w_356y9_290:not(#\9),
291
+ .awsui_visible-content-groups_tc96w_356y9_291:not(#\9),
292
+ .awsui_visible-content-group_tc96w_356y9_291:not(#\9) {
293
293
  /* used in test-utils */
294
294
  }
295
295
 
296
- .awsui_visible-content-title_tc96w_1xqaf_296:not(#\9) {
296
+ .awsui_visible-content-title_tc96w_356y9_296:not(#\9) {
297
297
  font-size: var(--font-size-body-m-x4okxb, 14px);
298
298
  line-height: var(--line-height-body-m-30ar75, 20px);
299
299
  font-weight: var(--font-display-label-weight-815ja9, 700);
@@ -303,13 +303,13 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
303
303
  margin-inline: 0;
304
304
  }
305
305
 
306
- .awsui_visible-content-group-label_tc96w_1xqaf_306:not(#\9) {
306
+ .awsui_visible-content-group-label_tc96w_356y9_306:not(#\9) {
307
307
  color: var(--color-text-group-label-8pk3es, #424650);
308
308
  padding-block-end: var(--space-xs-zb16t3, 8px);
309
309
  border-block-end: var(--border-divider-list-width-27y3k5, 1px) solid var(--color-border-divider-secondary-alwp8z, #ebebf0);
310
310
  }
311
311
 
312
- .awsui_visible-content-option_tc96w_1xqaf_312:not(#\9) {
312
+ .awsui_visible-content-option_tc96w_356y9_312:not(#\9) {
313
313
  display: flex;
314
314
  flex-wrap: nowrap;
315
315
  justify-content: space-between;
@@ -318,11 +318,11 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
318
318
  padding-inline-end: 0px;
319
319
  border-block-end: var(--border-divider-list-width-27y3k5, 1px) solid var(--color-border-divider-secondary-alwp8z, #ebebf0);
320
320
  }
321
- .awsui_visible-content-option_tc96w_1xqaf_312:not(#\9):last-child {
321
+ .awsui_visible-content-option_tc96w_356y9_312:not(#\9):last-child {
322
322
  border-block-end: none;
323
323
  }
324
324
 
325
- .awsui_visible-content-option-label_tc96w_1xqaf_325:not(#\9) {
325
+ .awsui_visible-content-option-label_tc96w_356y9_325:not(#\9) {
326
326
  overflow: hidden;
327
327
  text-overflow: ellipsis;
328
328
  padding-inline-end: var(--space-l-t419sm, 20px);
@@ -617,11 +617,11 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
617
617
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
618
618
  SPDX-License-Identifier: Apache-2.0
619
619
  */
620
- .awsui_content-display-option-toggle_tc96w_1xqaf_620:not(#\9) {
620
+ .awsui_content-display-option-toggle_tc96w_356y9_620:not(#\9) {
621
621
  /* used in test-utils */
622
622
  }
623
623
 
624
- .awsui_content-display-option-content_tc96w_1xqaf_624:not(#\9) {
624
+ .awsui_content-display-option-content_tc96w_356y9_624:not(#\9) {
625
625
  border-collapse: separate;
626
626
  border-spacing: 0;
627
627
  box-sizing: border-box;
@@ -664,52 +664,26 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
664
664
  border-end-end-radius: var(--border-radius-item-05df9h, 8px);
665
665
  }
666
666
 
667
- .awsui_content-display-option_tc96w_1xqaf_620:not(#\9) {
667
+ .awsui_content-display-option_tc96w_356y9_620:not(#\9) {
668
668
  list-style: none;
669
669
  position: relative;
670
670
  border-block-start: var(--border-divider-list-width-27y3k5, 1px) solid var(--color-border-divider-secondary-alwp8z, #ebebf0);
671
671
  }
672
- .awsui_content-display-option_tc96w_1xqaf_620:not(#\9):not(.awsui_placeholder_tc96w_1xqaf_671).awsui_sorting_tc96w_1xqaf_671 {
673
- transition: transform var(--motion-duration-transition-quick-6npj01, 90ms) var(--motion-easing-transition-quick-l9jfsx, linear);
674
- }
675
- @media (prefers-reduced-motion: reduce) {
676
- .awsui_content-display-option_tc96w_1xqaf_620:not(#\9):not(.awsui_placeholder_tc96w_1xqaf_671).awsui_sorting_tc96w_1xqaf_671 {
677
- animation: none;
678
- transition: none;
679
- }
680
- }
681
- .awsui-motion-disabled .awsui_content-display-option_tc96w_1xqaf_620:not(#\9):not(.awsui_placeholder_tc96w_1xqaf_671).awsui_sorting_tc96w_1xqaf_671, .awsui-mode-entering .awsui_content-display-option_tc96w_1xqaf_620:not(#\9):not(.awsui_placeholder_tc96w_1xqaf_671).awsui_sorting_tc96w_1xqaf_671 {
682
- animation: none;
683
- transition: none;
684
- }
685
- .awsui_content-display-option_tc96w_1xqaf_620.awsui_placeholder_tc96w_1xqaf_671 > .awsui_content-display-option-content_tc96w_1xqaf_624:not(#\9) {
686
- position: relative;
687
- }
688
- .awsui_content-display-option_tc96w_1xqaf_620.awsui_placeholder_tc96w_1xqaf_671 > .awsui_content-display-option-content_tc96w_1xqaf_624:not(#\9):after {
689
- content: " ";
690
- position: absolute;
691
- inset: 0;
692
- background: var(--color-drag-placeholder-hover-oikifl, #d1f1ff);
693
- border-start-start-radius: var(--border-radius-item-05df9h, 8px);
694
- border-start-end-radius: var(--border-radius-item-05df9h, 8px);
695
- border-end-start-radius: var(--border-radius-item-05df9h, 8px);
696
- border-end-end-radius: var(--border-radius-item-05df9h, 8px);
697
- }
698
672
 
699
- .awsui_content-display-option-label_tc96w_1xqaf_698:not(#\9) {
673
+ .awsui_content-display-option-label_tc96w_356y9_672:not(#\9) {
700
674
  flex-grow: 1;
701
675
  min-inline-size: 0;
702
676
  word-break: break-word;
703
677
  padding-inline-end: var(--space-l-t419sm, 20px);
704
678
  }
705
679
 
706
- .awsui_content-display_tc96w_1xqaf_620:not(#\9),
707
- .awsui_content-display-text-filter_tc96w_1xqaf_706:not(#\9),
708
- .awsui_content-display-no-match_tc96w_1xqaf_707:not(#\9) {
680
+ .awsui_content-display_tc96w_356y9_620:not(#\9),
681
+ .awsui_content-display-text-filter_tc96w_356y9_680:not(#\9),
682
+ .awsui_content-display-no-match_tc96w_356y9_681:not(#\9) {
709
683
  /* used in test-utils */
710
684
  }
711
685
 
712
- .awsui_content-display-title_tc96w_1xqaf_711:not(#\9) {
686
+ .awsui_content-display-title_tc96w_356y9_685:not(#\9) {
713
687
  font-size: var(--font-size-body-m-x4okxb, 14px);
714
688
  line-height: var(--line-height-body-m-30ar75, 20px);
715
689
  font-weight: var(--font-display-label-weight-815ja9, 700);
@@ -718,7 +692,7 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
718
692
  margin-inline: 0;
719
693
  }
720
694
 
721
- .awsui_content-display-description_tc96w_1xqaf_720:not(#\9) {
695
+ .awsui_content-display-description_tc96w_356y9_694:not(#\9) {
722
696
  color: var(--color-text-form-secondary-54emib, #656871);
723
697
  font-size: var(--font-size-body-s-asqx2i, 12px);
724
698
  line-height: var(--line-height-body-s-7zv1j5, 16px);
@@ -726,36 +700,36 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
726
700
  margin-block-start: var(--space-scaled-xxxs-27y4hv, 2px);
727
701
  }
728
702
 
729
- .awsui_content-display-option-list_tc96w_1xqaf_728:not(#\9) {
703
+ .awsui_content-display-option-list_tc96w_356y9_702:not(#\9) {
730
704
  position: relative;
731
705
  list-style: none;
732
706
  padding-block: 0;
733
707
  padding-inline: 0;
734
708
  }
735
709
 
736
- .awsui_root_tc96w_1xqaf_735:not(#\9),
737
- .awsui_modal-root_tc96w_1xqaf_736:not(#\9),
738
- .awsui_trigger-button_tc96w_1xqaf_737:not(#\9),
739
- .awsui_cancel-button_tc96w_1xqaf_738:not(#\9),
740
- .awsui_confirm-button_tc96w_1xqaf_739:not(#\9),
741
- .awsui_custom_tc96w_1xqaf_740:not(#\9) {
710
+ .awsui_root_tc96w_356y9_709:not(#\9),
711
+ .awsui_modal-root_tc96w_356y9_710:not(#\9),
712
+ .awsui_trigger-button_tc96w_356y9_711:not(#\9),
713
+ .awsui_cancel-button_tc96w_356y9_712:not(#\9),
714
+ .awsui_confirm-button_tc96w_356y9_713:not(#\9),
715
+ .awsui_custom_tc96w_356y9_714:not(#\9) {
742
716
  /* used in test-utils */
743
717
  }
744
718
 
745
- .awsui_second-column-small_tc96w_1xqaf_744:not(#\9) {
719
+ .awsui_second-column-small_tc96w_356y9_718:not(#\9) {
746
720
  padding-block-start: calc(2 * var(--space-scaled-l-0hpmd7, 20px));
747
721
  }
748
722
 
749
- .awsui_wrap-lines_tc96w_1xqaf_748:not(#\9),
750
- .awsui_striped-rows_tc96w_1xqaf_749:not(#\9),
751
- .awsui_content-density_tc96w_1xqaf_750:not(#\9),
752
- .awsui_page-size_tc96w_1xqaf_751:not(#\9),
753
- .awsui_page-size-form-field_tc96w_1xqaf_752:not(#\9),
754
- .awsui_page-size-radio-group_tc96w_1xqaf_753:not(#\9),
755
- .awsui_sticky-columns_tc96w_1xqaf_754:not(#\9),
756
- .awsui_sticky-columns-form-field_tc96w_1xqaf_755:not(#\9),
757
- .awsui_sticky-columns-radio-group_tc96w_1xqaf_756:not(#\9),
758
- .awsui_sticky-columns-first_tc96w_1xqaf_757:not(#\9),
759
- .awsui_sticky-columns-last_tc96w_1xqaf_758:not(#\9) {
723
+ .awsui_wrap-lines_tc96w_356y9_722:not(#\9),
724
+ .awsui_striped-rows_tc96w_356y9_723:not(#\9),
725
+ .awsui_content-density_tc96w_356y9_724:not(#\9),
726
+ .awsui_page-size_tc96w_356y9_725:not(#\9),
727
+ .awsui_page-size-form-field_tc96w_356y9_726:not(#\9),
728
+ .awsui_page-size-radio-group_tc96w_356y9_727:not(#\9),
729
+ .awsui_sticky-columns_tc96w_356y9_728:not(#\9),
730
+ .awsui_sticky-columns-form-field_tc96w_356y9_729:not(#\9),
731
+ .awsui_sticky-columns-radio-group_tc96w_356y9_730:not(#\9),
732
+ .awsui_sticky-columns-first_tc96w_356y9_731:not(#\9),
733
+ .awsui_sticky-columns-last_tc96w_356y9_732:not(#\9) {
760
734
  /* used in test-utils */
761
735
  }
@@ -2,43 +2,41 @@
2
2
  // es-module interop with Babel and Typescript
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  module.exports.default = {
5
- "visible-content": "awsui_visible-content_tc96w_1xqaf_289",
6
- "visible-content-toggle": "awsui_visible-content-toggle_tc96w_1xqaf_290",
7
- "visible-content-groups": "awsui_visible-content-groups_tc96w_1xqaf_291",
8
- "visible-content-group": "awsui_visible-content-group_tc96w_1xqaf_291",
9
- "visible-content-title": "awsui_visible-content-title_tc96w_1xqaf_296",
10
- "visible-content-group-label": "awsui_visible-content-group-label_tc96w_1xqaf_306",
11
- "visible-content-option": "awsui_visible-content-option_tc96w_1xqaf_312",
12
- "visible-content-option-label": "awsui_visible-content-option-label_tc96w_1xqaf_325",
13
- "content-display-option-toggle": "awsui_content-display-option-toggle_tc96w_1xqaf_620",
14
- "content-display-option-content": "awsui_content-display-option-content_tc96w_1xqaf_624",
15
- "content-display-option": "awsui_content-display-option_tc96w_1xqaf_620",
16
- "placeholder": "awsui_placeholder_tc96w_1xqaf_671",
17
- "sorting": "awsui_sorting_tc96w_1xqaf_671",
18
- "content-display-option-label": "awsui_content-display-option-label_tc96w_1xqaf_698",
19
- "content-display": "awsui_content-display_tc96w_1xqaf_620",
20
- "content-display-text-filter": "awsui_content-display-text-filter_tc96w_1xqaf_706",
21
- "content-display-no-match": "awsui_content-display-no-match_tc96w_1xqaf_707",
22
- "content-display-title": "awsui_content-display-title_tc96w_1xqaf_711",
23
- "content-display-description": "awsui_content-display-description_tc96w_1xqaf_720",
24
- "content-display-option-list": "awsui_content-display-option-list_tc96w_1xqaf_728",
25
- "root": "awsui_root_tc96w_1xqaf_735",
26
- "modal-root": "awsui_modal-root_tc96w_1xqaf_736",
27
- "trigger-button": "awsui_trigger-button_tc96w_1xqaf_737",
28
- "cancel-button": "awsui_cancel-button_tc96w_1xqaf_738",
29
- "confirm-button": "awsui_confirm-button_tc96w_1xqaf_739",
30
- "custom": "awsui_custom_tc96w_1xqaf_740",
31
- "second-column-small": "awsui_second-column-small_tc96w_1xqaf_744",
32
- "wrap-lines": "awsui_wrap-lines_tc96w_1xqaf_748",
33
- "striped-rows": "awsui_striped-rows_tc96w_1xqaf_749",
34
- "content-density": "awsui_content-density_tc96w_1xqaf_750",
35
- "page-size": "awsui_page-size_tc96w_1xqaf_751",
36
- "page-size-form-field": "awsui_page-size-form-field_tc96w_1xqaf_752",
37
- "page-size-radio-group": "awsui_page-size-radio-group_tc96w_1xqaf_753",
38
- "sticky-columns": "awsui_sticky-columns_tc96w_1xqaf_754",
39
- "sticky-columns-form-field": "awsui_sticky-columns-form-field_tc96w_1xqaf_755",
40
- "sticky-columns-radio-group": "awsui_sticky-columns-radio-group_tc96w_1xqaf_756",
41
- "sticky-columns-first": "awsui_sticky-columns-first_tc96w_1xqaf_757",
42
- "sticky-columns-last": "awsui_sticky-columns-last_tc96w_1xqaf_758"
5
+ "visible-content": "awsui_visible-content_tc96w_356y9_289",
6
+ "visible-content-toggle": "awsui_visible-content-toggle_tc96w_356y9_290",
7
+ "visible-content-groups": "awsui_visible-content-groups_tc96w_356y9_291",
8
+ "visible-content-group": "awsui_visible-content-group_tc96w_356y9_291",
9
+ "visible-content-title": "awsui_visible-content-title_tc96w_356y9_296",
10
+ "visible-content-group-label": "awsui_visible-content-group-label_tc96w_356y9_306",
11
+ "visible-content-option": "awsui_visible-content-option_tc96w_356y9_312",
12
+ "visible-content-option-label": "awsui_visible-content-option-label_tc96w_356y9_325",
13
+ "content-display-option-toggle": "awsui_content-display-option-toggle_tc96w_356y9_620",
14
+ "content-display-option-content": "awsui_content-display-option-content_tc96w_356y9_624",
15
+ "content-display-option": "awsui_content-display-option_tc96w_356y9_620",
16
+ "content-display-option-label": "awsui_content-display-option-label_tc96w_356y9_672",
17
+ "content-display": "awsui_content-display_tc96w_356y9_620",
18
+ "content-display-text-filter": "awsui_content-display-text-filter_tc96w_356y9_680",
19
+ "content-display-no-match": "awsui_content-display-no-match_tc96w_356y9_681",
20
+ "content-display-title": "awsui_content-display-title_tc96w_356y9_685",
21
+ "content-display-description": "awsui_content-display-description_tc96w_356y9_694",
22
+ "content-display-option-list": "awsui_content-display-option-list_tc96w_356y9_702",
23
+ "root": "awsui_root_tc96w_356y9_709",
24
+ "modal-root": "awsui_modal-root_tc96w_356y9_710",
25
+ "trigger-button": "awsui_trigger-button_tc96w_356y9_711",
26
+ "cancel-button": "awsui_cancel-button_tc96w_356y9_712",
27
+ "confirm-button": "awsui_confirm-button_tc96w_356y9_713",
28
+ "custom": "awsui_custom_tc96w_356y9_714",
29
+ "second-column-small": "awsui_second-column-small_tc96w_356y9_718",
30
+ "wrap-lines": "awsui_wrap-lines_tc96w_356y9_722",
31
+ "striped-rows": "awsui_striped-rows_tc96w_356y9_723",
32
+ "content-density": "awsui_content-density_tc96w_356y9_724",
33
+ "page-size": "awsui_page-size_tc96w_356y9_725",
34
+ "page-size-form-field": "awsui_page-size-form-field_tc96w_356y9_726",
35
+ "page-size-radio-group": "awsui_page-size-radio-group_tc96w_356y9_727",
36
+ "sticky-columns": "awsui_sticky-columns_tc96w_356y9_728",
37
+ "sticky-columns-form-field": "awsui_sticky-columns-form-field_tc96w_356y9_729",
38
+ "sticky-columns-radio-group": "awsui_sticky-columns-radio-group_tc96w_356y9_730",
39
+ "sticky-columns-first": "awsui_sticky-columns-first_tc96w_356y9_731",
40
+ "sticky-columns-last": "awsui_sticky-columns-last_tc96w_356y9_732"
43
41
  };
44
42
 
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { DndAreaProps } from './interfaces';
3
+ export declare function DndArea<Data>({ items, renderItem, onItemsChange, disableReorder, i18nStrings, borderRadiusVariant, }: DndAreaProps<Data>): JSX.Element;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/internal/components/dnd-area/index.tsx"],"names":[],"mappings":";AAWA,OAAO,EAAe,YAAY,EAAmB,MAAM,cAAc,CAAC;AAM1E,wBAAgB,OAAO,CAAC,IAAI,EAAE,EAC5B,KAAK,EACL,UAAU,EACV,aAAa,EACb,cAAc,EACd,WAAW,EACX,mBAA4B,GAC7B,EAAE,YAAY,CAAC,IAAI,CAAC,eA2EpB"}
@@ -4,12 +4,14 @@ import React, { useEffect, useRef } from 'react';
4
4
  import { DndContext, DragOverlay } from '@dnd-kit/core';
5
5
  import { arrayMove, SortableContext, useSortable, verticalListSortingStrategy } from '@dnd-kit/sortable';
6
6
  import { CSS } from '@dnd-kit/utilities';
7
+ import clsx from 'clsx';
7
8
  import { joinStrings } from '../../utils/strings';
8
9
  import Portal from '../portal';
9
10
  import useDragAndDropReorder from './use-drag-and-drop-reorder';
10
11
  import useLiveAnnouncements from './use-live-announcements';
11
12
  import styles from './styles.css.js';
12
- export function DndContainer({ items, renderItem, onItemsChange, disableReorder, i18nStrings, dragOverlayClassName = styles['drag-overlay'], }) {
13
+ export function DndArea({ items, renderItem, onItemsChange, disableReorder, i18nStrings, borderRadiusVariant = 'item', }) {
14
+ var _a;
13
15
  const { activeItemId, setActiveItemId, collisionDetection, handleKeyDown, sensors } = useDragAndDropReorder({
14
16
  items,
15
17
  });
@@ -33,19 +35,18 @@ export function DndContainer({ items, renderItem, onItemsChange, disableReorder,
33
35
  onItemsChange(arrayMove([...items], oldIndex, newIndex));
34
36
  }
35
37
  }, onDragCancel: () => setActiveItemId(null) },
36
- React.createElement(SortableContext, { disabled: disableReorder, items: items.map(item => item.id), strategy: verticalListSortingStrategy }, items.map(item => (React.createElement(DraggableItem, { key: item.id, item: item, renderItem: renderItem, onKeyDown: handleKeyDown, dragHandleAriaLabel: i18nStrings.dragHandleAriaLabel })))),
38
+ React.createElement(SortableContext, { disabled: disableReorder, items: items.map(item => item.id), strategy: verticalListSortingStrategy }, items.map(item => (React.createElement(DraggableItem, { key: item.id, item: item, renderItem: renderItem, onKeyDown: handleKeyDown, dragHandleAriaLabel: i18nStrings.dragHandleAriaLabel, borderRadiusVariant: borderRadiusVariant })))),
37
39
  React.createElement(Portal, { container: portalContainer },
38
- React.createElement(DragOverlay, { className: dragOverlayClassName, dropAnimation: null, style: { zIndex: 5000 } }, activeItem &&
40
+ React.createElement(DragOverlay, { className: clsx(styles['drag-overlay'], styles[`drag-overlay-${borderRadiusVariant}`]), dropAnimation: null, style: { zIndex: 5000 } }, activeItem &&
39
41
  renderItem({
40
42
  item: activeItem,
41
43
  style: {},
44
+ className: styles.active,
42
45
  isDragging: true,
43
46
  isSorting: false,
44
47
  isActive: true,
45
- dragHandleAttributes: {
46
- ['aria-label']: joinStrings(i18nStrings.dragHandleAriaLabel, activeItem.label),
47
- },
48
- dragHandleListeners: {
48
+ dragHandleProps: {
49
+ ariaLabel: (_a = joinStrings(i18nStrings.dragHandleAriaLabel, activeItem.label)) !== null && _a !== void 0 ? _a : '',
49
50
  onKeyDown: handleKeyDown,
50
51
  },
51
52
  })))));
@@ -65,7 +66,8 @@ function usePortalContainer() {
65
66
  }, []);
66
67
  return portalContainerRef.current;
67
68
  }
68
- function DraggableItem({ item, dragHandleAriaLabel, onKeyDown, renderItem, }) {
69
+ function DraggableItem({ item, dragHandleAriaLabel, onKeyDown, renderItem, borderRadiusVariant, }) {
70
+ var _a;
69
71
  const { isDragging, isSorting, listeners, setNodeRef, transform, attributes } = useSortable({ id: item.id });
70
72
  const style = { transform: CSS.Translate.toString(transform) };
71
73
  const dragHandleListeners = attributes['aria-disabled']
@@ -78,20 +80,16 @@ function DraggableItem({ item, dragHandleAriaLabel, onKeyDown, renderItem, }) {
78
80
  listeners.onKeyDown(event);
79
81
  }
80
82
  } });
81
- const dragHandleAttributes = {
82
- ['aria-label']: joinStrings(dragHandleAriaLabel, item.label),
83
- ['aria-describedby']: attributes['aria-describedby'],
84
- ['aria-disabled']: attributes['aria-disabled'],
85
- };
83
+ const className = clsx(isDragging && clsx(styles.placeholder, styles[`placeholder-${borderRadiusVariant}`]), isSorting && styles.sorting);
86
84
  return (React.createElement(React.Fragment, null, renderItem({
87
85
  item,
88
86
  ref: setNodeRef,
89
87
  style,
88
+ className,
90
89
  isDragging,
91
90
  isSorting,
92
91
  isActive: false,
93
- dragHandleListeners,
94
- dragHandleAttributes,
92
+ dragHandleProps: Object.assign(Object.assign({}, dragHandleListeners), { ariaLabel: (_a = joinStrings(dragHandleAriaLabel, item.label)) !== null && _a !== void 0 ? _a : '', ariaDescribedby: attributes['aria-describedby'], disabled: attributes['aria-disabled'] }),
95
93
  })));
96
94
  }
97
95
  //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/internal/components/dnd-area/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\n\nimport React, { useEffect, useRef } from 'react';\nimport { DndContext, DragOverlay } from '@dnd-kit/core';\nimport { arrayMove, SortableContext, useSortable, verticalListSortingStrategy } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport clsx from 'clsx';\n\nimport { joinStrings } from '../../utils/strings';\nimport Portal from '../portal';\nimport { DndAreaItem, DndAreaProps, RenderItemProps } from './interfaces';\nimport useDragAndDropReorder from './use-drag-and-drop-reorder';\nimport useLiveAnnouncements from './use-live-announcements';\n\nimport styles from './styles.css.js';\n\nexport function DndArea<Data>({\n items,\n renderItem,\n onItemsChange,\n disableReorder,\n i18nStrings,\n borderRadiusVariant = 'item',\n}: DndAreaProps<Data>) {\n const { activeItemId, setActiveItemId, collisionDetection, handleKeyDown, sensors } = useDragAndDropReorder({\n items,\n });\n const activeItem = activeItemId ? items.find(item => item.id === activeItemId) : null;\n const isDragging = activeItemId !== null;\n const announcements = useLiveAnnouncements({ items, isDragging, ...i18nStrings });\n const portalContainer = usePortalContainer();\n return (\n <DndContext\n sensors={sensors}\n collisionDetection={collisionDetection}\n accessibility={{\n announcements,\n restoreFocus: false,\n screenReaderInstructions: i18nStrings.dragHandleAriaDescription\n ? { draggable: i18nStrings.dragHandleAriaDescription }\n : undefined,\n container: portalContainer,\n }}\n onDragStart={({ active }) => setActiveItemId(active.id)}\n onDragEnd={event => {\n setActiveItemId(null);\n const { active, over } = event;\n\n if (over && active.id !== over.id) {\n const oldIndex = items.findIndex(item => item.id === active.id);\n const newIndex = items.findIndex(item => item.id === over.id);\n onItemsChange(arrayMove([...items], oldIndex, newIndex));\n }\n }}\n onDragCancel={() => setActiveItemId(null)}\n >\n <SortableContext\n disabled={disableReorder}\n items={items.map(item => item.id)}\n strategy={verticalListSortingStrategy}\n >\n {items.map(item => (\n <DraggableItem\n key={item.id}\n item={item}\n renderItem={renderItem}\n onKeyDown={handleKeyDown}\n dragHandleAriaLabel={i18nStrings.dragHandleAriaLabel}\n borderRadiusVariant={borderRadiusVariant}\n />\n ))}\n </SortableContext>\n\n <Portal container={portalContainer}>\n {/* Make sure that the drag overlay is above the modal by assigning the z-index as inline style\n so that it prevails over dnd-kit's inline z-index of 999 */}\n <DragOverlay\n className={clsx(styles['drag-overlay'], styles[`drag-overlay-${borderRadiusVariant}`])}\n dropAnimation={null}\n style={{ zIndex: 5000 }}\n >\n {activeItem &&\n renderItem({\n item: activeItem,\n style: {},\n className: styles.active,\n isDragging: true,\n isSorting: false,\n isActive: true,\n dragHandleProps: {\n ariaLabel: joinStrings(i18nStrings.dragHandleAriaLabel, activeItem.label) ?? '',\n onKeyDown: handleKeyDown,\n },\n })}\n </DragOverlay>\n </Portal>\n </DndContext>\n );\n}\n\nfunction usePortalContainer() {\n const portalContainerRef = useRef(document.createElement('div'));\n useEffect(() => {\n const container = portalContainerRef.current;\n if (!container.isConnected) {\n document.body.appendChild(container);\n }\n return () => {\n if (container.isConnected) {\n document.body.removeChild(container);\n }\n };\n }, []);\n return portalContainerRef.current;\n}\n\nfunction DraggableItem<Data>({\n item,\n dragHandleAriaLabel,\n onKeyDown,\n renderItem,\n borderRadiusVariant,\n}: {\n item: DndAreaItem<Data>;\n dragHandleAriaLabel?: string;\n onKeyDown: (event: React.KeyboardEvent) => void;\n renderItem: (props: RenderItemProps<Data>) => React.ReactNode;\n borderRadiusVariant: 'item' | 'container';\n}) {\n const { isDragging, isSorting, listeners, setNodeRef, transform, attributes } = useSortable({ id: item.id });\n const style = { transform: CSS.Translate.toString(transform) };\n const dragHandleListeners = attributes['aria-disabled']\n ? {}\n : {\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 const className = clsx(\n isDragging && clsx(styles.placeholder, styles[`placeholder-${borderRadiusVariant}`]),\n isSorting && styles.sorting\n );\n return (\n <>\n {renderItem({\n item,\n ref: setNodeRef,\n style,\n className,\n isDragging,\n isSorting,\n isActive: false,\n dragHandleProps: {\n ...dragHandleListeners,\n ariaLabel: joinStrings(dragHandleAriaLabel, item.label) ?? '',\n ariaDescribedby: attributes['aria-describedby'],\n disabled: attributes['aria-disabled'],\n },\n })}\n </>\n );\n}\n"]}
@@ -1,35 +1,34 @@
1
1
  /// <reference types="react" />
2
- export interface DndContainerProps<Data> {
3
- items: readonly DndContainerItem<Data>[];
2
+ export interface DndAreaProps<Data> {
3
+ items: readonly DndAreaItem<Data>[];
4
4
  renderItem: (props: RenderItemProps<Data>) => React.ReactNode;
5
- onItemsChange: (sortedOptions: readonly DndContainerItem<Data>[]) => void;
6
- i18nStrings: DndContainerI18nStrings;
5
+ onItemsChange: (sortedOptions: readonly DndAreaItem<Data>[]) => void;
6
+ i18nStrings: DndAreaI18nStrings;
7
7
  disableReorder?: boolean;
8
- dragOverlayClassName?: string;
8
+ borderRadiusVariant?: 'item' | 'container';
9
9
  }
10
- export interface DndContainerItem<Data> {
10
+ export interface DndAreaItem<Data> {
11
11
  id: string;
12
12
  label: string;
13
13
  data: Data;
14
14
  }
15
15
  export interface RenderItemProps<Data> {
16
16
  ref?: React.RefCallback<HTMLElement>;
17
- item: DndContainerItem<Data>;
17
+ item: DndAreaItem<Data>;
18
18
  style: React.CSSProperties;
19
+ className?: string;
19
20
  isDragging: boolean;
20
21
  isSorting: boolean;
21
22
  isActive: boolean;
22
- dragHandleAttributes: {
23
- 'aria-label'?: string;
24
- 'aria-describedby'?: string;
25
- 'aria-disabled'?: boolean;
26
- };
27
- dragHandleListeners?: {
23
+ dragHandleProps: {
24
+ ariaLabel: string;
25
+ ariaDescribedby?: string;
26
+ disabled?: boolean;
28
27
  onPointerDown?: React.PointerEventHandler;
29
28
  onKeyDown?: React.KeyboardEventHandler;
30
29
  };
31
30
  }
32
- export interface DndContainerI18nStrings {
31
+ export interface DndAreaI18nStrings {
33
32
  liveAnnouncementDndStarted?: (position: number, total: number) => string;
34
33
  liveAnnouncementDndItemReordered?: (initialPosition: number, currentPosition: number, total: number) => string;
35
34
  liveAnnouncementDndItemCommitted?: (initialPosition: number, finalPosition: number, total: number) => string;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../../../src/internal/components/dnd-area/interfaces.ts"],"names":[],"mappings":";AAGA,MAAM,WAAW,YAAY,CAAC,IAAI;IAChC,KAAK,EAAE,SAAS,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;IACpC,UAAU,EAAE,CAAC,KAAK,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,SAAS,CAAC;IAC9D,aAAa,EAAE,CAAC,aAAa,EAAE,SAAS,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC;IACrE,WAAW,EAAE,kBAAkB,CAAC;IAChC,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,mBAAmB,CAAC,EAAE,MAAM,GAAG,WAAW,CAAC;CAC5C;AAED,MAAM,WAAW,WAAW,CAAC,IAAI;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,IAAI,CAAC;CACZ;AAED,MAAM,WAAW,eAAe,CAAC,IAAI;IACnC,GAAG,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACrC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;IACxB,KAAK,EAAE,KAAK,CAAC,aAAa,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE;QACf,SAAS,EAAE,MAAM,CAAC;QAClB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,aAAa,CAAC,EAAE,KAAK,CAAC,mBAAmB,CAAC;QAC1C,SAAS,CAAC,EAAE,KAAK,CAAC,oBAAoB,CAAC;KACxC,CAAC;CACH;AAED,MAAM,WAAW,kBAAkB;IACjC,0BAA0B,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACzE,gCAAgC,CAAC,EAAE,CAAC,eAAe,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IAC/G,gCAAgC,CAAC,EAAE,CAAC,eAAe,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IAC7G,4BAA4B,CAAC,EAAE,MAAM,CAAC;IACtC,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,yBAAyB,CAAC,EAAE,MAAM,CAAC;CACpC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../../../src/internal/components/dnd-area/interfaces.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n\nexport interface DndAreaProps<Data> {\n items: readonly DndAreaItem<Data>[];\n renderItem: (props: RenderItemProps<Data>) => React.ReactNode;\n onItemsChange: (sortedOptions: readonly DndAreaItem<Data>[]) => void;\n i18nStrings: DndAreaI18nStrings;\n disableReorder?: boolean;\n borderRadiusVariant?: 'item' | 'container';\n}\n\nexport interface DndAreaItem<Data> {\n id: string;\n label: string;\n data: Data;\n}\n\nexport interface RenderItemProps<Data> {\n ref?: React.RefCallback<HTMLElement>;\n item: DndAreaItem<Data>;\n style: React.CSSProperties;\n className?: string;\n isDragging: boolean;\n isSorting: boolean;\n isActive: boolean;\n dragHandleProps: {\n ariaLabel: string;\n ariaDescribedby?: string;\n disabled?: boolean;\n onPointerDown?: React.PointerEventHandler;\n onKeyDown?: React.KeyboardEventHandler;\n };\n}\n\nexport interface DndAreaI18nStrings {\n liveAnnouncementDndStarted?: (position: number, total: number) => string;\n liveAnnouncementDndItemReordered?: (initialPosition: number, currentPosition: number, total: number) => string;\n liveAnnouncementDndItemCommitted?: (initialPosition: number, finalPosition: number, total: number) => string;\n liveAnnouncementDndDiscarded?: string;\n dragHandleAriaLabel?: string;\n dragHandleAriaDescription?: string;\n}\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../../../../../../src/internal/components/dnd-area/keyboard-sensor/defaults.ts"],"names":[],"mappings":"AAEA,OAAO,EAAgB,aAAa,EAAE,MAAM,eAAe,CAAC;AAE5D,eAAO,MAAM,oBAAoB,EAAE,aAIlC,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults.js","sourceRoot":"","sources":["../../../../../../src/internal/components/dnd-area/keyboard-sensor/defaults.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,OAAO,EAAE,YAAY,EAAiB,MAAM,eAAe,CAAC;AAE5D,MAAM,CAAC,MAAM,oBAAoB,GAAkB;IACjD,KAAK,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC;IAC/C,MAAM,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC;IAC1B,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC;CAC9C,CAAC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { KeyboardCode, KeyboardCodes } from '@dnd-kit/core';\n\nexport const defaultKeyboardCodes: KeyboardCodes = {\n start: [KeyboardCode.Space, KeyboardCode.Enter],\n cancel: [KeyboardCode.Esc],\n end: [KeyboardCode.Space, KeyboardCode.Enter],\n};\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/internal/components/dnd-area/keyboard-sensor/index.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEhE,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAyB3E,qBAAa,cAAe,YAAW,cAAc;IAMvC,OAAO,CAAC,KAAK;IALlB,iBAAiB,UAAS;IACjC,OAAO,CAAC,oBAAoB,CAA0B;IACtD,OAAO,CAAC,SAAS,CAAY;IAC7B,OAAO,CAAC,eAAe,CAAY;gBAEf,KAAK,EAAE,mBAAmB;IAc9C,OAAO,CAAC,MAAM;IAYd,OAAO,CAAC,WAAW;IAWnB,OAAO,CAAC,aAAa;IA8CrB,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,MAAM;IAQd,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,qBAAqB,CAAC,CAuBlD;CACH"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/internal/components/dnd-area/keyboard-sensor/index.ts"],"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 type { Activators, SensorInstance } from '@dnd-kit/core';\nimport { defaultCoordinates } from '@dnd-kit/core';\nimport { KeyboardSensorOptions, KeyboardSensorProps } from '@dnd-kit/core';\nimport {\n Coordinates,\n getOwnerDocument,\n getWindow,\n isKeyboardEvent,\n subtract as getCoordinatesDelta,\n} from '@dnd-kit/utilities';\n\nimport { scrollElementIntoView } from '../../../utils/scrollable-containers';\nimport { defaultKeyboardCodes } from './defaults';\nimport { EventName } from './utilities/events';\nimport { Listeners } from './utilities/listeners';\nimport { applyScroll } from './utilities/scroll';\n\n// Slightly modified version of @dnd-kit's KeyboardSensor:\n// https://github.com/clauderic/dnd-kit/blob/master/packages/core/src/sensors/keyboard/KeyboardSensor.ts\n\n// The only difference is that here, reordering is deactivated on blur, as in\n// this PR: https://github.com/clauderic/dnd-kit/pull/1087.\n// If it is merged, then @dnd-kit's KeyboardSensor can be used instead\n// and all files under this directory (`keyboard-sensor`) can be removed.\n\n// Changes from mainstream are marked below as \"Customization\"\n\nexport class KeyboardSensor implements SensorInstance {\n public autoScrollEnabled = false;\n private referenceCoordinates: Coordinates | undefined;\n private listeners: Listeners;\n private windowListeners: Listeners;\n\n constructor(private props: KeyboardSensorProps) {\n const {\n event: { target },\n } = props;\n\n this.props = props;\n this.listeners = new Listeners(getOwnerDocument(target));\n this.windowListeners = new Listeners(getWindow(target));\n this.handleKeyDown = this.handleKeyDown.bind(this);\n this.handleCancel = this.handleCancel.bind(this);\n\n this.attach();\n }\n\n private attach() {\n this.handleStart();\n\n this.windowListeners.add(EventName.Resize, this.handleCancel);\n this.windowListeners.add(EventName.VisibilityChange, this.handleCancel);\n\n // Customization: deactivate reordering on blur event\n this.props.event.target?.addEventListener(EventName.Blur, this.handleCancel);\n\n setTimeout(() => this.listeners.add(EventName.Keydown, this.handleKeyDown));\n }\n\n private handleStart() {\n const { activeNode, onStart } = this.props;\n const node = activeNode.node.current;\n\n if (node) {\n scrollElementIntoView(node);\n }\n\n onStart(defaultCoordinates);\n }\n\n private handleKeyDown(event: Event) {\n if (isKeyboardEvent(event)) {\n const { active, context, options } = this.props;\n const { keyboardCodes = defaultKeyboardCodes, coordinateGetter } = options;\n const { code } = event;\n\n if (keyboardCodes.end.indexOf(code) !== -1) {\n this.handleEnd(event);\n return;\n }\n\n if (keyboardCodes.cancel.indexOf(code) !== -1) {\n this.handleCancel(event);\n return;\n }\n\n const { collisionRect } = context.current;\n const currentCoordinates = collisionRect ? { x: collisionRect.left, y: collisionRect.top } : defaultCoordinates;\n\n if (!this.referenceCoordinates) {\n this.referenceCoordinates = currentCoordinates;\n }\n\n if (!coordinateGetter) {\n return;\n }\n\n const newCoordinates = coordinateGetter(event, {\n active,\n context: context.current,\n currentCoordinates,\n });\n\n if (newCoordinates) {\n const { scrollableAncestors } = context.current;\n const direction = event.code;\n\n const scrolled = applyScroll({ currentCoordinates, direction, newCoordinates, scrollableAncestors });\n\n if (!scrolled) {\n this.handleMove(event, getCoordinatesDelta(newCoordinates, this.referenceCoordinates));\n }\n }\n }\n }\n\n private handleMove(event: Event, coordinates: Coordinates) {\n const { onMove } = this.props;\n\n event.preventDefault();\n onMove(coordinates);\n }\n\n private handleEnd(event: Event) {\n const { onEnd } = this.props;\n\n event.preventDefault();\n this.detach();\n onEnd();\n }\n\n private handleCancel(event: Event) {\n const { onCancel } = this.props;\n\n // Customization: do not prevent browser from managing native focus\n if (event.type !== EventName.Blur) {\n event.preventDefault();\n }\n this.detach();\n onCancel();\n }\n\n private detach() {\n // Customization: clean up listener for blur event\n this.props.event.target?.removeEventListener(EventName.Blur, this.handleCancel);\n\n this.listeners.removeAll();\n this.windowListeners.removeAll();\n }\n\n static activators: Activators<KeyboardSensorOptions> = [\n {\n eventName: 'onKeyDown' as const,\n handler: (event: React.KeyboardEvent, { keyboardCodes = defaultKeyboardCodes, onActivation }, { active }) => {\n const { code } = event.nativeEvent;\n\n if (keyboardCodes.start.indexOf(code) !== -1) {\n const activator = active.activatorNode.current;\n\n if (activator && event.target !== activator) {\n return false;\n }\n\n event.preventDefault();\n\n onActivation?.({ event: event.nativeEvent });\n\n return true;\n }\n\n return false;\n },\n },\n ];\n}\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/events.ts"],"names":[],"mappings":"AAEA,oBAAY,SAAS;IACnB,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,gBAAgB,qBAAqB;CACtC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/events.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,MAAM,CAAN,IAAY,SAKX;AALD,WAAY,SAAS;IACnB,0BAAa,CAAA;IACb,gCAAmB,CAAA;IACnB,8BAAiB,CAAA;IACjB,kDAAqC,CAAA;AACvC,CAAC,EALW,SAAS,KAAT,SAAS,QAKpB","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nexport enum EventName {\n Blur = 'blur',\n Keydown = 'keydown',\n Resize = 'resize',\n VisibilityChange = 'visibilitychange',\n}\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listeners.d.ts","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/listeners.ts"],"names":[],"mappings":"AAEA,qBAAa,SAAS;IAGR,OAAO,CAAC,MAAM;IAF1B,OAAO,CAAC,SAAS,CAAqG;gBAElG,MAAM,EAAE,WAAW,GAAG,IAAI;IAEvC,GAAG,CAAC,CAAC,SAAS,KAAK,EACxB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,EAC3B,OAAO,CAAC,EAAE,uBAAuB,GAAG,OAAO;IAMtC,SAAS,aAEd;CACH"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listeners.js","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/listeners.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,MAAM,OAAO,SAAS;IAGpB,YAAoB,MAA0B;QAA1B,WAAM,GAAN,MAAM,CAAoB;QAFtC,cAAS,GAAkG,EAAE,CAAC;QAa/G,cAAS,GAAG,GAAG,EAAE;YACtB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,WAAC,OAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAC,CAAA,EAAA,CAAC,CAAC;QACpF,CAAC,CAAC;IAb+C,CAAC;IAE3C,GAAG,CACR,SAAiB,EACjB,OAA2B,EAC3B,OAA2C;;QAE3C,MAAA,IAAI,CAAC,MAAM,0CAAE,gBAAgB,CAAC,SAAS,EAAE,OAAwB,EAAE,OAAO,CAAC,CAAC;QAC5E,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,OAAwB,EAAE,OAAO,CAAC,CAAC,CAAC;IACtE,CAAC;CAKF","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nexport class Listeners {\n private listeners: [string, EventListenerOrEventListenerObject, AddEventListenerOptions | boolean | undefined][] = [];\n\n constructor(private target: EventTarget | null) {}\n\n public add<T extends Event>(\n eventName: string,\n handler: (event: T) => void,\n options?: AddEventListenerOptions | boolean\n ) {\n this.target?.addEventListener(eventName, handler as EventListener, options);\n this.listeners.push([eventName, handler as EventListener, options]);\n }\n\n public removeAll = () => {\n this.listeners.forEach(listener => this.target?.removeEventListener(...listener));\n };\n}\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scroll.d.ts","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/scroll.ts"],"names":[],"mappings":"AAGA,OAAO,EAAa,WAAW,EAAmC,MAAM,oBAAoB,CAAC;AAsE7F,wBAAgB,WAAW,CAAC,EAC1B,kBAAkB,EAClB,SAAS,EACT,cAAc,EACd,mBAAmB,GACpB,EAAE;IACD,kBAAkB,EAAE,WAAW,CAAC;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,WAAW,CAAC;IAC5B,mBAAmB,EAAE,OAAO,EAAE,CAAC;CAChC,WA0CA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scroll.js","sourceRoot":"","sources":["../../../../../../../src/internal/components/dnd-area/keyboard-sensor/utilities/scroll.ts"],"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 { KeyboardCode } from '@dnd-kit/core';\nimport { canUseDOM, Coordinates, subtract as getCoordinatesDelta } from '@dnd-kit/utilities';\n\nfunction isDocumentScrollingElement(element: Element | null) {\n if (!canUseDOM || !element) {\n return false;\n }\n\n return element === document.scrollingElement;\n}\n\nfunction getScrollPosition(scrollingContainer: Element) {\n const minScroll = {\n x: 0,\n y: 0,\n };\n const dimensions = isDocumentScrollingElement(scrollingContainer)\n ? {\n height: window.innerHeight,\n width: window.innerWidth,\n }\n : {\n height: scrollingContainer.clientHeight,\n width: scrollingContainer.clientWidth,\n };\n const maxScroll = {\n x: scrollingContainer.scrollWidth - dimensions.width,\n y: scrollingContainer.scrollHeight - dimensions.height,\n };\n\n const isTop = scrollingContainer.scrollTop <= minScroll.y;\n const isLeft = scrollingContainer.scrollLeft <= minScroll.x;\n const isBottom = scrollingContainer.scrollTop >= maxScroll.y;\n const isRight = scrollingContainer.scrollLeft >= maxScroll.x;\n\n return {\n isTop,\n isLeft,\n isBottom,\n isRight,\n maxScroll,\n minScroll,\n };\n}\n\nfunction getScrollElementRect(element: Element) {\n if (element === document.scrollingElement) {\n const { innerWidth, innerHeight } = window;\n\n return {\n top: 0,\n left: 0,\n right: innerWidth,\n bottom: innerHeight,\n width: innerWidth,\n height: innerHeight,\n };\n }\n\n const { top, left, right, bottom } = element.getBoundingClientRect();\n\n return {\n top,\n left,\n right,\n bottom,\n width: element.clientWidth,\n height: element.clientHeight,\n };\n}\n\nexport function applyScroll({\n currentCoordinates,\n direction,\n newCoordinates,\n scrollableAncestors,\n}: {\n currentCoordinates: Coordinates;\n direction: string;\n newCoordinates: Coordinates;\n scrollableAncestors: Element[];\n}) {\n for (const scrollContainer of scrollableAncestors) {\n const coordinatesDelta = getCoordinatesDelta(newCoordinates, currentCoordinates);\n const { isTop, isBottom, maxScroll, minScroll } = getScrollPosition(scrollContainer);\n const scrollElementRect = getScrollElementRect(scrollContainer);\n\n const clampedCoordinates = {\n y: Math.min(\n direction === KeyboardCode.Down\n ? scrollElementRect.bottom - scrollElementRect.height / 2\n : scrollElementRect.bottom,\n Math.max(\n direction === KeyboardCode.Down\n ? scrollElementRect.top\n : scrollElementRect.top + scrollElementRect.height / 2,\n newCoordinates.y\n )\n ),\n };\n\n const canScrollY = (direction === KeyboardCode.Down && !isBottom) || (direction === KeyboardCode.Up && !isTop);\n\n if (canScrollY && clampedCoordinates.y !== newCoordinates.y) {\n const newScrollCoordinates = scrollContainer.scrollTop + coordinatesDelta.y;\n const canScrollToNewCoordinates =\n (direction === KeyboardCode.Down && newScrollCoordinates <= maxScroll.y) ||\n (direction === KeyboardCode.Up && newScrollCoordinates >= minScroll.y);\n\n if (canScrollToNewCoordinates) {\n // We don't need to update coordinates, the scroll adjustment alone will trigger\n // logic to auto-detect the new container we are over\n scrollContainer.scrollTo({\n top: newScrollCoordinates,\n behavior: 'smooth',\n });\n return true;\n }\n\n break;\n }\n }\n return false;\n}\n"]}