@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.
- package/CHANGELOG.md +13 -0
- package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.js +1 -0
- package/lib/cjs/components/AccordionGridItem/AccordionGridItem.js +3 -0
- package/lib/cjs/components/AccordionGridItem/AccordionGridItemBody.js +3 -0
- package/lib/cjs/components/AccordionGridItem/AccordionGridItemHeader.js +10 -4
- package/lib/cjs/components/ArrayField/ArrayField.test.js +13 -0
- package/lib/cjs/components/ArrayField/ArrayFieldDeleteButton.js +3 -8
- package/lib/cjs/components/AstroWrapper/AstroWrapper.js +4 -4
- package/lib/cjs/components/CodeView/CodeView.js +11 -4
- package/lib/cjs/components/CodeView/CodeView.stories.js +33 -2
- package/lib/cjs/components/ComboBoxField/ComboBoxField.js +1 -1
- package/lib/cjs/components/ComboBoxField/ComboBoxField.test.js +8 -4
- package/lib/cjs/components/Image/Image.js +132 -11
- package/lib/cjs/components/Image/Image.stories.js +52 -6
- package/lib/cjs/components/Image/Image.test.js +138 -2
- package/lib/cjs/components/Image/imageConstants.js +13 -0
- package/lib/cjs/components/ImageUploadField/ImageUploadField.test.js +27 -8
- package/lib/cjs/components/ListViewItem/ListViewItem.js +2 -1
- package/lib/cjs/components/MultiselectFilter/MultiselectFilter.js +1 -1
- package/lib/cjs/components/MultiselectFilterItem/MultiselectFilterItem.js +32 -11
- package/lib/cjs/components/MultiselectFilterItem/MultiselectFilterItem.test.js +13 -1
- package/lib/cjs/components/NavBar/NavBar.js +20 -8
- package/lib/cjs/components/NavBar/NavBar.stories.js +3 -2
- package/lib/cjs/components/NavBarSection/NavBarItem.js +1 -1
- package/lib/cjs/components/NavBarSection/NavBarItemButton.js +1 -1
- package/lib/cjs/components/NavBarSection/NavBarItemHeader.js +61 -4
- package/lib/cjs/components/NavBarSection/NavBarItemLink.js +1 -1
- package/lib/cjs/components/NavBarSection/NavBarSection.js +5 -2
- package/lib/cjs/components/NumberField/NumberField.js +32 -2
- package/lib/cjs/components/Text/Text.js +5 -1
- package/lib/cjs/components/Text/Text.stories.js +56 -2
- package/lib/cjs/components/Text/Text.test.js +46 -0
- package/lib/cjs/components/TimeZonePicker/TimeZonePicker.js +21 -10
- package/lib/cjs/hooks/index.js +10 -1
- package/lib/cjs/hooks/useFallbackImage/index.js +18 -0
- package/lib/cjs/hooks/useFallbackImage/useFallbackImage.js +46 -0
- package/lib/cjs/hooks/useFallbackImage/useFallbackImage.test.js +65 -0
- package/lib/cjs/hooks/useNavBarPress/useNavBarPress.js +3 -3
- package/lib/cjs/hooks/useNavBarPress/useNavBarPress.test.js +4 -4
- package/lib/cjs/recipes/MultiselectListContainer.stories.js +352 -0
- package/lib/cjs/styles/variants/accordion.js +1 -1
- package/lib/cjs/styles/variants/boxes.js +2 -2
- package/lib/cjs/styles/variants/multiselectListContainer.js +4 -6
- package/lib/cjs/styles/variants/navBar.js +10 -1
- package/lib/cjs/styles/variants/separator.js +3 -3
- package/lib/cjs/styles/variants/text.js +5 -3
- package/lib/components/AccordionGridGroup/AccordionGridGroup.js +1 -0
- package/lib/components/AccordionGridItem/AccordionGridItem.js +3 -0
- package/lib/components/AccordionGridItem/AccordionGridItemBody.js +3 -0
- package/lib/components/AccordionGridItem/AccordionGridItemHeader.js +10 -4
- package/lib/components/ArrayField/ArrayField.test.js +9 -0
- package/lib/components/ArrayField/ArrayFieldDeleteButton.js +3 -8
- package/lib/components/AstroWrapper/AstroWrapper.js +4 -4
- package/lib/components/CodeView/CodeView.js +12 -5
- package/lib/components/CodeView/CodeView.stories.js +26 -0
- package/lib/components/ComboBoxField/ComboBoxField.js +1 -1
- package/lib/components/ComboBoxField/ComboBoxField.test.js +8 -4
- package/lib/components/Image/Image.js +123 -9
- package/lib/components/Image/Image.stories.js +39 -4
- package/lib/components/Image/Image.test.js +118 -1
- package/lib/components/Image/imageConstants.js +2 -0
- package/lib/components/ImageUploadField/ImageUploadField.test.js +27 -7
- package/lib/components/ListViewItem/ListViewItem.js +2 -1
- package/lib/components/MultiselectFilter/MultiselectFilter.js +1 -1
- package/lib/components/MultiselectFilterItem/MultiselectFilterItem.js +35 -12
- package/lib/components/MultiselectFilterItem/MultiselectFilterItem.test.js +11 -1
- package/lib/components/NavBar/NavBar.js +20 -8
- package/lib/components/NavBar/NavBar.stories.js +3 -2
- package/lib/components/NavBarSection/NavBarItem.js +1 -1
- package/lib/components/NavBarSection/NavBarItemButton.js +1 -1
- package/lib/components/NavBarSection/NavBarItemHeader.js +46 -4
- package/lib/components/NavBarSection/NavBarItemLink.js +1 -1
- package/lib/components/NavBarSection/NavBarSection.js +5 -2
- package/lib/components/NumberField/NumberField.js +32 -2
- package/lib/components/Text/Text.js +7 -2
- package/lib/components/Text/Text.stories.js +50 -0
- package/lib/components/Text/Text.test.js +36 -0
- package/lib/components/TimeZonePicker/TimeZonePicker.js +21 -10
- package/lib/hooks/index.js +2 -1
- package/lib/hooks/useFallbackImage/index.js +1 -0
- package/lib/hooks/useFallbackImage/useFallbackImage.js +32 -0
- package/lib/hooks/useFallbackImage/useFallbackImage.test.js +51 -0
- package/lib/hooks/useNavBarPress/useNavBarPress.js +3 -3
- package/lib/hooks/useNavBarPress/useNavBarPress.test.js +4 -4
- package/lib/recipes/MultiselectListContainer.stories.js +306 -0
- package/lib/styles/variants/accordion.js +1 -1
- package/lib/styles/variants/boxes.js +2 -2
- package/lib/styles/variants/multiselectListContainer.js +4 -6
- package/lib/styles/variants/navBar.js +10 -1
- package/lib/styles/variants/separator.js +3 -3
- package/lib/styles/variants/text.js +5 -3
- 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
|
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
|
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
|
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
|
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(
|
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
|
@@ -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),
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
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
|
20
|
+
var defaultSelectedKey = props.defaultSelectedKey,
|
21
|
+
defaultExpandedKeys = props.defaultExpandedKeys;
|
21
22
|
|
22
|
-
var _useState = useState(
|
23
|
+
var _useState = useState(defaultSelectedKey),
|
23
24
|
_useState2 = _slicedToArray(_useState, 2),
|
24
|
-
|
25
|
-
|
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
|
-
|
30
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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.
|
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.
|
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
|
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.
|
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
|
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'])
|
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,
|
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({
|