@cloudscape-design/components-themeable 3.0.1163 → 3.0.1165

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 (192) hide show
  1. package/lib/internal/manifest.json +1 -1
  2. package/lib/internal/scss/app-layout/visual-refresh/drawers.scss +1 -0
  3. package/lib/internal/scss/app-layout/visual-refresh-toolbar/drawer/styles.scss +4 -1
  4. package/lib/internal/scss/drawer/styles.scss +25 -0
  5. package/lib/internal/scss/internal/generated/custom-css-properties/index.scss +1 -1
  6. package/lib/internal/scss/table/resizer/styles.scss +7 -6
  7. package/lib/internal/template/anchor-navigation/styles.css.js +8 -8
  8. package/lib/internal/template/anchor-navigation/styles.scoped.css +21 -21
  9. package/lib/internal/template/anchor-navigation/styles.selectors.js +8 -8
  10. package/lib/internal/template/app-layout/runtime-drawer/index.d.ts.map +1 -1
  11. package/lib/internal/template/app-layout/runtime-drawer/index.js +20 -18
  12. package/lib/internal/template/app-layout/runtime-drawer/index.js.map +1 -1
  13. package/lib/internal/template/app-layout/visual-refresh/styles.css.js +86 -86
  14. package/lib/internal/template/app-layout/visual-refresh/styles.scoped.css +164 -163
  15. package/lib/internal/template/app-layout/visual-refresh/styles.selectors.js +86 -86
  16. package/lib/internal/template/app-layout/visual-refresh-toolbar/drawer/styles.css.js +30 -30
  17. package/lib/internal/template/app-layout/visual-refresh-toolbar/drawer/styles.scoped.css +86 -83
  18. package/lib/internal/template/app-layout/visual-refresh-toolbar/drawer/styles.selectors.js +30 -30
  19. package/lib/internal/template/app-layout/visual-refresh-toolbar/skeleton/toolbar-container.d.ts.map +1 -1
  20. package/lib/internal/template/app-layout/visual-refresh-toolbar/skeleton/toolbar-container.js +1 -1
  21. package/lib/internal/template/app-layout/visual-refresh-toolbar/skeleton/toolbar-container.js.map +1 -1
  22. package/lib/internal/template/attribute-editor/styles.css.js +15 -15
  23. package/lib/internal/template/attribute-editor/styles.scoped.css +28 -28
  24. package/lib/internal/template/attribute-editor/styles.selectors.js +15 -15
  25. package/lib/internal/template/autosuggest/interfaces.d.ts +1 -1
  26. package/lib/internal/template/autosuggest/interfaces.js.map +1 -1
  27. package/lib/internal/template/box/styles.css.js +192 -192
  28. package/lib/internal/template/box/styles.scoped.css +242 -242
  29. package/lib/internal/template/box/styles.selectors.js +192 -192
  30. package/lib/internal/template/breadcrumb-group/item/styles.css.js +7 -7
  31. package/lib/internal/template/breadcrumb-group/item/styles.scoped.css +28 -28
  32. package/lib/internal/template/breadcrumb-group/item/styles.selectors.js +7 -7
  33. package/lib/internal/template/button/styles.css.js +22 -22
  34. package/lib/internal/template/button/styles.scoped.css +96 -96
  35. package/lib/internal/template/button/styles.selectors.js +22 -22
  36. package/lib/internal/template/button-dropdown/category-elements/styles.css.js +17 -17
  37. package/lib/internal/template/button-dropdown/category-elements/styles.scoped.css +27 -27
  38. package/lib/internal/template/button-dropdown/category-elements/styles.selectors.js +17 -17
  39. package/lib/internal/template/button-dropdown/item-element/styles.css.js +20 -20
  40. package/lib/internal/template/button-dropdown/item-element/styles.scoped.css +35 -35
  41. package/lib/internal/template/button-dropdown/item-element/styles.selectors.js +20 -20
  42. package/lib/internal/template/button-group/interfaces.d.ts +9 -0
  43. package/lib/internal/template/button-group/interfaces.d.ts.map +1 -1
  44. package/lib/internal/template/button-group/interfaces.js.map +1 -1
  45. package/lib/internal/template/calendar/styles.css.js +21 -21
  46. package/lib/internal/template/calendar/styles.scoped.css +44 -44
  47. package/lib/internal/template/calendar/styles.selectors.js +21 -21
  48. package/lib/internal/template/cards/styles.css.js +39 -39
  49. package/lib/internal/template/cards/styles.scoped.css +51 -51
  50. package/lib/internal/template/cards/styles.selectors.js +39 -39
  51. package/lib/internal/template/code-editor/styles.css.js +33 -33
  52. package/lib/internal/template/code-editor/styles.scoped.css +187 -187
  53. package/lib/internal/template/code-editor/styles.selectors.js +33 -33
  54. package/lib/internal/template/collection-preferences/styles.css.js +36 -36
  55. package/lib/internal/template/collection-preferences/styles.scoped.css +38 -38
  56. package/lib/internal/template/collection-preferences/styles.selectors.js +36 -36
  57. package/lib/internal/template/date-range-picker/calendar/grids/styles.css.js +30 -30
  58. package/lib/internal/template/date-range-picker/calendar/grids/styles.scoped.css +56 -56
  59. package/lib/internal/template/date-range-picker/calendar/grids/styles.selectors.js +30 -30
  60. package/lib/internal/template/drawer/implementation.d.ts +1 -1
  61. package/lib/internal/template/drawer/implementation.d.ts.map +1 -1
  62. package/lib/internal/template/drawer/implementation.js +13 -4
  63. package/lib/internal/template/drawer/implementation.js.map +1 -1
  64. package/lib/internal/template/drawer/interfaces.d.ts +7 -0
  65. package/lib/internal/template/drawer/interfaces.d.ts.map +1 -1
  66. package/lib/internal/template/drawer/interfaces.js.map +1 -1
  67. package/lib/internal/template/drawer/styles.css.js +12 -8
  68. package/lib/internal/template/drawer/styles.scoped.css +35 -13
  69. package/lib/internal/template/drawer/styles.selectors.js +12 -8
  70. package/lib/internal/template/drawer/use-sticky-footer.d.ts +9 -0
  71. package/lib/internal/template/drawer/use-sticky-footer.d.ts.map +1 -0
  72. package/lib/internal/template/drawer/use-sticky-footer.js +35 -0
  73. package/lib/internal/template/drawer/use-sticky-footer.js.map +1 -0
  74. package/lib/internal/template/expandable-section/styles.css.js +35 -35
  75. package/lib/internal/template/expandable-section/styles.scoped.css +68 -68
  76. package/lib/internal/template/expandable-section/styles.selectors.js +35 -35
  77. package/lib/internal/template/help-panel/styles.css.js +6 -6
  78. package/lib/internal/template/help-panel/styles.scoped.css +75 -75
  79. package/lib/internal/template/help-panel/styles.selectors.js +6 -6
  80. package/lib/internal/template/icon/styles.css.js +39 -39
  81. package/lib/internal/template/icon/styles.scoped.css +87 -87
  82. package/lib/internal/template/icon/styles.selectors.js +39 -39
  83. package/lib/internal/template/internal/base-component/styles.scoped.css +504 -437
  84. package/lib/internal/template/internal/components/button-trigger/styles.css.js +13 -13
  85. package/lib/internal/template/internal/components/button-trigger/styles.scoped.css +29 -29
  86. package/lib/internal/template/internal/components/button-trigger/styles.selectors.js +13 -13
  87. package/lib/internal/template/internal/components/cartesian-chart/styles.css.js +28 -28
  88. package/lib/internal/template/internal/components/cartesian-chart/styles.scoped.css +33 -33
  89. package/lib/internal/template/internal/components/cartesian-chart/styles.selectors.js +28 -28
  90. package/lib/internal/template/internal/components/chart-series-details/styles.css.js +19 -19
  91. package/lib/internal/template/internal/components/chart-series-details/styles.scoped.css +33 -33
  92. package/lib/internal/template/internal/components/chart-series-details/styles.selectors.js +19 -19
  93. package/lib/internal/template/internal/components/option/styles.css.js +16 -16
  94. package/lib/internal/template/internal/components/option/styles.scoped.css +29 -29
  95. package/lib/internal/template/internal/components/option/styles.selectors.js +16 -16
  96. package/lib/internal/template/internal/components/selectable-item/styles.css.js +23 -23
  97. package/lib/internal/template/internal/components/selectable-item/styles.scoped.css +54 -54
  98. package/lib/internal/template/internal/components/selectable-item/styles.selectors.js +23 -23
  99. package/lib/internal/template/internal/components/token-list/styles.css.js +10 -10
  100. package/lib/internal/template/internal/components/token-list/styles.scoped.css +25 -25
  101. package/lib/internal/template/internal/components/token-list/styles.selectors.js +10 -10
  102. package/lib/internal/template/internal/environment.js +3 -3
  103. package/lib/internal/template/internal/environment.json +2 -2
  104. package/lib/internal/template/internal/generated/styles/tokens.js +8 -8
  105. package/lib/internal/template/internal/generated/theming/index.cjs +24 -24
  106. package/lib/internal/template/internal/generated/theming/index.js +24 -24
  107. package/lib/internal/template/internal/hooks/use-portal-mode-classes/index.d.ts +3 -1
  108. package/lib/internal/template/internal/hooks/use-portal-mode-classes/index.d.ts.map +1 -1
  109. package/lib/internal/template/internal/hooks/use-portal-mode-classes/index.js +2 -2
  110. package/lib/internal/template/internal/hooks/use-portal-mode-classes/index.js.map +1 -1
  111. package/lib/internal/template/internal/plugins/controllers/drawers.d.ts +2 -2
  112. package/lib/internal/template/internal/plugins/controllers/drawers.d.ts.map +1 -1
  113. package/lib/internal/template/internal/plugins/controllers/drawers.js.map +1 -1
  114. package/lib/internal/template/internal/plugins/widget/interfaces.d.ts +2 -2
  115. package/lib/internal/template/internal/plugins/widget/interfaces.d.ts.map +1 -1
  116. package/lib/internal/template/internal/plugins/widget/interfaces.js.map +1 -1
  117. package/lib/internal/template/key-value-pairs/styles.css.js +8 -8
  118. package/lib/internal/template/key-value-pairs/styles.scoped.css +10 -10
  119. package/lib/internal/template/key-value-pairs/styles.selectors.js +8 -8
  120. package/lib/internal/template/link/styles.css.js +20 -20
  121. package/lib/internal/template/link/styles.scoped.css +92 -92
  122. package/lib/internal/template/link/styles.selectors.js +20 -20
  123. package/lib/internal/template/pagination/styles.css.js +9 -9
  124. package/lib/internal/template/pagination/styles.scoped.css +24 -24
  125. package/lib/internal/template/pagination/styles.selectors.js +9 -9
  126. package/lib/internal/template/pie-chart/styles.css.js +27 -27
  127. package/lib/internal/template/pie-chart/styles.scoped.css +50 -50
  128. package/lib/internal/template/pie-chart/styles.selectors.js +27 -27
  129. package/lib/internal/template/popover/internal.js +1 -1
  130. package/lib/internal/template/popover/internal.js.map +1 -1
  131. package/lib/internal/template/popover/styles.css.js +57 -57
  132. package/lib/internal/template/popover/styles.scoped.css +87 -87
  133. package/lib/internal/template/popover/styles.selectors.js +57 -57
  134. package/lib/internal/template/progress-bar/styles.css.js +19 -19
  135. package/lib/internal/template/progress-bar/styles.scoped.css +31 -31
  136. package/lib/internal/template/progress-bar/styles.selectors.js +19 -19
  137. package/lib/internal/template/property-filter/styles.css.js +39 -39
  138. package/lib/internal/template/property-filter/styles.scoped.css +42 -42
  139. package/lib/internal/template/property-filter/styles.selectors.js +39 -39
  140. package/lib/internal/template/segmented-control/styles.css.js +16 -16
  141. package/lib/internal/template/segmented-control/styles.scoped.css +36 -36
  142. package/lib/internal/template/segmented-control/styles.selectors.js +16 -16
  143. package/lib/internal/template/select/interfaces.d.ts +1 -1
  144. package/lib/internal/template/select/interfaces.js.map +1 -1
  145. package/lib/internal/template/side-navigation/styles.css.js +30 -30
  146. package/lib/internal/template/side-navigation/styles.scoped.css +47 -47
  147. package/lib/internal/template/side-navigation/styles.selectors.js +30 -30
  148. package/lib/internal/template/split-panel/icons/styles.css.js +22 -22
  149. package/lib/internal/template/split-panel/icons/styles.scoped.css +27 -27
  150. package/lib/internal/template/split-panel/icons/styles.selectors.js +22 -22
  151. package/lib/internal/template/table/body-cell/styles.css.js +47 -47
  152. package/lib/internal/template/table/body-cell/styles.scoped.css +377 -377
  153. package/lib/internal/template/table/body-cell/styles.selectors.js +47 -47
  154. package/lib/internal/template/table/header-cell/index.d.ts +1 -1
  155. package/lib/internal/template/table/header-cell/index.d.ts.map +1 -1
  156. package/lib/internal/template/table/header-cell/index.js +1 -1
  157. package/lib/internal/template/table/header-cell/index.js.map +1 -1
  158. package/lib/internal/template/table/header-cell/th-element.d.ts +1 -1
  159. package/lib/internal/template/table/header-cell/th-element.d.ts.map +1 -1
  160. package/lib/internal/template/table/header-cell/th-element.js.map +1 -1
  161. package/lib/internal/template/table/resizer/index.d.ts +2 -1
  162. package/lib/internal/template/table/resizer/index.d.ts.map +1 -1
  163. package/lib/internal/template/table/resizer/index.js +8 -5
  164. package/lib/internal/template/table/resizer/index.js.map +1 -1
  165. package/lib/internal/template/table/resizer/styles.css.js +13 -12
  166. package/lib/internal/template/table/resizer/styles.scoped.css +22 -22
  167. package/lib/internal/template/table/resizer/styles.selectors.js +13 -12
  168. package/lib/internal/template/table/thead.d.ts +1 -1
  169. package/lib/internal/template/table/thead.d.ts.map +1 -1
  170. package/lib/internal/template/table/thead.js.map +1 -1
  171. package/lib/internal/template/tag-editor/styles.css.js +3 -3
  172. package/lib/internal/template/tag-editor/styles.scoped.css +13 -13
  173. package/lib/internal/template/tag-editor/styles.selectors.js +3 -3
  174. package/lib/internal/template/test-utils/dom/drawer/index.d.ts +1 -0
  175. package/lib/internal/template/test-utils/dom/drawer/index.js +3 -0
  176. package/lib/internal/template/test-utils/dom/drawer/index.js.map +1 -1
  177. package/lib/internal/template/test-utils/selectors/drawer/index.d.ts +1 -0
  178. package/lib/internal/template/test-utils/selectors/drawer/index.js +3 -0
  179. package/lib/internal/template/test-utils/selectors/drawer/index.js.map +1 -1
  180. package/lib/internal/template/text-content/styles.css.js +1 -1
  181. package/lib/internal/template/text-content/styles.scoped.css +66 -66
  182. package/lib/internal/template/text-content/styles.selectors.js +1 -1
  183. package/lib/internal/template/token/styles.css.js +14 -14
  184. package/lib/internal/template/token/styles.scoped.css +29 -29
  185. package/lib/internal/template/token/styles.selectors.js +14 -14
  186. package/lib/internal/template/top-navigation/styles.css.js +47 -47
  187. package/lib/internal/template/top-navigation/styles.scoped.css +66 -66
  188. package/lib/internal/template/top-navigation/styles.selectors.js +47 -47
  189. package/lib/internal/template/tutorial-panel/components/tutorial-list/styles.css.js +18 -18
  190. package/lib/internal/template/tutorial-panel/components/tutorial-list/styles.scoped.css +28 -28
  191. package/lib/internal/template/tutorial-panel/components/tutorial-list/styles.selectors.js +18 -18
  192. package/package.json +1 -1
