mon-entreprise/source/components/ComparativeTargets.js

117 lines
3.2 KiB
JavaScript
Raw Normal View History

2019-01-08 19:43:57 +00:00
import PeriodSwitch from 'Components/PeriodSwitch'
import withColours from 'Components/utils/withColours'
import { findRuleByDottedName } from 'Engine/rules'
import { compose } from 'ramda'
import React from 'react'
2019-01-08 19:43:57 +00:00
import emoji from 'react-easy-emoji'
import { connect } from 'react-redux'
import { Link } from 'react-router-dom'
import { formValueSelector } from 'redux-form'
2019-01-08 19:43:57 +00:00
import {
analysisWithDefaultsSelector,
2019-01-08 19:43:57 +00:00
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
)(
class ComparativeTargets extends React.Component {
render() {
let {
colours,
analyses,
target,
setSituationBranch,
simulationBranches
} = this.props
2019-01-08 19:43:57 +00:00
if (!simulationBranches) {
return null
}
// We retrieve the values necessary to compute the global % of taxes
// This is not elegant
let revenuTotal = analyses[0].targets.find(
t => t.dottedName === 'entreprise . rémunération totale du dirigeant'
)?.nodeValue,
getRevenuNet = analyse => analyse.cache["revenu net d'impôt"]?.nodeValue
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')
)
return (
<li
style={{
2019-01-07 15:05:36 +00:00
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={'/règle/' + dottedName}
onClick={() => setSituationBranch(i)}
className="explanation">
{emoji('📖')}
</Link>
</span>
<small>
Soit{' '}
{Math.round(
((revenuTotal - getRevenuNet(analysis)) /
+revenuTotal) *
100
)}{' '}
% de prélèvements
</small>
</>
)}
</li>
)
})}
</ul>
</div>
)
}
}
)