110 lines
2.5 KiB
JavaScript
110 lines
2.5 KiB
JavaScript
import { combineReducers } from 'redux'
|
|
import reduceReducers from 'reduce-reducers'
|
|
import { reducer as formReducer, formValueSelector } from 'redux-form'
|
|
import reduceSteps from './reduceSteps'
|
|
import computeThemeColours from 'Components/themeColours'
|
|
import { formatInputs } from 'Engine/rules'
|
|
|
|
import { popularTargetNames } from 'Components/TargetSelection'
|
|
|
|
function themeColours(state = computeThemeColours(), { type, colour }) {
|
|
if (type == 'CHANGE_THEME_COLOUR') return computeThemeColours(colour)
|
|
else return state
|
|
}
|
|
|
|
function explainedVariable(state = null, { type, variableName = null }) {
|
|
switch (type) {
|
|
case 'EXPLAIN_VARIABLE':
|
|
return variableName
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
|
|
function currentExample(state = null, { type, situation, name }) {
|
|
switch (type) {
|
|
case 'SET_EXAMPLE':
|
|
return name != null ? { name, situation } : null
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
|
|
function conversationStarted(state = false, { type }) {
|
|
switch (type) {
|
|
case 'START_CONVERSATION':
|
|
case 'LOAD_PREVIOUS_SIMULATION':
|
|
return true
|
|
case 'RESET_SIMULATION':
|
|
return false
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
function activeTargetInput(state = null, { type, name }) {
|
|
switch (type) {
|
|
case 'SET_ACTIVE_TARGET_INPUT':
|
|
return name
|
|
case 'RESET_SIMULATION':
|
|
return null
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
function foldedSteps(state = [], { type }) {
|
|
switch (type) {
|
|
case 'RESET_SIMULATION':
|
|
return []
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
|
|
function analysis(state = null, { type }) {
|
|
switch (type) {
|
|
case 'RESET_SIMULATION':
|
|
return null
|
|
default:
|
|
return state
|
|
}
|
|
}
|
|
export default (tracker, initialRules) =>
|
|
reduceReducers(
|
|
combineReducers({
|
|
sessionId: (id = Math.floor(Math.random() * 1000000000000) + '') => id,
|
|
// 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 */
|
|
foldedSteps,
|
|
currentQuestion: (state = null) => state,
|
|
nextSteps: (state = []) => state,
|
|
missingVariablesByTarget: (state = {}) => state,
|
|
|
|
parsedRules: (state = null) => state,
|
|
flatRules: (state = null) => state,
|
|
analysis,
|
|
|
|
targetNames: (state = popularTargetNames) => state,
|
|
|
|
situationGate: (state = () => null) => state,
|
|
|
|
iframe: (state = false) => state,
|
|
|
|
themeColours,
|
|
|
|
explainedVariable,
|
|
|
|
currentExample,
|
|
conversationStarted,
|
|
activeTargetInput
|
|
}),
|
|
// cross-cutting concerns because here `state` is the whole state tree
|
|
reduceSteps(
|
|
tracker,
|
|
initialRules,
|
|
formatInputs(initialRules, formValueSelector)
|
|
)
|
|
)
|