@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.
Files changed (135) hide show
  1. package/cjs/components/Combobox/Combobox.css +2 -2
  2. package/cjs/components/Combobox/ui/ComboboxDivider/ComboboxDivider.css +2 -2
  3. package/cjs/components/Combobox/ui/ComboboxDivider/ComboboxDivider.js +1 -1
  4. package/cjs/components/Combobox/ui/ComboboxFooter/ComboboxFooter.css +2 -2
  5. package/cjs/components/Combobox/ui/ComboboxFooter/ComboboxFooter.js +1 -1
  6. package/cjs/components/Combobox/ui/ComboboxGroup/ComboboxGroup.css +2 -2
  7. package/cjs/components/Combobox/ui/ComboboxGroup/ComboboxGroup.js +1 -1
  8. package/cjs/components/Combobox/ui/ComboboxHeader/ComboboxHeader.css +2 -2
  9. package/cjs/components/Combobox/ui/ComboboxHeader/ComboboxHeader.js +1 -1
  10. package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.css +2 -2
  11. package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.js +1 -1
  12. package/cjs/components/Combobox/ui/ComboboxItem/ComboboxItem.styles.js +1 -1
  13. package/cjs/components/Dropdown/Dropdown.css +2 -2
  14. package/cjs/components/Dropdown/Dropdown.js +27 -4
  15. package/cjs/components/Dropdown/Dropdown.js.map +1 -1
  16. package/cjs/components/Dropdown/Dropdown.styles.js +1 -1
  17. package/cjs/components/Dropdown/Dropdown.styles.js.map +1 -1
  18. package/cjs/components/Dropdown/{Dropdown.styles_1daxhqh.css → Dropdown.styles_13400l5.css} +1 -1
  19. package/cjs/components/Dropdown/Dropdown.tokens.js +1 -0
  20. package/cjs/components/Dropdown/Dropdown.tokens.js.map +1 -1
  21. package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +81 -0
  22. package/cjs/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -0
  23. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
  24. package/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
  25. package/cjs/components/Dropdown/utils/index.js +43 -0
  26. package/cjs/components/Dropdown/utils/index.js.map +1 -1
  27. package/cjs/components/Pagination/Pagination.css +2 -2
  28. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
  29. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.js +1 -1
  30. package/cjs/components/Select/Select.css +2 -2
  31. package/cjs/components/Select/ui/SelectDivider/SelectDivider.css +2 -2
  32. package/cjs/components/Select/ui/SelectDivider/SelectDivider.js +1 -1
  33. package/cjs/components/Select/ui/SelectFooter/SelectFooter.css +2 -2
  34. package/cjs/components/Select/ui/SelectFooter/SelectFooter.js +1 -1
  35. package/cjs/components/Select/ui/SelectGroup/SelectGroup.css +2 -2
  36. package/cjs/components/Select/ui/SelectGroup/SelectGroup.js +1 -1
  37. package/cjs/components/Select/ui/SelectHeader/SelectHeader.css +2 -2
  38. package/cjs/components/Select/ui/SelectHeader/SelectHeader.js +1 -1
  39. package/cjs/components/Select/ui/SelectItem/SelectItem.css +2 -2
  40. package/cjs/components/Select/ui/SelectItem/SelectItem.js +1 -1
  41. package/cjs/components/Select/ui/SelectItem/SelectItem.styles.js +1 -1
  42. package/cjs/index.css +2 -2
  43. package/cjs/index.js +2 -0
  44. package/cjs/index.js.map +1 -1
  45. package/es/components/Combobox/Combobox.css +2 -2
  46. package/es/components/Combobox/ui/ComboboxDivider/ComboboxDivider.css +2 -2
  47. package/es/components/Combobox/ui/ComboboxDivider/ComboboxDivider.js +1 -1
  48. package/es/components/Combobox/ui/ComboboxFooter/ComboboxFooter.css +2 -2
  49. package/es/components/Combobox/ui/ComboboxFooter/ComboboxFooter.js +1 -1
  50. package/es/components/Combobox/ui/ComboboxGroup/ComboboxGroup.css +2 -2
  51. package/es/components/Combobox/ui/ComboboxGroup/ComboboxGroup.js +1 -1
  52. package/es/components/Combobox/ui/ComboboxHeader/ComboboxHeader.css +2 -2
  53. package/es/components/Combobox/ui/ComboboxHeader/ComboboxHeader.js +1 -1
  54. package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.css +2 -2
  55. package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.js +1 -1
  56. package/es/components/Combobox/ui/ComboboxItem/ComboboxItem.styles.js +1 -1
  57. package/es/components/Dropdown/Dropdown.css +2 -2
  58. package/es/components/Dropdown/Dropdown.js +29 -6
  59. package/es/components/Dropdown/Dropdown.js.map +1 -1
  60. package/es/components/Dropdown/Dropdown.styles.js +1 -1
  61. package/es/components/Dropdown/Dropdown.styles.js.map +1 -1
  62. package/es/components/Dropdown/{Dropdown.styles_1daxhqh.css → Dropdown.styles_13400l5.css} +1 -1
  63. package/es/components/Dropdown/Dropdown.tokens.js +1 -0
  64. package/es/components/Dropdown/Dropdown.tokens.js.map +1 -1
  65. package/es/components/Dropdown/hooks/useKeyboardNavigation.js +76 -0
  66. package/es/components/Dropdown/hooks/useKeyboardNavigation.js.map +1 -0
  67. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
  68. package/es/components/Dropdown/ui/DropdownItem/DropdownItem.js.map +1 -1
  69. package/es/components/Dropdown/utils/index.js +45 -3
  70. package/es/components/Dropdown/utils/index.js.map +1 -1
  71. package/es/components/Pagination/Pagination.css +2 -2
  72. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +2 -2
  73. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.js +1 -1
  74. package/es/components/Select/Select.css +2 -2
  75. package/es/components/Select/ui/SelectDivider/SelectDivider.css +2 -2
  76. package/es/components/Select/ui/SelectDivider/SelectDivider.js +1 -1
  77. package/es/components/Select/ui/SelectFooter/SelectFooter.css +2 -2
  78. package/es/components/Select/ui/SelectFooter/SelectFooter.js +1 -1
  79. package/es/components/Select/ui/SelectGroup/SelectGroup.css +2 -2
  80. package/es/components/Select/ui/SelectGroup/SelectGroup.js +1 -1
  81. package/es/components/Select/ui/SelectHeader/SelectHeader.css +2 -2
  82. package/es/components/Select/ui/SelectHeader/SelectHeader.js +1 -1
  83. package/es/components/Select/ui/SelectItem/SelectItem.css +2 -2
  84. package/es/components/Select/ui/SelectItem/SelectItem.js +1 -1
  85. package/es/components/Select/ui/SelectItem/SelectItem.styles.js +1 -1
  86. package/es/index.css +2 -2
  87. package/es/index.js +1 -0
  88. package/es/index.js.map +1 -1
  89. package/package.json +3 -3
  90. package/styled-components/cjs/components/Dropdown/Dropdown.js +28 -6
  91. package/styled-components/cjs/components/Dropdown/Dropdown.styles.js +1 -1
  92. package/styled-components/cjs/components/Dropdown/Dropdown.tokens.js +1 -0
  93. package/styled-components/cjs/components/Dropdown/hooks/useKeyboardNavigation.js +83 -0
  94. package/styled-components/cjs/components/Dropdown/index.js +9 -1
  95. package/styled-components/cjs/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
  96. package/styled-components/cjs/components/Dropdown/utils/index.js +48 -1
  97. package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.js +1 -1
  98. package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.stories.tsx +27 -7
  99. package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.js +1 -1
  100. package/styled-components/cjs/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.stories.tsx +30 -11
  101. package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.js +1 -1
  102. package/styled-components/cjs/examples/plasma_web/components/Dropdown/Normal/Dropdown.stories.tsx +28 -9
  103. package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.js +1 -1
  104. package/styled-components/cjs/examples/plasma_web/components/Dropdown/Tight/Dropdown.stories.tsx +31 -12
  105. package/styled-components/es/components/Dropdown/Dropdown.js +29 -6
  106. package/styled-components/es/components/Dropdown/Dropdown.styles.js +1 -1
  107. package/styled-components/es/components/Dropdown/Dropdown.tokens.js +1 -0
  108. package/styled-components/es/components/Dropdown/hooks/useKeyboardNavigation.js +77 -0
  109. package/styled-components/es/components/Dropdown/index.js +1 -0
  110. package/styled-components/es/components/Dropdown/ui/DropdownItem/DropdownItem.js +5 -3
  111. package/styled-components/es/components/Dropdown/utils/index.js +48 -1
  112. package/styled-components/es/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.js +1 -1
  113. package/styled-components/es/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.stories.tsx +27 -7
  114. package/styled-components/es/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.js +1 -1
  115. package/styled-components/es/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.stories.tsx +30 -11
  116. package/styled-components/es/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.js +1 -1
  117. package/styled-components/es/examples/plasma_web/components/Dropdown/Normal/Dropdown.stories.tsx +28 -9
  118. package/styled-components/es/examples/plasma_web/components/Dropdown/Tight/Dropdown.config.js +1 -1
  119. package/styled-components/es/examples/plasma_web/components/Dropdown/Tight/Dropdown.stories.tsx +31 -12
  120. package/types/components/Dropdown/Dropdown.d.ts.map +1 -1
  121. package/types/components/Dropdown/Dropdown.tokens.d.ts +1 -0
  122. package/types/components/Dropdown/Dropdown.tokens.d.ts.map +1 -1
  123. package/types/components/Dropdown/Dropdown.types.d.ts +7 -2
  124. package/types/components/Dropdown/Dropdown.types.d.ts.map +1 -1
  125. package/types/components/Dropdown/hooks/useKeyboardNavigation.d.ts +13 -0
  126. package/types/components/Dropdown/hooks/useKeyboardNavigation.d.ts.map +1 -0
  127. package/types/components/Dropdown/index.d.ts +1 -0
  128. package/types/components/Dropdown/index.d.ts.map +1 -1
  129. package/types/components/Dropdown/ui/DropdownItem/DropdownItem.d.ts.map +1 -1
  130. package/types/components/Dropdown/utils/index.d.ts +5 -2
  131. package/types/components/Dropdown/utils/index.d.ts.map +1 -1
  132. package/types/examples/plasma_b2c/components/Dropdown/Normal/Dropdown.config.d.ts.map +1 -1
  133. package/types/examples/plasma_b2c/components/Dropdown/Tight/Dropdown.config.d.ts.map +1 -1
  134. package/types/examples/plasma_web/components/Dropdown/Normal/Dropdown.config.d.ts.map +1 -1
  135. 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
  };
