@salutejs/plasma-new-hope 0.76.3-canary.1178.8720542914.0 → 0.77.0-canary.1185.8719560164.0
Sign up to get free protection for your applications and to get access to all the features.
- package/cjs/components/Combobox/Combobox.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxDivider/ComboboxDivider.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxDivider/ComboboxDivider.js +1 -1
- package/cjs/components/Combobox/ui/ComboboxFooter/ComboboxFooter.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxFooter/ComboboxFooter.js +1 -1
- package/cjs/components/Combobox/ui/ComboboxGroup/ComboboxGroup.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxGroup/ComboboxGroup.js +1 -1
- package/cjs/components/Combobox/ui/ComboboxHeader/ComboboxHeader.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxHeader/ComboboxHeader.js +1 -1
- package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.css +2 -2
- package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.js +1 -1
- package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.styles.js +1 -1
- package/cjs/components/Dropdown/Dropdown.css +2 -2
- package/cjs/components/Dropdown/Dropdown.js +27 -4
- package/cjs/components/Dropdown/Dropdown.js.map +1 -1
- package/cjs/components/Dropdown/Dropdown.styles.js +1 -1
- package/cjs/components/Dropdown/Dropdown.styles.js.map +1 -1
- package/cjs/components/Dropdown/{Dropdown.styles_1daxhqh.css → Dropdown.styles_13400l5.css} +1 -1
- package/cjs/components/Dropdown/Dropdown.tokens.js +1 -0
- package/cjs/components/Dropdown/Dropdown.tokens.js.map +1 -1
- package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +81 -0
- package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -0
- package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
- package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
- package/cjs/components/Dropdown/utils/index.js +43 -0
- package/cjs/components/Dropdown/utils/index.js.map +1 -1
- package/cjs/components/Pagination/Pagination.css +2 -2
- package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
- package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.js +1 -1
- package/cjs/components/Select/Select.css +2 -2
- package/cjs/components/Select/ui/SelectDivider/SelectDivider.css +2 -2
- package/cjs/components/Select/ui/SelectDivider/SelectDivider.js +1 -1
- package/cjs/components/Select/ui/SelectFooter/SelectFooter.css +2 -2
- package/cjs/components/Select/ui/SelectFooter/SelectFooter.js +1 -1
- package/cjs/components/Select/ui/SelectGroup/SelectGroup.css +2 -2
- package/cjs/components/Select/ui/SelectGroup/SelectGroup.js +1 -1
- package/cjs/components/Select/ui/SelectHeader/SelectHeader.css +2 -2
- package/cjs/components/Select/ui/SelectHeader/SelectHeader.js +1 -1
- package/cjs/components/Select/ui/SelectItem/SelectItem.css +2 -2
- package/cjs/components/Select/ui/SelectItem/SelectItem.js +1 -1
- package/cjs/components/Select/ui/SelectItem/SelectItem.styles.js +1 -1
- package/cjs/index.css +2 -2
- package/cjs/index.js +2 -0
- package/cjs/index.js.map +1 -1
- package/es/components/Combobox/Combobox.css +2 -2
- package/es/components/Combobox/ui/ComboboxDivider/ComboboxDivider.css +2 -2
- package/es/components/Combobox/ui/ComboboxDivider/ComboboxDivider.js +1 -1
- package/es/components/Combobox/ui/ComboboxFooter/ComboboxFooter.css +2 -2
- package/es/components/Combobox/ui/ComboboxFooter/ComboboxFooter.js +1 -1
- package/es/components/Combobox/ui/ComboboxGroup/ComboboxGroup.css +2 -2
- package/es/components/Combobox/ui/ComboboxGroup/ComboboxGroup.js +1 -1
- package/es/components/Combobox/ui/ComboboxHeader/ComboboxHeader.css +2 -2
- package/es/components/Combobox/ui/ComboboxHeader/ComboboxHeader.js +1 -1
- package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.css +2 -2
- package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.js +1 -1
- package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.styles.js +1 -1
- package/es/components/Dropdown/Dropdown.css +2 -2
- package/es/components/Dropdown/Dropdown.js +29 -6
- package/es/components/Dropdown/Dropdown.js.map +1 -1
- package/es/components/Dropdown/Dropdown.styles.js +1 -1
- package/es/components/Dropdown/Dropdown.styles.js.map +1 -1
- package/es/components/Dropdown/{Dropdown.styles_1daxhqh.css → Dropdown.styles_13400l5.css} +1 -1
- package/es/components/Dropdown/Dropdown.tokens.js +1 -0
- package/es/components/Dropdown/Dropdown.tokens.js.map +1 -1
- package/es/components/Dropdown/hooks/useKeyboardNavigation.js +76 -0
- package/es/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -0
- package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
- package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
- package/es/components/Dropdown/utils/index.js +45 -3
- package/es/components/Dropdown/utils/index.js.map +1 -1
- package/es/components/Pagination/Pagination.css +2 -2
- package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
- package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.js +1 -1
- package/es/components/Select/Select.css +2 -2
- package/es/components/Select/ui/SelectDivider/SelectDivider.css +2 -2
- package/es/components/Select/ui/SelectDivider/SelectDivider.js +1 -1
- package/es/components/Select/ui/SelectFooter/SelectFooter.css +2 -2
- package/es/components/Select/ui/SelectFooter/SelectFooter.js +1 -1
- package/es/components/Select/ui/SelectGroup/SelectGroup.css +2 -2
- package/es/components/Select/ui/SelectGroup/SelectGroup.js +1 -1
- package/es/components/Select/ui/SelectHeader/SelectHeader.css +2 -2
- package/es/components/Select/ui/SelectHeader/SelectHeader.js +1 -1
- package/es/components/Select/ui/SelectItem/SelectItem.css +2 -2
- package/es/components/Select/ui/SelectItem/SelectItem.js +1 -1
- package/es/components/Select/ui/SelectItem/SelectItem.styles.js +1 -1
- package/es/index.css +2 -2
- package/es/index.js +1 -0
- package/es/index.js.map +1 -1
- package/package.json +3 -3
- package/styled-components/cjs/components/Dropdown/Dropdown.js +28 -6
- package/styled-components/cjs/components/Dropdown/Dropdown.styles.js +1 -1
- package/styled-components/cjs/components/Dropdown/Dropdown.tokens.js +1 -0
- package/styled-components/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +83 -0
- package/styled-components/cjs/components/Dropdown/index.js +9 -1
- package/styled-components/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
- package/styled-components/cjs/components/Dropdown/utils/index.js +48 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.js +1 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.stories.tsx +27 -7
- package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.js +1 -1
- package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.stories.tsx +30 -11
- package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.js +1 -1
- package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.stories.tsx +28 -9
- package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.js +1 -1
- package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.stories.tsx +31 -12
- package/styled-components/es/components/Dropdown/Dropdown.js +29 -6
- package/styled-components/es/components/Dropdown/Dropdown.styles.js +1 -1
- package/styled-components/es/components/Dropdown/Dropdown.tokens.js +1 -0
- package/styled-components/es/components/Dropdown/hooks/useKeyboardNavigation.js +77 -0
- package/styled-components/es/components/Dropdown/index.js +1 -0
- package/styled-components/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
- package/styled-components/es/components/Dropdown/utils/index.js +48 -1
- package/styled-components/es/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.js +1 -1
- package/styled-components/es/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.stories.tsx +27 -7
- package/styled-components/es/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.js +1 -1
- package/styled-components/es/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.stories.tsx +30 -11
- package/styled-components/es/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.js +1 -1
- package/styled-components/es/examples/plasma_web/components/Dropdown/Normal/Dropdown.stories.tsx +28 -9
- package/styled-components/es/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.js +1 -1
- package/styled-components/es/examples/plasma_web/components/Dropdown/Tight/Dropdown.stories.tsx +31 -12
- package/types/components/Dropdown/Dropdown.d.ts.map +1 -1
- package/types/components/Dropdown/Dropdown.tokens.d.ts +1 -0
- package/types/components/Dropdown/Dropdown.tokens.d.ts.map +1 -1
- package/types/components/Dropdown/Dropdown.types.d.ts +7 -2
- package/types/components/Dropdown/Dropdown.types.d.ts.map +1 -1
- package/types/components/Dropdown/hooks/useKeyboardNavigation.d.ts +13 -0
- package/types/components/Dropdown/hooks/useKeyboardNavigation.d.ts.map +1 -0
- package/types/components/Dropdown/index.d.ts +1 -0
- package/types/components/Dropdown/index.d.ts.map +1 -1
- package/types/components/Dropdown/ui/DropdownItem/DropdownItem.d.ts.map +1 -1
- package/types/components/Dropdown/utils/index.d.ts +5 -2
- package/types/components/Dropdown/utils/index.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.d.ts.map +1 -1
- package/types/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.d.ts.map +1 -1
- package/types/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.d.ts.map +1 -1
@@ -3,10 +3,15 @@
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
4
4
|
value: true
|
5
5
|
});
|
6
|
-
exports.getValidComponent = exports.getPlacements = exports.getPlacement = void 0;
|
6
|
+
exports.getValidComponent = exports.getPlacements = exports.getPlacement = exports.getChildren = void 0;
|
7
7
|
var _react = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("react"));
|
8
8
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
9
9
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
10
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
11
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
12
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
13
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
14
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
10
15
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
11
16
|
var getPlacement = exports.getPlacement = function getPlacement(placement) {
|
12
17
|
return "".concat(placement, "-start");
|
@@ -35,4 +40,46 @@ var getValidComponent = exports.getValidComponent = function getValidComponent(e
|
|
35
40
|
return /*#__PURE__*/_react["default"].createElement(Component, props);
|
36
41
|
}
|
37
42
|
return element;
|
43
|
+
};
|
44
|
+
var getChildren = exports.getChildren = function getChildren(children, externalProps) {
|
45
|
+
if (externalProps.childrenRefs) {
|
46
|
+
externalProps.childrenRefs.current = [];
|
47
|
+
}
|
48
|
+
var res = _react.Children.map(children || [], function (child) {
|
49
|
+
var hasValue = ('value' in (child === null || child === void 0 ? void 0 : child.props));
|
50
|
+
var hasTarget = ('target' in (child === null || child === void 0 ? void 0 : child.props));
|
51
|
+
if (! /*#__PURE__*/(0, _react.isValidElement)(child) || !hasValue && !hasTarget) {
|
52
|
+
return child;
|
53
|
+
}
|
54
|
+
if (hasTarget) {
|
55
|
+
var _ref = child === null || child === void 0 ? void 0 : child.props,
|
56
|
+
target = _ref.target;
|
57
|
+
if (! /*#__PURE__*/(0, _react.isValidElement)(target)) {
|
58
|
+
return child;
|
59
|
+
}
|
60
|
+
var targetProps = _objectSpread(_objectSpread({}, target === null || target === void 0 ? void 0 : target.props), {}, {
|
61
|
+
ref: function ref(element) {
|
62
|
+
var _externalProps$childr;
|
63
|
+
if (externalProps !== null && externalProps !== void 0 && (_externalProps$childr = externalProps.childrenRefs) !== null && _externalProps$childr !== void 0 && _externalProps$childr.current && element) {
|
64
|
+
externalProps.childrenRefs.current.push(element);
|
65
|
+
}
|
66
|
+
}
|
67
|
+
});
|
68
|
+
var updatedTarget = /*#__PURE__*/(0, _react.cloneElement)(target, targetProps);
|
69
|
+
var updatedProps = _objectSpread(_objectSpread({}, child === null || child === void 0 ? void 0 : child.props), {}, {
|
70
|
+
target: updatedTarget
|
71
|
+
});
|
72
|
+
return /*#__PURE__*/(0, _react.cloneElement)(child, updatedProps);
|
73
|
+
}
|
74
|
+
var props = _objectSpread(_objectSpread({}, child === null || child === void 0 ? void 0 : child.props), {}, {
|
75
|
+
ref: function ref(element) {
|
76
|
+
var _externalProps$childr2;
|
77
|
+
if (externalProps !== null && externalProps !== void 0 && (_externalProps$childr2 = externalProps.childrenRefs) !== null && _externalProps$childr2 !== void 0 && _externalProps$childr2.current && element) {
|
78
|
+
externalProps.childrenRefs.current.push(element);
|
79
|
+
}
|
80
|
+
}
|
81
|
+
});
|
82
|
+
return /*#__PURE__*/(0, _react.cloneElement)(child, props);
|
83
|
+
});
|
84
|
+
return res;
|
38
85
|
};
|
package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.js
CHANGED
@@ -21,7 +21,7 @@ var config = exports.config = {
|
|
21
21
|
l: /*#__PURE__*/(0, _styledComponents.css)(["", ";", ";", ":1.0625rem;", ":1rem;", ":1.0625rem;", ":1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], dropdownSizeCommon, dropdownItemSizeCommon, _Dropdown.dropdownTokens.itemPaddingTop, _Dropdown.dropdownTokens.itemPaddingRight, _Dropdown.dropdownTokens.itemPaddingBottom, _Dropdown.dropdownTokens.itemPaddingLeft, _Dropdown.dropdownTokens.itemBorderRadius, _Dropdown.dropdownTokens.itemFontFamily, _Dropdown.dropdownTokens.itemFontSize, _Dropdown.dropdownTokens.itemFontStyle, _Dropdown.dropdownTokens.itemFontWeightBold, _Dropdown.dropdownTokens.itemFontLetterSpacing, _Dropdown.dropdownTokens.itemFontLineHeight)
|
22
22
|
},
|
23
23
|
view: {
|
24
|
-
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
24
|
+
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-accent);", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.focusColor, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
25
25
|
}
|
26
26
|
}
|
27
27
|
};
|
package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.stories.tsx
CHANGED
@@ -112,10 +112,10 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
112
112
|
}
|
113
113
|
};
|
114
114
|
|
115
|
-
const handleSelect = (value: string, text: string) => {
|
115
|
+
const handleSelect = (value: string, text: string, toggleIsOpen: React.Dispatch<React.SetStateAction<boolean>>) => {
|
116
116
|
setSelected(value);
|
117
117
|
onSelect(value, text);
|
118
|
-
|
118
|
+
toggleIsOpen(false);
|
119
119
|
};
|
120
120
|
|
121
121
|
return (
|
@@ -127,34 +127,51 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
127
127
|
onToggle={onMainToggle}
|
128
128
|
offset={[Number(skidding), Number(distance)]}
|
129
129
|
placement={placement}
|
130
|
+
role="listbox"
|
130
131
|
{...rest}
|
131
132
|
>
|
132
133
|
{getDropdownItems('item', 6).map((item) => (
|
133
134
|
<DropdownItem
|
134
135
|
key={item.value}
|
135
136
|
isSelected={Boolean(item.value === selected)}
|
136
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
137
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpen)}
|
137
138
|
onClick={onClick}
|
138
139
|
value={item.value}
|
140
|
+
role="option"
|
139
141
|
>
|
140
142
|
{item.child}
|
141
143
|
</DropdownItem>
|
142
144
|
))}
|
143
145
|
<Dropdown
|
144
|
-
target={
|
146
|
+
target={
|
147
|
+
<DropdownItem
|
148
|
+
contentRight={DisclosureRightIcon}
|
149
|
+
role="option"
|
150
|
+
name="test"
|
151
|
+
text="Nested dropdown"
|
152
|
+
/>
|
153
|
+
}
|
145
154
|
onToggle={(is) => setIsOpenDropdown2(is)}
|
146
155
|
isOpen={isOpenDropdown2}
|
156
|
+
role="listbox"
|
147
157
|
offset={[0, 0]}
|
148
158
|
{...rest}
|
149
159
|
>
|
150
|
-
<DropdownItem
|
160
|
+
<DropdownItem
|
161
|
+
contentRight={StyledCheckbox}
|
162
|
+
role="option"
|
163
|
+
value="checked"
|
164
|
+
onChange={onChange}
|
165
|
+
text="Checkbox"
|
166
|
+
/>
|
151
167
|
{getDropdownItems('nested', 4).map((item) => (
|
152
168
|
<DropdownItem
|
153
169
|
key={item.value}
|
154
170
|
isSelected={Boolean(item.value === selected)}
|
155
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
171
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpenDropdown2)}
|
156
172
|
onClick={onClick}
|
157
173
|
value={item.value}
|
174
|
+
role="option"
|
158
175
|
>
|
159
176
|
{item.child}
|
160
177
|
</DropdownItem>
|
@@ -165,6 +182,7 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
165
182
|
value="1"
|
166
183
|
onChange={onChange}
|
167
184
|
text="Radiobox 1"
|
185
|
+
role="option"
|
168
186
|
/>
|
169
187
|
<DropdownItem
|
170
188
|
contentLeft={StyledRadiobox}
|
@@ -172,14 +190,16 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
172
190
|
value="2"
|
173
191
|
onChange={onChange}
|
174
192
|
text="Radiobox 2"
|
193
|
+
role="option"
|
175
194
|
/>
|
176
195
|
</Dropdown>
|
177
196
|
|
178
197
|
<DropdownItem
|
179
198
|
isSelected={selected === 'disabled'}
|
180
|
-
onSelect={() => handleSelect('disabled', 'disabled')}
|
199
|
+
onSelect={() => handleSelect('disabled', 'disabled', setIsOpen)}
|
181
200
|
onClick={onClick}
|
182
201
|
value="disabled"
|
202
|
+
role="option"
|
183
203
|
disabled
|
184
204
|
>
|
185
205
|
disabled
|
package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.js
CHANGED
@@ -21,7 +21,7 @@ var config = exports.config = {
|
|
21
21
|
l: /*#__PURE__*/(0, _styledComponents.css)(["", ";", ";", ":0.8125rem;", ":1rem;", ":0.8125rem;", ":1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], dropdownSizeCommon, dropdownItemSizeCommon, _Dropdown.dropdownTokens.itemPaddingTop, _Dropdown.dropdownTokens.itemPaddingRight, _Dropdown.dropdownTokens.itemPaddingBottom, _Dropdown.dropdownTokens.itemPaddingLeft, _Dropdown.dropdownTokens.itemBorderRadius, _Dropdown.dropdownTokens.itemFontFamily, _Dropdown.dropdownTokens.itemFontSize, _Dropdown.dropdownTokens.itemFontStyle, _Dropdown.dropdownTokens.itemFontWeightBold, _Dropdown.dropdownTokens.itemFontLetterSpacing, _Dropdown.dropdownTokens.itemFontLineHeight)
|
22
22
|
},
|
23
23
|
view: {
|
24
|
-
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
24
|
+
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-accent);", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.focusColor, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
25
25
|
}
|
26
26
|
}
|
27
27
|
};
|
package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.stories.tsx
CHANGED
@@ -92,7 +92,7 @@ const DisclosureRightIcon = (props) => (
|
|
92
92
|
</StyledDisclosureRightIcon>
|
93
93
|
);
|
94
94
|
|
95
|
-
const
|
95
|
+
const StoryNormal = (args: StoryDropdownProps) => {
|
96
96
|
const [selected, setSelected] = useState('');
|
97
97
|
const [isOpen, setIsOpen] = useState(false);
|
98
98
|
const [isOpenDropdown2, setIsOpenDropdown2] = useState(false);
|
@@ -112,10 +112,10 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
112
112
|
}
|
113
113
|
};
|
114
114
|
|
115
|
-
const handleSelect = (value: string, text: string) => {
|
115
|
+
const handleSelect = (value: string, text: string, toggleIsOpen: React.Dispatch<React.SetStateAction<boolean>>) => {
|
116
116
|
setSelected(value);
|
117
117
|
onSelect(value, text);
|
118
|
-
|
118
|
+
toggleIsOpen(false);
|
119
119
|
};
|
120
120
|
|
121
121
|
return (
|
@@ -127,35 +127,51 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
127
127
|
onToggle={onMainToggle}
|
128
128
|
offset={[Number(skidding), Number(distance)]}
|
129
129
|
placement={placement}
|
130
|
+
role="listbox"
|
130
131
|
{...rest}
|
131
132
|
>
|
132
133
|
{getDropdownItems('item', 6).map((item) => (
|
133
134
|
<DropdownItem
|
134
135
|
key={item.value}
|
135
136
|
isSelected={Boolean(item.value === selected)}
|
136
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
137
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpen)}
|
137
138
|
onClick={onClick}
|
138
139
|
value={item.value}
|
140
|
+
role="option"
|
139
141
|
>
|
140
142
|
{item.child}
|
141
143
|
</DropdownItem>
|
142
144
|
))}
|
143
145
|
<Dropdown
|
144
|
-
target={
|
146
|
+
target={
|
147
|
+
<DropdownItem
|
148
|
+
contentRight={DisclosureRightIcon}
|
149
|
+
role="option"
|
150
|
+
name="test"
|
151
|
+
text="Nested dropdown"
|
152
|
+
/>
|
153
|
+
}
|
145
154
|
onToggle={(is) => setIsOpenDropdown2(is)}
|
146
155
|
isOpen={isOpenDropdown2}
|
156
|
+
role="listbox"
|
147
157
|
offset={[0, 0]}
|
148
|
-
isNested
|
149
158
|
{...rest}
|
150
159
|
>
|
151
|
-
<DropdownItem
|
160
|
+
<DropdownItem
|
161
|
+
contentRight={StyledCheckbox}
|
162
|
+
role="option"
|
163
|
+
value="checked"
|
164
|
+
onChange={onChange}
|
165
|
+
text="Checkbox"
|
166
|
+
/>
|
152
167
|
{getDropdownItems('nested', 4).map((item) => (
|
153
168
|
<DropdownItem
|
154
169
|
key={item.value}
|
155
170
|
isSelected={Boolean(item.value === selected)}
|
156
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
171
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpenDropdown2)}
|
157
172
|
onClick={onClick}
|
158
173
|
value={item.value}
|
174
|
+
role="option"
|
159
175
|
>
|
160
176
|
{item.child}
|
161
177
|
</DropdownItem>
|
@@ -166,6 +182,7 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
166
182
|
value="1"
|
167
183
|
onChange={onChange}
|
168
184
|
text="Radiobox 1"
|
185
|
+
role="option"
|
169
186
|
/>
|
170
187
|
<DropdownItem
|
171
188
|
contentLeft={StyledRadiobox}
|
@@ -173,14 +190,16 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
173
190
|
value="2"
|
174
191
|
onChange={onChange}
|
175
192
|
text="Radiobox 2"
|
193
|
+
role="option"
|
176
194
|
/>
|
177
195
|
</Dropdown>
|
178
196
|
|
179
197
|
<DropdownItem
|
180
198
|
isSelected={selected === 'disabled'}
|
181
|
-
onSelect={() => handleSelect('disabled', 'disabled')}
|
199
|
+
onSelect={() => handleSelect('disabled', 'disabled', setIsOpen)}
|
182
200
|
onClick={onClick}
|
183
201
|
value="disabled"
|
202
|
+
role="option"
|
184
203
|
disabled
|
185
204
|
>
|
186
205
|
disabled
|
@@ -190,6 +209,6 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
190
209
|
);
|
191
210
|
};
|
192
211
|
|
193
|
-
export const
|
194
|
-
render: (args) => <
|
212
|
+
export const Normal: StoryObj<StoryDropdownProps> = {
|
213
|
+
render: (args) => <StoryNormal {...args} />,
|
195
214
|
};
|
package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.js
CHANGED
@@ -21,7 +21,7 @@ var config = exports.config = {
|
|
21
21
|
l: /*#__PURE__*/(0, _styledComponents.css)(["", ";", ";", ":1.0625rem;", ":1rem;", ":1.0625rem;", ":1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], dropdownSizeCommon, dropdownItemSizeCommon, _Dropdown.dropdownTokens.itemPaddingTop, _Dropdown.dropdownTokens.itemPaddingRight, _Dropdown.dropdownTokens.itemPaddingBottom, _Dropdown.dropdownTokens.itemPaddingLeft, _Dropdown.dropdownTokens.itemBorderRadius, _Dropdown.dropdownTokens.itemFontFamily, _Dropdown.dropdownTokens.itemFontSize, _Dropdown.dropdownTokens.itemFontStyle, _Dropdown.dropdownTokens.itemFontWeightBold, _Dropdown.dropdownTokens.itemFontLetterSpacing, _Dropdown.dropdownTokens.itemFontLineHeight)
|
22
22
|
},
|
23
23
|
view: {
|
24
|
-
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
24
|
+
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-accent);", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.focusColor, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
25
25
|
}
|
26
26
|
}
|
27
27
|
};
|
package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.stories.tsx
CHANGED
@@ -26,7 +26,7 @@ type StoryDropdownPropsCustom = {
|
|
26
26
|
type StoryDropdownProps = ComponentProps<typeof Dropdown> & StoryDropdownPropsCustom;
|
27
27
|
|
28
28
|
const meta: Meta<StoryDropdownProps> = {
|
29
|
-
title: '
|
29
|
+
title: 'plasma_b2c/Dropdown',
|
30
30
|
decorators: [WithTheme],
|
31
31
|
component: Dropdown,
|
32
32
|
argTypes: {
|
@@ -112,10 +112,10 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
112
112
|
}
|
113
113
|
};
|
114
114
|
|
115
|
-
const handleSelect = (value: string, text: string) => {
|
115
|
+
const handleSelect = (value: string, text: string, toggleIsOpen: React.Dispatch<React.SetStateAction<boolean>>) => {
|
116
116
|
setSelected(value);
|
117
117
|
onSelect(value, text);
|
118
|
-
|
118
|
+
toggleIsOpen(false);
|
119
119
|
};
|
120
120
|
|
121
121
|
return (
|
@@ -127,35 +127,51 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
127
127
|
onToggle={onMainToggle}
|
128
128
|
offset={[Number(skidding), Number(distance)]}
|
129
129
|
placement={placement}
|
130
|
+
role="listbox"
|
130
131
|
{...rest}
|
131
132
|
>
|
132
133
|
{getDropdownItems('item', 6).map((item) => (
|
133
134
|
<DropdownItem
|
134
135
|
key={item.value}
|
135
136
|
isSelected={Boolean(item.value === selected)}
|
136
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
137
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpen)}
|
137
138
|
onClick={onClick}
|
138
139
|
value={item.value}
|
140
|
+
role="option"
|
139
141
|
>
|
140
142
|
{item.child}
|
141
143
|
</DropdownItem>
|
142
144
|
))}
|
143
145
|
<Dropdown
|
144
|
-
target={
|
146
|
+
target={
|
147
|
+
<DropdownItem
|
148
|
+
contentRight={DisclosureRightIcon}
|
149
|
+
role="option"
|
150
|
+
name="test"
|
151
|
+
text="Nested dropdown"
|
152
|
+
/>
|
153
|
+
}
|
145
154
|
onToggle={(is) => setIsOpenDropdown2(is)}
|
146
155
|
isOpen={isOpenDropdown2}
|
156
|
+
role="listbox"
|
147
157
|
offset={[0, 0]}
|
148
|
-
isNested
|
149
158
|
{...rest}
|
150
159
|
>
|
151
|
-
<DropdownItem
|
160
|
+
<DropdownItem
|
161
|
+
contentRight={StyledCheckbox}
|
162
|
+
role="option"
|
163
|
+
value="checked"
|
164
|
+
onChange={onChange}
|
165
|
+
text="Checkbox"
|
166
|
+
/>
|
152
167
|
{getDropdownItems('nested', 4).map((item) => (
|
153
168
|
<DropdownItem
|
154
169
|
key={item.value}
|
155
170
|
isSelected={Boolean(item.value === selected)}
|
156
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
171
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpenDropdown2)}
|
157
172
|
onClick={onClick}
|
158
173
|
value={item.value}
|
174
|
+
role="option"
|
159
175
|
>
|
160
176
|
{item.child}
|
161
177
|
</DropdownItem>
|
@@ -166,6 +182,7 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
166
182
|
value="1"
|
167
183
|
onChange={onChange}
|
168
184
|
text="Radiobox 1"
|
185
|
+
role="option"
|
169
186
|
/>
|
170
187
|
<DropdownItem
|
171
188
|
contentLeft={StyledRadiobox}
|
@@ -173,14 +190,16 @@ const StoryNormal = (args: StoryDropdownProps) => {
|
|
173
190
|
value="2"
|
174
191
|
onChange={onChange}
|
175
192
|
text="Radiobox 2"
|
193
|
+
role="option"
|
176
194
|
/>
|
177
195
|
</Dropdown>
|
178
196
|
|
179
197
|
<DropdownItem
|
180
198
|
isSelected={selected === 'disabled'}
|
181
|
-
onSelect={() => handleSelect('disabled', 'disabled')}
|
199
|
+
onSelect={() => handleSelect('disabled', 'disabled', setIsOpen)}
|
182
200
|
onClick={onClick}
|
183
201
|
value="disabled"
|
202
|
+
role="option"
|
184
203
|
disabled
|
185
204
|
>
|
186
205
|
disabled
|
package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.js
CHANGED
@@ -21,7 +21,7 @@ var config = exports.config = {
|
|
21
21
|
l: /*#__PURE__*/(0, _styledComponents.css)(["", ";", ";", ":0.8125rem;", ":1rem;", ":0.8125rem;", ":1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], dropdownSizeCommon, dropdownItemSizeCommon, _Dropdown.dropdownTokens.itemPaddingTop, _Dropdown.dropdownTokens.itemPaddingRight, _Dropdown.dropdownTokens.itemPaddingBottom, _Dropdown.dropdownTokens.itemPaddingLeft, _Dropdown.dropdownTokens.itemBorderRadius, _Dropdown.dropdownTokens.itemFontFamily, _Dropdown.dropdownTokens.itemFontSize, _Dropdown.dropdownTokens.itemFontStyle, _Dropdown.dropdownTokens.itemFontWeightBold, _Dropdown.dropdownTokens.itemFontLetterSpacing, _Dropdown.dropdownTokens.itemFontLineHeight)
|
22
22
|
},
|
23
23
|
view: {
|
24
|
-
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
24
|
+
"default": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;", ":var(--surface-accent);", ":var(--surface-solid-card);", ":var(--shadow-down-soft-s);", ":var(--plasma-colors-transparent);", ":var(--surface-transparent-secondary);", ":inherit;", ":inherit;", ":inherit;", ":inherit;", ":var(--text-primary);"], _Dropdown.dropdownTokens.disabledOpacity, _Dropdown.dropdownTokens.focusColor, _Dropdown.dropdownTokens.background, _Dropdown.dropdownTokens.boxShadow, _Dropdown.dropdownTokens.itemBackground, _Dropdown.dropdownTokens.itemBackgroundHover, _Dropdown.dropdownTokens.itemBackgroundSelected, _Dropdown.dropdownTokens.itemColorSelected, _Dropdown.dropdownTokens.itemBackgroundSelectedHover, _Dropdown.dropdownTokens.itemColorSelectedHover, _Dropdown.dropdownTokens.itemColor)
|
25
25
|
}
|
26
26
|
}
|
27
27
|
};
|
package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.stories.tsx
CHANGED
@@ -26,7 +26,7 @@ type StoryDropdownPropsCustom = {
|
|
26
26
|
type StoryDropdownProps = ComponentProps<typeof Dropdown> & StoryDropdownPropsCustom;
|
27
27
|
|
28
28
|
const meta: Meta<StoryDropdownProps> = {
|
29
|
-
title: '
|
29
|
+
title: 'plasma_b2c/Dropdown',
|
30
30
|
decorators: [WithTheme],
|
31
31
|
component: Dropdown,
|
32
32
|
argTypes: {
|
@@ -92,7 +92,7 @@ const DisclosureRightIcon = (props) => (
|
|
92
92
|
</StyledDisclosureRightIcon>
|
93
93
|
);
|
94
94
|
|
95
|
-
const
|
95
|
+
const StoryNormal = (args: StoryDropdownProps) => {
|
96
96
|
const [selected, setSelected] = useState('');
|
97
97
|
const [isOpen, setIsOpen] = useState(false);
|
98
98
|
const [isOpenDropdown2, setIsOpenDropdown2] = useState(false);
|
@@ -112,10 +112,10 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
112
112
|
}
|
113
113
|
};
|
114
114
|
|
115
|
-
const handleSelect = (value: string, text: string) => {
|
115
|
+
const handleSelect = (value: string, text: string, toggleIsOpen: React.Dispatch<React.SetStateAction<boolean>>) => {
|
116
116
|
setSelected(value);
|
117
117
|
onSelect(value, text);
|
118
|
-
|
118
|
+
toggleIsOpen(false);
|
119
119
|
};
|
120
120
|
|
121
121
|
return (
|
@@ -127,35 +127,51 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
127
127
|
onToggle={onMainToggle}
|
128
128
|
offset={[Number(skidding), Number(distance)]}
|
129
129
|
placement={placement}
|
130
|
+
role="listbox"
|
130
131
|
{...rest}
|
131
132
|
>
|
132
133
|
{getDropdownItems('item', 6).map((item) => (
|
133
134
|
<DropdownItem
|
134
135
|
key={item.value}
|
135
136
|
isSelected={Boolean(item.value === selected)}
|
136
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
137
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpen)}
|
137
138
|
onClick={onClick}
|
138
139
|
value={item.value}
|
140
|
+
role="option"
|
139
141
|
>
|
140
142
|
{item.child}
|
141
143
|
</DropdownItem>
|
142
144
|
))}
|
143
145
|
<Dropdown
|
144
|
-
target={
|
146
|
+
target={
|
147
|
+
<DropdownItem
|
148
|
+
contentRight={DisclosureRightIcon}
|
149
|
+
role="option"
|
150
|
+
name="test"
|
151
|
+
text="Nested dropdown"
|
152
|
+
/>
|
153
|
+
}
|
145
154
|
onToggle={(is) => setIsOpenDropdown2(is)}
|
146
155
|
isOpen={isOpenDropdown2}
|
156
|
+
role="listbox"
|
147
157
|
offset={[0, 0]}
|
148
|
-
isNested
|
149
158
|
{...rest}
|
150
159
|
>
|
151
|
-
<DropdownItem
|
160
|
+
<DropdownItem
|
161
|
+
contentRight={StyledCheckbox}
|
162
|
+
role="option"
|
163
|
+
value="checked"
|
164
|
+
onChange={onChange}
|
165
|
+
text="Checkbox"
|
166
|
+
/>
|
152
167
|
{getDropdownItems('nested', 4).map((item) => (
|
153
168
|
<DropdownItem
|
154
169
|
key={item.value}
|
155
170
|
isSelected={Boolean(item.value === selected)}
|
156
|
-
onSelect={() => handleSelect(item.value, item.child)}
|
171
|
+
onSelect={() => handleSelect(item.value, item.child, setIsOpenDropdown2)}
|
157
172
|
onClick={onClick}
|
158
173
|
value={item.value}
|
174
|
+
role="option"
|
159
175
|
>
|
160
176
|
{item.child}
|
161
177
|
</DropdownItem>
|
@@ -166,6 +182,7 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
166
182
|
value="1"
|
167
183
|
onChange={onChange}
|
168
184
|
text="Radiobox 1"
|
185
|
+
role="option"
|
169
186
|
/>
|
170
187
|
<DropdownItem
|
171
188
|
contentLeft={StyledRadiobox}
|
@@ -173,14 +190,16 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
173
190
|
value="2"
|
174
191
|
onChange={onChange}
|
175
192
|
text="Radiobox 2"
|
193
|
+
role="option"
|
176
194
|
/>
|
177
195
|
</Dropdown>
|
178
196
|
|
179
197
|
<DropdownItem
|
180
198
|
isSelected={selected === 'disabled'}
|
181
|
-
onSelect={() => handleSelect('disabled', 'disabled')}
|
199
|
+
onSelect={() => handleSelect('disabled', 'disabled', setIsOpen)}
|
182
200
|
onClick={onClick}
|
183
201
|
value="disabled"
|
202
|
+
role="option"
|
184
203
|
disabled
|
185
204
|
>
|
186
205
|
disabled
|
@@ -190,6 +209,6 @@ const StoryTight = (args: StoryDropdownProps) => {
|
|
190
209
|
);
|
191
210
|
};
|
192
211
|
|
193
|
-
export const
|
194
|
-
render: (args) => <
|
212
|
+
export const Normal: StoryObj<StoryDropdownProps> = {
|
213
|
+
render: (args) => <StoryNormal {...args} />,
|
195
214
|
};
|
@@ -1,13 +1,17 @@
|
|
1
|
-
var _excluded = ["id", "target", "children", "hasArrow", "
|
1
|
+
var _excluded = ["id", "target", "children", "hasArrow", "view", "size", "frame", "onToggle", "className", "isFocusTrapped", "isOpen", "role", "placement", "trigger", "offset", "preventOverflow", "closeOnOverlayClick", "closeOnEsc"];
|
2
2
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
3
3
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
4
4
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
5
|
-
import React, { forwardRef, useRef } from 'react';
|
5
|
+
import React, { Children, forwardRef, useMemo, useRef } from 'react';
|
6
6
|
import { useFocusTrap, useForkRef, useUniqId } from '@salutejs/plasma-core';
|
7
|
+
import { cx } from '../../utils';
|
7
8
|
import { base as viewCSS } from './variations/_view/base';
|
8
9
|
import { base as sizeCSS } from './variations/_size/base';
|
9
10
|
import { StyledDropdown, StyledPopover } from './Dropdown.styles';
|
10
|
-
import { getPlacements } from './utils';
|
11
|
+
import { getChildren, getPlacements } from './utils';
|
12
|
+
import { classes } from './Dropdown.tokens';
|
13
|
+
import { useKeyNavigation } from './hooks/useKeyboardNavigation';
|
14
|
+
|
11
15
|
/**
|
12
16
|
* Выпадающий список без внешнего контроля видимости.
|
13
17
|
*/
|
@@ -17,15 +21,17 @@ export var dropdownRoot = function dropdownRoot(Root) {
|
|
17
21
|
target = _ref.target,
|
18
22
|
children = _ref.children,
|
19
23
|
hasArrow = _ref.hasArrow,
|
20
|
-
role = _ref.role,
|
21
24
|
view = _ref.view,
|
22
25
|
size = _ref.size,
|
23
26
|
frame = _ref.frame,
|
24
27
|
_onToggle = _ref.onToggle,
|
28
|
+
className = _ref.className,
|
25
29
|
_ref$isFocusTrapped = _ref.isFocusTrapped,
|
26
30
|
isFocusTrapped = _ref$isFocusTrapped === void 0 ? true : _ref$isFocusTrapped,
|
27
31
|
_ref$isOpen = _ref.isOpen,
|
28
32
|
isOpen = _ref$isOpen === void 0 ? false : _ref$isOpen,
|
33
|
+
_ref$role = _ref.role,
|
34
|
+
role = _ref$role === void 0 ? 'listbox' : _ref$role,
|
29
35
|
_ref$placement = _ref.placement,
|
30
36
|
placement = _ref$placement === void 0 ? 'auto' : _ref$placement,
|
31
37
|
_ref$trigger = _ref.trigger,
|
@@ -43,9 +49,24 @@ export var dropdownRoot = function dropdownRoot(Root) {
|
|
43
49
|
var innerId = id || uniqId;
|
44
50
|
var rootRef = useRef(null);
|
45
51
|
var dropdownRef = useRef(null);
|
52
|
+
var itemsRefs = useRef([]);
|
46
53
|
var handleRef = useForkRef(rootRef, outerRootRef);
|
47
54
|
var trapRef = useFocusTrap(isOpen && isFocusTrapped);
|
48
55
|
var dropdownForkRef = useForkRef(dropdownRef, trapRef);
|
56
|
+
var _useKeyNavigation = useKeyNavigation({
|
57
|
+
itemsRefs: itemsRefs,
|
58
|
+
opened: isOpen,
|
59
|
+
updateOpened: _onToggle
|
60
|
+
}),
|
61
|
+
onKeyDownTarget = _useKeyNavigation.onKeyDownTarget;
|
62
|
+
var childrenArray = useMemo(function () {
|
63
|
+
return Children.toArray(children);
|
64
|
+
}, [children]);
|
65
|
+
var childrenMemo = useMemo(function () {
|
66
|
+
return getChildren(childrenArray, {
|
67
|
+
childrenRefs: itemsRefs
|
68
|
+
});
|
69
|
+
}, [childrenArray, isOpen]);
|
49
70
|
return /*#__PURE__*/React.createElement(StyledPopover, {
|
50
71
|
role: role,
|
51
72
|
isOpen: isOpen,
|
@@ -64,12 +85,14 @@ export var dropdownRoot = function dropdownRoot(Root) {
|
|
64
85
|
closeOnOverlayClick: closeOnOverlayClick,
|
65
86
|
closeOnEsc: closeOnEsc,
|
66
87
|
isFocusTrapped: isFocusTrapped,
|
67
|
-
frame: frame
|
88
|
+
frame: frame,
|
89
|
+
onKeyDown: onKeyDownTarget
|
68
90
|
}, /*#__PURE__*/React.createElement(Root, _extends({
|
91
|
+
className: cx(className, classes.dropdownRoot),
|
69
92
|
ref: handleRef,
|
70
93
|
view: view,
|
71
94
|
size: size
|
72
|
-
}, rest), /*#__PURE__*/React.createElement(StyledDropdown, null,
|
95
|
+
}, rest), /*#__PURE__*/React.createElement(StyledDropdown, null, childrenMemo)));
|
73
96
|
});
|
74
97
|
};
|
75
98
|
export var dropdownConfig = {
|
@@ -7,7 +7,7 @@ import { tokens } from './Dropdown.tokens';
|
|
7
7
|
var Popover = /*#__PURE__*/component(popoverConfig);
|
8
8
|
export var StyledPopover = /*#__PURE__*/styled(Popover).withConfig({
|
9
9
|
componentId: "plasma-new-hope__sc-13ezpo5-0"
|
10
|
-
})([".", "{display:block;}"], /*#__PURE__*/String(popoverClasses.target));
|
10
|
+
})([".", ",.", "{display:block;}"], /*#__PURE__*/String(popoverClasses.wrapper), /*#__PURE__*/String(popoverClasses.target));
|
11
11
|
export var StyledDropdown = /*#__PURE__*/styled.div.withConfig({
|
12
12
|
componentId: "plasma-new-hope__sc-13ezpo5-1"
|
13
13
|
})(["box-sizing:border-box;background:var(", ");box-shadow:var(", ");border-radius:var(", ");width:var(", ");height:var(", ");padding:var(", ") var(", ") var(", ") var(", ");"], tokens.background, tokens.boxShadow, tokens.borderRadius, tokens.width, tokens.height, tokens.paddingTop, tokens.paddingRight, tokens.paddingBottom, tokens.paddingLeft);
|