Skip to content

Commit

Permalink
#2108 Need shouldFilterItem support for oneofselect control (#2109)
Browse files Browse the repository at this point in the history
Signed-off-by: srikant <[email protected]>
  • Loading branch information
srikant-ch5 authored Aug 21, 2024
1 parent 23e4ada commit d73fff1
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -521,11 +521,29 @@ describe("oneofselect with custom value allowed works correctly", () => {
);
let dropdownWrapper = wrapper.find("div[data-id='properties-oneofselect-custom']");
const dropdownInput = dropdownWrapper.find("input");
dropdownInput.simulate("click");
// Enter '' in input to check [one, three] are filtered using enumFilter and shouldFilterItem
dropdownInput.simulate("change", { target: { value: "" } });
dropdownWrapper = wrapper.find("div[data-id='properties-oneofselect-custom']");
const dropdownList = dropdownWrapper.find("li.cds--list-box__menu-item");
expect(dropdownList).to.be.length(2);
});

it("Validate oneofselect filters correctly using shouldFilterItem", () => {
const wrapper = mount(
<OneofselectControl
store={controller.getStore()}
control={control}
controller={controller}
propertyId={propertyId}
/>
);
let dropdownWrapper = wrapper.find("div[data-id='properties-oneofselect-custom']");
const dropdownInput = dropdownWrapper.find("input");
dropdownInput.simulate("change", { target: { value: "one" } });
dropdownWrapper = wrapper.find("div[data-id='properties-oneofselect-custom']");
const dropdownList = dropdownWrapper.find("li.cds--list-box__menu-item");
expect(dropdownList).to.be.length(1);
});
});

describe("oneofselect classnames appear correctly", () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,11 @@ class DropDown extends React.Component {
}
}

// Filter Oneofselect items as per entered input.
filterItems(list) {
return list?.item?.label?.toLowerCase().includes(list?.inputValue?.toLowerCase());
}

render() {
let dropDown;
if (this.props.control.controlType === ControlType.SELECTSCHEMA) {
Expand Down Expand Up @@ -249,6 +254,7 @@ class DropDown extends React.Component {
translateWithId={(id) => listBoxMenuIconTranslationIds[id]}
titleText={this.props.controlItem}
helperText={this.props.control.helperText}
shouldFilterItem={this.filterItems}
/>
);
} else {
Expand Down

0 comments on commit d73fff1

Please sign in to comment.