@cloudscape-design/components 3.0.328 → 3.0.330

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 (92) hide show
  1. package/app-layout/runtime-api.d.ts.map +1 -1
  2. package/app-layout/runtime-api.js +5 -4
  3. package/app-layout/runtime-api.js.map +1 -1
  4. package/app-layout/visual-refresh/styles.css.js +69 -69
  5. package/app-layout/visual-refresh/styles.scoped.css +167 -167
  6. package/app-layout/visual-refresh/styles.selectors.js +69 -69
  7. package/area-chart/chart-container.d.ts.map +1 -1
  8. package/area-chart/chart-container.js +8 -15
  9. package/area-chart/chart-container.js.map +1 -1
  10. package/area-chart/internal.d.ts.map +1 -1
  11. package/area-chart/internal.js +2 -16
  12. package/area-chart/internal.js.map +1 -1
  13. package/area-chart/styles.css.js +6 -13
  14. package/area-chart/styles.scoped.css +10 -82
  15. package/area-chart/styles.selectors.js +6 -13
  16. package/expandable-section/styles.css.js +28 -31
  17. package/expandable-section/styles.scoped.css +85 -66
  18. package/expandable-section/styles.selectors.js +28 -31
  19. package/form-field/internal.d.ts.map +1 -1
  20. package/form-field/internal.js +5 -1
  21. package/form-field/internal.js.map +1 -1
  22. package/internal/analytics/components/analytics-funnel.d.ts.map +1 -1
  23. package/internal/analytics/components/analytics-funnel.js +4 -1
  24. package/internal/analytics/components/analytics-funnel.js.map +1 -1
  25. package/internal/analytics/interfaces.d.ts +2 -0
  26. package/internal/analytics/interfaces.d.ts.map +1 -1
  27. package/internal/analytics/interfaces.js.map +1 -1
  28. package/internal/analytics/selectors.d.ts +1 -0
  29. package/internal/analytics/selectors.d.ts.map +1 -1
  30. package/internal/analytics/selectors.js +1 -0
  31. package/internal/analytics/selectors.js.map +1 -1
  32. package/internal/components/cartesian-chart/chart-container.d.ts +11 -0
  33. package/internal/components/cartesian-chart/chart-container.d.ts.map +1 -0
  34. package/internal/components/cartesian-chart/chart-container.js +15 -0
  35. package/internal/components/cartesian-chart/chart-container.js.map +1 -0
  36. package/internal/components/cartesian-chart/styles.css.js +23 -21
  37. package/internal/components/cartesian-chart/styles.scoped.css +37 -25
  38. package/internal/components/cartesian-chart/styles.selectors.js +23 -21
  39. package/internal/components/chart-wrapper/index.d.ts +17 -0
  40. package/internal/components/chart-wrapper/index.d.ts.map +1 -0
  41. package/internal/components/chart-wrapper/index.js +26 -0
  42. package/internal/components/chart-wrapper/index.js.map +1 -0
  43. package/internal/components/chart-wrapper/styles.css.js +11 -0
  44. package/internal/components/chart-wrapper/styles.scoped.css +155 -0
  45. package/internal/components/chart-wrapper/styles.selectors.js +12 -0
  46. package/internal/environment.js +1 -1
  47. package/internal/manifest.json +1 -1
  48. package/internal/plugins/drawers-controller.d.ts +2 -4
  49. package/internal/plugins/drawers-controller.d.ts.map +1 -1
  50. package/internal/plugins/drawers-controller.js.map +1 -1
  51. package/link/internal.d.ts.map +1 -1
  52. package/link/internal.js +9 -1
  53. package/link/internal.js.map +1 -1
  54. package/mixed-line-bar-chart/chart-container.d.ts.map +1 -1
  55. package/mixed-line-bar-chart/chart-container.js +12 -19
  56. package/mixed-line-bar-chart/chart-container.js.map +1 -1
  57. package/mixed-line-bar-chart/internal.d.ts.map +1 -1
  58. package/mixed-line-bar-chart/internal.js +10 -15
  59. package/mixed-line-bar-chart/internal.js.map +1 -1
  60. package/mixed-line-bar-chart/styles.css.js +11 -19
  61. package/mixed-line-bar-chart/styles.scoped.css +18 -94
  62. package/mixed-line-bar-chart/styles.selectors.js +11 -19
  63. package/package.json +1 -1
  64. package/pie-chart/index.d.ts.map +1 -1
  65. package/pie-chart/index.js +26 -14
  66. package/pie-chart/index.js.map +1 -1
  67. package/pie-chart/pie-chart.d.ts +5 -3
  68. package/pie-chart/pie-chart.d.ts.map +1 -1
  69. package/pie-chart/pie-chart.js +14 -40
  70. package/pie-chart/pie-chart.js.map +1 -1
  71. package/pie-chart/styles.css.js +23 -27
  72. package/pie-chart/styles.scoped.css +38 -94
  73. package/pie-chart/styles.selectors.js +23 -27
  74. package/table/body-cell/styles.css.js +28 -28
  75. package/table/body-cell/styles.scoped.css +75 -69
  76. package/table/body-cell/styles.selectors.js +28 -28
  77. package/test-utils/dom/mixed-line-bar-chart/index.js +2 -1
  78. package/test-utils/dom/mixed-line-bar-chart/index.js.map +1 -1
  79. package/test-utils/dom/pie-chart/index.js +2 -1
  80. package/test-utils/dom/pie-chart/index.js.map +1 -1
  81. package/test-utils/selectors/mixed-line-bar-chart/index.js +2 -1
  82. package/test-utils/selectors/mixed-line-bar-chart/index.js.map +1 -1
  83. package/test-utils/selectors/pie-chart/index.js +2 -1
  84. package/test-utils/selectors/pie-chart/index.js.map +1 -1
  85. package/test-utils/tsconfig.tsbuildinfo +1 -1
  86. package/wizard/internal.d.ts.map +1 -1
  87. package/wizard/internal.js +5 -2
  88. package/wizard/internal.js.map +1 -1
  89. package/mixed-line-bar-chart/chart-filters.d.ts +0 -13
  90. package/mixed-line-bar-chart/chart-filters.d.ts.map +0 -1
  91. package/mixed-line-bar-chart/chart-filters.js +0 -22
  92. package/mixed-line-bar-chart/chart-filters.js.map +0 -1
@@ -1,24 +1,16 @@
1
1
 
2
2
  import './styles.scoped.css';
