import React from 'react'; import { MenuToggle, MenuFooter, MenuSearch, MenuSearchInput, Divider, InputGroup, InputGroupItem, Button, ButtonVariant, SearchInput, Dropdown, DropdownList, DropdownItem } from '@patternfly/react-core'; import SearchIcon from '@patternfly/react-icons/dist/esm/icons/search-icon'; interface ItemData { text: string; href?: string; isDisabled?: boolean | undefined; } type ItemArrayType = (ItemData | string)[]; export const ContextSelectorDemo: React.FunctionComponent = () => { const items: ItemArrayType = [ { text: 'Action' }, { text: 'Link', href: '#' }, { text: 'Disabled action', isDisabled: true }, { text: 'Disabled link', href: '#', isDisabled: true }, 'My project', 'OpenShift cluster', 'Production Ansible', 'AWS', 'Azure', 'My project 2', 'OpenShift cluster ', 'Production Ansible 2 ', 'AWS 2', 'Azure 2' ]; const [isOpen, setIsOpen] = React.useState(false); const [selected, setSelected] = React.useState(typeof items[0] === 'string' ? items[0] : items[0].text); const [filteredItems, setFilteredItems] = React.useState(items); const [searchInputValue, setSearchInputValue] = React.useState(''); const menuRef = React.useRef(null); const menuFooterBtnRef = React.useRef(null); const onToggleClick = () => { setIsOpen(!isOpen); }; const onSelect = (ev: React.MouseEvent | undefined, itemId: string | number | undefined) => { if (typeof itemId === 'number' || typeof itemId === 'undefined') { return; } setSelected(itemId.toString()); setIsOpen(!isOpen); }; const onSearchInputChange = (value: string) => { setSearchInputValue(value); }; const onSearchButtonClick = () => { const filtered = searchInputValue === '' ? items : items.filter((item) => { const str = typeof item === 'string' ? item : item.text; return str.toLowerCase().indexOf(searchInputValue.toLowerCase()) !== -1; }); setFilteredItems(filtered || []); setIsOpen(true); // Keep menu open after search executed }; const onEnterPressed = (event: React.KeyboardEvent) => { if (event.key === 'Enter') { onSearchButtonClick(); } }; return ( setIsOpen(isOpen)} onOpenChangeKeys={['Escape']} toggle={(toggleRef) => ( {selected} )} ref={menuRef} id="context-selector" onSelect={onSelect} isScrollable > onSearchInputChange(value)} onKeyPress={onEnterPressed} aria-labelledby="pf-v6-context-selector-search-button-id-1" /> ); };