@@ -1,3 +1,3 @@
1
1
  {
2
- "commit": "857f6370d1a3aabe5c7be70005373ebbf1c48a45"
2
+ "commit": "1bfc081cf3a606d870361eaabd7f385af0fd3d98"
3
3
  }
@@ -155,6 +155,7 @@
155
155
  block-size: 100%;
156
156
  display: flex;
157
157
  align-items: center;
158
+ z-index: 850;
158
159
  }
159
160
 
160
161
  &:not(.is-drawer-open) {
@@ -23,7 +23,7 @@
23
23
  $global-drawer-gap-size: 8px;
24
24
  $global-drawer-expanded-mode-motion: #{awsui.$motion-duration-refresh-only-slow} #{awsui.$motion-easing-refresh-only-a};
25
25
  $drawer-resize-handle-size: awsui.$space-m;
26
- $ai-drawer-heider-height: 41px;
26
+ $ai-drawer-heider-height: 42px;
27
27
 
28
28
  .drawer {
29
29
  position: sticky;
@@ -156,6 +156,7 @@ $ai-drawer-heider-height: 41px;
156
156
  }
157
157
 
158
158
  > .drawer-slider {
159
+ z-index: 850;
159
160
  grid-column: 1;
160
161
  grid-row: 1;
161
162
  block-size: 100%;
@@ -184,6 +185,7 @@ $ai-drawer-heider-height: 41px;
184
185
  }
185
186
 
186
187
  > .drawer-slider {
188
+ z-index: 850;
187
189
  grid-column: 2;
188
190
  grid-row: 1;
189
191
  display: flex;
@@ -259,6 +261,7 @@ $ai-drawer-heider-height: 41px;
259
261
  }
260
262
 
261
263
  > .drawer-slider {
264
+ z-index: 850;
262
265
  display: flex;
263
266
  justify-content: center;
264
267
  inline-size: awsui.$space-xs;
@@ -16,6 +16,16 @@
16
16
  .drawer {
17
17
  @include styles.styles-reset;
18
18
  word-wrap: break-word;
19
+
20
+ &.with-footer {
21
+ display: flex;
22
+ flex-direction: column;
23
+ min-block-size: 100%;
24
+
25
+ > .content {
26
+ flex: 1;
27
+ }
28
+ }
19
29
  }
20
30
 
21
31
  .header {
@@ -73,6 +83,21 @@
73
83
  padding-block-end: awsui.$space-panel-content-bottom;
74
84
  }
75
85
 
86
+ .footer {
87
+ background-color: awsui.$color-background-container-content;
88
+ border-block-start: awsui.$border-divider-section-width solid awsui.$color-border-panel-header;
89
+ padding-block: awsui.$space-panel-content-top;
90
+ padding-inline: awsui.$space-panel-side-left awsui.$space-panel-side-right;
91
+
92
+ &.is-sticky {
93
+ position: sticky;
94
+ inset-block-end: 0;
95
+ inset-inline-start: 0;
96
+ inset-inline-end: 0;
97
+ z-index: 810;
98
+ }
99
+ }
100
+
76
101
  .test-utils-drawer-content {
77
102
  /* used in test-utils */
78
103
  }
@@ -1,6 +1,6 @@
1
1
 
2
2
  // Build environment
3
- $awsui-commit-hash: "857f6370";
3
+ $awsui-commit-hash: "1bfc081c";
4
4
  // Manually managed CSS-variables
5
5
  $maxContentWidth: --awsui-max-content-width-d43v8n;
6
6
  $minContentWidth: --awsui-min-content-width-d43v8n;
@@ -20,12 +20,12 @@ $block-gap: calc(2 * #{awsui.$space-xs} + #{awsui.$space-xxxs});
20
20
  .resizer-wrapper {
21
21
  inset-block: 0;
22
22
  position: absolute;
23
- inset-inline-end: calc(-1 * #{$handle-width} / 2);
23
+ inset-inline-end: calc(-1 * $handle-width / 2);
24
24
  inline-size: $handle-width;
25
25
  overflow: hidden;
26
26
  z-index: 10;
27
27
 
28
- th:last-child > &:has(.divider-interactive):not(.is-visual-refresh) {
28
+ th:last-child > &:has(.divider-interactive).is-borderless {
29
29
  inset-inline-end: 0;
30
30
  }
31
31
  }
@@ -58,6 +58,11 @@ th:not(:last-child) > .divider-disabled {
58
58
  inset-inline-end: calc(#{$handle-width} / 2);
59
59
  }
60
60
 
61
+ // stylelint-disable-next-line selector-combinator-disallowed-list
62
+ th:last-child > .resizer-wrapper.visual-refresh.is-borderless .divider-interactive {
63
+ inset-inline-end: 0;
64
+ }
65
+
61
66
  .divider-active {
62
67
  border-inline-start: $active-separator-width solid awsui.$color-border-divider-active;
63
68
  }
@@ -89,10 +94,6 @@ th:not(:last-child) > .divider-disabled {
89
94
  }
90
95
  }
91
96
 
92
- th:last-child > .resizer:not(.is-visual-refresh) {
93
- inset-inline-end: 0;
94
- }
95
-
96
97
  .tracker {
97
98
  display: none;
98
99
  position: absolute;
@@ -1,13 +1,13 @@
1
1
 
2
2
  import './styles.scoped.css';
3
3
  export default {
4
- "root": "awsui_root_swimc_1xp97_189",
5
- "anchor-list": "awsui_anchor-list_swimc_1xp97_221",
6
- "anchor-item": "awsui_anchor-item_swimc_1xp97_244",
7
- "anchor-item--active": "awsui_anchor-item--active_swimc_1xp97_264",
8
- "anchor-link": "awsui_anchor-link_swimc_1xp97_281",
9
- "anchor-link--active": "awsui_anchor-link--active_swimc_1xp97_323",
10
- "anchor-link-text": "awsui_anchor-link-text_swimc_1xp97_330",
11
- "anchor-link-info": "awsui_anchor-link-info_swimc_1xp97_334"
4
+ "root": "awsui_root_swimc_2kzat_189",
5
+ "anchor-list": "awsui_anchor-list_swimc_2kzat_221",
6
+ "anchor-item": "awsui_anchor-item_swimc_2kzat_244",
7
+ "anchor-item--active": "awsui_anchor-item--active_swimc_2kzat_264",
8
+ "anchor-link": "awsui_anchor-link_swimc_2kzat_281",
9
+ "anchor-link--active": "awsui_anchor-link--active_swimc_2kzat_323",
10
+ "anchor-link-text": "awsui_anchor-link-text_swimc_2kzat_330",
11
+ "anchor-link-info": "awsui_anchor-link-info_swimc_2kzat_334"
12
12
  };
13
13
 
@@ -186,7 +186,7 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
186
186
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
187
187
  SPDX-License-Identifier: Apache-2.0
188
188
  */
189
- .awsui_root_swimc_1xp97_189:not(#\9) {
189
+ .awsui_root_swimc_2kzat_189:not(#\9) {
190
190
  border-collapse: separate;
191
191
  border-spacing: 0;
192
192
  box-sizing: border-box;
@@ -218,7 +218,7 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
218
218
  -moz-osx-font-smoothing: auto;
219
219
  }
220
220
 
221
- .awsui_anchor-list_swimc_1xp97_221:not(#\9) {
221
+ .awsui_anchor-list_swimc_2kzat_221:not(#\9) {
222
222
  list-style: none;
223
223
  margin-block: 0;
224
224
  margin-inline: 0;
@@ -227,7 +227,7 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
227
227
  position: relative;
228
228
  text-indent: 0;
229
229
  }
230
- .awsui_anchor-list_swimc_1xp97_221:not(#\9)::before {
230
+ .awsui_anchor-list_swimc_2kzat_221:not(#\9)::before {
231
231
  content: "";
232
232
  background-color: var(--color-border-divider-default-ipvpev, #eaeded);
233
233
  border-start-start-radius: var(--border-radius-tabs-focus-ring-ciyqfm, 0px);
@@ -241,10 +241,10 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
241
241
  inline-size: 2px;
242
242
  }
243
243
 
244
- .awsui_anchor-item_swimc_1xp97_244:not(#\9) {
244
+ .awsui_anchor-item_swimc_2kzat_244:not(#\9) {
245
245
  font-size: var(--font-size-body-m-vv54cm, 14px);
246
246
  line-height: var(--line-height-body-m-bedeoh, 22px);
247
- color: var(--color-text-body-secondary-twh4xm, #545b64);
247
+ color: var(--color-text-body-secondary-gaft81, #545b64);
248
248
  font-weight: 400;
249
249
  margin-block: var(--space-scaled-xxs-jatbiv, 4px);
250
250
  margin-inline: 0;
@@ -252,19 +252,19 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
252
252
  transition-property: all;
253
253
  }
254
254
  @media (prefers-reduced-motion: reduce) {
255
- .awsui_anchor-item_swimc_1xp97_244:not(#\9) {
255
+ .awsui_anchor-item_swimc_2kzat_244:not(#\9) {
256
256
  animation: none;
257
257
  transition: none;
258
258
  }
259
259
  }
260
- .awsui-motion-disabled .awsui_anchor-item_swimc_1xp97_244:not(#\9), .awsui-mode-entering .awsui_anchor-item_swimc_1xp97_244:not(#\9) {
260
+ .awsui-motion-disabled .awsui_anchor-item_swimc_2kzat_244:not(#\9), .awsui-mode-entering .awsui_anchor-item_swimc_2kzat_244:not(#\9) {
261
261
  animation: none;
262
262
  transition: none;
263
263
  }
264
- .awsui_anchor-item--active_swimc_1xp97_264:not(#\9) {
264
+ .awsui_anchor-item--active_swimc_2kzat_264:not(#\9) {
265
265
  position: relative;
266
266
  }
267
- .awsui_anchor-item--active_swimc_1xp97_264:not(#\9)::before {
267
+ .awsui_anchor-item--active_swimc_2kzat_264:not(#\9)::before {
268
268
  content: "";
269
269
  background-color: var(--color-text-accent-rvq171, #0073bb);
270
270
  border-start-start-radius: var(--border-radius-tabs-focus-ring-ciyqfm, 0px);
@@ -278,11 +278,11 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
278
278
  inline-size: 2px;
279
279
  }
280
280
 
281
- .awsui_anchor-link_swimc_1xp97_281:not(#\9) {
281
+ .awsui_anchor-link_swimc_2kzat_281:not(#\9) {
282
282
  font-size: var(--font-size-body-m-vv54cm, 14px);
283
283
  line-height: var(--line-height-body-m-bedeoh, 22px);
284
284
  align-items: baseline;
285
- color: var(--color-text-body-secondary-twh4xm, #545b64);
285
+ color: var(--color-text-body-secondary-gaft81, #545b64);
286
286
  display: flex;
287
287
  flex-direction: row;
288
288
  font-weight: 400;
@@ -291,16 +291,16 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
291
291
  transition-property: all;
292
292
  }
293
293
  @media (prefers-reduced-motion: reduce) {
294
- .awsui_anchor-link_swimc_1xp97_281:not(#\9) {
294
+ .awsui_anchor-link_swimc_2kzat_281:not(#\9) {
295
295
  animation: none;
296
296
  transition: none;
297
297
  }
298
298
  }
299
- .awsui-motion-disabled .awsui_anchor-link_swimc_1xp97_281:not(#\9), .awsui-mode-entering .awsui_anchor-link_swimc_1xp97_281:not(#\9) {
299
+ .awsui-motion-disabled .awsui_anchor-link_swimc_2kzat_281:not(#\9), .awsui-mode-entering .awsui_anchor-link_swimc_2kzat_281:not(#\9) {
300
300
  animation: none;
301
301
  transition: none;
302
302
  }
303
- body[data-awsui-focus-visible=true] .awsui_anchor-link_swimc_1xp97_281:not(#\9):focus {
303
+ body[data-awsui-focus-visible=true] .awsui_anchor-link_swimc_2kzat_281:not(#\9):focus {
304
304
  outline: thin dotted;
305
305
  outline: var(--border-link-focus-ring-outline-c5423y, 5px auto Highlight);
306
306
  outline-offset: 2px;
@@ -311,27 +311,27 @@ body[data-awsui-focus-visible=true] .awsui_anchor-link_swimc_1xp97_281:not(#\9):
311
311
  border-end-end-radius: var(--border-radius-control-default-focus-ring-9xsko1, 2px);
312
312
  box-shadow: 0 0 0 var(--border-link-focus-ring-shadow-spread-woh62o, 0px) var(--color-border-item-focused-r5f6xl, #0073bb);
313
313
  }
314
- .awsui_anchor-link_swimc_1xp97_281:not(#\9):hover {
314
+ .awsui_anchor-link_swimc_2kzat_281:not(#\9):hover {
315
315
  color: var(--color-text-accent-rvq171, #0073bb);
316
316
  }
317
- .awsui_anchor-link_swimc_1xp97_281:not(#\9):focus {
317
+ .awsui_anchor-link_swimc_2kzat_281:not(#\9):focus {
318
318
  outline: none;
319
319
  }
320
- .awsui_anchor-link_swimc_1xp97_281:not(#\9):hover, .awsui_anchor-link_swimc_1xp97_281:not(#\9):focus {
320
+ .awsui_anchor-link_swimc_2kzat_281:not(#\9):hover, .awsui_anchor-link_swimc_2kzat_281:not(#\9):focus {
321
321
  text-decoration: none;
322
322
  }
323
- .awsui_anchor-link--active_swimc_1xp97_323:not(#\9) {
323
+ .awsui_anchor-link--active_swimc_2kzat_323:not(#\9) {
324
324
  font-weight: var(--font-wayfinding-link-active-weight-lhxtkr, 700);
325
325
  -webkit-font-smoothing: var(--font-smoothing-webkit-px4az4, auto);
326
326
  -moz-osx-font-smoothing: var(--font-smoothing-moz-osx-ev3sgf, auto);
327
327
  color: var(--color-text-accent-rvq171, #0073bb);
328
328
  }
329
329
 
330
- .awsui_anchor-link-text_swimc_1xp97_330:not(#\9) {
330
+ .awsui_anchor-link-text_swimc_2kzat_330:not(#\9) {
331
331
  display: block;
332
332
  }
333
333
 
334
- .awsui_anchor-link-info_swimc_1xp97_334:not(#\9) {
334
+ .awsui_anchor-link-info_swimc_2kzat_334:not(#\9) {
335
335
  margin-inline-start: var(--space-xs-kw7k3v, 8px);
336
336
  font-size: var(--font-size-body-s-psgqn2, 12px);
337
337
  line-height: var(--line-height-body-s-otgtsr, 16px);
@@ -340,5 +340,5 @@ body[data-awsui-focus-visible=true] .awsui_anchor-link_swimc_1xp97_281:not(#\9):
340
340
  -moz-osx-font-smoothing: var(--font-smoothing-moz-osx-ev3sgf, auto);
341
341
  font-weight: 700;
342
342
  letter-spacing: 0.005em;
343
- color: var(--color-text-link-default-x6cnv5, #0073bb);
343
+ color: var(--color-text-link-default-z7zuy8, #0073bb);
344
344
  }
@@ -2,13 +2,13 @@
2
2
  // es-module interop with Babel and Typescript
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  module.exports.default = {
5
- "root": "awsui_root_swimc_1xp97_189",
6
- "anchor-list": "awsui_anchor-list_swimc_1xp97_221",
7
- "anchor-item": "awsui_anchor-item_swimc_1xp97_244",
8
- "anchor-item--active": "awsui_anchor-item--active_swimc_1xp97_264",
9
- "anchor-link": "awsui_anchor-link_swimc_1xp97_281",
10
- "anchor-link--active": "awsui_anchor-link--active_swimc_1xp97_323",
11
- "anchor-link-text": "awsui_anchor-link-text_swimc_1xp97_330",
12
- "anchor-link-info": "awsui_anchor-link-info_swimc_1xp97_334"
5
+ "root": "awsui_root_swimc_2kzat_189",
6
+ "anchor-list": "awsui_anchor-list_swimc_2kzat_221",
7
+ "anchor-item": "awsui_anchor-item_swimc_2kzat_244",
8
+ "anchor-item--active": "awsui_anchor-item--active_swimc_2kzat_264",
9
+ "anchor-link": "awsui_anchor-link_swimc_2kzat_281",
10
+ "anchor-link--active": "awsui_anchor-link--active_swimc_2kzat_323",
11
+ "anchor-link-text": "awsui_anchor-link-text_swimc_2kzat_330",
12
+ "anchor-link-info": "awsui_anchor-link-info_swimc_2kzat_334"
13
13
  };
14
14
 
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/app-layout/runtime-drawer/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAwC,MAAM,OAAO,CAAC;AAI7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAA0B,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAC1F,OAAO,EACL,YAAY,IAAI,mBAAmB,EACnC,uBAAuB,EACxB,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,aAAa,IAAI,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AAClG,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAK/C,MAAM,WAAW,aAAc,SAAQ,cAAc,CAAC,MAAM;IAC1D,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,QAAQ,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;CAC9B;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;IAC7B,WAAW,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;IAClC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;CAClC;AAkFD,eAAO,MAAM,wBAAwB,GACnC,eAAe,mBAAmB,KACjC,cAAc,CAAC,MAAM,GAAG;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,aAAa,CAAC,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;CA2BtD,CAAC;AAEF,eAAO,MAAM,0BAA0B,GACrC,eAAe,qBAAqB,KACnC,cAAc,CAAC,MAAM,GAAG;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,aAAa,CAAC,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACrD,uBAAuB,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1C,iBAAiB,CAAC,EAAE,yBAAyB,CAAC;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CAoCxE,CAAC;AAEF,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,KAAK,CAAC,mBAAmB,CAAC,EACxC,aAAa,EAAE,KAAK,CAAC,mBAAmB,CAAC,GACxC,aAAa,CAQf"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/app-layout/runtime-drawer/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAwC,MAAM,OAAO,CAAC;AAE7D,OAAO,EAAE,gBAAgB,EAAe,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAA0B,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAC1F,OAAO,EACL,YAAY,IAAI,mBAAmB,EACnC,uBAAuB,EACxB,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,aAAa,IAAI,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AAClG,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAK/C,MAAM,WAAW,aAAc,SAAQ,cAAc,CAAC,MAAM;IAC1D,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,QAAQ,CAAC,EAAE,MAAM,GAAG,QAAQ,CAAC;CAC9B;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;IAC7B,WAAW,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;IAClC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;CAClC;AAmFD,eAAO,MAAM,wBAAwB,GACnC,eAAe,mBAAmB,KACjC,cAAc,CAAC,MAAM,GAAG;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,aAAa,CAAC,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;CA6BtD,CAAC;AAEF,eAAO,MAAM,0BAA0B,GACrC,eAAe,qBAAqB,KACnC,cAAc,CAAC,MAAM,GAAG;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,yBAAyB,CAAC,uBAAuB,CAAC,CAAC;IAC9D,aAAa,CAAC,EAAE,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACrD,uBAAuB,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1C,iBAAiB,CAAC,EAAE,yBAAyB,CAAC;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CAsCxE,CAAC;AAEF,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,KAAK,CAAC,mBAAmB,CAAC,EACxC,aAAa,EAAE,KAAK,CAAC,mBAAmB,CAAC,GACxC,aAAa,CAQf"}
@@ -1,7 +1,6 @@
1
1
  // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
2
  // SPDX-License-Identifier: Apache-2.0
3
3
  import React, { useContext, useEffect, useRef } from 'react';
4
- import { warnOnce } from '@cloudscape-design/component-toolkit/internal';
5
4
  import { fireNonCancelableEvent } from '../../internal/events';
6
5
  import { sortByPriority } from '../../internal/plugins/helpers/utils';
7
6
  import { ActiveDrawersContext } from '../utils/visibility-context';
@@ -42,21 +41,20 @@ function RuntimeDrawerHeader({ mountHeader, unmountHeader }) {
42
41
  }, []);
43
42
  return React.createElement("div", { className: styles['runtime-header-wrapper'], ref: ref });
44
43
  }
45
- function checkForUnsupportedProps(headerActions) {
46
- const unsupportedProps = new Set([
47
- 'iconSvg',
48
- 'popoverFeedback',
49
- 'pressedIconSvg',
50
- 'popoverFeedback',
51
- 'pressedPopoverFeedback',
52
- ]);
53
- for (const item of headerActions) {
54
- const unsupported = Object.keys(item).filter(key => unsupportedProps.has(key));
55
- if (unsupported.length > 0) {
56
- warnOnce('AppLayout', `The headerActions properties are not supported for runtime api: ${unsupported.join(' ')}`);
57
- }
58
- }
59
- return headerActions;
44
+ function mapRuntimeHeaderActionsToHeaderActions(runtimeHeaderActions) {
45
+ return runtimeHeaderActions.map(runtimeHeaderAction => {
46
+ return {
47
+ ...runtimeHeaderAction,
48
+ ...('iconSvg' in runtimeHeaderAction &&
49
+ runtimeHeaderAction.iconSvg && {
50
+ iconSvg: convertRuntimeTriggerToReactNode(runtimeHeaderAction.iconSvg),
51
+ }),
52
+ ...('pressedIconSvg' in runtimeHeaderAction &&
53
+ runtimeHeaderAction.pressedIconSvg && {
54
+ iconSvg: convertRuntimeTriggerToReactNode(runtimeHeaderAction.pressedIconSvg),
55
+ }),
56
+ };
57
+ });
60
58
  }
61
59
  const convertRuntimeTriggerToReactNode = (runtimeTrigger) => {
62
60
  if (!runtimeTrigger) {
@@ -82,7 +80,9 @@ export const mapRuntimeConfigToDrawer = (runtimeConfig) => {
82
80
  onResize: event => {
83
81
  fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });
84
82
  },
85
- headerActions: runtimeDrawer.headerActions ? checkForUnsupportedProps(runtimeDrawer.headerActions) : undefined,
83
+ headerActions: runtimeDrawer.headerActions
84
+ ? mapRuntimeHeaderActionsToHeaderActions(runtimeDrawer.headerActions)
85
+ : undefined,
86
86
  };
87
87
  };
88
88
  export const mapRuntimeConfigToAiDrawer = (runtimeConfig) => {
@@ -109,7 +109,9 @@ export const mapRuntimeConfigToAiDrawer = (runtimeConfig) => {
109
109
  onResize: event => {
110
110
  fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });
111
111
  },
112
- headerActions: runtimeDrawer.headerActions ? checkForUnsupportedProps(runtimeDrawer.headerActions) : undefined,
112
+ headerActions: runtimeDrawer.headerActions
113
+ ? mapRuntimeHeaderActionsToHeaderActions(runtimeDrawer.headerActions)
114
+ : undefined,
113
115
  };
114
116
  };
115
117
  export function convertRuntimeDrawers(localDrawers, globalDrawers) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/app-layout/runtime-drawer/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 React, { useContext, useEffect, useRef } from 'react';\n\nimport { warnOnce } from '@cloudscape-design/component-toolkit/internal';\n\nimport { ButtonGroupProps } from '../../button-group/interfaces';\nimport { fireNonCancelableEvent, NonCancelableEventHandler } from '../../internal/events';\nimport {\n DrawerConfig as RuntimeDrawerConfig,\n DrawerStateChangeParams,\n} from '../../internal/plugins/controllers/drawers';\nimport { sortByPriority } from '../../internal/plugins/helpers/utils';\nimport { DrawerPayload as RuntimeAiDrawerConfig } from '../../internal/plugins/widget/interfaces';\nimport { AppLayoutProps } from '../interfaces';\nimport { ActiveDrawersContext } from '../utils/visibility-context';\n\nimport styles from './styles.css.js';\n\nexport interface RuntimeDrawer extends AppLayoutProps.Drawer {\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n position?: 'side' | 'bottom';\n}\n\nexport interface DrawersLayout {\n global: Array<RuntimeDrawer>;\n localBefore: Array<RuntimeDrawer>;\n localAfter: Array<RuntimeDrawer>;\n}\n\ntype VisibilityCallback = (isVisible: boolean) => void;\n\ninterface RuntimeContentWrapperProps {\n id?: string;\n mountContent: RuntimeDrawerConfig['mountContent'];\n unmountContent: RuntimeDrawerConfig['unmountContent'];\n}\n\nfunction RuntimeDrawerWrapper({ mountContent, unmountContent, id }: RuntimeContentWrapperProps) {\n const ref = useRef<HTMLDivElement>(null);\n const visibilityChangeCallback = useRef<VisibilityCallback | null>(null);\n const activeDrawersIds = useContext(ActiveDrawersContext);\n const isVisible = !!id && activeDrawersIds.includes(id);\n\n useEffect(() => {\n const container = ref.current!;\n mountContent(container, {\n onVisibilityChange: cb => {\n visibilityChangeCallback.current = cb;\n },\n });\n return () => {\n unmountContent(container);\n visibilityChangeCallback.current = null;\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n visibilityChangeCallback.current?.(isVisible);\n }, [isVisible]);\n\n return <div ref={ref} className={styles['runtime-content-wrapper']} data-awsui-runtime-drawer-root-id={id}></div>;\n}\n\ninterface RuntimeContentHeaderProps {\n mountHeader: (container: HTMLElement) => void;\n unmountHeader?: (container: HTMLElement) => void;\n}\n\nfunction RuntimeDrawerHeader({ mountHeader, unmountHeader }: RuntimeContentHeaderProps) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const container = ref.current!;\n mountHeader?.(container);\n return () => {\n unmountHeader?.(container);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return <div className={styles['runtime-header-wrapper']} ref={ref} />;\n}\n\nfunction checkForUnsupportedProps(headerActions: ReadonlyArray<ButtonGroupProps.Item>) {\n const unsupportedProps = new Set([\n 'iconSvg',\n 'popoverFeedback',\n 'pressedIconSvg',\n 'popoverFeedback',\n 'pressedPopoverFeedback',\n ]);\n for (const item of headerActions) {\n const unsupported = Object.keys(item).filter(key => unsupportedProps.has(key));\n if (unsupported.length > 0) {\n warnOnce('AppLayout', `The headerActions properties are not supported for runtime api: ${unsupported.join(' ')}`);\n }\n }\n return headerActions;\n}\n\nconst convertRuntimeTriggerToReactNode = (runtimeTrigger?: string) => {\n if (!runtimeTrigger) {\n return undefined;\n }\n // eslint-disable-next-line react/no-danger\n return <span style={{ lineHeight: 0 }} dangerouslySetInnerHTML={{ __html: runtimeTrigger }} />;\n};\n\nexport const mapRuntimeConfigToDrawer = (\n runtimeConfig: RuntimeDrawerConfig\n): AppLayoutProps.Drawer & {\n orderPriority?: number;\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n headerActions?: ReadonlyArray<ButtonGroupProps.Item>;\n} => {\n const { mountContent, unmountContent, trigger, ...runtimeDrawer } = runtimeConfig;\n\n return {\n ...runtimeDrawer,\n ariaLabels: { drawerName: runtimeDrawer.ariaLabels.content ?? '', ...runtimeDrawer.ariaLabels },\n trigger: trigger\n ? {\n ...(trigger.iconSvg && {\n iconSvg: convertRuntimeTriggerToReactNode(trigger.iconSvg),\n }),\n }\n : undefined,\n content: (\n <RuntimeDrawerWrapper\n key={runtimeDrawer.id}\n mountContent={mountContent}\n unmountContent={unmountContent}\n id={runtimeDrawer.id}\n />\n ),\n onResize: event => {\n fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });\n },\n headerActions: runtimeDrawer.headerActions ? checkForUnsupportedProps(runtimeDrawer.headerActions) : undefined,\n };\n};\n\nexport const mapRuntimeConfigToAiDrawer = (\n runtimeConfig: RuntimeAiDrawerConfig\n): AppLayoutProps.Drawer & {\n orderPriority?: number;\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n headerActions?: ReadonlyArray<ButtonGroupProps.Item>;\n exitExpandedModeTrigger?: React.ReactNode;\n onToggleFocusMode?: NonCancelableEventHandler<{ isExpanded: boolean }>;\n} => {\n const { mountContent, unmountContent, trigger, exitExpandedModeTrigger, ...runtimeDrawer } = runtimeConfig;\n\n return {\n ...runtimeDrawer,\n ariaLabels: { drawerName: runtimeDrawer.ariaLabels.content ?? '', ...runtimeDrawer.ariaLabels },\n ...(trigger && {\n trigger: {\n customIcon: convertRuntimeTriggerToReactNode(trigger?.customIcon),\n iconSvg: convertRuntimeTriggerToReactNode(trigger?.iconSvg),\n },\n }),\n exitExpandedModeTrigger: exitExpandedModeTrigger\n ? {\n customIcon: convertRuntimeTriggerToReactNode(exitExpandedModeTrigger?.customIcon),\n }\n : undefined,\n content: (\n <RuntimeDrawerWrapper\n key={runtimeDrawer.id}\n mountContent={mountContent}\n unmountContent={unmountContent}\n id={runtimeDrawer.id}\n />\n ),\n ...(runtimeDrawer.mountHeader && {\n header: (\n <RuntimeDrawerHeader mountHeader={runtimeDrawer.mountHeader} unmountHeader={runtimeDrawer.unmountHeader} />\n ),\n }),\n onResize: event => {\n fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });\n },\n headerActions: runtimeDrawer.headerActions ? checkForUnsupportedProps(runtimeDrawer.headerActions) : undefined,\n };\n};\n\nexport function convertRuntimeDrawers(\n localDrawers: Array<RuntimeDrawerConfig>,\n globalDrawers: Array<RuntimeDrawerConfig>\n): DrawersLayout {\n const converted = localDrawers.map(mapRuntimeConfigToDrawer);\n const sorted = sortByPriority(converted);\n return {\n global: sortByPriority(globalDrawers.map(mapRuntimeConfigToDrawer)),\n localBefore: sorted.filter(item => (item.orderPriority ?? 0) > 0),\n localAfter: sorted.filter(item => (item.orderPriority ?? 0) <= 0),\n };\n}\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/app-layout/runtime-drawer/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 React, { useContext, useEffect, useRef } from 'react';\n\nimport { ButtonGroupProps, ItemRuntime } from '../../button-group/interfaces';\nimport { fireNonCancelableEvent, NonCancelableEventHandler } from '../../internal/events';\nimport {\n DrawerConfig as RuntimeDrawerConfig,\n DrawerStateChangeParams,\n} from '../../internal/plugins/controllers/drawers';\nimport { sortByPriority } from '../../internal/plugins/helpers/utils';\nimport { DrawerPayload as RuntimeAiDrawerConfig } from '../../internal/plugins/widget/interfaces';\nimport { AppLayoutProps } from '../interfaces';\nimport { ActiveDrawersContext } from '../utils/visibility-context';\n\nimport styles from './styles.css.js';\n\nexport interface RuntimeDrawer extends AppLayoutProps.Drawer {\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n position?: 'side' | 'bottom';\n}\n\nexport interface DrawersLayout {\n global: Array<RuntimeDrawer>;\n localBefore: Array<RuntimeDrawer>;\n localAfter: Array<RuntimeDrawer>;\n}\n\ntype VisibilityCallback = (isVisible: boolean) => void;\n\ninterface RuntimeContentWrapperProps {\n id?: string;\n mountContent: RuntimeDrawerConfig['mountContent'];\n unmountContent: RuntimeDrawerConfig['unmountContent'];\n}\n\nfunction RuntimeDrawerWrapper({ mountContent, unmountContent, id }: RuntimeContentWrapperProps) {\n const ref = useRef<HTMLDivElement>(null);\n const visibilityChangeCallback = useRef<VisibilityCallback | null>(null);\n const activeDrawersIds = useContext(ActiveDrawersContext);\n const isVisible = !!id && activeDrawersIds.includes(id);\n\n useEffect(() => {\n const container = ref.current!;\n mountContent(container, {\n onVisibilityChange: cb => {\n visibilityChangeCallback.current = cb;\n },\n });\n return () => {\n unmountContent(container);\n visibilityChangeCallback.current = null;\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n visibilityChangeCallback.current?.(isVisible);\n }, [isVisible]);\n\n return <div ref={ref} className={styles['runtime-content-wrapper']} data-awsui-runtime-drawer-root-id={id}></div>;\n}\n\ninterface RuntimeContentHeaderProps {\n mountHeader: (container: HTMLElement) => void;\n unmountHeader?: (container: HTMLElement) => void;\n}\n\nfunction RuntimeDrawerHeader({ mountHeader, unmountHeader }: RuntimeContentHeaderProps) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const container = ref.current!;\n mountHeader?.(container);\n return () => {\n unmountHeader?.(container);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return <div className={styles['runtime-header-wrapper']} ref={ref} />;\n}\n\nfunction mapRuntimeHeaderActionsToHeaderActions(\n runtimeHeaderActions: ReadonlyArray<ItemRuntime>\n): ReadonlyArray<ButtonGroupProps.Item> {\n return runtimeHeaderActions.map(runtimeHeaderAction => {\n return {\n ...runtimeHeaderAction,\n ...('iconSvg' in runtimeHeaderAction &&\n runtimeHeaderAction.iconSvg && {\n iconSvg: convertRuntimeTriggerToReactNode(runtimeHeaderAction.iconSvg),\n }),\n ...('pressedIconSvg' in runtimeHeaderAction &&\n runtimeHeaderAction.pressedIconSvg && {\n iconSvg: convertRuntimeTriggerToReactNode(runtimeHeaderAction.pressedIconSvg),\n }),\n };\n });\n}\n\nconst convertRuntimeTriggerToReactNode = (runtimeTrigger?: string) => {\n if (!runtimeTrigger) {\n return undefined;\n }\n // eslint-disable-next-line react/no-danger\n return <span style={{ lineHeight: 0 }} dangerouslySetInnerHTML={{ __html: runtimeTrigger }} />;\n};\n\nexport const mapRuntimeConfigToDrawer = (\n runtimeConfig: RuntimeDrawerConfig\n): AppLayoutProps.Drawer & {\n orderPriority?: number;\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n headerActions?: ReadonlyArray<ButtonGroupProps.Item>;\n} => {\n const { mountContent, unmountContent, trigger, ...runtimeDrawer } = runtimeConfig;\n\n return {\n ...runtimeDrawer,\n ariaLabels: { drawerName: runtimeDrawer.ariaLabels.content ?? '', ...runtimeDrawer.ariaLabels },\n trigger: trigger\n ? {\n ...(trigger.iconSvg && {\n iconSvg: convertRuntimeTriggerToReactNode(trigger.iconSvg),\n }),\n }\n : undefined,\n content: (\n <RuntimeDrawerWrapper\n key={runtimeDrawer.id}\n mountContent={mountContent}\n unmountContent={unmountContent}\n id={runtimeDrawer.id}\n />\n ),\n onResize: event => {\n fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });\n },\n headerActions: runtimeDrawer.headerActions\n ? mapRuntimeHeaderActionsToHeaderActions(runtimeDrawer.headerActions)\n : undefined,\n };\n};\n\nexport const mapRuntimeConfigToAiDrawer = (\n runtimeConfig: RuntimeAiDrawerConfig\n): AppLayoutProps.Drawer & {\n orderPriority?: number;\n onToggle?: NonCancelableEventHandler<DrawerStateChangeParams>;\n headerActions?: ReadonlyArray<ButtonGroupProps.Item>;\n exitExpandedModeTrigger?: React.ReactNode;\n onToggleFocusMode?: NonCancelableEventHandler<{ isExpanded: boolean }>;\n} => {\n const { mountContent, unmountContent, trigger, exitExpandedModeTrigger, ...runtimeDrawer } = runtimeConfig;\n\n return {\n ...runtimeDrawer,\n ariaLabels: { drawerName: runtimeDrawer.ariaLabels.content ?? '', ...runtimeDrawer.ariaLabels },\n ...(trigger && {\n trigger: {\n customIcon: convertRuntimeTriggerToReactNode(trigger?.customIcon),\n iconSvg: convertRuntimeTriggerToReactNode(trigger?.iconSvg),\n },\n }),\n exitExpandedModeTrigger: exitExpandedModeTrigger\n ? {\n customIcon: convertRuntimeTriggerToReactNode(exitExpandedModeTrigger?.customIcon),\n }\n : undefined,\n content: (\n <RuntimeDrawerWrapper\n key={runtimeDrawer.id}\n mountContent={mountContent}\n unmountContent={unmountContent}\n id={runtimeDrawer.id}\n />\n ),\n ...(runtimeDrawer.mountHeader && {\n header: (\n <RuntimeDrawerHeader mountHeader={runtimeDrawer.mountHeader} unmountHeader={runtimeDrawer.unmountHeader} />\n ),\n }),\n onResize: event => {\n fireNonCancelableEvent(runtimeDrawer.onResize, { size: event.detail.size, id: runtimeDrawer.id });\n },\n headerActions: runtimeDrawer.headerActions\n ? mapRuntimeHeaderActionsToHeaderActions(runtimeDrawer.headerActions)\n : undefined,\n };\n};\n\nexport function convertRuntimeDrawers(\n localDrawers: Array<RuntimeDrawerConfig>,\n globalDrawers: Array<RuntimeDrawerConfig>\n): DrawersLayout {\n const converted = localDrawers.map(mapRuntimeConfigToDrawer);\n const sorted = sortByPriority(converted);\n return {\n global: sortByPriority(globalDrawers.map(mapRuntimeConfigToDrawer)),\n localBefore: sorted.filter(item => (item.orderPriority ?? 0) > 0),\n localAfter: sorted.filter(item => (item.orderPriority ?? 0) <= 0),\n };\n}\n"]}