@redsift/design-system 11.6.0-muiv5-alpha.5 → 11.6.0-muiv5-alpha.7

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 (150) hide show
  1. package/_internal/Alert2.js +182 -39
  2. package/_internal/AppBar.js +240 -29
  3. package/_internal/AppContainer.js +132 -86
  4. package/_internal/AppContent.js +84 -17
  5. package/_internal/Badge2.js +137 -4
  6. package/_internal/BreadcrumbItem.js +85 -3
  7. package/_internal/Breadcrumbs2.js +86 -21
  8. package/_internal/Button2.js +81 -20
  9. package/_internal/ButtonGroup.js +165 -25
  10. package/_internal/ButtonLink.js +74 -18
  11. package/_internal/Card2.js +151 -29
  12. package/_internal/CardActions.js +38 -3
  13. package/_internal/CardBody.js +36 -3
  14. package/_internal/CardHeader.js +77 -3
  15. package/_internal/Checkbox2.js +234 -58
  16. package/_internal/CheckboxGroup.js +182 -4
  17. package/_internal/ConditionalWrapper.js +11 -12
  18. package/_internal/DetailedCard.js +6912 -48
  19. package/_internal/DetailedCardCollapsibleSectionItems.js +58 -3
  20. package/_internal/DetailedCardHeader.js +61 -3
  21. package/_internal/DetailedCardSection.js +166 -3
  22. package/_internal/DetailedCardSectionItem.js +88 -3
  23. package/_internal/Flexbox2.js +85 -22
  24. package/_internal/Grid2.js +87 -24
  25. package/_internal/GridItem.js +34 -3
  26. package/_internal/Heading2.js +107 -3
  27. package/_internal/Icon2.js +206 -5
  28. package/_internal/IconButton.js +71 -3
  29. package/_internal/IconButtonLink.js +65 -18
  30. package/_internal/Item2.js +390 -73
  31. package/_internal/Link2.js +56 -15
  32. package/_internal/LinkButton.js +56 -13
  33. package/_internal/Number2.js +103 -61
  34. package/_internal/NumberField.js +3959 -65
  35. package/_internal/Pill2.js +400 -4
  36. package/_internal/ProgressBar.js +61 -18
  37. package/_internal/Radio2.js +227 -56
  38. package/_internal/RadioGroup.js +170 -4
  39. package/_internal/Shield2.js +220 -4
  40. package/_internal/SideNavigationMenu.js +586 -4
  41. package/_internal/SideNavigationMenuItem.js +299 -4
  42. package/_internal/Skeleton2.js +36 -9
  43. package/_internal/SkeletonCircle.js +52 -3
  44. package/_internal/SkeletonText.js +71 -3
  45. package/_internal/Spinner2.js +319 -29
  46. package/_internal/Switch2.js +310 -56
  47. package/_internal/SwitchGroup.js +182 -4
  48. package/_internal/Text2.js +45 -3
  49. package/_internal/TextArea.js +430 -20
  50. package/_internal/TextField.js +463 -19
  51. package/_internal/alert.js +2 -5
  52. package/_internal/app-bar.js +2 -8
  53. package/_internal/app-container.js +3 -9
  54. package/_internal/app-content.js +2 -5
  55. package/_internal/app-side-panel.js +3 -11
  56. package/_internal/badge.js +2 -6
  57. package/_internal/breadcrumb-item.js +1 -4
  58. package/_internal/breadcrumbs.js +2 -6
  59. package/_internal/button-group.js +2 -5
  60. package/_internal/button-link.js +2 -8
  61. package/_internal/button.js +3 -8
  62. package/_internal/card-actions.js +1 -4
  63. package/_internal/card-body.js +1 -4
  64. package/_internal/card-header.js +1 -8
  65. package/_internal/card.js +2 -11
  66. package/_internal/checkbox-group.js +2 -6
  67. package/_internal/checkbox.js +2 -6
  68. package/_internal/colors.js +87 -91
  69. package/_internal/conditional-wrapper.js +2 -2
  70. package/_internal/detailed-card-collapsible-section-items.js +1 -3
  71. package/_internal/detailed-card-header.js +1 -7
  72. package/_internal/detailed-card-section-item.js +1 -10
  73. package/_internal/detailed-card-section.js +1 -6
  74. package/_internal/detailed-card.js +2 -16
  75. package/_internal/flexbox.js +2 -5
  76. package/_internal/focus-within-group.js +3 -3
  77. package/_internal/fonts.js +4 -6
  78. package/_internal/gradient-border.js +35 -16
  79. package/_internal/grid-item.js +1 -4
  80. package/_internal/grid.js +2 -6
  81. package/_internal/heading.js +2 -6
  82. package/_internal/icon-button-link.js +2 -8
  83. package/_internal/icon-button.js +2 -6
  84. package/_internal/icon.js +2 -6
  85. package/_internal/item.js +2 -8
  86. package/_internal/link-button.js +2 -8
  87. package/_internal/link.js +3 -8
  88. package/_internal/listbox.js +3 -6
  89. package/_internal/number-field.js +2 -9
  90. package/_internal/number.js +2 -7
  91. package/_internal/pill.js +2 -6
  92. package/_internal/progress-bar.js +2 -5
  93. package/_internal/radio-group.js +2 -6
  94. package/_internal/radio.js +2 -6
  95. package/_internal/shared.js +2 -5
  96. package/_internal/shield.js +2 -6
  97. package/_internal/side-navigation-menu-bar.js +3 -9
  98. package/_internal/side-navigation-menu-item.js +2 -8
  99. package/_internal/side-navigation-menu.js +2 -8
  100. package/_internal/skeleton-circle.js +1 -6
  101. package/_internal/skeleton-text.js +2 -6
  102. package/_internal/skeleton.js +1 -7
  103. package/_internal/spinner.js +2 -5
  104. package/_internal/styles.js +235 -17
  105. package/_internal/styles2.js +44 -280
  106. package/_internal/switch-group.js +2 -6
  107. package/_internal/switch.js +2 -6
  108. package/_internal/text-area.js +2 -9
  109. package/_internal/text-field.js +2 -10
  110. package/_internal/text.js +2 -6
  111. package/_internal/theme.js +1 -3
  112. package/_internal/types.js +7 -31
  113. package/_internal/types2.js +18 -29
  114. package/_internal/types3.js +15 -18
  115. package/_internal/useAppSidePanel.js +331 -6
  116. package/_internal/useFocusOnList.js +502 -44
  117. package/_internal/useListboxItem.js +120 -23
  118. package/_internal/useSideNavigationMenuBar.js +371 -7
  119. package/_internal/useTheme.js +10 -8
  120. package/index.d.ts +4667 -0
  121. package/index.js +523 -1674
  122. package/package.json +2 -2
  123. package/_internal/SideNavigationMenuBar.js +0 -9
  124. package/_internal/helpers.js +0 -23
  125. package/_internal/types10.js +0 -20
  126. package/_internal/types11.js +0 -27
  127. package/_internal/types12.js +0 -35
  128. package/_internal/types13.js +0 -143
  129. package/_internal/types14.js +0 -11
  130. package/_internal/types15.js +0 -62
  131. package/_internal/types16.js +0 -56
  132. package/_internal/types17.js +0 -57
  133. package/_internal/types18.js +0 -40
  134. package/_internal/types19.js +0 -101
  135. package/_internal/types20.js +0 -47
  136. package/_internal/types21.js +0 -68
  137. package/_internal/types22.js +0 -52
  138. package/_internal/types23.js +0 -174
  139. package/_internal/types24.js +0 -18
  140. package/_internal/types25.js +0 -12
  141. package/_internal/types26.js +0 -36
  142. package/_internal/types27.js +0 -72
  143. package/_internal/types28.js +0 -73
  144. package/_internal/types29.js +0 -99
  145. package/_internal/types4.js +0 -67
  146. package/_internal/types5.js +0 -11
  147. package/_internal/types6.js +0 -11
  148. package/_internal/types7.js +0 -28
  149. package/_internal/types8.js +0 -72
  150. package/_internal/types9.js +0 -16
