@pingux/astro 1.7.0-alpha.9 → 1.8.0-alpha.1

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/CHANGELOG.md +13 -0
  2. package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.js +1 -0
  3. package/lib/cjs/components/AccordionGridItem/AccordionGridItem.js +3 -0
  4. package/lib/cjs/components/AccordionGridItem/AccordionGridItemBody.js +3 -0
  5. package/lib/cjs/components/AccordionGridItem/AccordionGridItemHeader.js +10 -4
  6. package/lib/cjs/components/ArrayField/ArrayField.test.js +13 -0
  7. package/lib/cjs/components/ArrayField/ArrayFieldDeleteButton.js +3 -8
  8. package/lib/cjs/components/AstroWrapper/AstroWrapper.js +4 -4
  9. package/lib/cjs/components/CodeView/CodeView.js +11 -4
  10. package/lib/cjs/components/CodeView/CodeView.stories.js +33 -2
  11. package/lib/cjs/components/ComboBoxField/ComboBoxField.js +1 -1
  12. package/lib/cjs/components/ComboBoxField/ComboBoxField.test.js +8 -4
  13. package/lib/cjs/components/Image/Image.js +132 -11
  14. package/lib/cjs/components/Image/Image.stories.js +52 -6
  15. package/lib/cjs/components/Image/Image.test.js +138 -2
  16. package/lib/cjs/components/Image/imageConstants.js +13 -0
  17. package/lib/cjs/components/ImageUploadField/ImageUploadField.test.js +27 -8
  18. package/lib/cjs/components/ListViewItem/ListViewItem.js +2 -1
  19. package/lib/cjs/components/MultiselectFilter/MultiselectFilter.js +1 -1
  20. package/lib/cjs/components/MultiselectFilterItem/MultiselectFilterItem.js +32 -11
  21. package/lib/cjs/components/MultiselectFilterItem/MultiselectFilterItem.test.js +13 -1
  22. package/lib/cjs/components/NavBar/NavBar.js +20 -8
  23. package/lib/cjs/components/NavBar/NavBar.stories.js +3 -2
  24. package/lib/cjs/components/NavBarSection/NavBarItem.js +1 -1
  25. package/lib/cjs/components/NavBarSection/NavBarItemButton.js +1 -1
  26. package/lib/cjs/components/NavBarSection/NavBarItemHeader.js +61 -4
  27. package/lib/cjs/components/NavBarSection/NavBarItemLink.js +1 -1
  28. package/lib/cjs/components/NavBarSection/NavBarSection.js +5 -2
  29. package/lib/cjs/components/NumberField/NumberField.js +32 -2
  30. package/lib/cjs/components/Text/Text.js +5 -1
  31. package/lib/cjs/components/Text/Text.stories.js +56 -2
  32. package/lib/cjs/components/Text/Text.test.js +46 -0
  33. package/lib/cjs/components/TimeZonePicker/TimeZonePicker.js +21 -10
  34. package/lib/cjs/hooks/index.js +10 -1
  35. package/lib/cjs/hooks/useFallbackImage/index.js +18 -0
  36. package/lib/cjs/hooks/useFallbackImage/useFallbackImage.js +46 -0
  37. package/lib/cjs/hooks/useFallbackImage/useFallbackImage.test.js +65 -0
  38. package/lib/cjs/hooks/useNavBarPress/useNavBarPress.js +3 -3
  39. package/lib/cjs/hooks/useNavBarPress/useNavBarPress.test.js +4 -4
  40. package/lib/cjs/recipes/MultiselectListContainer.stories.js +352 -0
  41. package/lib/cjs/styles/variants/accordion.js +1 -1
  42. package/lib/cjs/styles/variants/boxes.js +2 -2
  43. package/lib/cjs/styles/variants/multiselectListContainer.js +4 -6
  44. package/lib/cjs/styles/variants/navBar.js +10 -1
  45. package/lib/cjs/styles/variants/separator.js +3 -3
  46. package/lib/cjs/styles/variants/text.js +5 -3
  47. package/lib/components/AccordionGridGroup/AccordionGridGroup.js +1 -0
  48. package/lib/components/AccordionGridItem/AccordionGridItem.js +3 -0
  49. package/lib/components/AccordionGridItem/AccordionGridItemBody.js +3 -0
  50. package/lib/components/AccordionGridItem/AccordionGridItemHeader.js +10 -4
  51. package/lib/components/ArrayField/ArrayField.test.js +9 -0
  52. package/lib/components/ArrayField/ArrayFieldDeleteButton.js +3 -8
  53. package/lib/components/AstroWrapper/AstroWrapper.js +4 -4
  54. package/lib/components/CodeView/CodeView.js +12 -5
  55. package/lib/components/CodeView/CodeView.stories.js +26 -0
  56. package/lib/components/ComboBoxField/ComboBoxField.js +1 -1
  57. package/lib/components/ComboBoxField/ComboBoxField.test.js +8 -4
  58. package/lib/components/Image/Image.js +123 -9
  59. package/lib/components/Image/Image.stories.js +39 -4
  60. package/lib/components/Image/Image.test.js +118 -1
  61. package/lib/components/Image/imageConstants.js +2 -0
  62. package/lib/components/ImageUploadField/ImageUploadField.test.js +27 -7
  63. package/lib/components/ListViewItem/ListViewItem.js +2 -1
  64. package/lib/components/MultiselectFilter/MultiselectFilter.js +1 -1
  65. package/lib/components/MultiselectFilterItem/MultiselectFilterItem.js +35 -12
  66. package/lib/components/MultiselectFilterItem/MultiselectFilterItem.test.js +11 -1
  67. package/lib/components/NavBar/NavBar.js +20 -8
  68. package/lib/components/NavBar/NavBar.stories.js +3 -2
  69. package/lib/components/NavBarSection/NavBarItem.js +1 -1
  70. package/lib/components/NavBarSection/NavBarItemButton.js +1 -1
  71. package/lib/components/NavBarSection/NavBarItemHeader.js +46 -4
  72. package/lib/components/NavBarSection/NavBarItemLink.js +1 -1
  73. package/lib/components/NavBarSection/NavBarSection.js +5 -2
  74. package/lib/components/NumberField/NumberField.js +32 -2
  75. package/lib/components/Text/Text.js +7 -2
  76. package/lib/components/Text/Text.stories.js +50 -0
  77. package/lib/components/Text/Text.test.js +36 -0
  78. package/lib/components/TimeZonePicker/TimeZonePicker.js +21 -10
  79. package/lib/hooks/index.js +2 -1
  80. package/lib/hooks/useFallbackImage/index.js +1 -0
  81. package/lib/hooks/useFallbackImage/useFallbackImage.js +32 -0
  82. package/lib/hooks/useFallbackImage/useFallbackImage.test.js +51 -0
  83. package/lib/hooks/useNavBarPress/useNavBarPress.js +3 -3
  84. package/lib/hooks/useNavBarPress/useNavBarPress.test.js +4 -4
  85. package/lib/recipes/MultiselectListContainer.stories.js +306 -0
  86. package/lib/styles/variants/accordion.js +1 -1
  87. package/lib/styles/variants/boxes.js +2 -2
  88. package/lib/styles/variants/multiselectListContainer.js +4 -6
  89. package/lib/styles/variants/navBar.js +10 -1
  90. package/lib/styles/variants/separator.js +3 -3
  91. package/lib/styles/variants/text.js +5 -3
  92. package/package.json +2 -1
