import { startConversation } from 'Actions/actions' import AnswerList from 'Components/AnswerList' import { ScrollToTop } from 'Components/utils/Scroll' import withColours from 'Components/utils/withColours' import withLanguage from 'Components/utils/withLanguage' import React, { Component } from 'react' import { Trans, translate } from 'react-i18next' import { connect } from 'react-redux' import { Redirect, withRouter } from 'react-router' import { Link } from 'react-router-dom' import { blockingInputControlsSelector, nextStepsSelector, noUserInputSelector, validInputEnteredSelector } from 'Selectors/analyseSelectors' import * as Animate from 'Ui/animate' import { normalizeBasePath } from '../utils' import Conversation from './conversation/Conversation' import Distribution from './Distribution' import PageFeedback from './Feedback/PageFeedback' import PaySlip from './PaySlip' import PeriodSwitch from './PeriodSwitch' import QuickLink from './QuickLink' import ResultView from './ResultView' import './Simu.css' import TargetSelection from './TargetSelection' @withRouter @withColours @translate() // Triggers rerender when the language changes @connect( state => ({ blockingInputControls: blockingInputControlsSelector(state), conversationStarted: state.conversationStarted, validInputEntered: validInputEnteredSelector(state), arePreviousAnswers: state.conversationSteps.foldedSteps.length !== 0, nextSteps: state.conversationStarted && nextStepsSelector(state), userInput: noUserInputSelector(state) }), { startConversation } ) @withLanguage class Simulation extends Component { state = { displayPreviousAnswers: false } render() { let { colours, conversationStarted, arePreviousAnswers, nextSteps, startConversation, blockingInputControls, match, validInputEntered, location } = this.props const displayConversation = conversationStarted && !blockingInputControls const simulationCompleted = !blockingInputControls && conversationStarted && !nextSteps.length const displayPreviousAnswers = arePreviousAnswers && this.state.displayPreviousAnswers const simulationHomePath = normalizeBasePath(match.path).replace( /\/simulation\/$/, '' ) return ( <>
> )}