3
3
  export default {
4
- "series": "awsui_series_1yz9c_sug3s_93",
5
- "series--bar": "awsui_series--bar_1yz9c_sug3s_94",
6
- "series__rect": "awsui_series__rect_1yz9c_sug3s_94",
7
- "exiting": "awsui_exiting_1yz9c_sug3s_111",
8
- "awsui-motion-fade-out-0": "awsui_awsui-motion-fade-out-0_1yz9c_sug3s_1",
9
- "root": "awsui_root_1yz9c_sug3s_137",
10
- "filter-container": "awsui_filter-container_1yz9c_sug3s_152",
11
- "has-default-filter": "awsui_has-default-filter_1yz9c_sug3s_156",
12
- "chart-container": "awsui_chart-container_1yz9c_sug3s_160",
13
- "chart-container__vertical": "awsui_chart-container__vertical_1yz9c_sug3s_166",
14
- "chart-container__horizontal": "awsui_chart-container__horizontal_1yz9c_sug3s_172",
15
- "content": "awsui_content_1yz9c_sug3s_176",
16
- "content--reserve-filter": "awsui_content--reserve-filter_1yz9c_sug3s_183",
17
- "content--reserve-legend": "awsui_content--reserve-legend_1yz9c_sug3s_187",
18
- "series--highlighted": "awsui_series--highlighted_1yz9c_sug3s_200",
19
- "series__bar--highlighted": "awsui_series__bar--highlighted_1yz9c_sug3s_201",
20
- "series--dimmed": "awsui_series--dimmed_1yz9c_sug3s_205",
21
- "series--threshold": "awsui_series--threshold_1yz9c_sug3s_214",
22
- "bar-group": "awsui_bar-group_1yz9c_sug3s_219"
4
+ "series": "awsui_series_1yz9c_1gpid_93",
5
+ "series--bar": "awsui_series--bar_1yz9c_1gpid_94",
6
+ "series__rect": "awsui_series__rect_1yz9c_1gpid_94",
7
+ "exiting": "awsui_exiting_1yz9c_1gpid_111",
8
+ "awsui-motion-fade-out-0": "awsui_awsui-motion-fade-out-0_1yz9c_1gpid_1",
9
+ "root": "awsui_root_1yz9c_1gpid_137",
10
+ "series--highlighted": "awsui_series--highlighted_1yz9c_1gpid_150",
11
+ "series__bar--highlighted": "awsui_series__bar--highlighted_1yz9c_1gpid_151",
12
+ "series--dimmed": "awsui_series--dimmed_1yz9c_1gpid_155",
13
+ "series--threshold": "awsui_series--threshold_1yz9c_1gpid_164",
14
+ "bar-group": "awsui_bar-group_1yz9c_1gpid_169"
23
15
  };
24
16
 
@@ -90,26 +90,26 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
90
90
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
91
91
  SPDX-License-Identifier: Apache-2.0
92
92
  */