@@ -1,18 +1,62 @@
1
+ import _Object$defineProperty from "@babel/runtime-corejs3/core-js-stable/object/define-property";
2
+ import _Object$defineProperties from "@babel/runtime-corejs3/core-js-stable/object/define-properties";
3
+ import _Object$getOwnPropertyDescriptors from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors";
4
+ import _forEachInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/for-each";
5
+ import _Object$getOwnPropertyDescriptor from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor";
6
+ import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter";
7
+ import _Object$getOwnPropertySymbols from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols";
8
+ import _Object$keys from "@babel/runtime-corejs3/core-js-stable/object/keys";
9
+ import _defineProperty from "@babel/runtime-corejs3/helpers/esm/defineProperty";
10
+ import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
11
+
12
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
13
+
14
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
15
+
1
16
  import React from 'react';
17
+ import { act } from '@testing-library/react';
2
18
  import axeTest from '../../utils/testUtils/testAxe';
3
19
  import { render, screen } from '../../utils/testUtils/testWrapper';
4
20
  import Image from '.';
5
21
  import { jsx as ___EmotionJSX } from "@emotion/react";
22
+ var testSrc = 'test-src';
23
+ var testFallbackSrc = 'test-fallback-src';
24
+ var skeletonImageId = 'skeleton-image';
25
+ var defaultProps = {
26
+ src: testSrc,
27
+ fallbackImage: testFallbackSrc
28
+ };
6
29
 
7
30
  var getComponent = function getComponent() {
8
31
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
9
- return render(___EmotionJSX(Image, props));
32
+ return render(___EmotionJSX(Image, _extends({}, defaultProps, props)));
10
33
  }; // Need to be added to each test file to test accessibility using axe.
11
34
 
12
35
 
13
36
  axeTest(getComponent);
