code7-leia 0.1.122 → 0.1.123

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.
@@ -986,6 +986,9 @@ var MultiSelect = function MultiSelect(_ref) {
986
986
  var _useState = React.useState(false),
987
987
  expanded = _useState[0],
988
988
  setExpanded = _useState[1];
989
+ var _useState2 = React.useState(''),
990
+ newOption = _useState2[0],
991
+ setNewOption = _useState2[1];
989
992
  var handleCheckboxChange = function handleCheckboxChange(value) {
990
993
  setPresset(function (prevPresset) {
991
994
  if (prevPresset.includes(value)) {
@@ -998,10 +1001,22 @@ var MultiSelect = function MultiSelect(_ref) {
998
1001
  });
999
1002
  };
1000
1003
  var showCheckboxes = function showCheckboxes() {
1001
- if (!expanded) {
1002
- setExpanded(true);
1003
- } else {
1004
- setExpanded(false);
1004
+ setExpanded(!expanded);
1005
+ };
1006
+ var handleInputChange = function handleInputChange(event) {
1007
+ setNewOption(event.target.value);
1008
+ };
1009
+ var handleInputKeyPress = function handleInputKeyPress(event) {
1010
+ if (event.key === 'Enter') {
1011
+ event.preventDefault();
1012
+ if (newOption.trim() !== '' && !options.some(function (option) {
1013
+ return option.value === newOption;
1014
+ })) {
1015
+ setPresset(function (prevPresset) {
1016
+ return [].concat(prevPresset, [newOption]);
1017
+ });
1018
+ }
1019
+ setNewOption('');
1005
1020
  }
1006
1021
  };
1007
1022
  return React__default.createElement("form", null, React__default.createElement(MultiSelectWrapper, null, React__default.createElement(SelectBox, {
@@ -1022,7 +1037,17 @@ var MultiSelect = function MultiSelect(_ref) {
1022
1037
  return handleCheckboxChange(option.value);
1023
1038
  }
1024
1039
  }), option.label);
1025
- }))));
1040
+ }), React__default.createElement("input", {
1041
+ type: "text",
1042
+ placeholder: "Add new option",
1043
+ value: newOption,
1044
+ onChange: handleInputChange,
1045
+ onKeyPress: handleInputKeyPress
1046
+ }))), React__default.createElement("div", null, "Selected Options:", presset.map(function (selectedOption, index) {
1047
+ return React__default.createElement("span", {
1048
+ key: index
1049
+ }, selectedOption, ", ");
1050
+ })));
1026
1051
  };
1027
1052
 
1028
1053
  var _templateObject$7;