@pingux/astro 1.2.0-alpha.6 → 1.2.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 +43 -0
- package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.js +32 -25
- package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.stories.js +148 -169
- package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.test.js +25 -30
- package/lib/cjs/components/AccordionGridItem/AccordionGridItem.js +29 -14
- package/lib/cjs/components/AccordionGridItem/AccordionGridItemBody.js +3 -3
- package/lib/cjs/components/AccordionGridItem/AccordionGridItemHeader.js +16 -18
- package/lib/cjs/components/AccordionGroup/AccordionGroup.js +2 -1
- package/lib/cjs/components/AccordionGroup/AccordionGroup.test.js +20 -1
- package/lib/cjs/components/Breadcrumbs/Breadcrumbs.stories.js +3 -3
- package/lib/cjs/components/Button/Button.js +14 -2
- package/lib/cjs/components/Button/Button.stories.js +33 -33
- package/lib/cjs/components/EnvironmentBreadcrumb/EnvironmentBreadcrumb.js +5 -3
- package/lib/cjs/components/Link/Link.js +2 -1
- package/lib/cjs/components/ListView/ListView.js +9 -13
- package/lib/cjs/components/ListViewItem/ListViewItem.js +15 -3
- package/lib/cjs/components/Modal/Modal.stories.js +1 -1
- package/lib/cjs/components/OverlayPanel/OverlayPanel.js +2 -16
- package/lib/cjs/components/OverlayPanel/OverlayPanel.test.js +44 -0
- package/lib/cjs/components/RockerButton/RockerButton.js +14 -22
- package/lib/cjs/components/RockerButtonGroup/RockerButtonGroup.js +5 -9
- package/lib/cjs/components/RockerButtonGroup/RockerButtonGroup.stories.js +4 -22
- package/lib/cjs/components/RockerButtonGroup/RockerButtonGroup.test.js +5 -14
- package/lib/cjs/components/SearchField/SearchField.stories.js +1 -15
- package/lib/cjs/components/TextAreaField/TextAreaField.js +54 -9
- package/lib/cjs/components/TextAreaField/TextAreaField.stories.js +31 -52
- package/lib/cjs/components/TextAreaField/TextAreaField.test.js +12 -0
- package/lib/cjs/context/AccordionGridContext/index.js +20 -0
- package/lib/cjs/hooks/useAriaLabelWarning/useAriaLabelWarning.js +2 -1
- package/lib/cjs/hooks/useField/useField.js +5 -0
- package/lib/cjs/hooks/useRockerButton/useRockerButton.js +4 -6
- package/lib/cjs/layouts/ListLayout.stories.js +6 -6
- package/lib/cjs/recipes/ArrayField.stories.js +1 -1
- package/lib/cjs/recipes/ConditionalFilter.stories.js +7 -3
- package/lib/cjs/recipes/RadioButtonsWithLinks.stories.js +1 -1
- package/lib/cjs/styles/variants/boxes.js +9 -0
- package/lib/cjs/styles/variants/buttons.js +20 -0
- package/lib/components/AccordionGridGroup/AccordionGridGroup.js +32 -24
- package/lib/components/AccordionGridGroup/AccordionGridGroup.stories.js +143 -166
- package/lib/components/AccordionGridGroup/AccordionGridGroup.test.js +24 -25
- package/lib/components/AccordionGridItem/AccordionGridItem.js +29 -15
- package/lib/components/AccordionGridItem/AccordionGridItemBody.js +4 -4
- package/lib/components/AccordionGridItem/AccordionGridItemHeader.js +19 -20
- package/lib/components/AccordionGroup/AccordionGroup.js +2 -1
- package/lib/components/AccordionGroup/AccordionGroup.test.js +16 -2
- package/lib/components/Breadcrumbs/Breadcrumbs.stories.js +3 -3
- package/lib/components/Button/Button.js +15 -3
- package/lib/components/Button/Button.stories.js +17 -15
- package/lib/components/EnvironmentBreadcrumb/EnvironmentBreadcrumb.js +5 -3
- package/lib/components/Link/Link.js +2 -1
- package/lib/components/ListView/ListView.js +9 -12
- package/lib/components/ListViewItem/ListViewItem.js +14 -3
- package/lib/components/Modal/Modal.stories.js +1 -1
- package/lib/components/OverlayPanel/OverlayPanel.js +3 -16
- package/lib/components/OverlayPanel/OverlayPanel.test.js +38 -0
- package/lib/components/RockerButton/RockerButton.js +14 -21
- package/lib/components/RockerButtonGroup/RockerButtonGroup.js +5 -9
- package/lib/components/RockerButtonGroup/RockerButtonGroup.stories.js +2 -17
- package/lib/components/RockerButtonGroup/RockerButtonGroup.test.js +5 -11
- package/lib/components/SearchField/SearchField.stories.js +0 -11
- package/lib/components/TextAreaField/TextAreaField.js +54 -10
- package/lib/components/TextAreaField/TextAreaField.stories.js +26 -42
- package/lib/components/TextAreaField/TextAreaField.test.js +13 -0
- package/lib/context/AccordionGridContext/index.js +5 -0
- package/lib/hooks/useAriaLabelWarning/useAriaLabelWarning.js +2 -1
- package/lib/hooks/useField/useField.js +5 -0
- package/lib/hooks/useRockerButton/useRockerButton.js +4 -6
- package/lib/layouts/ListLayout.stories.js +6 -6
- package/lib/recipes/ArrayField.stories.js +1 -1
- package/lib/recipes/ConditionalFilter.stories.js +7 -3
- package/lib/recipes/RadioButtonsWithLinks.stories.js +1 -1
- package/lib/styles/variants/boxes.js +9 -0
- package/lib/styles/variants/buttons.js +20 -0
- package/package.json +3 -3
- package/lib/cjs/components/AccordionGridGroup/AccordionGridContext.js +0 -17
- package/lib/components/AccordionGridGroup/AccordionGridContext.js +0 -2
@@ -40,11 +40,9 @@ var _collections = require("@react-stately/collections");
|
|
40
40
|
|
41
41
|
var _focus = require("@react-aria/focus");
|
42
42
|
|
43
|
-
var _utils = require("@react-aria/utils");
|
44
|
-
|
45
43
|
var _hooks = require("../../hooks");
|
46
44
|
|
47
|
-
var
|
45
|
+
var _index = require("../../index");
|
48
46
|
|
49
47
|
var _RockerButtonGroup = require("../RockerButtonGroup");
|
50
48
|
|
@@ -56,19 +54,12 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
|
|
56
54
|
|
57
55
|
var CollectionRockerButton = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
58
56
|
var className = props.className,
|
59
|
-
item = props.item
|
60
|
-
buttonGroupDisabled = props.isDisabled;
|
61
|
-
var defaultSelectedStyles = {
|
62
|
-
bg: 'active'
|
63
|
-
};
|
57
|
+
item = props.item;
|
64
58
|
var key = item.key,
|
65
59
|
rendered = item.rendered,
|
66
60
|
itemProps = item.props;
|
67
|
-
var _itemProps$selectedSt = itemProps.selectedStyles,
|
68
|
-
selectedStyles = _itemProps$selectedSt === void 0 ? defaultSelectedStyles : _itemProps$selectedSt,
|
69
|
-
rockerButtonDisabled = itemProps.isDisabled;
|
70
|
-
var isDisabled = buttonGroupDisabled || rockerButtonDisabled;
|
71
61
|
var state = (0, _react.useContext)(_RockerButtonGroup.RockerContext);
|
62
|
+
var isDisabled = state.disabledKeys.has(key);
|
72
63
|
|
73
64
|
var _useFocusRing = (0, _focus.useFocusRing)(),
|
74
65
|
isFocusVisible = _useFocusRing.isFocusVisible,
|
@@ -78,7 +69,8 @@ var CollectionRockerButton = /*#__PURE__*/(0, _react.forwardRef)(function (props
|
|
78
69
|
|
79
70
|
var _useStatusClasses = (0, _hooks.useStatusClasses)(className, {
|
80
71
|
isFocused: isFocusVisible,
|
81
|
-
isSelected: isSelected
|
72
|
+
isSelected: isSelected,
|
73
|
+
isDisabled: isDisabled
|
82
74
|
}),
|
83
75
|
classNames = _useStatusClasses.classNames;
|
84
76
|
|
@@ -92,26 +84,26 @@ var CollectionRockerButton = /*#__PURE__*/(0, _react.forwardRef)(function (props
|
|
92
84
|
|
93
85
|
var _useRockerButton = (0, _hooks.useRockerButton)({
|
94
86
|
item: item,
|
95
|
-
isDisabled: isDisabled
|
87
|
+
isDisabled: isDisabled,
|
88
|
+
isSelected: isSelected
|
96
89
|
}, state, rockerButtonRef),
|
97
90
|
rockerButtonProps = _useRockerButton.rockerButtonProps;
|
98
91
|
|
99
|
-
return (0, _react2.jsx)(
|
92
|
+
return (0, _react2.jsx)(_index.Box, (0, _extends2["default"])({
|
93
|
+
as: "button",
|
100
94
|
className: classNames,
|
101
|
-
variant: "rocker"
|
102
|
-
},
|
103
|
-
ref: rockerButtonRef
|
95
|
+
variant: "buttons.rocker"
|
96
|
+
}, rockerButtonProps, {
|
97
|
+
ref: rockerButtonRef
|
98
|
+
}, focusProps, itemProps, {
|
104
99
|
sx: {
|
105
|
-
'&.is-selected': _objectSpread({}, selectedStyles)
|
100
|
+
'&.is-selected': _objectSpread({}, itemProps.selectedStyles)
|
106
101
|
}
|
107
102
|
}), rendered);
|
108
103
|
});
|
109
104
|
exports.CollectionRockerButton = CollectionRockerButton;
|
110
105
|
CollectionRockerButton.displayName = 'CollectionRockerButton';
|
111
106
|
CollectionRockerButton.propTypes = {
|
112
|
-
/** Whether the button is disabled. */
|
113
|
-
isDisabled: _propTypes["default"].bool,
|
114
|
-
|
115
107
|
/** Allows custom styles to be passed to button. */
|
116
108
|
selectedStyles: _propTypes["default"].shape({}),
|
117
109
|
// adding to surface in props table
|
@@ -70,10 +70,10 @@ var RockerButtonGroup = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref
|
|
70
70
|
var _context;
|
71
71
|
|
72
72
|
var children = props.children,
|
73
|
-
isDisabled = props.isDisabled,
|
74
73
|
onSelectionChange = props.onSelectionChange,
|
75
74
|
tabListProps = props.tabListProps,
|
76
|
-
|
75
|
+
disabledKeys = props.disabledKeys,
|
76
|
+
others = (0, _objectWithoutProperties2["default"])(props, ["children", "onSelectionChange", "tabListProps", "disabledKeys"]);
|
77
77
|
var buttonGroupRef = (0, _react.useRef)();
|
78
78
|
(0, _hooks.usePropWarning)(props, 'disabled', 'isDisabled');
|
79
79
|
/* istanbul ignore next */
|
@@ -102,8 +102,7 @@ var RockerButtonGroup = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref
|
|
102
102
|
}), (0, _map["default"])(_context = (0, _from["default"])(state.collection)).call(_context, function (item) {
|
103
103
|
return (0, _react2.jsx)(_RockerButton.CollectionRockerButton, {
|
104
104
|
key: item.key,
|
105
|
-
item: item
|
106
|
-
isDisabled: isDisabled
|
105
|
+
item: item
|
107
106
|
});
|
108
107
|
}))));
|
109
108
|
});
|
@@ -114,15 +113,12 @@ RockerButtonGroup.propTypes = {
|
|
114
113
|
/** The button key that is currently selected. (controlled) */
|
115
114
|
selectedKey: _propTypes["default"].string,
|
116
115
|
|
117
|
-
/**
|
118
|
-
|
116
|
+
/** Which keys should be disabled. */
|
117
|
+
disabledKeys: _propTypes["default"].arrayOf(_propTypes["default"].string),
|
119
118
|
|
120
119
|
/** Handler that is called when the selected button has changed. */
|
121
120
|
onSelectionChange: _propTypes["default"].func
|
122
121
|
};
|
123
|
-
RockerButtonGroup.defaultProps = {
|
124
|
-
isDisabled: false
|
125
|
-
};
|
126
122
|
RockerButtonGroup.displayName = 'RockerButtonGroup';
|
127
123
|
var _default = RockerButtonGroup;
|
128
124
|
exports["default"] = _default;
|
@@ -10,7 +10,7 @@ _Object$defineProperty(exports, "__esModule", {
|
|
10
10
|
value: true
|
11
11
|
});
|
12
12
|
|
13
|
-
exports.
|
13
|
+
exports.DisabledSingleButton = exports.withCustomSelectedColors = exports.Controlled = exports.Uncontrolled = exports.Default = exports["default"] = void 0;
|
14
14
|
|
15
15
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
|
16
16
|
|
@@ -129,26 +129,8 @@ exports.withCustomSelectedColors = withCustomSelectedColors;
|
|
129
129
|
|
130
130
|
var DisabledSingleButton = function DisabledSingleButton() {
|
131
131
|
return (0, _react2.jsx)(_RockerButtonGroup["default"], {
|
132
|
-
defaultSelectedKey: "or"
|
133
|
-
|
134
|
-
name: "and",
|
135
|
-
key: "and",
|
136
|
-
isDisabled: true
|
137
|
-
}, "And"), (0, _react2.jsx)(_RockerButton["default"], {
|
138
|
-
name: "or",
|
139
|
-
key: "or"
|
140
|
-
}, "Or"), (0, _react2.jsx)(_RockerButton["default"], {
|
141
|
-
name: "maybe",
|
142
|
-
key: "maybe"
|
143
|
-
}, "Maybe"));
|
144
|
-
};
|
145
|
-
|
146
|
-
exports.DisabledSingleButton = DisabledSingleButton;
|
147
|
-
|
148
|
-
var DisabledRockerButtonGroup = function DisabledRockerButtonGroup() {
|
149
|
-
return (0, _react2.jsx)(_RockerButtonGroup["default"], {
|
150
|
-
isDisabled: true,
|
151
|
-
defaultSelectedKey: "and"
|
132
|
+
defaultSelectedKey: "or",
|
133
|
+
disabledKeys: ['and']
|
152
134
|
}, (0, _react2.jsx)(_RockerButton["default"], {
|
153
135
|
name: "and",
|
154
136
|
key: "and"
|
@@ -161,4 +143,4 @@ var DisabledRockerButtonGroup = function DisabledRockerButtonGroup() {
|
|
161
143
|
}, "Maybe"));
|
162
144
|
};
|
163
145
|
|
164
|
-
exports.
|
146
|
+
exports.DisabledSingleButton = DisabledSingleButton;
|
@@ -82,9 +82,11 @@ test('buttonGroup is not disabled by default', function () {
|
|
82
82
|
expect(buttonKey).not.toHaveClass('is-disabled');
|
83
83
|
});
|
84
84
|
});
|
85
|
-
test('
|
85
|
+
test('rocker button is disabled when its key is included in disabledKeys', function () {
|
86
86
|
getComponent({
|
87
|
-
|
87
|
+
disabledKeys: (0, _map["default"])(testButtons).call(testButtons, function (button) {
|
88
|
+
return button.key;
|
89
|
+
})
|
88
90
|
});
|
89
91
|
(0, _forEach["default"])(testButtons).call(testButtons, function (button) {
|
90
92
|
var buttonKey = _testWrapper.screen.getByText(button.key);
|
@@ -100,9 +102,7 @@ test('rockerButton renders selectedStyles prop when selected', function () {
|
|
100
102
|
expect(buttonColorKey).toHaveClass('is-selected');
|
101
103
|
});
|
102
104
|
test('selected button can be changed by keyboard interaction', function () {
|
103
|
-
getComponent();
|
104
|
-
|
105
|
-
_userEvent["default"].tab();
|
105
|
+
getComponent();
|
106
106
|
|
107
107
|
_userEvent["default"].tab();
|
108
108
|
|
@@ -114,20 +114,11 @@ test('selected button can be changed by keyboard interaction', function () {
|
|
114
114
|
|
115
115
|
expect(button1).not.toHaveClass('is-selected');
|
116
116
|
|
117
|
-
_userEvent["default"].tab();
|
118
|
-
|
119
|
-
_userEvent["default"].tab();
|
120
|
-
|
121
117
|
_testWrapper.fireEvent.keyDown(_testWrapper.screen.getByText(testButtons[0].key), {
|
122
118
|
key: 'ArrowRight',
|
123
119
|
code: 'ArrowRight'
|
124
120
|
});
|
125
121
|
|
126
|
-
_testWrapper.fireEvent.keyDown(_testWrapper.screen.getByText(testButtons[1].key), {
|
127
|
-
key: 'ArrowRight',
|
128
|
-
code: 'ArrowRight'
|
129
|
-
});
|
130
|
-
|
131
122
|
expect(_testWrapper.screen.getByText(testButtons[1].key)).toHaveClass('is-selected');
|
132
123
|
expect(_testWrapper.screen.getByText(testButtons[0].key)).not.toHaveClass('is-selected');
|
133
124
|
});
|
@@ -10,7 +10,7 @@ _Object$defineProperty(exports, "__esModule", {
|
|
10
10
|
value: true
|
11
11
|
});
|
12
12
|
|
13
|
-
exports.ControlledWithDebouncedInput = exports.
|
13
|
+
exports.ControlledWithDebouncedInput = exports.NoClearButton = exports.CustomIcon = exports.Controlled = exports.Default = exports["default"] = void 0;
|
14
14
|
|
15
15
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
|
16
16
|
|
@@ -137,20 +137,6 @@ var NoClearButton = function NoClearButton() {
|
|
137
137
|
|
138
138
|
exports.NoClearButton = NoClearButton;
|
139
139
|
|
140
|
-
var MaxLength = function MaxLength(args) {
|
141
|
-
return (0, _react2.jsx)(_index.SearchField, (0, _extends2["default"])({}, args, {
|
142
|
-
icon: _SearchIcon["default"],
|
143
|
-
"aria-label": "Search Groups",
|
144
|
-
onSubmit: function onSubmit(text) {
|
145
|
-
return alert(text);
|
146
|
-
} // eslint-disable-line no-alert
|
147
|
-
,
|
148
|
-
maxLength: 9
|
149
|
-
}));
|
150
|
-
};
|
151
|
-
|
152
|
-
exports.MaxLength = MaxLength;
|
153
|
-
|
154
140
|
var ControlledWithDebouncedInput = function ControlledWithDebouncedInput() {
|
155
141
|
var _useState3 = (0, _react.useState)(''),
|
156
142
|
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
@@ -38,6 +38,8 @@ var _react = _interopRequireWildcard(require("react"));
|
|
38
38
|
|
39
39
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
40
40
|
|
41
|
+
var _utils = require("@react-aria/utils");
|
42
|
+
|
41
43
|
var _hooks = require("../../hooks");
|
42
44
|
|
43
45
|
var _statuses = _interopRequireDefault(require("../../utils/devUtils/constants/statuses"));
|
@@ -63,7 +65,8 @@ var TextAreaField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
63
65
|
var helperText = props.helperText,
|
64
66
|
isUnresizable = props.isUnresizable,
|
65
67
|
rows = props.rows,
|
66
|
-
status = props.status
|
68
|
+
status = props.status,
|
69
|
+
slots = props.slots;
|
67
70
|
var statusClasses = {
|
68
71
|
isUnresizable: isUnresizable
|
69
72
|
};
|
@@ -77,6 +80,9 @@ var TextAreaField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
77
80
|
|
78
81
|
var textAreaRef = (0, _react.useRef)();
|
79
82
|
var labelRef = (0, _react.useRef)();
|
83
|
+
var containerRef = (0, _react.useRef)();
|
84
|
+
var inputContainerRef = (0, _react.useRef)();
|
85
|
+
var slotContainer = (0, _react.useRef)();
|
80
86
|
(0, _hooks.usePropWarning)(props, 'disabled', 'isDisabled');
|
81
87
|
/* istanbul ignore next */
|
82
88
|
|
@@ -89,6 +95,24 @@ var TextAreaField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
89
95
|
/* istanbul ignore next */
|
90
96
|
labelRef.current.style.width = textAreaRef.current.style.width;
|
91
97
|
};
|
98
|
+
/* istanbul ignore next */
|
99
|
+
|
100
|
+
|
101
|
+
var resizeSlotContainer = function resizeSlotContainer() {
|
102
|
+
inputContainerRef.current.style.width = textAreaRef.current.style.width;
|
103
|
+
};
|
104
|
+
|
105
|
+
var onResize = (0, _react.useCallback)(function () {
|
106
|
+
/* istanbul ignore next */
|
107
|
+
if (slots === null || slots === void 0 ? void 0 : slots.inContainer) {
|
108
|
+
resizeSlotContainer();
|
109
|
+
}
|
110
|
+
}, [slotContainer]);
|
111
|
+
(0, _utils.useResizeObserver)({
|
112
|
+
ref: textAreaRef,
|
113
|
+
onResize: onResize
|
114
|
+
});
|
115
|
+
(0, _utils.useLayoutEffect)(onResize, [onResize]);
|
92
116
|
|
93
117
|
var _useLabelHeight = (0, _hooks.useLabelHeight)({
|
94
118
|
labelRef: labelRef,
|
@@ -100,18 +124,22 @@ var TextAreaField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
100
124
|
labelMode: props.labelMode
|
101
125
|
});
|
102
126
|
(0, _react.useEffect)(function () {
|
127
|
+
var thisRef = textAreaRef.current;
|
128
|
+
|
103
129
|
if (!props.isUnresizable && props.labelMode === 'float') {
|
104
|
-
|
130
|
+
thisRef.addEventListener('mousemove', props.resizeCallback ? props.resizeCallback : resizeFloatLabel);
|
105
131
|
}
|
106
132
|
|
107
133
|
return function () {
|
108
|
-
|
134
|
+
thisRef.removeEventListener('mousemove', props.resizeCallback ? props.resizeCallback : resizeFloatLabel);
|
109
135
|
};
|
110
|
-
}, []);
|
136
|
+
}, [props.isUnresizable, props.labelMode, props.resizeCallback]);
|
111
137
|
return (0, _react2.jsx)(_Box["default"], (0, _extends2["default"])({
|
112
138
|
variant: "forms.input.wrapper"
|
113
139
|
}, fieldContainerProps, {
|
114
|
-
sx: _objectSpread(_objectSpread({}, columnStyleProps === null || columnStyleProps === void 0 ? void 0 : columnStyleProps.sx), fieldContainerProps === null || fieldContainerProps === void 0 ? void 0 : fieldContainerProps.sx)
|
140
|
+
sx: _objectSpread(_objectSpread({}, columnStyleProps === null || columnStyleProps === void 0 ? void 0 : columnStyleProps.sx), fieldContainerProps === null || fieldContainerProps === void 0 ? void 0 : fieldContainerProps.sx),
|
141
|
+
ref: containerRef,
|
142
|
+
maxWidth: "100%"
|
115
143
|
}), (0, _react2.jsx)(_Label["default"], (0, _extends2["default"])({
|
116
144
|
ref: labelRef
|
117
145
|
}, fieldLabelProps, {
|
@@ -119,12 +147,23 @@ var TextAreaField = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
119
147
|
gridRow: '1/5'
|
120
148
|
}
|
121
149
|
})), (0, _react2.jsx)(_Box["default"], {
|
150
|
+
isRow: true,
|
122
151
|
variant: "forms.input.container",
|
123
|
-
className: fieldControlProps.className
|
152
|
+
className: fieldControlProps.className,
|
153
|
+
minWidth: "40px",
|
154
|
+
maxWidth: "100%",
|
155
|
+
ref: inputContainerRef
|
124
156
|
}, (0, _react2.jsx)(_TextArea["default"], (0, _extends2["default"])({
|
125
157
|
ref: textAreaRef,
|
126
158
|
rows: rows
|
127
|
-
}, fieldControlProps
|
159
|
+
}, fieldControlProps, {
|
160
|
+
sx: (slots === null || slots === void 0 ? void 0 : slots.inContainer) && {
|
161
|
+
paddingRight: '35px'
|
162
|
+
}
|
163
|
+
})), (slots === null || slots === void 0 ? void 0 : slots.inContainer) && (0, _react2.jsx)(_Box["default"], {
|
164
|
+
variant: "boxes.textFieldInContainerSlot",
|
165
|
+
ref: slotContainer
|
166
|
+
}, slots === null || slots === void 0 ? void 0 : slots.inContainer)), helperText && (0, _react2.jsx)(_FieldHelperText["default"], {
|
128
167
|
status: status
|
129
168
|
}, helperText));
|
130
169
|
});
|
@@ -219,7 +258,13 @@ TextAreaField.propTypes = {
|
|
219
258
|
controlProps: _propTypes["default"].shape({}),
|
220
259
|
|
221
260
|
/** Props object that is spread directly into the label element. */
|
222
|
-
labelProps: _propTypes["default"].shape({})
|
261
|
+
labelProps: _propTypes["default"].shape({}),
|
262
|
+
|
263
|
+
/** Provides a way to insert markup in specified places. */
|
264
|
+
slots: _propTypes["default"].shape({
|
265
|
+
/** The given node will be inserted into the field container. */
|
266
|
+
inContainer: _propTypes["default"].node
|
267
|
+
})
|
223
268
|
};
|
224
269
|
TextAreaField.defaultProps = {
|
225
270
|
hasAutoFocus: false,
|
@@ -227,7 +272,7 @@ TextAreaField.defaultProps = {
|
|
227
272
|
isReadOnly: false,
|
228
273
|
isRequired: false,
|
229
274
|
isUnresizable: false,
|
230
|
-
rows:
|
275
|
+
rows: 4,
|
231
276
|
status: _statuses["default"].DEFAULT
|
232
277
|
};
|
233
278
|
TextAreaField.displayName = 'TextAreaField';
|
@@ -10,18 +10,24 @@ _Object$defineProperty(exports, "__esModule", {
|
|
10
10
|
value: true
|
11
11
|
});
|
12
12
|
|
13
|
-
exports.MaxLength = exports.WithoutStatusIndicator = exports.
|
13
|
+
exports.MaxLength = exports.WithoutStatusIndicator = exports.Error = exports.Unresizable = exports.Rows = exports.Required = exports.ReadOnly = exports.Disabled = exports.Controlled = exports.FloatLabel = exports.WithSlots = exports.Default = exports["default"] = void 0;
|
14
14
|
|
15
15
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
|
16
16
|
|
17
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
18
|
+
|
17
19
|
var _values = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/values"));
|
18
20
|
|
19
21
|
var _react = _interopRequireWildcard(require("react"));
|
20
22
|
|
23
|
+
var _SearchIcon = _interopRequireDefault(require("mdi-react/SearchIcon"));
|
24
|
+
|
21
25
|
var _ = _interopRequireDefault(require("."));
|
22
26
|
|
23
27
|
var _Box = _interopRequireDefault(require("../Box"));
|
24
28
|
|
29
|
+
var _Icon = _interopRequireDefault(require("../Icon"));
|
30
|
+
|
25
31
|
var _statuses = _interopRequireDefault(require("../../utils/devUtils/constants/statuses"));
|
26
32
|
|
27
33
|
var _constants = require("../Label/constants");
|
@@ -85,6 +91,11 @@ var _default = {
|
|
85
91
|
}
|
86
92
|
};
|
87
93
|
exports["default"] = _default;
|
94
|
+
var IconSlot = (0, _react2.jsx)(_Box["default"], {
|
95
|
+
isRow: true
|
96
|
+
}, (0, _react2.jsx)(_Icon["default"], {
|
97
|
+
icon: _SearchIcon["default"]
|
98
|
+
}));
|
88
99
|
|
89
100
|
var Default = function Default(args) {
|
90
101
|
return (0, _react2.jsx)(_["default"], args);
|
@@ -92,6 +103,25 @@ var Default = function Default(args) {
|
|
92
103
|
|
93
104
|
exports.Default = Default;
|
94
105
|
|
106
|
+
var WithSlots = function WithSlots(args) {
|
107
|
+
return (// This is an example of a slot that can be passed into the component
|
108
|
+
// const IconSlot = (
|
109
|
+
// <Box isRow>
|
110
|
+
// <Icon
|
111
|
+
// icon={SearchIcon}
|
112
|
+
// />
|
113
|
+
// </Box>
|
114
|
+
// );
|
115
|
+
(0, _react2.jsx)(_["default"], (0, _extends2["default"])({}, args, {
|
116
|
+
slots: {
|
117
|
+
inContainer: IconSlot
|
118
|
+
}
|
119
|
+
}))
|
120
|
+
);
|
121
|
+
};
|
122
|
+
|
123
|
+
exports.WithSlots = WithSlots;
|
124
|
+
|
95
125
|
var FloatLabel = function FloatLabel() {
|
96
126
|
return (0, _react2.jsx)(_["default"], {
|
97
127
|
label: "Example label",
|
@@ -101,37 +131,6 @@ var FloatLabel = function FloatLabel() {
|
|
101
131
|
|
102
132
|
exports.FloatLabel = FloatLabel;
|
103
133
|
|
104
|
-
var LeftLabel = function LeftLabel() {
|
105
|
-
return (0, _react2.jsx)(_Box["default"], {
|
106
|
-
gap: "xl",
|
107
|
-
width: "fit-content"
|
108
|
-
}, (0, _react2.jsx)(_["default"], {
|
109
|
-
label: "Example label",
|
110
|
-
labelMode: "left"
|
111
|
-
}), (0, _react2.jsx)(_["default"], {
|
112
|
-
label: "Example label that is much longer than the previous one",
|
113
|
-
labelMode: "left",
|
114
|
-
status: "error"
|
115
|
-
}), (0, _react2.jsx)(_["default"], {
|
116
|
-
label: "Example label with set width",
|
117
|
-
labelMode: "left",
|
118
|
-
containerProps: {
|
119
|
-
sx: {
|
120
|
-
gridTemplateColumns: '120px auto'
|
121
|
-
}
|
122
|
-
}
|
123
|
-
}));
|
124
|
-
};
|
125
|
-
|
126
|
-
exports.LeftLabel = LeftLabel;
|
127
|
-
LeftLabel.parameters = {
|
128
|
-
docs: {
|
129
|
-
description: {
|
130
|
-
story: 'Users are able to override the default 40% column width when using left label by providing a new gridTemplatesColumn value, as shown in the example below.'
|
131
|
-
}
|
132
|
-
}
|
133
|
-
};
|
134
|
-
|
135
134
|
var Controlled = function Controlled() {
|
136
135
|
var _useState = (0, _react.useState)(),
|
137
136
|
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
@@ -206,26 +205,6 @@ var Error = function Error() {
|
|
206
205
|
|
207
206
|
exports.Error = Error;
|
208
207
|
|
209
|
-
var Success = function Success() {
|
210
|
-
return (0, _react2.jsx)(_["default"], {
|
211
|
-
helperText: "Here is some helpful text...",
|
212
|
-
label: "Example Label",
|
213
|
-
status: "success"
|
214
|
-
});
|
215
|
-
};
|
216
|
-
|
217
|
-
exports.Success = Success;
|
218
|
-
|
219
|
-
var Warning = function Warning() {
|
220
|
-
return (0, _react2.jsx)(_["default"], {
|
221
|
-
helperText: "Here is some helpful text...",
|
222
|
-
label: "Example Label",
|
223
|
-
status: "warning"
|
224
|
-
});
|
225
|
-
};
|
226
|
-
|
227
|
-
exports.Warning = Warning;
|
228
|
-
|
229
208
|
var WithoutStatusIndicator = function WithoutStatusIndicator() {
|
230
209
|
return (0, _react2.jsx)(_["default"], {
|
231
210
|
label: "Example Label",
|
@@ -153,4 +153,16 @@ test('form wrapper will have a max label column width when custom width set', fu
|
|
153
153
|
var textAreaContainer = _testWrapper.screen.getByTestId(testId);
|
154
154
|
|
155
155
|
expect(textAreaContainer).toHaveStyle('grid-template-columns: 120px auto');
|
156
|
+
});
|
157
|
+
test('providing slot props causes slot to render', function () {
|
158
|
+
var slot = (0, _react3.jsx)("p", {
|
159
|
+
"data-testid": "testSlot"
|
160
|
+
}, "testText");
|
161
|
+
var slots = {
|
162
|
+
inContainer: slot
|
163
|
+
};
|
164
|
+
getComponent({
|
165
|
+
slots: slots
|
166
|
+
});
|
167
|
+
expect(_testWrapper.screen.getByTestId('testSlot')).toBeInTheDocument();
|
156
168
|
});
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
|
4
|
+
|
5
|
+
_Object$defineProperty(exports, "__esModule", {
|
6
|
+
value: true
|
7
|
+
});
|
8
|
+
|
9
|
+
exports.useAccordionGridContext = exports.AccordionGridContext = void 0;
|
10
|
+
|
11
|
+
var _react = require("react");
|
12
|
+
|
13
|
+
var AccordionGridContext = /*#__PURE__*/(0, _react.createContext)({});
|
14
|
+
exports.AccordionGridContext = AccordionGridContext;
|
15
|
+
|
16
|
+
var useAccordionGridContext = function useAccordionGridContext() {
|
17
|
+
return (0, _react.useContext)(AccordionGridContext);
|
18
|
+
};
|
19
|
+
|
20
|
+
exports.useAccordionGridContext = useAccordionGridContext;
|
@@ -17,8 +17,9 @@ var _react = require("react");
|
|
17
17
|
* e.g. "\`Component\` requires an aria-label."
|
18
18
|
*/
|
19
19
|
var useAriaLabelWarning = function useAriaLabelWarning(component, ariaLabel) {
|
20
|
+
var condition = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
|
20
21
|
(0, _react.useEffect)(function () {
|
21
|
-
if (process.env.NODE_ENV === 'development' && !ariaLabel) {
|
22
|
+
if (process.env.NODE_ENV === 'development' && condition && !ariaLabel) {
|
22
23
|
// eslint-disable-next-line no-console
|
23
24
|
console.warn("".concat(component, " requires an aria-label"), '\n', '\n', 'NOTE: This is a development-only warning and will not display in production.');
|
24
25
|
}
|
@@ -145,6 +145,11 @@ var useField = function useField() {
|
|
145
145
|
setHasValue(true);
|
146
146
|
} else {
|
147
147
|
setHasValue(false);
|
148
|
+
} // adding this function resolves the error brought up in UIP-5116
|
149
|
+
|
150
|
+
|
151
|
+
if (e.persist) {
|
152
|
+
e.persist();
|
148
153
|
} // Make sure to call the original onChange event
|
149
154
|
|
150
155
|
|
@@ -38,24 +38,22 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
|
|
38
38
|
|
39
39
|
var useRockerButton = function useRockerButton(props, state, ref) {
|
40
40
|
var item = props.item,
|
41
|
-
|
41
|
+
isDisabled = props.isDisabled,
|
42
|
+
isSelected = props.isSelected;
|
42
43
|
var key = item.key;
|
43
|
-
var manager = state.selectionManager
|
44
|
-
selectedKey = state.selectedKey;
|
45
|
-
var isSelected = key === selectedKey;
|
44
|
+
var manager = state.selectionManager;
|
46
45
|
|
47
46
|
var _useSelectableItem = (0, _selection.useSelectableItem)({
|
47
|
+
isDisabled: isDisabled,
|
48
48
|
selectionManager: manager,
|
49
49
|
key: key,
|
50
50
|
ref: ref
|
51
51
|
}),
|
52
52
|
itemProps = _useSelectableItem.itemProps;
|
53
53
|
|
54
|
-
var isDisabled = propsDisabled || state.disabledKeys.has(key);
|
55
54
|
var rockerButtonId = (0, _utils.useId)();
|
56
55
|
return {
|
57
56
|
rockerButtonProps: _objectSpread(_objectSpread({}, itemProps), {}, {
|
58
|
-
isDisabled: isDisabled,
|
59
57
|
id: rockerButtonId,
|
60
58
|
'aria-pressed': isSelected,
|
61
59
|
'aria-disabled': isDisabled || undefined
|
@@ -574,7 +574,7 @@ var Default = function Default() {
|
|
574
574
|
mr: "md",
|
575
575
|
"aria-label": "Save Button"
|
576
576
|
}, "Save"), (0, _react2.jsx)(_index.Button, {
|
577
|
-
variant: "
|
577
|
+
variant: "link",
|
578
578
|
onPress: viewItem,
|
579
579
|
"aria-label": "Cancel Button"
|
580
580
|
}, "Cancel"))), editConfigurationVisible && (0, _react2.jsx)(_index.OverlayPanel, {
|
@@ -704,7 +704,7 @@ var Default = function Default() {
|
|
704
704
|
mr: "md",
|
705
705
|
"aria-label": "Save Button"
|
706
706
|
}, "Save"), (0, _react2.jsx)(_index.Button, {
|
707
|
-
variant: "
|
707
|
+
variant: "link",
|
708
708
|
onPress: viewItem,
|
709
709
|
"aria-label": "Cancel Button"
|
710
710
|
}, "Cancel"))), addItemVisible && (0, _react2.jsx)(_index.OverlayPanel, {
|
@@ -790,7 +790,7 @@ var Default = function Default() {
|
|
790
790
|
isRow: true,
|
791
791
|
sx: buttonBarStyles
|
792
792
|
}, (0, _react2.jsx)(_index.Button, {
|
793
|
-
variant: "
|
793
|
+
variant: "link",
|
794
794
|
onPress: resetListItem,
|
795
795
|
mr: "md",
|
796
796
|
"aria-label": "Cancel Button"
|
@@ -851,7 +851,7 @@ var Default = function Default() {
|
|
851
851
|
isRow: true,
|
852
852
|
sx: buttonBarStyles
|
853
853
|
}, (0, _react2.jsx)(_index.Button, {
|
854
|
-
variant: "
|
854
|
+
variant: "link",
|
855
855
|
onPress: resetListItem,
|
856
856
|
mr: "md"
|
857
857
|
}, "Cancel"), (0, _react2.jsx)(_index.Button, {
|
@@ -873,11 +873,11 @@ var Default = function Default() {
|
|
873
873
|
pt: "lg",
|
874
874
|
mr: "auto"
|
875
875
|
}, (0, _react2.jsx)(_index.Button, {
|
876
|
-
variant: "
|
876
|
+
variant: "critical",
|
877
877
|
mr: "md",
|
878
878
|
onPress: deleteItem
|
879
879
|
}, "Delete"), (0, _react2.jsx)(_index.Button, {
|
880
|
-
variant: "
|
880
|
+
variant: "link",
|
881
881
|
onPress: function onPress() {
|
882
882
|
return setIsDeleting(false);
|
883
883
|
}
|