mon-entreprise/source/reducers/reducers.js

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)
)
)