2019-11-10 15:57:44 +00:00
|
|
|
import { SitePaths } from 'Components/utils/withSitePaths'
|
|
|
|
import { History } from 'history'
|
2020-03-30 17:14:03 +00:00
|
|
|
import { DottedName } from 'Publicode/rules'
|
2019-11-28 11:03:23 +00:00
|
|
|
import { RootState, SimulationConfig } from 'Reducers/rootReducer'
|
2019-11-10 15:57:44 +00:00
|
|
|
import { ThunkAction } from 'redux-thunk'
|
|
|
|
import { deletePersistedSimulation } from '../storage/persistSimulation'
|
|
|
|
|
|
|
|
export type Action =
|
|
|
|
| ResetSimulationAction
|
|
|
|
| StepAction
|
|
|
|
| UpdateAction
|
|
|
|
| SetSimulationConfigAction
|
|
|
|
| DeletePreviousSimulationAction
|
|
|
|
| SetExempleAction
|
|
|
|
| ExplainVariableAction
|
2019-11-28 11:03:23 +00:00
|
|
|
| UpdateSituationAction
|
2019-11-10 15:57:44 +00:00
|
|
|
| HideControlAction
|
|
|
|
| LoadPreviousSimulationAction
|
|
|
|
| SetSituationBranchAction
|
2020-03-30 16:24:18 +00:00
|
|
|
| UpdateDefaultUnitAction
|
2019-11-10 15:57:44 +00:00
|
|
|
| SetActiveTargetAction
|
|
|
|
|
2019-12-13 16:22:18 +00:00
|
|
|
export type ThunkResult<R> = ThunkAction<
|
2019-11-10 15:57:44 +00:00
|
|
|
R,
|
|
|
|
RootState,
|
|
|
|
{ history: History; sitePaths: SitePaths },
|
|
|
|
Action
|
|
|
|
>
|
|
|
|
|
|
|
|
type StepAction = {
|
|
|
|
type: 'STEP_ACTION'
|
|
|
|
name: 'fold' | 'unfold'
|
2019-12-13 10:01:02 +00:00
|
|
|
step: DottedName
|
2019-11-10 15:57:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type SetSimulationConfigAction = {
|
|
|
|
type: 'SET_SIMULATION'
|
|
|
|
url: string
|
2019-11-28 11:03:23 +00:00
|
|
|
config: SimulationConfig
|
2020-01-07 13:41:37 +00:00
|
|
|
useCompanyDetails: boolean
|
2019-11-10 15:57:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type DeletePreviousSimulationAction = {
|
|
|
|
type: 'DELETE_PREVIOUS_SIMULATION'
|
|
|
|
}
|
|
|
|
|
2019-12-18 16:47:43 +00:00
|
|
|
type SetExempleAction =
|
|
|
|
| {
|
|
|
|
type: 'SET_EXAMPLE'
|
|
|
|
name: null
|
|
|
|
}
|
|
|
|
| {
|
|
|
|
type: 'SET_EXAMPLE'
|
|
|
|
name: string
|
|
|
|
situation: object
|
|
|
|
dottedName: DottedName
|
|
|
|
}
|
2019-11-10 15:57:44 +00:00
|
|
|
|
|
|
|
type ResetSimulationAction = ReturnType<typeof resetSimulation>
|
|
|
|
type UpdateAction = ReturnType<typeof updateSituation>
|
2019-11-28 11:03:23 +00:00
|
|
|
type UpdateSituationAction = ReturnType<typeof updateSituation>
|
2019-11-10 15:57:44 +00:00
|
|
|
type LoadPreviousSimulationAction = ReturnType<typeof loadPreviousSimulation>
|
|
|
|
type SetSituationBranchAction = ReturnType<typeof setSituationBranch>
|
|
|
|
type SetActiveTargetAction = ReturnType<typeof setActiveTarget>
|
|
|
|
type HideControlAction = ReturnType<typeof hideControl>
|
|
|
|
type ExplainVariableAction = ReturnType<typeof explainVariable>
|
2020-03-30 16:24:18 +00:00
|
|
|
type UpdateDefaultUnitAction = ReturnType<typeof updateUnit>
|
2019-11-10 15:57:44 +00:00
|
|
|
|
|
|
|
export const resetSimulation = () =>
|
|
|
|
({
|
|
|
|
type: 'RESET_SIMULATION'
|
|
|
|
} as const)
|
|
|
|
|
|
|
|
export const goToQuestion = (question: string) =>
|
|
|
|
({
|
|
|
|
type: 'STEP_ACTION',
|
|
|
|
name: 'unfold',
|
|
|
|
step: question
|
|
|
|
} as const)
|
|
|
|
|
|
|
|
export const validateStepWithValue = (
|
|
|
|
dottedName: DottedName,
|
2019-12-13 16:22:18 +00:00
|
|
|
value: unknown
|
2019-11-10 15:57:44 +00:00
|
|
|
): ThunkResult<void> => dispatch => {
|
|
|
|
dispatch(updateSituation(dottedName, value))
|
|
|
|
dispatch({
|
|
|
|
type: 'STEP_ACTION',
|
|
|
|
name: 'fold',
|
|
|
|
step: dottedName
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
export const setSituationBranch = (id: number) =>
|
|
|
|
({
|
|
|
|
type: 'SET_SITUATION_BRANCH',
|
|
|
|
id
|
|
|
|
} as const)
|
|
|
|
|
2020-01-07 13:41:37 +00:00
|
|
|
export const setSimulationConfig = (
|
|
|
|
config: Object,
|
|
|
|
useCompanyDetails: boolean = false
|
|
|
|
): ThunkResult<void> => (dispatch, getState, { history }): void => {
|
2019-11-28 11:03:23 +00:00
|
|
|
if (getState().simulation?.config === config) {
|
|
|
|
return
|
|
|
|
}
|
2019-11-10 15:57:44 +00:00
|
|
|
const url = history.location.pathname
|
|
|
|
dispatch({
|
|
|
|
type: 'SET_SIMULATION',
|
|
|
|
url,
|
2020-01-07 13:41:37 +00:00
|
|
|
useCompanyDetails,
|
2019-11-10 15:57:44 +00:00
|
|
|
config
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-12-13 10:01:02 +00:00
|
|
|
export const setActiveTarget = (targetName: DottedName) =>
|
2019-11-10 15:57:44 +00:00
|
|
|
({
|
|
|
|
type: 'SET_ACTIVE_TARGET_INPUT',
|
|
|
|
name: targetName
|
|
|
|
} as const)
|
|
|
|
|
|
|
|
export const deletePreviousSimulation = (): ThunkResult<void> => dispatch => {
|
|
|
|
dispatch({
|
|
|
|
type: 'DELETE_PREVIOUS_SIMULATION'
|
|
|
|
})
|
|
|
|
deletePersistedSimulation()
|
|
|
|
}
|
|
|
|
|
2019-12-13 16:22:18 +00:00
|
|
|
export const updateSituation = (fieldName: DottedName, value: unknown) =>
|
2019-11-10 15:57:44 +00:00
|
|
|
({
|
|
|
|
type: 'UPDATE_SITUATION',
|
|
|
|
fieldName,
|
|
|
|
value
|
|
|
|
} as const)
|
|
|
|
|
2019-11-28 11:03:23 +00:00
|
|
|
export const updateUnit = (defaultUnit: string) =>
|
2019-11-10 15:57:44 +00:00
|
|
|
({
|
2019-11-28 11:03:23 +00:00
|
|
|
type: 'UPDATE_DEFAULT_UNIT',
|
|
|
|
defaultUnit
|
2019-11-10 15:57:44 +00:00
|
|
|
} as const)
|
|
|
|
|
2019-12-13 10:01:02 +00:00
|
|
|
export function setExample(name: string, situation, dottedName: DottedName) {
|
2019-11-10 15:57:44 +00:00
|
|
|
return { type: 'SET_EXAMPLE', name, situation, dottedName } as const
|
|
|
|
}
|
|
|
|
|
|
|
|
export const goBackToSimulation = (): ThunkResult<void> => (
|
|
|
|
dispatch,
|
|
|
|
getState,
|
|
|
|
{ history }
|
|
|
|
) => {
|
|
|
|
dispatch({ type: 'SET_EXAMPLE', name: null })
|
2019-12-18 16:47:43 +00:00
|
|
|
const url = getState().simulation?.url
|
|
|
|
url && history.push(url)
|
2019-11-10 15:57:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export function loadPreviousSimulation() {
|
|
|
|
return {
|
|
|
|
type: 'LOAD_PREVIOUS_SIMULATION'
|
|
|
|
} as const
|
|
|
|
}
|
|
|
|
|
|
|
|
export function hideControl(id: string) {
|
|
|
|
return { type: 'HIDE_CONTROL', id } as const
|
|
|
|
}
|
|
|
|
|
2019-12-18 16:47:43 +00:00
|
|
|
export const explainVariable = (variableName: DottedName | null = null) =>
|
2019-11-10 15:57:44 +00:00
|
|
|
({
|
|
|
|
type: 'EXPLAIN_VARIABLE',
|
|
|
|
variableName
|
|
|
|
} as const)
|