Skip to content

Commit

Permalink
[TASK] Cleanup TagSelectBox component
Browse files Browse the repository at this point in the history
This commit cleans up a bit `TagSelectBox` component:

- references in names to collections were removed
- dedicated css file was created for `TagSelectBox` this module
- small changes in code
  • Loading branch information
soee committed Nov 3, 2023
1 parent 7947e65 commit 4a1a71e
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 7 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
.tagSelectBox input {
/* Hack to override Neos backend CSS override */
background-color: transparent !important;
border: none !important;
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,7 @@ import { Headline, MultiSelectBox } from '@neos-project/react-ui-components';
import { useIntl } from '@media-ui/core';
import { IconLabel } from '@media-ui/core/src/components';

import * as classes from './CollectionSelectBox.module.css';
import { CollectionOption } from './AssetCollectionOptionPreviewElement';
import * as classes from './TagSelectBox.module.css';

interface TagSelectBoxProps {
values: string[];
Expand All @@ -15,28 +14,33 @@ interface TagSelectBoxProps {
disabled?: boolean;
}

interface TagOption {
label: string;
id: string;
}

const TagSelectBox = ({ values, options, onChange, disabled = false }: TagSelectBoxProps) => {
const { translate } = useIntl();
const [searchTerm, setSearchTerm] = useState('');

const filteredSelectBoxOptions: CollectionOption[] = useMemo(
() => options.filter(({ label }) => label.toLowerCase().includes(searchTerm)),
const filteredSelectBoxOptions: TagOption[] = useMemo(
() => options.filter(({ label }) => label.toLowerCase().includes(searchTerm.toLowerCase())),
[options, searchTerm]
);

const handleChange = (tagIds) => onChange(tagIds.map((tagId) => options.find((o) => o.id === tagId)));

const handleSearchTermChange = useCallback((searchTerm) => {
setSearchTerm(searchTerm.toLowerCase());
setSearchTerm(searchTerm);
}, []);

return (
<div className="tagSelectBox">
<div className="tagSelectBoxWrapper">
<Headline type="h2">
<IconLabel icon="tags" label={translate('inspector.tags', 'Tags')} />
</Headline>
<MultiSelectBox
className={classes.collectionSelectBox}
className={classes.tagSelectBox}
disabled={disabled}
placeholder={translate('inspector.tags.placeholder', 'Select a tag')}
noMatchesFoundLabel={translate('general.noMatchesFound', 'No matches found')}
Expand Down

0 comments on commit 4a1a71e

Please sign in to comment.