93
- .awsui_series_1yz9c_sug3s_93:not(#\9),
94
- .awsui_series--bar_1yz9c_sug3s_94 > .awsui_series__rect_1yz9c_sug3s_94:not(#\9) {
93
+ .awsui_series_1yz9c_1gpid_93:not(#\9),
94
+ .awsui_series--bar_1yz9c_1gpid_94 > .awsui_series__rect_1yz9c_1gpid_94:not(#\9) {
95
95
  transition: opacity var(--motion-duration-transition-quick-0viajb, 90ms) var(--motion-easing-transition-quick-191occ, linear);
96
96
  }
97
97
  @media (prefers-reduced-motion: reduce) {
98
- .awsui_series_1yz9c_sug3s_93:not(#\9),
99
- .awsui_series--bar_1yz9c_sug3s_94 > .awsui_series__rect_1yz9c_sug3s_94:not(#\9) {
98
+ .awsui_series_1yz9c_1gpid_93:not(#\9),
99
+ .awsui_series--bar_1yz9c_1gpid_94 > .awsui_series__rect_1yz9c_1gpid_94:not(#\9) {
100
100
  animation: none;
101
101
  transition: none;
102
102
  }
103
103
  }
104
- .awsui-motion-disabled .awsui_series_1yz9c_sug3s_93:not(#\9), .awsui-mode-entering .awsui_series_1yz9c_sug3s_93:not(#\9), .awsui-motion-disabled .awsui_series--bar_1yz9c_sug3s_94 > .awsui_series__rect_1yz9c_sug3s_94:not(#\9), .awsui-mode-entering .awsui_series--bar_1yz9c_sug3s_94 > .awsui_series__rect_1yz9c_sug3s_94:not(#\9) {
104
+ .awsui-motion-disabled .awsui_series_1yz9c_1gpid_93:not(#\9), .awsui-mode-entering .awsui_series_1yz9c_1gpid_93:not(#\9), .awsui-motion-disabled .awsui_series--bar_1yz9c_1gpid_94 > .awsui_series__rect_1yz9c_1gpid_94:not(#\9), .awsui-mode-entering .awsui_series--bar_1yz9c_1gpid_94 > .awsui_series__rect_1yz9c_1gpid_94:not(#\9) {
105
105
  animation: none;
106
106
  transition: none;
107
107
  }
108
108
 
109
- .awsui_exiting_1yz9c_sug3s_111:not(#\9) {
110
- animation: awsui_awsui-motion-fade-out-0_1yz9c_sug3s_1 var(--motion-duration-refresh-only-fast-q2mprk, 115ms) var(--motion-easing-refresh-only-b-uzywy7, cubic-bezier(1, 0, 0.83, 1));
109
+ .awsui_exiting_1yz9c_1gpid_111:not(#\9) {
110
+ animation: awsui_awsui-motion-fade-out-0_1yz9c_1gpid_1 var(--motion-duration-refresh-only-fast-q2mprk, 115ms) var(--motion-easing-refresh-only-b-uzywy7, cubic-bezier(1, 0, 0.83, 1));
111
111
  }
112
- @keyframes awsui_awsui-motion-fade-out-0_1yz9c_sug3s_1 {
112
+ @keyframes awsui_awsui-motion-fade-out-0_1yz9c_1gpid_1 {
113
113
  from {
114
114
  opacity: 1;
115
115
  }
@@ -118,12 +118,12 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
118
118
  }
119
119
  }
120
120
  @media (prefers-reduced-motion: reduce) {
121
- .awsui_exiting_1yz9c_sug3s_111:not(#\9) {
121
+ .awsui_exiting_1yz9c_1gpid_111:not(#\9) {
122
122
  animation: none;
123
123
  transition: none;
124
124
  }
125
125
  }
126
- .awsui-motion-disabled .awsui_exiting_1yz9c_sug3s_111:not(#\9), .awsui-mode-entering .awsui_exiting_1yz9c_sug3s_111:not(#\9) {
126
+ .awsui-motion-disabled .awsui_exiting_1yz9c_1gpid_111:not(#\9), .awsui-mode-entering .awsui_exiting_1yz9c_1gpid_111:not(#\9) {
127
127
  animation: none;
128
128
  transition: none;
129
129
  }
@@ -132,87 +132,11 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
132
132
  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
133
133
  SPDX-License-Identifier: Apache-2.0
134
134
  */
135
- .awsui_root_1yz9c_sug3s_137:not(#\9) {
136
- /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
137
- border-collapse: separate;
138
- border-spacing: 0;
139
- caption-side: top;
140
- cursor: auto;
141
- direction: ltr;
142
- empty-cells: show;
143
- font-family: serif;
144
- font-size: medium;
145
- font-style: normal;
146
- font-variant: normal;
147
- font-weight: normal;
148
- font-stretch: normal;
149
- line-height: normal;
150
- -webkit-hyphens: none;
151
- hyphens: none;
152
- letter-spacing: normal;
153
- list-style: disc outside none;
154
- tab-size: 8;
155
- text-align: left;
156
- text-align-last: auto;
157
- text-indent: 0;
158
- text-shadow: none;
159
- text-transform: none;
160
- visibility: visible;
161
- white-space: normal;
162
- widows: 2;
163
- word-spacing: normal;
164
- box-sizing: border-box;
165
- font-size: var(--font-body-m-size-7dign1, 14px);
166
- line-height: var(--font-body-m-line-height-rfgrp9, 22px);
167
- color: var(--color-text-body-default-su7kuo, #000716);
168
- font-weight: 400;
169
- font-family: var(--font-family-base-wn913o, "Open Sans", "Helvetica Neue", Roboto, Arial, sans-serif);
170
- -webkit-font-smoothing: auto;
171
- -moz-osx-font-smoothing: auto;
172
- position: relative;
173
- display: block;
174
- }
175
-
176
- .awsui_filter-container_1yz9c_sug3s_152:not(#\9) {
135
+ .awsui_root_1yz9c_1gpid_137:not(#\9) {
177
136
  /* used in test-utils */
178
137
  }
179
138
 
180
- .awsui_has-default-filter_1yz9c_sug3s_156 > :not(#\9):first-child {
181
- flex: 280px 0 1;
182
- }
183
-
184
- .awsui_chart-container_1yz9c_sug3s_160:not(#\9) {
185
- display: flex;
186
- width: 100%;
187
- flex-direction: column;
188
- }
189
-
190
- .awsui_chart-container__vertical_1yz9c_sug3s_166:not(#\9) {
191
- display: flex;
192
- flex-direction: column;
193
- width: 100%;
194
- }
195
-
196
- .awsui_chart-container__horizontal_1yz9c_sug3s_172:not(#\9) {
197
- display: flex;
198
- }
199
-
200
- .awsui_content_1yz9c_sug3s_176:not(#\9) {
201
- display: flex;
202
- position: relative;
203
- justify-content: center;
204
- align-items: center;
205
- }
206
-
207
- .awsui_content--reserve-filter_1yz9c_sug3s_183:not(#\9) {
208
- margin-top: calc(2 * var(--font-body-m-line-height-rfgrp9, 22px));
209
- }
210
-
211
- .awsui_content--reserve-legend_1yz9c_sug3s_187:not(#\9) {
212
- margin-bottom: calc(2 * var(--font-body-m-line-height-rfgrp9, 22px));
213
- }
214
-
215
- .awsui_series_1yz9c_sug3s_93:not(#\9) {
139
+ .awsui_series_1yz9c_1gpid_93:not(#\9) {
216
140
  display: block;
217
141
  stroke-width: var(--border-line-chart-width-qfyiov, 2px);
218
142
  fill: none;
@@ -221,25 +145,25 @@ surrounding text. (WCAG F73) https://www.w3.org/WAI/WCAG21/Techniques/failures/F
221
145
  pointer-events: none;
222
146
  }
223
147
 
224
- .awsui_series--highlighted_1yz9c_sug3s_200:not(#\9),
225
- .awsui_series__bar--highlighted_1yz9c_sug3s_201:not(#\9) {
148
+ .awsui_series--highlighted_1yz9c_1gpid_150:not(#\9),
149
+ .awsui_series__bar--highlighted_1yz9c_1gpid_151:not(#\9) {
226
150
  /* used in dom query */
227
151
  }
228
152
 
229
- .awsui_series--dimmed_1yz9c_sug3s_205:not(#\9) {
153
+ .awsui_series--dimmed_1yz9c_1gpid_155:not(#\9) {
230
154
  opacity: 0.3;
231
155
  }
232
156
 
233
- .awsui_series--bar_1yz9c_sug3s_94 > .awsui_series__rect_1yz9c_sug3s_94:not(#\9) {
157
+ .awsui_series--bar_1yz9c_1gpid_94 > .awsui_series__rect_1yz9c_1gpid_94:not(#\9) {
234
158
  stroke: var(--color-background-container-content-og3y0v, #ffffff);
235
159
  stroke-width: 2px;
236
160
  }
237
161
 
238
- .awsui_series--threshold_1yz9c_sug3s_214:not(#\9) {
162
+ .awsui_series--threshold_1yz9c_1gpid_164:not(#\9) {
239
163
  stroke-dasharray: var(--border-line-chart-dash-array-ry3ko4, 3 5);
240
164
  stroke-width: var(--border-line-chart-width-qfyiov, 2px);
241
165
  }
242
166
 
243
- .awsui_bar-group_1yz9c_sug3s_219:not(#\9) {
167
+ .awsui_bar-group_1yz9c_1gpid_169:not(#\9) {
244
168
  /* used in dom query */
245
169
  }
@@ -2,24 +2,16 @@
2
2
  // es-module interop with Babel and Typescript
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  module.exports.default = {
5
- "series": "awsui_series_1yz9c_sug3s_93",
6
- "series--bar": "awsui_series--bar_1yz9c_sug3s_94",
7
- "series__rect": "awsui_series__rect_1yz9c_sug3s_94",
8
- "exiting": "awsui_exiting_1yz9c_sug3s_111",
9
- "awsui-motion-fade-out-0": "awsui_awsui-motion-fade-out-0_1yz9c_sug3s_1",
10
- "root": "awsui_root_1yz9c_sug3s_137",
11
- "filter-container": "awsui_filter-container_1yz9c_sug3s_152",
12
- "has-default-filter": "awsui_has-default-filter_1yz9c_sug3s_156",
13
- "chart-container": "awsui_chart-container_1yz9c_sug3s_160",
14
- "chart-container__vertical": "awsui_chart-container__vertical_1yz9c_sug3s_166",
15
- "chart-container__horizontal": "awsui_chart-container__horizontal_1yz9c_sug3s_172",
16
- "content": "awsui_content_1yz9c_sug3s_176",
17
- "content--reserve-filter": "awsui_content--reserve-filter_1yz9c_sug3s_183",
18
- "content--reserve-legend": "awsui_content--reserve-legend_1yz9c_sug3s_187",
19
- "series--highlighted": "awsui_series--highlighted_1yz9c_sug3s_200",
20
- "series__bar--highlighted": "awsui_series__bar--highlighted_1yz9c_sug3s_201",
21
- "series--dimmed": "awsui_series--dimmed_1yz9c_sug3s_205",
22
- "series--threshold": "awsui_series--threshold_1yz9c_sug3s_214",
23
- "bar-group": "awsui_bar-group_1yz9c_sug3s_219"
5
+ "series": "awsui_series_1yz9c_1gpid_93",
6
+ "series--bar": "awsui_series--bar_1yz9c_1gpid_94",
7
+ "series__rect": "awsui_series__rect_1yz9c_1gpid_94",
8
+ "exiting": "awsui_exiting_1yz9c_1gpid_111",
9
+ "awsui-motion-fade-out-0": "awsui_awsui-motion-fade-out-0_1yz9c_1gpid_1",
10
+ "root": "awsui_root_1yz9c_1gpid_137",
11
+ "series--highlighted": "awsui_series--highlighted_1yz9c_1gpid_150",
12
+ "series__bar--highlighted": "awsui_series__bar--highlighted_1yz9c_1gpid_151",
13
+ "series--dimmed": "awsui_series--dimmed_1yz9c_1gpid_155",
14
+ "series--threshold": "awsui_series--threshold_1yz9c_1gpid_164",
15
+ "bar-group": "awsui_bar-group_1yz9c_1gpid_169"
24
16
  };
25
17
 
package/package.json CHANGED
@@ -136,7 +136,7 @@
136
136
  "./internal/base-component/index.js",
137
137
  "./internal/base-component/styles.css.js"
138
138
  ],
139
- "version": "3.0.328",
139
+ "version": "3.0.330",
140
140
  "repository": {
141
141
  "type": "git",
142
142
  "url": "https://github.com/cloudscape-design/components.git"
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"lib/default/","sources":["pie-chart/index.tsx"],"names":[],"mappings":";AAcA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAS7C,OAAO,EAAE,aAAa,EAAE,CAAC;AAEzB,QAAA,MAAM,QAAQ,yaAyKb,CAAC;AAGF,eAAe,QAAQ,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"lib/default/","sources":["pie-chart/index.tsx"],"names":[],"mappings":";AAaA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAW7C,OAAO,EAAE,aAAa,EAAE,CAAC;AAEzB,QAAA,MAAM,QAAQ,yaAyMb,CAAC;AAGF,eAAe,QAAQ,CAAC"}
@@ -8,8 +8,7 @@ import { useControllable } from '../internal/hooks/use-controllable';
8
8
  import { fireNonCancelableEvent } from '../internal/events';
9
9
  import Legend from '../internal/components/chart-legend';
10
10
  import Filter from '../internal/components/chart-filter';
11
- import InternalSpaceBetween from '../space-between/internal';
12
- import InternalBox from '../box/internal';
11
+ import { pie } from 'd3-shape';
13
12
  import InternalPieChart from './pie-chart';
14
13
  import styles from './styles.css.js';
15
14
  import { applyDisplayName } from '../internal/utils/apply-display-name';
@@ -18,12 +17,12 @@ import { useMergeRefs } from '../internal/hooks/use-merge-refs';
18
17
  import createCategoryColorScale from '../internal/utils/create-category-color-scale';
19
18
  import useContainerWidth from '../internal/utils/use-container-width';
20
19
  import { nodeBelongs } from '../internal/utils/node-belongs';
20
+ import { ChartWrapper } from '../internal/components/chart-wrapper';
21
+ import ChartStatusContainer, { getChartStatus } from '../internal/components/chart-status-container';
21
22
  const PieChart = function PieChart(_a) {
22
23
  var { variant = 'pie', size = 'medium', hideTitles = false, hideDescriptions = false, hideLegend = false, hideFilter = false, statusType = 'finished', data: externalData = [], i18nStrings = {}, highlightedSegment: controlledHighlightedSegment, visibleSegments: controlledVisibleSegments, onHighlightChange: controlledOnHighlightChange, onFilterChange, additionalFilters, legendTitle, detailPopoverSize = 'medium' } = _a, props = __rest(_a, ["variant", "size", "hideTitles", "hideDescriptions", "hideLegend", "hideFilter", "statusType", "data", "i18nStrings", "highlightedSegment", "visibleSegments", "onHighlightChange", "onFilterChange", "additionalFilters", "legendTitle", "detailPopoverSize"]);
23
24
  const { __internalRootRef = null } = useBaseComponent('PieChart');
24
25
  const baseProps = getBaseProps(props);
25
- const isEmpty = !externalData || externalData.length === 0;
26
- const containerAttr = Object.assign(Object.assign({}, baseProps), { className: clsx(baseProps.className, styles.root) });
27
26
  const containerRef = useRef(null);
28
27
  const [containerWidth, measureRef] = useContainerWidth();
29
28
  const data = useMemo(() => {
@@ -75,16 +74,29 @@ const PieChart = function PieChart(_a) {
75
74
  }
76
75
  };
77
76
  const mergedRef = useMergeRefs(containerRef, measureRef, __internalRootRef);
78
- return (React.createElement("div", Object.assign({}, containerAttr, { ref: mergedRef, onBlur: onBlur }),
79
- statusType === 'finished' && !isEmpty && (additionalFilters || !hideFilter) && (React.createElement(InternalBox, { className: styles['filter-container'], margin: { bottom: 'l' } },
80
- React.createElement(InternalSpaceBetween, { size: "l", direction: "horizontal", className: clsx({
81
- [styles['has-default-filter']]: !hideFilter,
82
- }) },
83
- !hideFilter && (React.createElement(Filter, { series: filterItems, onChange: filterChange, selectedSeries: visibleSegments, i18nStrings: i18nStrings })),
84
- additionalFilters))),
85
- React.createElement(InternalPieChart, Object.assign({}, props, { variant: variant, size: size, data: externalData, visibleData: visibleData, width: containerWidth, statusType: statusType, hideTitles: hideTitles, hideDescriptions: hideDescriptions, hideLegend: hideLegend, hideFilter: hideFilter, additionalFilters: additionalFilters, i18nStrings: i18nStrings, onHighlightChange: onHighlightChange, highlightedSegment: highlightedSegment, legendSegment: legendSegment, pinnedSegment: pinnedSegment, setPinnedSegment: setPinnedSegment, detailPopoverSize: detailPopoverSize })),
86
- !hideLegend && !isEmpty && statusType === 'finished' && (React.createElement(InternalBox, { margin: { top: 'm' } },
87
- React.createElement(Legend, { series: legendItems, highlightedSeries: legendSegment, legendTitle: legendTitle, ariaLabel: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.legendAriaLabel, onHighlightChange: onHighlightChange, plotContainerRef: containerRef })))));
77
+ const { pieData, dataSum } = useMemo(() => {
78
+ const dataSum = visibleData.reduce((sum, d) => sum + d.datum.value, 0);
79
+ const pieFactory = pie()
80
+ // Minimum 1% segment size
81
+ .value(d => (d.datum.value < dataSum / 100 ? dataSum / 100 : d.datum.value))
82
+ .sort(null);
83
+ // Filter out segments with value of zero or below
84
+ const pieData = pieFactory(visibleData.filter(d => d.datum.value > 0));
85
+ return { pieData, dataSum };
86
+ }, [visibleData]);
87
+ const hasNoData = !externalData || externalData.length === 0;
88
+ const { isEmpty, showChart } = getChartStatus({ externalData: data, visibleData: pieData, statusType });
89
+ // Pie charts have a special condition for empty/noMatch due to how zero-value segments are handled.
90
+ const isNoMatch = isEmpty && visibleData.length !== data.length;
91
+ const showFilters = statusType === 'finished' && !hasNoData && (additionalFilters || !hideFilter);
92
+ const reserveLegendSpace = !showChart && !hideLegend;
93
+ const reserveFilterSpace = statusType !== 'finished' && !isNoMatch && (!hideFilter || additionalFilters);
94
+ const hasLabels = !(hideTitles && hideDescriptions);
95
+ return (React.createElement(ChartWrapper, Object.assign({ ref: mergedRef }, baseProps, { className: clsx(baseProps.className, styles.root), contentClassName: clsx(styles.content, styles[`content--${size}`], {
96
+ [styles['content--without-labels']]: !hasLabels,
97
+ }), defaultFilter: showFilters && !hideFilter ? (React.createElement(Filter, { series: filterItems, onChange: filterChange, selectedSeries: visibleSegments, i18nStrings: i18nStrings })) : null, additionalFilters: showFilters ? additionalFilters : null, reserveFilterSpace: !!reserveFilterSpace, reserveLegendSpace: !!reserveLegendSpace, chartStatus: React.createElement(ChartStatusContainer, { isEmpty: isEmpty, isNoMatch: isNoMatch, showChart: showChart, statusType: statusType, empty: props.empty, noMatch: props.noMatch, loadingText: props.loadingText, errorText: props.errorText, recoveryText: props.recoveryText, onRecoveryClick: props.onRecoveryClick }), chart: showChart ? (React.createElement(InternalPieChart, Object.assign({}, props, { variant: variant, size: size, data: externalData, width: containerWidth, hideTitles: hideTitles, hideDescriptions: hideDescriptions, i18nStrings: i18nStrings, onHighlightChange: onHighlightChange, highlightedSegment: highlightedSegment, legendSegment: legendSegment, pinnedSegment: pinnedSegment, setPinnedSegment: setPinnedSegment, detailPopoverSize: detailPopoverSize, pieData: pieData, dataSum: dataSum }))) : null, legend: !hideLegend &&
98
+ !hasNoData &&
99
+ statusType === 'finished' && (React.createElement(Legend, { series: legendItems, highlightedSeries: legendSegment, legendTitle: legendTitle, ariaLabel: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.legendAriaLabel, onHighlightChange: onHighlightChange, plotContainerRef: containerRef })), onBlur: onBlur })));
88
100
  };
89
101
  applyDisplayName(PieChart, 'PieChart');
90
102
  export default PieChart;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"lib/default/","sources":["pie-chart/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, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport clsx from 'clsx';\n\nimport { getBaseProps } from '../internal/base-component';\nimport { useControllable } from '../internal/hooks/use-controllable';\nimport { fireNonCancelableEvent } from '../internal/events';\nimport Legend, { ChartLegendProps } from '../internal/components/chart-legend';\nimport Filter, { ChartFilterProps } from '../internal/components/chart-filter';\nimport InternalSpaceBetween from '../space-between/internal';\nimport InternalBox from '../box/internal';\n\nimport InternalPieChart, { InternalChartDatum } from './pie-chart';\nimport { PieChartProps } from './interfaces';\nimport styles from './styles.css.js';\nimport { applyDisplayName } from '../internal/utils/apply-display-name';\nimport useBaseComponent from '../internal/hooks/use-base-component';\nimport { useMergeRefs } from '../internal/hooks/use-merge-refs';\nimport createCategoryColorScale from '../internal/utils/create-category-color-scale';\nimport useContainerWidth from '../internal/utils/use-container-width';\nimport { nodeBelongs } from '../internal/utils/node-belongs';\n\nexport { PieChartProps };\n\nconst PieChart = function PieChart<T extends PieChartProps.Datum = PieChartProps.Datum>({\n variant = 'pie',\n size = 'medium',\n hideTitles = false,\n hideDescriptions = false,\n hideLegend = false,\n hideFilter = false,\n statusType = 'finished',\n data: externalData = [],\n i18nStrings = {},\n highlightedSegment: controlledHighlightedSegment,\n visibleSegments: controlledVisibleSegments,\n onHighlightChange: controlledOnHighlightChange,\n onFilterChange,\n additionalFilters,\n legendTitle,\n detailPopoverSize = 'medium',\n ...props\n}: PieChartProps<T>) {\n const { __internalRootRef = null } = useBaseComponent('PieChart');\n const baseProps = getBaseProps(props);\n const isEmpty = !externalData || externalData.length === 0;\n const containerAttr = {\n ...baseProps,\n className: clsx(baseProps.className, styles.root),\n };\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, measureRef] = useContainerWidth();\n\n const data: ReadonlyArray<InternalChartDatum<T>> = useMemo(() => {\n const colors = createCategoryColorScale(externalData, undefined, it => it.color || null);\n\n return externalData.map((datum, i) => ({\n index: i,\n color: colors[i],\n datum,\n }));\n }, [externalData]);\n\n const [highlightedSegment = null, setHighlightedSegment] = useControllable(\n controlledHighlightedSegment,\n controlledOnHighlightChange,\n null,\n {\n componentName: 'PieChart',\n controlledProp: 'highlightedSegment',\n changeHandler: 'onHighlightChange',\n }\n );\n const [legendSegment, setLegendSegment] = useState<null | T>(highlightedSegment);\n useEffect(() => {\n setLegendSegment(controlledHighlightedSegment || null);\n }, [controlledHighlightedSegment]);\n\n const [visibleSegments, setVisibleSegments] = useControllable(\n controlledVisibleSegments,\n onFilterChange,\n externalData,\n {\n componentName: 'PieChart',\n controlledProp: 'visibleSegments',\n changeHandler: 'onFilterChange',\n }\n );\n\n const [pinnedSegment, setPinnedSegment] = useState<T | null>(null);\n\n const visibleData = useMemo(\n () => data.filter(d => visibleSegments?.indexOf(d.datum) !== -1),\n [data, visibleSegments]\n );\n\n const filterItems: ChartFilterProps<T>['series'] = data?.map(data => ({\n label: data.datum.title,\n color: data.color,\n type: 'rectangle',\n datum: data.datum,\n }));\n\n const legendItems: ChartLegendProps<T>['series'] = filterItems.filter(d => visibleSegments?.indexOf(d.datum) !== -1);\n\n const filterChange = useCallback(\n (selectedSeries: ReadonlyArray<T>) => {\n setVisibleSegments(selectedSeries);\n fireNonCancelableEvent(onFilterChange, {\n visibleSegments: selectedSeries,\n });\n },\n [setVisibleSegments, onFilterChange]\n );\n\n const onHighlightChange = useCallback(\n (segment: T | null) => {\n setLegendSegment(segment);\n setHighlightedSegment(segment);\n fireNonCancelableEvent(controlledOnHighlightChange, { highlightedSegment: segment });\n },\n [controlledOnHighlightChange, setHighlightedSegment]\n );\n\n const onBlur = (event: React.FocusEvent) => {\n if (event.relatedTarget && !nodeBelongs(containerRef.current, event.relatedTarget)) {\n highlightedSegment && onHighlightChange(null);\n setLegendSegment(null);\n }\n };\n\n const mergedRef = useMergeRefs(containerRef, measureRef, __internalRootRef);\n\n return (\n <div {...containerAttr} ref={mergedRef} onBlur={onBlur}>\n {statusType === 'finished' && !isEmpty && (additionalFilters || !hideFilter) && (\n <InternalBox className={styles['filter-container']} margin={{ bottom: 'l' }}>\n <InternalSpaceBetween\n size=\"l\"\n direction=\"horizontal\"\n className={clsx({\n [styles['has-default-filter']]: !hideFilter,\n })}\n >\n {!hideFilter && (\n <Filter\n series={filterItems}\n onChange={filterChange}\n selectedSeries={visibleSegments}\n i18nStrings={i18nStrings}\n />\n )}\n {additionalFilters}\n </InternalSpaceBetween>\n </InternalBox>\n )}\n\n <InternalPieChart\n {...props}\n variant={variant}\n size={size}\n data={externalData}\n visibleData={visibleData}\n width={containerWidth}\n statusType={statusType}\n hideTitles={hideTitles}\n hideDescriptions={hideDescriptions}\n hideLegend={hideLegend}\n hideFilter={hideFilter}\n additionalFilters={additionalFilters}\n i18nStrings={i18nStrings}\n onHighlightChange={onHighlightChange}\n highlightedSegment={highlightedSegment}\n legendSegment={legendSegment}\n pinnedSegment={pinnedSegment}\n setPinnedSegment={setPinnedSegment}\n detailPopoverSize={detailPopoverSize}\n />\n\n {!hideLegend && !isEmpty && statusType === 'finished' && (\n <InternalBox margin={{ top: 'm' }}>\n <Legend<T>\n series={legendItems}\n highlightedSeries={legendSegment}\n legendTitle={legendTitle}\n ariaLabel={i18nStrings?.legendAriaLabel}\n onHighlightChange={onHighlightChange}\n plotContainerRef={containerRef}\n />\n </InternalBox>\n )}\n </div>\n );\n};\n\napplyDisplayName(PieChart, 'PieChart');\nexport default PieChart;\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"lib/default/","sources":["pie-chart/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, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport clsx from 'clsx';\n\nimport { getBaseProps } from '../internal/base-component';\nimport { useControllable } from '../internal/hooks/use-controllable';\nimport { fireNonCancelableEvent } from '../internal/events';\nimport Legend, { ChartLegendProps } from '../internal/components/chart-legend';\nimport Filter, { ChartFilterProps } from '../internal/components/chart-filter';\nimport { pie } from 'd3-shape';\n\nimport InternalPieChart, { InternalChartDatum } from './pie-chart';\nimport { PieChartProps } from './interfaces';\nimport styles from './styles.css.js';\nimport { applyDisplayName } from '../internal/utils/apply-display-name';\nimport useBaseComponent from '../internal/hooks/use-base-component';\nimport { useMergeRefs } from '../internal/hooks/use-merge-refs';\nimport createCategoryColorScale from '../internal/utils/create-category-color-scale';\nimport useContainerWidth from '../internal/utils/use-container-width';\nimport { nodeBelongs } from '../internal/utils/node-belongs';\nimport { ChartWrapper } from '../internal/components/chart-wrapper';\nimport ChartStatusContainer, { getChartStatus } from '../internal/components/chart-status-container';\n\nexport { PieChartProps };\n\nconst PieChart = function PieChart<T extends PieChartProps.Datum = PieChartProps.Datum>({\n variant = 'pie',\n size = 'medium',\n hideTitles = false,\n hideDescriptions = false,\n hideLegend = false,\n hideFilter = false,\n statusType = 'finished',\n data: externalData = [],\n i18nStrings = {},\n highlightedSegment: controlledHighlightedSegment,\n visibleSegments: controlledVisibleSegments,\n onHighlightChange: controlledOnHighlightChange,\n onFilterChange,\n additionalFilters,\n legendTitle,\n detailPopoverSize = 'medium',\n ...props\n}: PieChartProps<T>) {\n const { __internalRootRef = null } = useBaseComponent('PieChart');\n const baseProps = getBaseProps(props);\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, measureRef] = useContainerWidth();\n\n const data: ReadonlyArray<InternalChartDatum<T>> = useMemo(() => {\n const colors = createCategoryColorScale(externalData, undefined, it => it.color || null);\n\n return externalData.map((datum, i) => ({\n index: i,\n color: colors[i],\n datum,\n }));\n }, [externalData]);\n\n const [highlightedSegment = null, setHighlightedSegment] = useControllable(\n controlledHighlightedSegment,\n controlledOnHighlightChange,\n null,\n {\n componentName: 'PieChart',\n controlledProp: 'highlightedSegment',\n changeHandler: 'onHighlightChange',\n }\n );\n const [legendSegment, setLegendSegment] = useState<null | T>(highlightedSegment);\n useEffect(() => {\n setLegendSegment(controlledHighlightedSegment || null);\n }, [controlledHighlightedSegment]);\n\n const [visibleSegments, setVisibleSegments] = useControllable(\n controlledVisibleSegments,\n onFilterChange,\n externalData,\n {\n componentName: 'PieChart',\n controlledProp: 'visibleSegments',\n changeHandler: 'onFilterChange',\n }\n );\n\n const [pinnedSegment, setPinnedSegment] = useState<T | null>(null);\n\n const visibleData = useMemo(\n () => data.filter(d => visibleSegments?.indexOf(d.datum) !== -1),\n [data, visibleSegments]\n );\n\n const filterItems: ChartFilterProps<T>['series'] = data?.map(data => ({\n label: data.datum.title,\n color: data.color,\n type: 'rectangle',\n datum: data.datum,\n }));\n\n const legendItems: ChartLegendProps<T>['series'] = filterItems.filter(d => visibleSegments?.indexOf(d.datum) !== -1);\n\n const filterChange = useCallback(\n (selectedSeries: ReadonlyArray<T>) => {\n setVisibleSegments(selectedSeries);\n fireNonCancelableEvent(onFilterChange, {\n visibleSegments: selectedSeries,\n });\n },\n [setVisibleSegments, onFilterChange]\n );\n\n const onHighlightChange = useCallback(\n (segment: T | null) => {\n setLegendSegment(segment);\n setHighlightedSegment(segment);\n fireNonCancelableEvent(controlledOnHighlightChange, { highlightedSegment: segment });\n },\n [controlledOnHighlightChange, setHighlightedSegment]\n );\n\n const onBlur = (event: React.FocusEvent) => {\n if (event.relatedTarget && !nodeBelongs(containerRef.current, event.relatedTarget)) {\n highlightedSegment && onHighlightChange(null);\n setLegendSegment(null);\n }\n };\n\n const mergedRef = useMergeRefs(containerRef, measureRef, __internalRootRef);\n\n const { pieData, dataSum } = useMemo(() => {\n const dataSum = visibleData.reduce((sum, d) => sum + d.datum.value, 0);\n\n const pieFactory = pie<InternalChartDatum<T>>()\n // Minimum 1% segment size\n .value(d => (d.datum.value < dataSum / 100 ? dataSum / 100 : d.datum.value))\n .sort(null);\n\n // Filter out segments with value of zero or below\n const pieData = pieFactory(visibleData.filter(d => d.datum.value > 0));\n\n return { pieData, dataSum };\n }, [visibleData]);\n\n const hasNoData = !externalData || externalData.length === 0;\n const { isEmpty, showChart } = getChartStatus({ externalData: data, visibleData: pieData, statusType });\n // Pie charts have a special condition for empty/noMatch due to how zero-value segments are handled.\n const isNoMatch = isEmpty && visibleData.length !== data.length;\n const showFilters = statusType === 'finished' && !hasNoData && (additionalFilters || !hideFilter);\n const reserveLegendSpace = !showChart && !hideLegend;\n const reserveFilterSpace = statusType !== 'finished' && !isNoMatch && (!hideFilter || additionalFilters);\n const hasLabels = !(hideTitles && hideDescriptions);\n\n return (\n <ChartWrapper\n ref={mergedRef}\n {...baseProps}\n className={clsx(baseProps.className, styles.root)}\n contentClassName={clsx(styles.content, styles[`content--${size}`], {\n [styles['content--without-labels']]: !hasLabels,\n })}\n defaultFilter={\n showFilters && !hideFilter ? (\n <Filter\n series={filterItems}\n onChange={filterChange}\n selectedSeries={visibleSegments}\n i18nStrings={i18nStrings}\n />\n ) : null\n }\n additionalFilters={showFilters ? additionalFilters : null}\n reserveFilterSpace={!!reserveFilterSpace}\n reserveLegendSpace={!!reserveLegendSpace}\n chartStatus={\n <ChartStatusContainer\n isEmpty={isEmpty}\n isNoMatch={isNoMatch}\n showChart={showChart}\n statusType={statusType}\n empty={props.empty}\n noMatch={props.noMatch}\n loadingText={props.loadingText}\n errorText={props.errorText}\n recoveryText={props.recoveryText}\n onRecoveryClick={props.onRecoveryClick}\n />\n }\n chart={\n showChart ? (\n <InternalPieChart\n {...props}\n variant={variant}\n size={size}\n data={externalData}\n width={containerWidth}\n hideTitles={hideTitles}\n hideDescriptions={hideDescriptions}\n i18nStrings={i18nStrings}\n onHighlightChange={onHighlightChange}\n highlightedSegment={highlightedSegment}\n legendSegment={legendSegment}\n pinnedSegment={pinnedSegment}\n setPinnedSegment={setPinnedSegment}\n detailPopoverSize={detailPopoverSize}\n pieData={pieData}\n dataSum={dataSum}\n />\n ) : null\n }\n legend={\n !hideLegend &&\n !hasNoData &&\n statusType === 'finished' && (\n <Legend<T>\n series={legendItems}\n highlightedSeries={legendSegment}\n legendTitle={legendTitle}\n ariaLabel={i18nStrings?.legendAriaLabel}\n onHighlightChange={onHighlightChange}\n plotContainerRef={containerRef}\n />\n )\n }\n onBlur={onBlur}\n />\n );\n};\n\napplyDisplayName(PieChart, 'PieChart');\nexport default PieChart;\n"]}
@@ -1,3 +1,4 @@
1
+ import { PieArcDatum } from 'd3-shape';
1
2
  import React from 'react';
2
3
  import { PieChartProps, SeriesInfo } from './interfaces';
3
4
  import { SomeRequired } from '../internal/types';
@@ -6,20 +7,21 @@ export interface InternalChartDatum<T> {
6
7
  color: string;
7
8
  datum: Readonly<T>;
8
9
  }
9
- interface InternalPieChartProps<T extends PieChartProps.Datum> extends SomeRequired<Omit<PieChartProps<T>, 'onHighlightChange'>, 'variant' | 'size' | 'i18nStrings' | 'hideTitles' | 'hideDescriptions' | 'statusType'> {
10
- visibleData: Array<InternalChartDatum<T>>;
10
+ interface InternalPieChartProps<T extends PieChartProps.Datum> extends SomeRequired<Omit<PieChartProps<T>, 'onHighlightChange' | 'statusType'>, 'variant' | 'size' | 'i18nStrings' | 'hideTitles' | 'hideDescriptions'> {
11
11
  width: number;
12
12
  highlightedSegment: T | null;
13
13
  onHighlightChange: (segment: null | T) => void;
14
14
  legendSegment: T | null;
15
15
  pinnedSegment: T | null;
16
16
  setPinnedSegment: React.Dispatch<React.SetStateAction<T | null>>;
17
+ pieData: PieArcDatum<InternalChartDatum<T>>[];
18
+ dataSum: number;
17
19
  }
18
20
  export interface TooltipData<T> {
19
21
  datum: T;
20
22
  trackRef: React.RefObject<SVGElement>;
21
23
  series: SeriesInfo;
22
24
  }
23
- declare const _default: <T extends PieChartProps.Datum>({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, data, visibleData, ariaDescription, innerMetricValue, innerMetricDescription, hideTitles, hideDescriptions, detailPopoverContent, detailPopoverSize, detailPopoverFooter, width, additionalFilters, hideFilter, hideLegend, statusType, empty, noMatch, errorText, recoveryText, loadingText, onRecoveryClick, segmentDescription, highlightedSegment, onHighlightChange, legendSegment, pinnedSegment, setPinnedSegment, }: InternalPieChartProps<T>) => JSX.Element;
25
+ declare const _default: <T extends PieChartProps.Datum>({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, ariaDescription, innerMetricValue, innerMetricDescription, hideTitles, hideDescriptions, detailPopoverContent, detailPopoverSize, detailPopoverFooter, width, segmentDescription, highlightedSegment, onHighlightChange, legendSegment, pinnedSegment, setPinnedSegment, pieData, dataSum, }: InternalPieChartProps<T>) => JSX.Element;
24
26
  export default _default;
25
27
  //# sourceMappingURL=pie-chart.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"pie-chart.d.ts","sourceRoot":"lib/default/","sources":["pie-chart/pie-chart.tsx"],"names":[],"mappings":"AAEA,OAAO,KAA4D,MAAM,OAAO,CAAC;AAajF,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAMzD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAIjD,MAAM,WAAW,kBAAkB,CAAC,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;CACpB;AAED,UAAU,qBAAqB,CAAC,CAAC,SAAS,aAAa,CAAC,KAAK,CAC3D,SAAQ,YAAY,CAClB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,mBAAmB,CAAC,EAC3C,SAAS,GAAG,MAAM,GAAG,aAAa,GAAG,YAAY,GAAG,kBAAkB,GAAG,YAAY,CACtF;IACD,WAAW,EAAE,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,KAAK,EAAE,MAAM,CAAC;IAEd,kBAAkB,EAAE,CAAC,GAAG,IAAI,CAAC;IAC7B,iBAAiB,EAAE,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,KAAK,IAAI,CAAC;IAE/C,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC;IAExB,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC;IACxB,gBAAgB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;CAClE;AAED,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,KAAK,EAAE,CAAC,CAAC;IACT,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACtC,MAAM,EAAE,UAAU,CAAC;CACpB;;AAED,wBAmXE"}
1
+ {"version":3,"file":"pie-chart.d.ts","sourceRoot":"lib/default/","sources":["pie-chart/pie-chart.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,KAA4D,MAAM,OAAO,CAAC;AAUjF,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAMzD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAIjD,MAAM,WAAW,kBAAkB,CAAC,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;CACpB;AAED,UAAU,qBAAqB,CAAC,CAAC,SAAS,aAAa,CAAC,KAAK,CAC3D,SAAQ,YAAY,CAClB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,mBAAmB,GAAG,YAAY,CAAC,EAC1D,SAAS,GAAG,MAAM,GAAG,aAAa,GAAG,YAAY,GAAG,kBAAkB,CACvE;IACD,KAAK,EAAE,MAAM,CAAC;IAEd,kBAAkB,EAAE,CAAC,GAAG,IAAI,CAAC;IAC7B,iBAAiB,EAAE,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,KAAK,IAAI,CAAC;IAE/C,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC;IAExB,aAAa,EAAE,CAAC,GAAG,IAAI,CAAC;IACxB,gBAAgB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;IAEjE,OAAO,EAAE,WAAW,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAC9C,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,KAAK,EAAE,CAAC,CAAC;IACT,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACtC,MAAM,EAAE,UAAU,CAAC;CACpB;;AAED,wBA2TE"}
@@ -1,14 +1,9 @@
1
- // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
2
- // SPDX-License-Identifier: Apache-2.0
3
1
  import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';
4
- import clsx from 'clsx';
5
- import { pie } from 'd3-shape';
6
2
  import { KeyCode } from '../internal/keycode';
7
3
  import { useUniqueId } from '../internal/hooks/use-unique-id';
8
4
  import ChartPopover from '../internal/components/chart-popover';
9
5
  import SeriesDetails from '../internal/components/chart-series-details';
10
6
  import SeriesMarker from '../internal/components/chart-series-marker';
11
- import ChartStatusContainer, { getChartStatus } from '../internal/components/chart-status-container';
12
7
  import InternalBox from '../box/internal';
13
8
  import Labels from './labels';
14
9
  import styles from './styles.css.js';
@@ -18,7 +13,7 @@ import { useVisualRefresh } from '../internal/hooks/use-visual-mode';
18
13
  import ChartPlot from '../internal/components/chart-plot';
19
14
  import { useInternalI18n } from '../internal/i18n/context';
20
15
  import { nodeBelongs } from '../internal/utils/node-belongs';
21
- export default ({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, data, visibleData, ariaDescription, innerMetricValue, innerMetricDescription, hideTitles, hideDescriptions, detailPopoverContent, detailPopoverSize, detailPopoverFooter, width, additionalFilters, hideFilter, hideLegend, statusType, empty, noMatch, errorText, recoveryText, loadingText, onRecoveryClick, segmentDescription, highlightedSegment, onHighlightChange, legendSegment, pinnedSegment, setPinnedSegment, }) => {
16
+ export default ({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, ariaDescription, innerMetricValue, innerMetricDescription, hideTitles, hideDescriptions, detailPopoverContent, detailPopoverSize, detailPopoverFooter, width, segmentDescription, highlightedSegment, onHighlightChange, legendSegment, pinnedSegment, setPinnedSegment, pieData, dataSum, }) => {
22
17
  var _a;
23
18
  const plotRef = useRef(null);
24
19
  const containerRef = useRef(null);
@@ -35,16 +30,6 @@ export default ({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, data, v
35
30
  const innerMetricId = useUniqueId('awsui-pie-chart__inner');
36
31
  const [isTooltipOpen, setTooltipOpen] = useState(false);
37
32
  const [tooltipData, setTooltipData] = useState();
38
- const { pieData, dataSum } = useMemo(() => {
39
- const dataSum = visibleData.reduce((sum, d) => sum + d.datum.value, 0);
40
- const pieFactory = pie()
41
- // Minimum 1% segment size
42
- .value(d => (d.datum.value < dataSum / 100 ? dataSum / 100 : d.datum.value))
43
- .sort(null);
44
- // Filter out segments with value of zero or below
45
- const pieData = pieFactory(visibleData.filter(d => d.datum.value > 0));
46
- return { pieData, dataSum };
47
- }, [visibleData]);
48
33
  const highlightedSegmentIndex = useMemo(() => {
49
34
  for (let index = 0; index < pieData.length; index++) {
50
35
  if (pieData[index].data.datum === highlightedSegment) {
@@ -58,11 +43,6 @@ export default ({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, data, v
58
43
  const detailFunction = detailPopoverContent || defaultDetails(i18n, i18nStrings);
59
44
  const details = tooltipData ? detailFunction(tooltipData.datum, dataSum) : [];
60
45
  const tooltipContent = tooltipData && React.createElement(SeriesDetails, { details: details });
61
- const { isEmpty, showChart } = getChartStatus({ externalData: data, visibleData: pieData, statusType });
62
- // Pie charts have a special condition for empty/noMatch due to how zero-value segments are handled.
63
- const isNoMatch = isEmpty && visibleData.length !== data.length;
64
- const reserveLegendSpace = !showChart && !hideLegend;
65
- const reserveFilterSpace = statusType !== 'finished' && !isNoMatch && (!hideFilter || additionalFilters);
66
46
  const popoverDismissedRecently = useRef(false);
67
47
  const escapePressed = useRef(false);
68
48
  const highlightSegment = useCallback((internalDatum) => {
@@ -195,24 +175,18 @@ export default ({ variant, size, i18nStrings, ariaLabel, ariaLabelledby, data, v
195
175
  }
196
176
  clearHighlightedSegment();
197
177
  };
198
- return (React.createElement("div", { className: clsx(styles.content, styles[`content--${size}`], {
199
- [styles['content--without-labels']]: !hasLabels,
200
- [styles['content--reserve-filter']]: reserveFilterSpace,
201
- [styles['content--reserve-legend']]: reserveLegendSpace,
202
- }) },
203
- React.createElement(ChartStatusContainer, { isEmpty: isEmpty, isNoMatch: isNoMatch, showChart: showChart, statusType: statusType, empty: empty, noMatch: noMatch, loadingText: loadingText, errorText: errorText, recoveryText: recoveryText, onRecoveryClick: onRecoveryClick }),
204
- showChart && (React.createElement("div", { className: styles['chart-container'], ref: containerRef },
205
- React.createElement(ChartPlot, { ref: plotRef, width: width, height: height, transform: `translate(${width / 2} ${height / 2})`, isPrecise: true, isClickable: !isTooltipOpen, ariaLabel: ariaLabel, ariaLabelledby: ariaLabelledby, ariaDescription: ariaDescription, ariaDescribedby: hasInnerContent ? innerMetricId : undefined, ariaRoleDescription: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.chartAriaRoleDescription, ariaLiveRegion: tooltipContent, activeElementRef: focusedSegmentRef, activeElementKey: highlightedSegmentIndex === null || highlightedSegmentIndex === void 0 ? void 0 : highlightedSegmentIndex.toString(), onFocus: onFocus, onBlur: onBlur, onKeyDown: onKeyDown, onMouseOut: onMouseOut },
206
- React.createElement(Segments, { pieData: pieData, size: size, variant: variant, focusedSegmentRef: focusedSegmentRef, popoverTrackRef: popoverTrackRef, highlightedSegment: highlightedSegment, segmentAriaRoleDescription: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.segmentAriaRoleDescription, onMouseDown: onMouseDown, onMouseOver: onMouseOver, onMouseOut: onMouseOut }),
207
- hasLabels && (React.createElement(Labels, { pieData: pieData, size: size, segmentDescription: segmentDescription, visibleDataSum: dataSum, hideTitles: hideTitles, hideDescriptions: hideDescriptions, highlightedSegment: highlightedSegment, containerRef: containerRef }))),
208
- hasInnerContent && (React.createElement("div", { className: styles['inner-content'], id: innerMetricId },
209
- innerMetricValue && (React.createElement(InternalBox, { variant: size === 'small' ? 'h3' : 'h1', tagOverride: "div", color: "inherit", padding: "n" }, innerMetricValue)),
210
- innerMetricDescription && size !== 'small' && (React.createElement(InternalBox, { variant: "h3", color: "text-body-secondary", tagOverride: "div", padding: "n" }, innerMetricDescription)))),
211
- isTooltipOpen && tooltipData && (React.createElement(ChartPopover, { ref: popoverRef, title: tooltipData.series && (React.createElement(InternalBox, { className: styles['popover-header'], variant: "strong" },
212
- React.createElement(SeriesMarker, { color: tooltipData.series.color, type: tooltipData.series.markerType }),
213
- ' ',
214
- tooltipData.series.label)), trackRef: tooltipData.trackRef, trackKey: tooltipData.series.index, dismissButton: pinnedSegment !== null, dismissAriaLabel: i18nStrings.detailPopoverDismissAriaLabel, onDismiss: onPopoverDismiss, container: ((_a = plotRef.current) === null || _a === void 0 ? void 0 : _a.svg) || null, size: detailPopoverSize, onMouseLeave: onPopoverLeave },
215
- tooltipContent,
216
- detailPopoverFooterContent && (React.createElement(InternalBox, { margin: { top: 's' } }, detailPopoverFooterContent))))))));
178
+ return (React.createElement("div", { className: styles['chart-container'], ref: containerRef },
179
+ React.createElement(ChartPlot, { ref: plotRef, width: width, height: height, transform: `translate(${width / 2} ${height / 2})`, isPrecise: true, isClickable: !isTooltipOpen, ariaLabel: ariaLabel, ariaLabelledby: ariaLabelledby, ariaDescription: ariaDescription, ariaDescribedby: hasInnerContent ? innerMetricId : undefined, ariaRoleDescription: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.chartAriaRoleDescription, ariaLiveRegion: tooltipContent, activeElementRef: focusedSegmentRef, activeElementKey: highlightedSegmentIndex === null || highlightedSegmentIndex === void 0 ? void 0 : highlightedSegmentIndex.toString(), onFocus: onFocus, onBlur: onBlur, onKeyDown: onKeyDown, onMouseOut: onMouseOut },
180
+ React.createElement(Segments, { pieData: pieData, size: size, variant: variant, focusedSegmentRef: focusedSegmentRef, popoverTrackRef: popoverTrackRef, highlightedSegment: highlightedSegment, segmentAriaRoleDescription: i18nStrings === null || i18nStrings === void 0 ? void 0 : i18nStrings.segmentAriaRoleDescription, onMouseDown: onMouseDown, onMouseOver: onMouseOver, onMouseOut: onMouseOut }),
181
+ hasLabels && (React.createElement(Labels, { pieData: pieData, size: size, segmentDescription: segmentDescription, visibleDataSum: dataSum, hideTitles: hideTitles, hideDescriptions: hideDescriptions, highlightedSegment: highlightedSegment, containerRef: containerRef }))),
182
+ hasInnerContent && (React.createElement("div", { className: styles['inner-content'], id: innerMetricId },
183
+ innerMetricValue && (React.createElement(InternalBox, { variant: size === 'small' ? 'h3' : 'h1', tagOverride: "div", color: "inherit", padding: "n" }, innerMetricValue)),
184
+ innerMetricDescription && size !== 'small' && (React.createElement(InternalBox, { variant: "h3", color: "text-body-secondary", tagOverride: "div", padding: "n" }, innerMetricDescription)))),
185
+ isTooltipOpen && tooltipData && (React.createElement(ChartPopover, { ref: popoverRef, title: tooltipData.series && (React.createElement(InternalBox, { className: styles['popover-header'], variant: "strong" },
186
+ React.createElement(SeriesMarker, { color: tooltipData.series.color, type: tooltipData.series.markerType }),
187
+ ' ',
188
+ tooltipData.series.label)), trackRef: tooltipData.trackRef, trackKey: tooltipData.series.index, dismissButton: pinnedSegment !== null, dismissAriaLabel: i18nStrings.detailPopoverDismissAriaLabel, onDismiss: onPopoverDismiss, container: ((_a = plotRef.current) === null || _a === void 0 ? void 0 : _a.svg) || null, size: detailPopoverSize, onMouseLeave: onPopoverLeave },
189
+ tooltipContent,
190
+ detailPopoverFooterContent && React.createElement(InternalBox, { margin: { top: 's' } }, detailPopoverFooterContent)))));
217
191
  };
218
192
  //# sourceMappingURL=pie-chart.js.map