2016-04-12 15:10:07 +02:00
|
|
|
const items = (state = [], action) => {
|
|
|
|
switch (action.type) {
|
|
|
|
case 'ADD_ITEM':
|
|
|
|
// Add object to items array
|
|
|
|
let newState = [...state, {
|
2016-04-14 15:43:36 +02:00
|
|
|
id: action.id,
|
2016-06-27 15:46:12 +02:00
|
|
|
choiceId: action.choiceId,
|
2016-04-12 15:10:07 +02:00
|
|
|
value: action.value,
|
2016-04-16 18:06:27 +02:00
|
|
|
label: action.label,
|
2016-04-12 15:10:07 +02:00
|
|
|
active: true,
|
|
|
|
selected: false
|
|
|
|
}];
|
|
|
|
|
|
|
|
return newState.map((item) => {
|
|
|
|
if(item.selected) {
|
|
|
|
item.selected = false;
|
|
|
|
}
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
|
|
|
case 'REMOVE_ITEM':
|
|
|
|
// Set item to inactive
|
|
|
|
return state.map((item) => {
|
2016-04-14 15:43:36 +02:00
|
|
|
if(item.id === action.id) {
|
2016-04-12 15:10:07 +02:00
|
|
|
item.active = false;
|
|
|
|
}
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
|
|
|
case 'SELECT_ITEM':
|
|
|
|
return state.map((item) => {
|
2016-04-14 15:43:36 +02:00
|
|
|
if(item.id === action.id) {
|
2016-04-12 21:16:36 +02:00
|
|
|
item.selected = action.selected;
|
2016-04-12 15:10:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return item;
|
|
|
|
});
|
|
|
|
|
|
|
|
default:
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default items;
|