37
+ var fallbackImageObj = null;
38
+ jest.mock('../../hooks/useFallbackImage', function () {
39
+ return function (props) {
40
+ fallbackImageObj = _objectSpread({}, props);
41
+ return [];
42
+ };
43
+ });
14
44
  test('an image is rendered', function () {
15
45
  getComponent();
46
+ act(function () {
47
+ fallbackImageObj.onImageLoad();
48
+ });
49
+ var img = screen.getByRole('img');
50
+ expect(img).toBeInstanceOf(HTMLImageElement);
51
+ expect(img).toBeInTheDocument();
52
+ });
53
+ test('an image is rendered with no fallback', function () {
54
+ getComponent({
55
+ fallbackImage: null
56
+ });
57
+ act(function () {
58
+ fallbackImageObj.onImageLoad();
59
+ });
16
60
  var img = screen.getByRole('img');
17
61
  expect(img).toBeInstanceOf(HTMLImageElement);
18
62
  expect(img).toBeInTheDocument();
@@ -21,6 +65,79 @@ test('image shows disabled status', function () {
21
65
  getComponent({
22
66
  isDisabled: true
23
67
  });
68
+ act(function () {
69
+ fallbackImageObj.onImageLoad();
70
+ });
24
71
  var img = screen.getByRole('img');
25
72
  expect(img).toHaveClass('is-disabled');
73
+ });
74
+ describe('test Image component with useFallbackImage hook', function () {
75
+ test('image component will use src if loaded correctly', function () {
76
+ getComponent();
77
+ act(function () {
78
+ fallbackImageObj.onImageLoad();
79
+ });
80
+ expect(screen.getByRole('img')).toHaveAttribute('src', testSrc);
81
+ });
82
+ test('image component will use fallbackImg if src loaded with error', function () {
83
+ getComponent();
84
+ act(function () {
85
+ fallbackImageObj.onImageError();
86
+ });
87
+ var img = screen.getByRole('img');
88
+ expect(img).toHaveAttribute('src', testFallbackSrc);
89
+ });
90
+ test('image component will use fallbackImg if src timed out', function () {
91
+ getComponent();
92
+ act(function () {
93
+ fallbackImageObj.onFallbackTimeout();
94
+ });
95
+ var img = screen.getByRole('img');
96
+ expect(img).toHaveAttribute('src', testFallbackSrc);
97
+ });
98
+ test('if image loads after timeout src still be the fallback', function () {
99
+ getComponent();
100
+ act(function () {
101
+ fallbackImageObj.onFallbackTimeout();
102
+ fallbackImageObj.onImageLoad();
103
+ });
104
+ var img = screen.getByRole('img');
105
+ expect(img).toHaveAttribute('src', testFallbackSrc);
106
+ });
107
+ test('if image loads before timeout src still be the the origin one', function () {
108
+ getComponent();
109
+ act(function () {
110
+ fallbackImageObj.onImageLoad();
111
+ fallbackImageObj.onFallbackTimeout();
112
+ });
113
+ expect(screen.getByRole('img')).toHaveAttribute('src', testSrc);
114
+ });
115
+ test('the skeleton loading will appear if no fallback image is given', function () {
116
+ getComponent({
117
+ fallbackImage: null
118
+ });
119
+ expect(screen.getByTestId(skeletonImageId)).toBeInTheDocument();
120
+ act(function () {
121
+ fallbackImageObj.onImageLoad();
122
+ });
123
+ expect(screen.getByRole('img')).toHaveAttribute('src', testSrc);
124
+ });
125
+ test('the skeleton will be shown instead of img if no fallback image is given and image load failed', function () {
126
+ getComponent({
127
+ fallbackImage: null
128
+ });
129
+ act(function () {
130
+ fallbackImageObj.onImageError();
131
+ });
132
+ expect(screen.getByTestId(skeletonImageId)).toBeInTheDocument();
133
+ });
134
+ test('the skeleton will be shown instead of img if no fallback image is given and image load timed out', function () {
135
+ getComponent({
136
+ fallbackImage: null
137
+ });
138
+ act(function () {
139
+ fallbackImageObj.onFallbackTimeout();
140
+ });
141
+ expect(screen.getByTestId(skeletonImageId)).toBeInTheDocument();
142
+ });
26
143
  });
@@ -0,0 +1,2 @@
1
+ export var pingImg = '';
2
+ export var chiefIdentityChampions = 'https://images.pingidentity.com/image/upload/f_auto,q_auto,w_auto,c_scale/ping_dam/content/dam/ping-6-2-assets/images/company/our-company/chief-identity-champions.png';
@@ -7,15 +7,21 @@ import userEvent from '@testing-library/user-event';
7
7
  import axeTest from '../../utils/testUtils/testAxe';
8
8
  import { render, screen } from '../../utils/testUtils/testWrapper';
9
9
  import ImageUploadField from './ImageUploadField';
10
- import { Image } from '../../index';
11
10
  import { jsx as ___EmotionJSX } from "@emotion/react";
11
+ var imageUploadNoImagePreview = 'image-upload-no-image-preview';
12
+ jest.mock('../Image', function () {
13
+ return function (props) {
14
+ return ___EmotionJSX("img", _extends({
15
+ alt: "mock"
16
+ }, props));
17
+ };
18
+ });
12
19
  var testLabel = 'test-label';
13
20
  var testButtonId = 'image-preview-button';
14
21
  var testHelperText = 'test-helper-text';
15
22
  var testImageURL = 'test-image-url';
16
23
  var testImageURL2 = 'test-image-url2';
17
24
  var imageUploadImagePreview = 'image-upload-image-preview';
18
- var imageUploadNoImagePreview = 'image-upload-no-image-preview';
19
25
  var file = new File(['(⌐□_□)'], 'chucknorris.png', {
20
26
  type: 'image/png'
21
27
  });
@@ -185,10 +191,16 @@ test('should change image if the corresponding menu option clicked', /*#__PURE__
185
191
  files: [file]
186
192
  }
187
193
  });
188
- expect(imagePreview).toBeInTheDocument();
194
+ _context4.t0 = expect;
195
+ _context4.next = 14;
196
+ return screen.findByTestId(imageUploadImagePreview);
197
+
198
+ case 14:
199
+ _context4.t1 = _context4.sent;
200
+ (0, _context4.t0)(_context4.t1).toBeInTheDocument();
189
201
  expect(imagePreview).toHaveAttribute('src');
190
202
 
191
- case 13:
203
+ case 17:
192
204
  case "end":
193
205
  return _context4.stop();
194
206
  }
@@ -228,12 +240,18 @@ test('should call onRemove cb (when provided) when a file is uploaded', /*#__PUR
228
240
  case 5:
229
241
  imagePreview = _context5.sent;
230
242
  userEvent.click(screen.getByTestId(testButtonId));
231
- expect(imagePreview).toBeInTheDocument();
243
+ _context5.t0 = expect;
244
+ _context5.next = 10;
245
+ return screen.findByTestId(imageUploadImagePreview);
246
+
247
+ case 10:
248
+ _context5.t1 = _context5.sent;
249
+ (0, _context5.t0)(_context5.t1).toBeInTheDocument();
232
250
  userEvent.click(screen.getByText('Remove Image'));
233
251
  expect(imagePreview).not.toBeInTheDocument();
234
252
  expect(testOnRemove).toHaveBeenCalledTimes(1);
235
253
 
236
- case 11:
254
+ case 15:
237
255
  case "end":
238
256
  return _context5.stop();
239
257
  }
@@ -372,7 +390,9 @@ test('should show the menu if label clicked when preview image exists', /*#__PUR
372
390
  })));
373
391
  test('should render node element if passed as default image', function () {
374
392
  getComponent({
375
- defaultPreviewImage: ___EmotionJSX(Image, null)
393
+ defaultPreviewImage: ___EmotionJSX("img", {
394
+ alt: "mock"
395
+ })
376
396
  });
377
397
  var img = screen.getByRole('img');
378
398
  expect(img).toBeInstanceOf(HTMLImageElement);
@@ -34,6 +34,7 @@ var ListViewItem = function ListViewItem(props) {
34
34
  var isDisabled = state.disabledKeys.has(item.key);
35
35
  var rowRef = useRef();
36
36
  var cellRef = useRef();
37
+ var isSelectable = state.selectionManager.selectionMode !== 'none';
37
38
 
38
39
  var _useFocusRing = useFocusRing({
39
40
  within: true
@@ -73,7 +74,7 @@ var ListViewItem = function ListViewItem(props) {
73
74
  var mergedProps = mergeProps(gridCellProps, hoverProps, focusWithinProps, focusProps, selectableItemProps);
74
75
 
75
76
  var _useStatusClasses = useStatusClasses(className, {
76
- isHovered: isHovered,
77
+ isHovered: isSelectable && isHovered,
77
78
  isSelected: isSelected,
78
79
  isFocused: isDisabled ? false : isFocusVisible,
79
80
  hasSeparator: hasSeparator
@@ -72,7 +72,7 @@ var MultiselectFilter = /*#__PURE__*/forwardRef(function (props, ref) {
72
72
  }, ___EmotionJSX(ListView, {
73
73
  items: items,
74
74
  onSelectionChange: onSelectionChange,
75
- selectionMode: "multiple",
75
+ selectionMode: "none",
76
76
  style: {
77
77
  width: '100%'
78
78
  },
@@ -1,25 +1,37 @@
1
1
  import React, { forwardRef } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { Box, Icon, Text } from '../../index';
3
+ import { Box, Icon, IconButton, Text } from '../../index';
4
4
  import { jsx as ___EmotionJSX } from "@emotion/react";
5
5
  var MultiselectFilterItem = /*#__PURE__*/forwardRef(function (props, ref) {
6
6
  var text = props.text,
7
- icon = props.icon;
7
+ icon = props.icon,
8
+ isDefaultSelected = props.isDefaultSelected,
9
+ onPress = props.onPress;
10
+
11
+ var iconElement = icon && ___EmotionJSX(Icon, {
12
+ "data-testid": "multiselect-filter-data-icon",
13
+ icon: icon,
14
+ color: isDefaultSelected ? 'neutral.10' : 'active',
15
+ size: 13
16
+ });
17
+
8
18
  return ___EmotionJSX(Box, {
9
19
  "data-testid": "multiselect-filter-item",
10
20
  isRow: true,
11
- justifyContent: "space-between",
12
21
  ref: ref
13
22
  }, ___EmotionJSX(Text, {
14
23
  variant: "multiselectFilterItem"
15
- }, text), icon && ___EmotionJSX(Icon, {
16
- "data-testid": "multiselect-filter-data-icon",
17
- icon: icon,
18
- mr: "md",
19
- color: "neutral.10",
20
- size: 13,
21
- flexShrink: 0
22
- }));
24
+ }, text), iconElement && (isDefaultSelected ? iconElement : ___EmotionJSX(IconButton, {
25
+ sx: {
26
+ width: 13,
27
+ height: 13,
28
+ alignSelf: 'auto',
29
+ '& path': {
30
+ fill: 'inherit'
31
+ }
32
+ },
33
+ onPress: onPress
34
+ }, iconElement)));
23
35
  });
24
36
  MultiselectFilterItem.propTypes = {
25
37
  /**
@@ -30,7 +42,18 @@ MultiselectFilterItem.propTypes = {
30
42
  /**
31
43
  * List icon.
32
44
  */
33
- icon: PropTypes.shape({})
45
+ icon: PropTypes.shape({}),
46
+
47
+ /**
48
+ * Whether the element is default selected
49
+ * and has to use Icon element instead of IconButton
50
+ */
51
+ isDefaultSelected: PropTypes.bool,
52
+
53
+ /**
54
+ * Handler that is called at the press on icon button
55
+ */
56
+ onPress: PropTypes.func
34
57
  };
35
58
  MultiselectFilterItem.displayName = 'MultiselectFilterItem';
36
59
  export default MultiselectFilterItem;
@@ -28,10 +28,20 @@ test('default multiselectFilter', function () {
28
28
  expect(icon).not.toBeInTheDocument();
29
29
  expect(multiselectFilterItem).toBeInTheDocument();
30
30
  });
31
- test('icon displays when icon prop is present', function () {
31
+ test('icon button displays when icon prop is present', function () {
32
32
  getComponent({
33
33
  icon: FilterIcon
34
34
  });
35
35
  var icon = screen.getByTestId(iconId);
36
36
  expect(icon).toBeInTheDocument();
37
+ expect(icon.parentElement).toBeInstanceOf(HTMLButtonElement);
38
+ });
39
+ test('icon displays when icon prop is present and default selected', function () {
40
+ getComponent({
41
+ icon: FilterIcon,
42
+ isDefaultSelected: true
43
+ });
44
+ var icon = screen.getByTestId(iconId);
45
+ expect(icon).toBeInTheDocument();
46
+ expect(icon.parentElement).not.toBeInstanceOf(HTMLButtonElement);
37
47
  });
@@ -17,17 +17,25 @@ import Box from '../Box/Box';
17
17
  import { jsx as ___EmotionJSX } from "@emotion/react";
18
18
 
19
19
  var NavBar = function NavBar(props) {
20
- var defaultSelectedKeys = props.defaultSelectedKeys;
20
+ var defaultSelectedKey = props.defaultSelectedKey,
21
+ defaultExpandedKeys = props.defaultExpandedKeys;
21
22
 
22
- var _useState = useState(defaultSelectedKeys),
23
+ var _useState = useState(defaultSelectedKey),
23
24
  _useState2 = _slicedToArray(_useState, 2),
24
- selectedKeys = _useState2[0],
25
- setSelectedKeys = _useState2[1];
25
+ selectedKey = _useState2[0],
26
+ setSelectedKey = _useState2[1];
27
+
28
+ var _useState3 = useState(defaultExpandedKeys),
29
+ _useState4 = _slicedToArray(_useState3, 2),
30
+ expandedKeys = _useState4[0],
31
+ setExpandedKeys = _useState4[1];
26
32
 
27
33
  return ___EmotionJSX(NavBarContext.Provider, {
28
34
  value: {
29
- selectedKeys: selectedKeys,
30
- setSelectedKeys: setSelectedKeys
35
+ selectedKey: selectedKey,
36
+ setSelectedKey: setSelectedKey,
37
+ expandedKeys: expandedKeys,
38
+ setExpandedKeys: setExpandedKeys
31
39
  }
32
40
  }, ___EmotionJSX(Box, {
33
41
  variant: "navBar.container",
@@ -37,9 +45,13 @@ var NavBar = function NavBar(props) {
37
45
  };
38
46
 
39
47
  NavBar.propTypes = {
40
- defaultSelectedKeys: isIterableProp
48
+ /** The initial selected key in the collection (uncontrolled). */
49
+ defaultSelectedKey: isIterableProp,
50
+
51
+ /** The initial expanded keys in the collection (uncontrolled). */
52
+ defaultExpandedKeys: isIterableProp
41
53
  };
42
54
  NavBar.defaultProps = {
43
- defaultSelectedKeys: []
55
+ defaultSelectedKey: []
44
56
  };
45
57
  export default NavBar;
@@ -228,7 +228,7 @@ var thirdData = [{
228
228
  }];
229
229
  export var Default = function Default() {
230
230
  return ___EmotionJSX(NavBar, {
231
- defaultSelectedKeys: ['Dashboard Link Group']
231
+ defaultSelectedKey: "Dashboard Link Group"
232
232
  }, ___EmotionJSX(Box, {
233
233
  padding: "md"
234
234
  }, ___EmotionJSX(Link, {
@@ -237,7 +237,8 @@ export var Default = function Default() {
237
237
  "aria-label": "home link"
238
238
  }, logo)), ___EmotionJSX(Separator, {
239
239
  marginTop: "lg",
240
- marginBottom: "sm"
240
+ marginBottom: "sm",
241
+ backgroundColor: "neutral.60"
241
242
  }), ___EmotionJSX(Box, {
242
243
  variant: "navBar.sectionContainer",
243
244
  paddingBottom: "xl"
@@ -43,7 +43,7 @@ var NavBarItem = /*#__PURE__*/forwardRef(function (props, ref) {
43
43
 
44
44
  var state = useNavBarContext();
45
45
 
46
- var isSelected = _includesInstanceProperty(_context = state.selectedKeys).call(_context, key);
46
+ var isSelected = _includesInstanceProperty(_context = state.selectedKey).call(_context, key);
47
47
 
48
48
  var _useNavBarPress = useNavBarPress({
49
49
  key: key,
@@ -34,7 +34,7 @@ var NavBarItemButton = function NavBarItemButton(props) {
34
34
 
35
35
  var state = useNavBarContext();
36
36
 
37
- var isSelected = _includesInstanceProperty(_context = state.selectedKeys).call(_context, key);
37
+ var isSelected = _includesInstanceProperty(_context = state.selectedKey).call(_context, key);
38
38
 
39
39
  var _useNavBarPress = useNavBarPress({
40
40
  key: key,
@@ -1,13 +1,43 @@
1
- import React from 'react';
1
+ import _includesInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/includes";
2
+ import _mapInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/map";
3
+ import React, { useContext } from 'react';
2
4
  import PropTypes from 'prop-types';
5
+ import MenuDown from 'mdi-react/MenuDownIcon';
6
+ import MenuUp from 'mdi-react/MenuUpIcon';
3
7
  import { Box, Icon, Text } from '../../index';
8
+ import { AccordionGridContext } from '../../context/AccordionGridContext';
9
+ import { NavBarContext } from '../../context/NavBarContext';
10
+ import { useStatusClasses } from '../../hooks';
4
11
  import { jsx as ___EmotionJSX } from "@emotion/react";
5
12
 
6
13
  var NavBarItemHeader = function NavBarItemHeader(props) {
14
+ var _state$selectionManag, _context;
15
+
7
16
  var item = props.item;
8
- var icon = item.icon;
17
+ var icon = item.icon,
18
+ key = item.key,
19
+ className = item.className;
20
+
21
+ var _useContext = useContext(AccordionGridContext),
22
+ state = _useContext.state;
23
+
24
+ var navState = useContext(NavBarContext);
25
+ var isExpanded = (_state$selectionManag = state.selectionManager.selectedKeys) === null || _state$selectionManag === void 0 ? void 0 : _state$selectionManag.has(key);
26
+
27
+ var array = _mapInstanceProperty(_context = item.children).call(_context, function (i) {
28
+ return i.key;
29
+ });
30
+
31
+ var childSelected = _includesInstanceProperty(array).call(array, navState.selectedKey);
32
+
33
+ var _useStatusClasses = useStatusClasses(className, {
34
+ isSelected: childSelected && !isExpanded
35
+ }),
36
+ classNames = _useStatusClasses.classNames;
37
+
9
38
  return ___EmotionJSX(Box, {
10
39
  variant: "navBar.itemHeaderContainer",
40
+ className: classNames,
11
41
  isRow: true
12
42
  }, icon && ___EmotionJSX(Icon, {
13
43
  icon: icon,
@@ -19,13 +49,25 @@ var NavBarItemHeader = function NavBarItemHeader(props) {
19
49
  }
20
50
  }), ___EmotionJSX(Text, {
21
51
  variant: "navBarHeaderText"
22
- }, props.item.heading));
52
+ }, props.item.heading), ___EmotionJSX(Box, {
53
+ isRow: true,
54
+ alignItems: "center",
55
+ sx: {
56
+ ml: 'auto'
57
+ }
58
+ }, ___EmotionJSX(Icon, {
59
+ icon: isExpanded ? MenuUp : MenuDown,
60
+ size: 20
61
+ })));
23
62
  };
24
63
 
25
64
  NavBarItemHeader.propTypes = {
26
65
  item: PropTypes.shape({
27
66
  heading: PropTypes.string,
28
- icon: PropTypes.elementType
67
+ icon: PropTypes.elementType,
68
+ className: PropTypes.string,
69
+ children: PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object])),
70
+ key: PropTypes.string
29
71
  })
30
72
  };
31
73
  export default NavBarItemHeader;
@@ -33,7 +33,7 @@ var NavBarItemLink = function NavBarItemLink(props) {
33
33
 
34
34
  var state = useNavBarContext();
35
35
 
36
- var isSelected = _includesInstanceProperty(_context = state.selectedKeys).call(_context, key);
36
+ var isSelected = _includesInstanceProperty(_context = state.selectedKey).call(_context, key);
37
37
 
38
38
  var _useNavBarPress = useNavBarPress({
39
39
  key: key,
@@ -25,7 +25,8 @@ var NavBarSection = function NavBarSection(props) {
25
25
  }, function (item) {
26
26
  return ___EmotionJSX(Item, {
27
27
  headerProps: {
28
- variant: 'accordion.accordionGridHeaderNav'
28
+ variant: 'accordion.accordionGridHeaderNav',
29
+ hasCaret: false
29
30
  },
30
31
  bodyProps: {
31
32
  variant: 'navBar.sectionBody'
@@ -40,7 +41,9 @@ var NavBarSection = function NavBarSection(props) {
40
41
  sx: {
41
42
  pl: '15px',
42
43
  pr: '15px',
43
- my: '10px'
44
+ my: '10px',
45
+ mt: '15px',
46
+ mb: '15px'
44
47
  }
45
48
  }, ___EmotionJSX(Separator, {
46
49
  variant: "separator.navBarSeparator"
@@ -7,12 +7,13 @@ import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/insta
7
7
  import _Object$getOwnPropertySymbols from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols";
8
8
  import _Object$keys from "@babel/runtime-corejs3/core-js-stable/object/keys";
9
9
  import _Object$values from "@babel/runtime-corejs3/core-js-stable/object/values";
10
+ import _trimInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/trim";
10
11
  import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
11
12
  import _defineProperty from "@babel/runtime-corejs3/helpers/esm/defineProperty";
12
13
 
13
14
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
14
15
 
15
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
16
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context2, _context3; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(source), !0)).call(_context2, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context3 = ownKeys(Object(source))).call(_context3, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
16
17
 
17
18
  import React, { forwardRef, useCallback, useImperativeHandle, useMemo } from 'react';
18
19
  import PropTypes from 'prop-types';
@@ -105,6 +106,33 @@ var NumberField = /*#__PURE__*/forwardRef(function (props, ref) {
105
106
  onBlur: onInputBlur
106
107
  });
107
108
  }, [fieldControlProps, onInputBlur, onInputFocus]);
109
+
110
+ var onInputChange = function onInputChange(e) {
111
+ var _context;
112
+
113
+ var minValue = props.minValue;
114
+
115
+ var trimmedInputValue = _trimInstanceProperty(_context = e.target.value).call(_context);
116
+
117
+ var trimmedValueEvent = _objectSpread(_objectSpread({}, e), {}, {
118
+ target: _objectSpread(_objectSpread({}, e.target), {}, {
119
+ value: trimmedInputValue
120
+ })
121
+ });
122
+
123
+ if (!trimmedInputValue && typeof minValue !== 'undefined') {
124
+ var minValueEvent = _objectSpread(_objectSpread({}, e), {}, {
125
+ target: _objectSpread(_objectSpread({}, e.target), {}, {
126
+ value: minValue.toString()
127
+ })
128
+ });
129
+
130
+ inputProps.onChange(minValueEvent);
131
+ } else {
132
+ inputProps.onChange(trimmedValueEvent);
133
+ }
134
+ };
135
+
108
136
  return ___EmotionJSX(Box, fieldContainerProps, ___EmotionJSX(Label, mergeProps(fieldLabelProps, labelProps)), ___EmotionJSX(Box, _extends({
109
137
  variant: "numberField.noDefaultArrows"
110
138
  }, groupProps), ___EmotionJSX(Box, {
@@ -115,7 +143,9 @@ var NumberField = /*#__PURE__*/forwardRef(function (props, ref) {
115
143
  ref: inputRef // we don't want to merge this props, we want to
116
144
  // overwrite them like defaultValue, value, ect.
117
145
 
118
- }, updatedFieldControlProps, omit(inputProps, ['name', 'onFocus', 'onBlur']))), ControlArrows), helperText && ___EmotionJSX(FieldHelperText, {
146
+ }, updatedFieldControlProps, omit(inputProps, ['name', 'onFocus', 'onBlur']), {
147
+ onChange: onInputChange
148
+ })), ControlArrows), helperText && ___EmotionJSX(FieldHelperText, {
119
149
  status: status
120
150
  }, helperText)));
121
151
  });
@@ -2,7 +2,7 @@ import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
2
2
  import _styled from "@emotion/styled/base";
3
3
  import React from 'react';
4
4
  import PropTypes from 'prop-types';
5
- import { layout, flexbox } from 'styled-system';
5
+ import { layout, flexbox, typography } from 'styled-system';
6
6
  import { Text as ThemeUIText } from 'theme-ui';
7
7
  import { textVariants } from '../../utils/devUtils/constants/variants';
8
8
  import { jsx as ___EmotionJSX } from "@emotion/react";
@@ -12,7 +12,12 @@ var ExtendedText = /*#__PURE__*/_styled(ThemeUIText, process.env.NODE_ENV === "p
12
12
  } : {
13
13
  target: "eifd86o0",
14
14
  label: "ExtendedText"
15
- })(layout, flexbox, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHQvVGV4dC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRcUIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dC9UZXh0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBsYXlvdXQsIGZsZXhib3ggfSBmcm9tICdzdHlsZWQtc3lzdGVtJztcbmltcG9ydCB7IFRleHQgYXMgVGhlbWVVSVRleHQgfSBmcm9tICd0aGVtZS11aSc7XG5cbmltcG9ydCB7IHRleHRWYXJpYW50cyB9IGZyb20gJy4uLy4uL3V0aWxzL2RldlV0aWxzL2NvbnN0YW50cy92YXJpYW50cyc7XG5cbmNvbnN0IEV4dGVuZGVkVGV4dCA9IHN0eWxlZChUaGVtZVVJVGV4dCkobGF5b3V0LCBmbGV4Ym94KTtcblxuY29uc3QgVGV4dCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IChcbiAgPEV4dGVuZGVkVGV4dCB2YXJpYW50PVwiYmFzZVwiIHsuLi5wcm9wc30gcmVmPXtyZWZ9IC8+XG4pKTtcblxuVGV4dC5wcm9wVHlwZXMgPSB7XG4gIHZhcmlhbnQ6IFByb3BUeXBlcy5zdHJpbmcsXG59O1xuXG5cblRleHQuZGVmYXVsdFByb3BzID0ge1xuICB2YXJpYW50OiB0ZXh0VmFyaWFudHMuQkFTRSxcbn07XG5cblRleHQuZGlzcGxheU5hbWUgPSAnVGV4dCc7XG5cbmV4cG9ydCBkZWZhdWx0IFRleHQ7XG4iXX0= */");
15
+ })(layout, flexbox, typography, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHQvVGV4dC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRcUIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dC9UZXh0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBsYXlvdXQsIGZsZXhib3gsIHR5cG9ncmFwaHkgfSBmcm9tICdzdHlsZWQtc3lzdGVtJztcbmltcG9ydCB7IFRleHQgYXMgVGhlbWVVSVRleHQgfSBmcm9tICd0aGVtZS11aSc7XG5cbmltcG9ydCB7IHRleHRWYXJpYW50cyB9IGZyb20gJy4uLy4uL3V0aWxzL2RldlV0aWxzL2NvbnN0YW50cy92YXJpYW50cyc7XG5cbmNvbnN0IEV4dGVuZGVkVGV4dCA9IHN0eWxlZChUaGVtZVVJVGV4dCkobGF5b3V0LCBmbGV4Ym94LCB0eXBvZ3JhcGh5KTtcblxuLyoqXG4gKiBUaGUgVGV4dCBjb21wb25lbnQgaXMgdXNlZCBmb3IgZGlzcGxheWluZyB0ZXh0LlxuICogVGV4dCBzdXBwb3J0cyBbVHlwb2dyYXBoeSBQcm9wcyBmcm9tIFN0eWxlZCBTeXN0ZW0gXShodHRwczovL3N0eWxlZC1zeXN0ZW0uY29tL3RhYmxlLyN0eXBvZ3JhcGh5KS5cbiAqL1xuXG5jb25zdCBUZXh0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4gKFxuICA8RXh0ZW5kZWRUZXh0IHZhcmlhbnQ9XCJiYXNlXCIgey4uLnByb3BzfSByZWY9e3JlZn0gLz5cbikpO1xuXG5UZXh0LnByb3BUeXBlcyA9IHtcbiAgdmFyaWFudDogUHJvcFR5cGVzLnN0cmluZyxcbn07XG5cblxuVGV4dC5kZWZhdWx0UHJvcHMgPSB7XG4gIHZhcmlhbnQ6IHRleHRWYXJpYW50cy5CQVNFLFxufTtcblxuVGV4dC5kaXNwbGF5TmFtZSA9ICdUZXh0JztcblxuZXhwb3J0IGRlZmF1bHQgVGV4dDtcbiJdfQ== */");
16
+ /**
17
+ * The Text component is used for displaying text.
18
+ * Text supports [Typography Props from Styled System ](https://styled-system.com/table/#typography).
19
+ */
20
+
16
21
 
17
22
  var Text = /*#__PURE__*/React.forwardRef(function (props, ref) {
18
23
  return ___EmotionJSX(ExtendedText, _extends({