2016-04-12 15:10:07 +02:00
|
|
|
const items = (state = [], action) => {
|
2016-09-05 23:04:15 +02:00
|
|
|
switch (action.type) {
|
|
|
|
case 'ADD_ITEM': {
|
|
|
|
// Add object to items array
|
|
|
|
const newState = [...state, {
|
|
|
|
id: action.id,
|
|
|
|
choiceId: action.choiceId,
|
|
|
|
value: action.value,
|
|
|
|
label: action.label,
|
|
|
|
active: true,
|
|
|
|
highlighted: false,
|
|
|
|
}];
|
2016-04-12 15:10:07 +02:00
|
|
|
|
2016-09-05 23:04:15 +02:00
|
|
|
return newState.map((item) => {
|
|
|
|
if (item.highlighted) {
|
|
|
|
item.highlighted = false;
|
2016-08-14 23:14:37 +02:00
|
|
|
}
|
2016-09-05 23:04:15 +02:00
|
|
|
return item;
|
|
|
|
});
|
|
|
|
}
|
2016-04-12 15:10:07 +02:00
|
|
|
|
2016-09-05 23:04:15 +02:00
|
|
|
case 'REMOVE_ITEM': {
|
|
|
|
// Set item to inactive
|
|
|
|
return state.map((item) => {
|
|
|
|
if (item.id === action.id) {
|
|
|
|
item.active = false;
|
2016-08-14 23:14:37 +02:00
|
|
|
}
|
2016-09-05 23:04:15 +02:00
|
|
|
return item;
|
|
|
|
});
|
|
|
|
}
|
2016-04-12 15:10:07 +02:00
|
|
|
|
2016-09-05 23:04:15 +02:00
|
|
|
case 'HIGHLIGHT_ITEM': {
|
|
|
|
return state.map((item) => {
|
|
|
|
if (item.id === action.id) {
|
|
|
|
item.highlighted = action.highlighted;
|
2016-08-14 23:14:37 +02:00
|
|
|
}
|
2016-09-05 23:04:15 +02:00
|
|
|
return item;
|
|
|
|
});
|
|
|
|
}
|
2016-04-12 15:10:07 +02:00
|
|
|
|
2016-09-05 23:04:15 +02:00
|
|
|
default: {
|
|
|
|
return state;
|
2016-04-12 15:10:07 +02:00
|
|
|
}
|
2016-09-05 23:04:15 +02:00
|
|
|
}
|
2016-08-14 23:14:37 +02:00
|
|
|
};
|
2016-04-12 15:10:07 +02:00
|
|
|
|
|
|
|
export default items;
|