All files / SearchableMultiSelect SearchableMultiSelect.reducers.ts

100% Statements 4/4
100% Branches 0/0
100% Functions 3/3
100% Lines 4/4

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42                  2x 2x                     1x                       1x                
import _ from 'lodash';
import * as DropMenu from '../DropMenu/DropMenu.reducers';
import * as SearchField from '../SearchField/SearchField.reducers';
import { ISearchableMultiSelectState } from './SearchableMultiSelect';
 
export function onSelect(
	state: ISearchableMultiSelectState,
	selectedIndex: number[] | number
): ISearchableMultiSelectState {
	const arr: number[] = [];
	return {
		...state,
		selectedIndices: _.xor(state.selectedIndices, arr.concat(selectedIndex)),
	};
}
 
export function onSearch(
	state: ISearchableMultiSelectState,
	searchText: string,
	firstVisibleIndex: number
): ISearchableMultiSelectState {
	return {
		...state,
		searchText,
		DropMenu: {
			...DropMenu.onFocusOption(state.DropMenu, firstVisibleIndex),
		},
	};
}
 
export function onRemoveAll(
	state: ISearchableMultiSelectState
): ISearchableMultiSelectState {
	return {
		...state,
		selectedIndices: [],
	};
}
 
export { DropMenu };
export default SearchField;