@@ -1,43 +1,333 @@
1
- import { ComponentProps } from 'react';
2
- import { V as ValueOf, C as Comp } from './helpers.js';
3
- import { L as LayoutProps, S as SpacingProps, P as PositioningProps } from './styles2.js';
4
- import { T as Theme } from './colors.js';
1
+ import { a as _defineProperty, b as _objectWithoutProperties, c as _extends } from './_rollupPluginBabelHelpers.js';
2
+ import React__default, { useMemo, forwardRef } from 'react';
3
+ import classNames from 'classnames';
4
+ import styled from 'styled-components';
5
+ import { i as baseStyling } from './styles4.js';
6
+ import { u as useLocale } from './context2.js';
7
+ import { u as useTheme } from './useTheme.js';
8
+
9
+ /* eslint-disable prefer-const */
10
+ // @ts-nocheck
11
+ /*
12
+ * Copyright 2022 Adobe. All rights reserved.
13
+ * This file is licensed to you under the Apache License, Version 2.0 (the "License");
14
+ * you may not use this file except in compliance with the License. You may obtain a copy
15
+ * of the License at http://www.apache.org/licenses/LICENSE-2.0
16
+ *
17
+ * Unless required by applicable law or agreed to in writing, software distributed under
18
+ * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
19
+ * OF ANY KIND, either express or implied. See the License for the specific language
20
+ * governing permissions and limitations under the License.
21
+ */
22
+
23
+ const localeSymbol = Symbol.for('react-aria.i18n.locale');
24
+ const stringsSymbol = Symbol.for('react-aria.i18n.strings');
25
+ let cachedGlobalStrings = undefined;
26
+
27
+ /**
28
+ * Stores a mapping of localized strings. Can be used to find the
29
+ * closest available string for a given locale.
30
+ */
31
+ class LocalizedStringDictionary {
32
+ constructor(messages) {
33
+ let defaultLocale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
34
+ _defineProperty(this, "strings", void 0);
35
+ _defineProperty(this, "defaultLocale", void 0);
36
+ // Clone messages so we don't modify the original object.
37
+ // Filter out entries with falsy values which may have been caused by applying optimize-locales-plugin.
38
+ this.strings = Object.fromEntries(Object.entries(messages).filter(_ref => {
39
+ let [, v] = _ref;
40
+ return v;
41
+ }));
42
+ this.defaultLocale = defaultLocale;
43
+ }
44
+
45
+ /** Returns a localized string for the given key and locale. */
46
+ getStringForLocale(key, locale) {
47
+ let strings = this.getStringsForLocale(locale);
48
+ let string = strings[key];
49
+ if (!string) {
50
+ throw new Error(`Could not find intl message ${key} in ${locale} locale`);
51
+ }
52
+ return string;
53
+ }
54
+
55
+ /** Returns all localized strings for the given locale. */
56
+ getStringsForLocale(locale) {
57
+ let strings = this.strings[locale];
58
+ if (!strings) {
59
+ strings = getStringsForLocale(locale, this.strings, this.defaultLocale);
60
+ this.strings[locale] = strings;
61
+ }
62
+ return strings;
63
+ }
64
+ static getGlobalDictionaryForPackage(packageName) {
65
+ var _cachedGlobalStrings;
66
+ if (typeof window === 'undefined') {
67
+ return null;
68
+ }
69
+ let locale = window[localeSymbol];
70
+ if (cachedGlobalStrings === undefined) {
71
+ let globalStrings = window[stringsSymbol];
72
+ if (!globalStrings) {
73
+ return null;
74
+ }
75
+ cachedGlobalStrings = {};
76
+ for (let pkg in globalStrings) {
77
+ cachedGlobalStrings[pkg] = new LocalizedStringDictionary({
78
+ [locale]: globalStrings[pkg]
79
+ }, locale);
80
+ }
81
+ }
82
+ let dictionary = (_cachedGlobalStrings = cachedGlobalStrings) === null || _cachedGlobalStrings === void 0 ? void 0 : _cachedGlobalStrings[packageName];
83
+ if (!dictionary) {
84
+ throw new Error(`Strings for package "${packageName}" were not included by LocalizedStringProvider. Please add it to the list passed to createLocalizedStringDictionary.`);
85
+ }
86
+ return dictionary;
87
+ }
88
+ }
89
+ function getStringsForLocale(locale, strings) {
90
+ let defaultLocale = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'en-US';
91
+ // If there is an exact match, use it.
92
+ if (strings[locale]) {
93
+ return strings[locale];
94
+ }
95
+
96
+ // Attempt to find the closest match by language.
97
+ // For example, if the locale is fr-CA (French Canadian), but there is only
98
+ // an fr-FR (France) set of strings, use that.
99
+ // This could be replaced with Intl.LocaleMatcher once it is supported.
100
+ // https://github.com/tc39/proposal-intl-localematcher
101
+ let language = getLanguage(locale);
102
+ if (strings[language]) {
103
+ return strings[language];
104
+ }
105
+ for (let key in strings) {
106
+ if (key.startsWith(language + '-')) {
107
+ return strings[key];
108
+ }
109
+ }
110
+
111
+ // Nothing close, use english.
112
+ return strings[defaultLocale];
113
+ }
114
+ function getLanguage(locale) {
115
+ // @ts-ignore
116
+ if (Intl.Locale) {
117
+ // @ts-ignore
118
+ return new Intl.Locale(locale).language;
119
+ }
120
+ return locale.split('-')[0];
121
+ }
122
+
123
+ /* eslint-disable prefer-const */
124
+ // @ts-nocheck
125
+ /*
126
+ * Copyright 2022 Adobe. All rights reserved.
127
+ * This file is licensed to you under the Apache License, Version 2.0 (the "License");
128
+ * you may not use this file except in compliance with the License. You may obtain a copy
129
+ * of the License at http://www.apache.org/licenses/LICENSE-2.0
130
+ *
131
+ * Unless required by applicable law or agreed to in writing, software distributed under
132
+ * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
133
+ * OF ANY KIND, either express or implied. See the License for the specific language
134
+ * governing permissions and limitations under the License.
135
+ */
136
+
137
+ const pluralRulesCache = new Map();
138
+ const numberFormatCache = new Map();
139
+
140
+ /**
141
+ * Formats localized strings from a LocalizedStringDictionary. Supports interpolating variables,
142
+ * selecting the correct pluralization, and formatting numbers for the locale.
143
+ */
144
+ class LocalizedStringFormatter {
145
+ constructor(locale, strings) {
146
+ _defineProperty(this, "locale", void 0);
147
+ _defineProperty(this, "strings", void 0);
148
+ this.locale = locale;
149
+ this.strings = strings;
150
+ }
151
+
152
+ /** Formats a localized string for the given key with the provided variables. */
153
+ format(key, variables) {
154
+ let message = this.strings.getStringForLocale(key, this.locale);
155
+ return typeof message === 'function' ? message(variables, this) : message;
156
+ }
157
+ plural(count, options) {
158
+ let type = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'cardinal';
159
+ let opt = options['=' + count];
160
+ if (opt) {
161
+ return typeof opt === 'function' ? opt() : opt;
162
+ }
163
+ let key = this.locale + ':' + type;
164
+ let pluralRules = pluralRulesCache.get(key);
165
+ if (!pluralRules) {
166
+ pluralRules = new Intl.PluralRules(this.locale, {
167
+ type
168
+ });
169
+ pluralRulesCache.set(key, pluralRules);
170
+ }
171
+ let selected = pluralRules.select(count);
172
+ opt = options[selected] || options.other;
173
+ return typeof opt === 'function' ? opt() : opt;
174
+ }
175
+ number(value) {
176
+ let numberFormat = numberFormatCache.get(this.locale);
177
+ if (!numberFormat) {
178
+ numberFormat = new Intl.NumberFormat(this.locale);
179
+ numberFormatCache.set(this.locale, numberFormat);
180
+ }
181
+ return numberFormat.format(value);
182
+ }
183
+ select(options, value) {
184
+ let opt = options[value] || options.other;
185
+ return typeof opt === 'function' ? opt() : opt;
186
+ }
187
+ }
188
+
189
+ /* eslint-disable prefer-const */
190
+ const cache = new WeakMap();
191
+ function getCachedDictionary(strings) {
192
+ let dictionary = cache.get(strings);
193
+ if (!dictionary) {
194
+ dictionary = new LocalizedStringDictionary(strings);
195
+ cache.set(strings, dictionary);
196
+ }
197
+ return dictionary;
198
+ }
199
+
200
+ /**
201
+ * Returns a cached LocalizedStringDictionary for the given strings.
202
+ */
203
+ function useLocalizedStringDictionary(strings, packageName) {
204
+ return packageName && LocalizedStringDictionary.getGlobalDictionaryForPackage(packageName) || getCachedDictionary(strings);
205
+ }
206
+
207
+ /**
208
+ * Provides localized string formatting for the current locale. Supports interpolating variables,
209
+ * selecting the correct pluralization, and formatting numbers. Automatically updates when the locale changes.
210
+ * @param strings - A mapping of languages to localized strings by key.
211
+ */
212
+ function useLocalizedStringFormatter(strings, packageName) {
213
+ let {
214
+ locale
215
+ } = useLocale();
216
+ let dictionary = useLocalizedStringDictionary(strings, packageName);
217
+ return useMemo(() => new LocalizedStringFormatter(locale, dictionary), [locale, dictionary]);
218
+ }
219
+
220
+ var loading$1 = "Loading...";
221
+ var enUS = {
222
+ loading: loading$1
223
+ };
224
+
225
+ var loading = "Chargement...";
226
+ var frFR = {
227
+ loading: loading
228
+ };
229
+
230
+ var intlMessages = {
231
+ 'en-US': enUS,
232
+ 'fr-FR': frFR
233
+ };
5
234
 