@@ -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
  };
@@ -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
- setIsOpen(false);
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={<DropdownItem contentRight={DisclosureRightIcon} name="test" text="Nested dropdown" />}
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 contentRight={StyledCheckbox} value="checked" onChange={onChange} text="Checkbox" />
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
@@ -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
  };
@@ -92,7 +92,7 @@ const DisclosureRightIcon = (props) => (
92
92
  </StyledDisclosureRightIcon>
93
93
  );
94
94
 
95
- const StoryTight = (args: StoryDropdownProps) => {
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
- setIsOpen(false);
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={<DropdownItem contentRight={DisclosureRightIcon} name="test" text="Nested dropdown" />}
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 contentRight={StyledCheckbox} value="checked" onChange={onChange} text="Checkbox" />
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 Tight: StoryObj<StoryDropdownProps> = {
194
- render: (args) => <StoryTight {...args} />,
212
+ export const Normal: StoryObj<StoryDropdownProps> = {
213
+ render: (args) => <StoryNormal {...args} />,
195
214
  };
@@ -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
  };
@@ -26,7 +26,7 @@ type StoryDropdownPropsCustom = {
26
26
  type StoryDropdownProps = ComponentProps<typeof Dropdown> & StoryDropdownPropsCustom;
27
27
 
28
28
  const meta: Meta<StoryDropdownProps> = {
29
- title: 'plasma_web/Dropdown',
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
- setIsOpen(false);
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={<DropdownItem contentRight={DisclosureRightIcon} name="test" text="Nested dropdown" />}
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 contentRight={StyledCheckbox} value="checked" onChange={onChange} text="Checkbox" />
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
@@ -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
  };
@@ -26,7 +26,7 @@ type StoryDropdownPropsCustom = {
26
26
  type StoryDropdownProps = ComponentProps<typeof Dropdown> & StoryDropdownPropsCustom;
27
27
 
28
28
  const meta: Meta<StoryDropdownProps> = {
29
- title: 'plasma_web/Dropdown',
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 StoryTight = (args: StoryDropdownProps) => {
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
- setIsOpen(false);
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={<DropdownItem contentRight={DisclosureRightIcon} name="test" text="Nested dropdown" />}
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 contentRight={StyledCheckbox} value="checked" onChange={onChange} text="Checkbox" />
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 Tight: StoryObj<StoryDropdownProps> = {
194
- render: (args) => <StoryTight {...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", "role", "view", "size", "frame", "onToggle", "isFocusTrapped", "isOpen", "placement", "trigger", "offset", "preventOverflow", "closeOnOverlayClick", "closeOnEsc"];
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, children)));
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);