mon-entreprise/source/components/ComparativeTargets.js

127 lines
3.5 KiB
JavaScript

import PeriodSwitch from 'Components/PeriodSwitch'
import withColours from 'Components/utils/withColours'
import withSitePaths from 'Components/utils/withSitePaths'
import { encodeRuleName, findRuleByDottedName } from 'Engine/rules'
import { compose } from 'ramda'
import React from 'react'
import emoji from 'react-easy-emoji'
import { connect } from 'react-redux'
import { Link } from 'react-router-dom'
import {
analysisWithDefaultsSelector,
flatRulesSelector
} from 'Selectors/analyseSelectors'
import AnimatedTargetValue from './AnimatedTargetValue'
import './ComparativeTargets.css'
export default compose(
connect(
state => ({
target: findRuleByDottedName(
flatRulesSelector(state),
state.simulationConfig?.objectifs[0]
),
simulationBranches: state.simulationConfig?.branches,
analyses: analysisWithDefaultsSelector(state)
}),
dispatch => ({
setSituationBranch: id => dispatch({ type: 'SET_SITUATION_BRANCH', id })
})
),
withColours,
withSitePaths
)(
class ComparativeTargets extends React.Component {
render() {
let {
colours,
analyses,
target,
setSituationBranch,
sitePaths,
simulationBranches
} = this.props
if (!simulationBranches) {
return null
}
// We retrieve the values necessary to compute the global % of taxes
// This is not elegant
let getRatioPrélèvements = analysis =>
analysis.targets.find(t => t.dottedName === 'ratio de prélèvements')
return (
<div id="comparative-targets">
<h3>{target.title}</h3>
<PeriodSwitch />
<ul>
{analyses.map((analysis, i) => {
if (!analysis.targets) return null
let { nodeValue, dottedName } = analysis.targets[0],
name = simulationBranches[i].nom
let microNotApplicable =
name === 'Micro-entreprise' &&
analysis.controls?.find(({ test }) =>
test.includes('base des cotisations > plafond')
)
let ratioPrélèvements = getRatioPrélèvements(analysis)
return (
<li
style={{
color: colours.textColour,
background: `linear-gradient(
60deg,
${colours.darkColour} 0%,
${colours.colour} 100%
)`
}}
className={microNotApplicable ? 'microNotApplicable' : ''}
key={name}>
<span className="title">{name}</span>
{microNotApplicable ? (
<p id="microNotApplicable">{microNotApplicable.message}</p>
) : (
<>
<span className="figure">
<span className="value">
<AnimatedTargetValue value={nodeValue} />
</span>{' '}
<Link
title="Quel est calcul ?"
style={{ color: this.props.colours.colour }}
to={
sitePaths.documentation.index +
'/' +
encodeRuleName(dottedName)
}
onClick={() => setSituationBranch(i)}
className="explanation">
{emoji('📖')}
</Link>
</span>
<small>
Soit{' '}
{Math.round((1 - ratioPrélèvements.nodeValue) * 100)} %
de{' '}
<Link
style={{ color: 'white' }}
to={
sitePaths.documentation.index +
'/' +
encodeRuleName(ratioPrélèvements.dottedName)
}>
prélèvements
</Link>
</small>
</>
)}
</li>
)
})}
</ul>
</div>
)
}
}
)