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'
|
2018-12-11 12:50:53 +00:00
|
|
|
import React from 'react'
|
2019-01-08 19:43:57 +00:00
|
|
|
import emoji from 'react-easy-emoji'
|
2018-12-11 12:50:53 +00:00
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import { Link } from 'react-router-dom'
|
2018-12-21 16:27:20 +00:00
|
|
|
import { formValueSelector } from 'redux-form'
|
2019-01-08 19:43:57 +00:00
|
|
|
import {
|
2019-01-08 20:18:04 +00:00
|
|
|
analysisWithDefaultsSelector,
|
2019-01-08 19:43:57 +00:00
|
|
|
flatRulesSelector
|
|
|
|
} from 'Selectors/analyseSelectors'
|
|
|
|
import AnimatedTargetValue from './AnimatedTargetValue'
|
|
|
|
import './ComparativeTargets.css'
|
2018-12-11 12:50:53 +00:00
|
|
|
export default compose(
|
2018-12-17 16:18:49 +00:00
|
|
|
connect(
|
|
|
|
state => ({
|
|
|
|
target: findRuleByDottedName(
|
|
|
|
flatRulesSelector(state),
|
2019-01-08 09:33:05 +00:00
|
|
|
state.simulationConfig?.objectifs[0]
|
2018-12-17 16:18:49 +00:00
|
|
|
),
|
2019-01-08 09:33:05 +00:00
|
|
|
simulationBranches: state.simulationConfig?.branches,
|
2019-01-09 09:18:28 +00:00
|
|
|
analyses: analysisWithDefaultsSelector(state)
|
2018-12-17 16:18:49 +00:00
|
|
|
}),
|
|
|
|
dispatch => ({
|
|
|
|
setSituationBranch: id => dispatch({ type: 'SET_SITUATION_BRANCH', id })
|
|
|
|
})
|
|
|
|
),
|
2018-12-11 12:50:53 +00:00
|
|
|
withColours
|
|
|
|
)(
|
2018-12-13 18:12:19 +00:00
|
|
|
class ComparativeTargets extends React.Component {
|
2018-12-11 12:50:53 +00:00
|
|
|
render() {
|
2018-12-21 16:27:20 +00:00
|
|
|
let {
|
|
|
|
colours,
|
|
|
|
analyses,
|
|
|
|
target,
|
|
|
|
setSituationBranch,
|
2019-01-08 09:33:05 +00:00
|
|
|
simulationBranches
|
2018-12-21 16:27:20 +00:00
|
|
|
} = this.props
|
2019-01-08 19:43:57 +00:00
|
|
|
if (!simulationBranches) {
|
|
|
|
return null
|
2019-01-08 11:54:56 +00:00
|
|
|
}
|
2019-01-09 09:18:28 +00:00
|
|
|
// 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
|
|
|
|
|
2018-12-11 12:50:53 +00:00
|
|
|
return (
|
2019-01-08 11:54:56 +00:00
|
|
|
<div id="comparative-targets">
|
2018-12-17 11:31:14 +00:00
|
|
|
<h3>{target.title}</h3>
|
2018-12-14 16:16:24 +00:00
|
|
|
<PeriodSwitch />
|
|
|
|
<ul>
|
|
|
|
{analyses.map((analysis, i) => {
|
2018-12-17 11:31:14 +00:00
|
|
|
if (!analysis.targets) return null
|
|
|
|
let { nodeValue, dottedName } = analysis.targets[0],
|
2019-01-08 09:33:05 +00:00
|
|
|
name = simulationBranches[i].nom
|
2019-01-04 18:24:49 +00:00
|
|
|
|
|
|
|
let microNotApplicable =
|
|
|
|
name === 'Micro-entreprise' &&
|
|
|
|
analysis.controls?.find(({ test }) =>
|
|
|
|
test.includes('base des cotisations > plafond')
|
|
|
|
)
|
|
|
|
|
2018-12-14 16:16:24 +00:00
|
|
|
return (
|
|
|
|
<li
|
|
|
|
style={{
|
2019-01-07 15:05:36 +00:00
|
|
|
color: colours.textColour,
|
|
|
|
background: `linear-gradient(
|
2019-01-04 18:24:49 +00:00
|
|
|
60deg,
|
|
|
|
${colours.darkColour} 0%,
|
|
|
|
${colours.colour} 100%
|
|
|
|
)`
|
2018-12-14 16:16:24 +00:00
|
|
|
}}
|
2019-01-04 18:24:49 +00:00
|
|
|
className={microNotApplicable ? 'microNotApplicable' : ''}
|
2018-12-14 16:16:24 +00:00
|
|
|
key={name}>
|
|
|
|
<span className="title">{name}</span>
|
2019-01-04 18:24:49 +00:00
|
|
|
{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(
|
2019-01-09 09:18:28 +00:00
|
|
|
((revenuTotal - getRevenuNet(analysis)) /
|
|
|
|
+revenuTotal) *
|
2019-01-04 18:24:49 +00:00
|
|
|
100
|
|
|
|
)}{' '}
|
|
|
|
% de prélèvements
|
|
|
|
</small>
|
|
|
|
</>
|
|
|
|
)}
|
2018-12-14 16:16:24 +00:00
|
|
|
</li>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</ul>
|
2018-12-11 12:50:53 +00:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|