@entur/dropdown 5.2.0-beta.0 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -780,14 +780,6 @@ var DropdownInputGroupDeprecated = function DropdownInputGroupDeprecated(_ref) {
780
780
  }, feedback)));
781
781
  };
782
782
 
783
- // export type DropdownItemType<ValueType> =
784
- // | { value?: ValueType; label: string; icons?: React.ComponentType<any>[] }
785
- // | string;
786
- // export type NormalizedDropdownItemType = {
787
- // value: string | number | Record<any, any>;
788
- // label: string;
789
- // icons?: React.ComponentType<any>[];
790
- // };
791
783
  var useNormalizedItems = function useNormalizedItems(items) {
792
784
  return React.useMemo(function () {
793
785
  return items.map(function (item) {
@@ -797,12 +789,14 @@ var useNormalizedItems = function useNormalizedItems(items) {
797
789
  label: item
798
790
  };
799
791
  }
800
- if (!('value' in item)) {
792
+ if ((item == null ? void 0 : item.value) === undefined) {
801
793
  return _extends({}, item, {
802
794
  value: item.label
803
795
  });
804
796
  }
805
- return item;
797
+ return _extends({}, item, {
798
+ value: item.value
799
+ });
806
800
  });
807
801
  }, [items]);
808
802
  };
@@ -1779,14 +1773,15 @@ var SearchableDropdown = function SearchableDropdown(_ref) {
1779
1773
  stateReducer: stateReducer,
1780
1774
  onStateChange: function onStateChange(_ref5) {
1781
1775
  var type = _ref5.type,
1782
- clickedItem = _ref5.selectedItem;
1776
+ newSelectedItem = _ref5.selectedItem;
1783
1777
  switch (type) {
1784
1778
  // @ts-expect-error This falltrough is wanted
1785
1779
  case useCombobox.stateChangeTypes.InputBlur:
1786
1780
  if (!selectOnBlur) break;
1787
1781
  case useCombobox.stateChangeTypes.InputKeyDownEnter: // eslint-disable-line no-fallthrough
1788
1782
  case useCombobox.stateChangeTypes.ItemClick:
1789
- onChange(clickedItem != null ? clickedItem : null);
1783
+ if (newSelectedItem === undefined) return;
1784
+ onChange(newSelectedItem != null ? newSelectedItem : null);
1790
1785
  }
1791
1786
  },
1792
1787
  // Accessibility
@@ -2207,7 +2202,10 @@ var MultiSelect = function MultiSelect(_ref) {
2207
2202
  }, rest), React.createElement("div", {
2208
2203
  className: classNames('eds-dropdown--multiselect__selected-items-and-input', {
2209
2204
  'eds-dropdown--multiselect__selected-items-and-input--filled': hasSelectedItems
2210
- })
2205
+ }),
2206
+ onClick: function onClick(e) {
2207
+ if (e.target === e.currentTarget) openMenu();
2208
+ }
2211
2209
  }, selectedItems.length < maxChips ? React.createElement(React.Fragment, null, selectedItems.length > 1 ? React.createElement(VisuallyHidden, {
2212
2210
  onClick: function onClick() {
2213
2211
  var _inputRef$current5;
@@ -2328,7 +2326,7 @@ var Dropdown = function Dropdown(_ref) {
2328
2326
  selectedItem: selectedItem,
2329
2327
  onStateChange: function onStateChange(_ref2) {
2330
2328
  var type = _ref2.type,
2331
- clickedItem = _ref2.selectedItem;
2329
+ newSelectedItem = _ref2.selectedItem;
2332
2330
  switch (type) {
2333
2331
  // @ts-expect-error This falltrough is wanted
2334
2332
  case useSelect.stateChangeTypes.ToggleButtonBlur:
@@ -2336,7 +2334,8 @@ var Dropdown = function Dropdown(_ref) {
2336
2334
  case useSelect.stateChangeTypes.ToggleButtonKeyDownEnter: // eslint-disable-line no-fallthrough
2337
2335
  case useSelect.stateChangeTypes.ItemClick:
2338
2336
  {
2339
- onChange == null ? void 0 : onChange(clickedItem !== undefined ? clickedItem : null);
2337
+ if (newSelectedItem === undefined) return;
2338
+ onChange == null ? void 0 : onChange(newSelectedItem != null ? newSelectedItem : null);
2340
2339
  }
2341
2340
  }
2342
2341
  },
@@ -2395,7 +2394,7 @@ var Dropdown = function Dropdown(_ref) {
2395
2394
  }
2396
2395
  }
2397
2396
  }
2398
- })), (_ref3 = (_selectedItem$label = selectedItem == null ? void 0 : selectedItem.label) != null ? _selectedItem$label : React.createElement("span", {
2397
+ })), (_ref3 = (_selectedItem$label = selectedItem == null ? void 0 : selectedItem.label) != null ? _selectedItem$label : React.createElement("div", {
2399
2398
  className: classNames('eds-dropdown__selected-item__placeholder', {
2400
2399
  'eds-dropdown__selected-item__placeholder--readonly': readOnly
2401
2400
  })