mirror of
https://github.com/Choices-js/Choices.git
synced 2024-05-02 05:52:46 +02:00
68313da412
* Typescript config setup * Add type annotations to components * Further type additions * And more... * Add types to actions * Add types to templates * Further type checks * Further type additons * Install fuse latest * Housekeeping * Remove old type definitions * Fix remaning type issues * Fix some failing tests * Remove types workflow * Fix failing unit tests * Resolve back space event regression * Convert cypress files to .ts * Fix eslint issues * Remove cachebusting urls * Resolve delete button bug * Resolve regression bugs * Fix lint script * Fix lint workflow * Pass args instead of object to keyboard handlers * Flatten misc reducer * Resolve keyboad action test failures * Use Pick instead of Partial * Use interfaces in action tests * Update firefox image * Incorporate #791 * Incorporate #788
74 lines
1.7 KiB
TypeScript
74 lines
1.7 KiB
TypeScript
import { Item, State } from '../interfaces';
|
|
import {
|
|
AddItemAction,
|
|
RemoveItemAction,
|
|
HighlightItemAction,
|
|
} from '../actions/items';
|
|
|
|
export const defaultState = [];
|
|
|
|
type ActionTypes = AddItemAction | RemoveItemAction | HighlightItemAction;
|
|
|
|
export default function items(
|
|
state: Item[] = defaultState,
|
|
action: ActionTypes,
|
|
): State['items'] {
|
|
switch (action.type) {
|
|
case 'ADD_ITEM': {
|
|
const addItemAction = action as AddItemAction;
|
|
// Add object to items array
|
|
const newState = [
|
|
...state,
|
|
{
|
|
id: addItemAction.id,
|
|
choiceId: addItemAction.choiceId,
|
|
groupId: addItemAction.groupId,
|
|
value: addItemAction.value,
|
|
label: addItemAction.label,
|
|
active: true,
|
|
highlighted: false,
|
|
customProperties: addItemAction.customProperties,
|
|
placeholder: addItemAction.placeholder || false,
|
|
keyCode: null,
|
|
},
|
|
];
|
|
|
|
return newState.map((obj: Item) => {
|
|
const item = obj;
|
|
item.highlighted = false;
|
|
|
|
return item;
|
|
});
|
|
}
|
|
|
|
case 'REMOVE_ITEM': {
|
|
// Set item to inactive
|
|
return state.map(obj => {
|
|
const item = obj;
|
|
if (item.id === action.id) {
|
|
item.active = false;
|
|
}
|
|
|
|
return item;
|
|
});
|
|
}
|
|
|
|
case 'HIGHLIGHT_ITEM': {
|
|
const highlightItemAction = action as HighlightItemAction;
|
|
|
|
return state.map(obj => {
|
|
const item = obj;
|
|
if (item.id === highlightItemAction.id) {
|
|
item.highlighted = highlightItemAction.highlighted;
|
|
}
|
|
|
|
return item;
|
|
});
|
|
}
|
|
|
|
default: {
|
|
return state;
|
|
}
|
|
}
|
|
}
|