2017-01-10 18:22:44 +00:00
|
|
|
import React from 'react'
|
2016-11-15 18:46:17 +00:00
|
|
|
import { combineReducers } from 'redux'
|
2017-01-10 18:22:44 +00:00
|
|
|
import reduceReducers from 'reduce-reducers'
|
|
|
|
import {reducer as formReducer, formValueSelector} from 'redux-form'
|
2017-02-16 10:45:40 +00:00
|
|
|
import { euro, months } from './components/conversation/formValueTypes.js'
|
2017-01-10 18:22:44 +00:00
|
|
|
|
2017-04-28 15:03:34 +00:00
|
|
|
import { EXPLAIN_VARIABLE, POINT_OUT_OBJECTIVES} from './actions'
|
2017-01-10 18:22:44 +00:00
|
|
|
import R from 'ramda'
|
2017-01-23 18:06:46 +00:00
|
|
|
|
2017-05-09 15:14:13 +00:00
|
|
|
import {findGroup, findRuleByDottedName, parentName, findVariantsAndRecords} from './engine/rules'
|
2017-04-24 18:03:38 +00:00
|
|
|
|
2017-04-28 15:03:34 +00:00
|
|
|
import {reduceSteps, generateGridQuestions, generateSimpleQuestions} from './engine/generateQuestions'
|
2017-01-10 18:22:44 +00:00
|
|
|
|
|
|
|
import computeThemeColours from './components/themeColours'
|
|
|
|
|
|
|
|
function themeColours(state = computeThemeColours(), {type, colour}) {
|
|
|
|
if (type == 'CHANGE_THEME_COLOUR')
|
|
|
|
return computeThemeColours(colour)
|
|
|
|
else return state
|
|
|
|
}
|
|
|
|
|
2017-02-09 17:38:51 +00:00
|
|
|
function explainedVariable(state = null, {type, variableName=null}) {
|
|
|
|
switch (type) {
|
|
|
|
case EXPLAIN_VARIABLE:
|
2017-02-09 17:15:25 +00:00
|
|
|
return variableName
|
2017-02-09 17:38:51 +00:00
|
|
|
default:
|
|
|
|
return state
|
|
|
|
}
|
2017-02-08 16:50:22 +00:00
|
|
|
}
|
|
|
|
|
2017-03-15 15:26:00 +00:00
|
|
|
function pointedOutObjectives(state=[], {type, objectives}) {
|
|
|
|
switch (type) {
|
|
|
|
case POINT_OUT_OBJECTIVES:
|
|
|
|
return objectives
|
|
|
|
default:
|
|
|
|
return state
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-22 17:18:37 +00:00
|
|
|
|
2017-01-10 18:22:44 +00:00
|
|
|
export default reduceReducers(
|
|
|
|
combineReducers({
|
2017-05-18 14:04:23 +00:00
|
|
|
sessionId: (id = Math.floor(Math.random() * 1000000000000) + '') => id,
|
2017-01-10 18:22:44 +00:00
|
|
|
// this is handled by redux-form, pas touche !
|
|
|
|
form: formReducer,
|
|
|
|
|
|
|
|
/* Have forms been filled or ignored ?
|
|
|
|
false means the user is reconsidering its previous input */
|
2017-04-24 18:03:38 +00:00
|
|
|
foldedSteps: (steps = []) => steps,
|
|
|
|
unfoldedSteps: (steps = []) => steps,
|
2017-01-10 18:22:44 +00:00
|
|
|
|
|
|
|
analysedSituation: (state = []) => state,
|
|
|
|
|
2017-02-08 16:50:22 +00:00
|
|
|
themeColours,
|
|
|
|
|
2017-03-15 15:26:00 +00:00
|
|
|
explainedVariable,
|
|
|
|
|
2017-04-24 18:03:38 +00:00
|
|
|
pointedOutObjectives,
|
2017-01-10 18:22:44 +00:00
|
|
|
}),
|
|
|
|
// cross-cutting concerns because here `state` is the whole state tree
|
2017-04-28 15:03:34 +00:00
|
|
|
reduceSteps
|
2017-01-10 18:22:44 +00:00
|
|
|
)
|