6
235
  /**
7
236
  * Component size.
8
237
  */
9
- declare const SpinnerSize: {
10
- readonly xsmall: "xsmall";
11
- readonly small: "small";
12
- readonly medium: "medium";
13
- readonly large: "large";
238
+ const SpinnerSize = {
239
+ xsmall: 'xsmall',
240
+ small: 'small',
241
+ medium: 'medium',
242
+ large: 'large'
14
243
  };
15
- type SpinnerSize = ValueOf<typeof SpinnerSize>;
244
+
16
245
  /**
17
246
  * Component props.
18
247
  */
19
- interface SpinnerProps extends Omit<ComponentProps<'img'>, 'color'>, LayoutProps, SpacingProps, PositioningProps {
20
- /** Indicates whether the element is exposed to an accessibility API. */
21
- 'aria-hidden'?: boolean | 'false' | 'true';
22
- /** A screen reader only label for the Spinner. */
23
- 'aria-label'?: string;
24
- /** Color variant. */
25
- color?: 'primary' | 'grey-l1' | 'grey-l2' | 'grey-l3';
26
- /** @deprecated: Whether the spinner is colored or not. */
27
- isColored?: boolean;
28
- /** Spinner size. */
29
- size?: SpinnerSize;
30
- /** Theme. */
31
- theme?: Theme;
32
- }
33
- type StyledSpinnerProps = Omit<SpinnerProps, 'color'> & {
34
- $size?: SpinnerProps['size'];
35
- $theme?: SpinnerProps['theme'];
248
+
249
+ const StyledSpinner = styled.img`
250
+ ${baseStyling}
251
+
252
+ display: inline;
253
+ line-height: 0px;
254
+ vertical-align: -0.125em;
255
+ `;
256
+
257
+ var spinnerPrimaryN = '';
258
+
259
+ var spinnerGreyL1 = '';
260
+
261
+ var spinnerGreyL2 = '';
262
+
263
+ var spinnerGreyL3 = '';
264
+
265
+ const _excluded = ["aria-hidden", "aria-label", "className", "color", "isColored", "size", "theme"];
266
+ const COMPONENT_NAME = 'Spinner';
267
+ const CLASSNAME = 'redsift-shield';
268
+ const sizeToDimension = size => {
269
+ switch (size) {
270
+ case SpinnerSize.xsmall:
271
+ return {
272
+ width: 15,
273
+ height: 15
274
+ };
275
+ case SpinnerSize.small:
276
+ return {
277
+ width: 24,
278
+ height: 24
279
+ };
280
+ case SpinnerSize.large:
281
+ return {
282
+ width: 56,
283
+ height: 56
284
+ };
285
+ case SpinnerSize.medium:
286
+ default:
287
+ return {
288
+ width: 40,
289
+ height: 40
290
+ };
291
+ }
36
292
  };
37
293
 
38
294
  /**
39
295
  * The Spinner component.
40
296
  */
41
- declare const Spinner: Comp<SpinnerProps, HTMLImageElement>;
297
+ const Spinner = /*#__PURE__*/forwardRef((props, ref) => {
298
+ const {
299
+ 'aria-hidden': ariaHidden,
300
+ 'aria-label': ariaLabel,
301
+ className,
302
+ color: propsColor,
303
+ isColored = true,
304
+ size = SpinnerSize.medium,
305
+ theme: propsTheme
306
+ } = props,
307
+ forwardedProps = _objectWithoutProperties(props, _excluded);
308
+ const theme = useTheme(propsTheme);
309
+ const color = propsColor !== null && propsColor !== void 0 ? propsColor : isColored ? 'primary' : 'grey-l3';
310
+ const {
311
+ width,
312
+ height
313
+ } = sizeToDimension(size);
314
+ const stringFormatter = useLocalizedStringFormatter(intlMessages);
315
+ return /*#__PURE__*/React__default.createElement(StyledSpinner, _extends({
316
+ alt: stringFormatter.format('loading')
317
+ }, forwardedProps, {
318
+ "aria-hidden": ariaLabel ? ariaHidden ? ariaHidden : undefined : true,
319
+ "aria-label": ariaLabel,
320
+ className: classNames(Spinner.className, className),
321
+ height: height,
322
+ ref: ref,
323
+ src: color === 'primary' ? spinnerPrimaryN : color === 'grey-l1' ? spinnerGreyL1 : color === 'grey-l2' ? spinnerGreyL2 : spinnerGreyL3,
324
+ width: width,
325
+ $size: size,
326
+ $theme: theme
327
+ }));
328
+ });
329
+ Spinner.className = CLASSNAME;
330
+ Spinner.displayName = COMPONENT_NAME;
42
331
 
43
- export { Spinner as S, SpinnerSize as a, SpinnerProps as b, StyledSpinnerProps as c };
332
+ export { Spinner as S, SpinnerSize as a, useLocalizedStringDictionary as b, useLocalizedStringFormatter as u };
333
+ //# sourceMappingURL=Spinner2.js.map