mon-entreprise/source/components/ComparativeTargets.js

72 lines
1.9 KiB
JavaScript
Raw Normal View History

import React from 'react'
import {
flatRulesSelector,
analysisWithDefaultsSelector
} from 'Selectors/analyseSelectors'
import { connect } from 'react-redux'
import './ComparativeTargets.css'
import withColours from 'Components/utils/withColours'
import { Link } from 'react-router-dom'
import emoji from 'react-easy-emoji'
import { compose } from 'ramda'
import simulationConfig from './simulateur-rémunération-dirigeant.yaml'
import AnimatedTargetValue from './AnimatedTargetValue'
import PeriodSwitch from 'Components/PeriodSwitch'
import { findRuleByDottedName } from 'Engine/rules'
export default compose(
connect(state => ({
target: findRuleByDottedName(
flatRulesSelector(state),
simulationConfig.objectif
),
analyses: analysisWithDefaultsSelector(state, simulationConfig)
})),
withColours
)(
class ComparativeTargets extends React.Component {
render() {
let { colours, analyses, target } = this.props
return (
<div id="targets">
<h3>{target.title}</h3>
<PeriodSwitch />
<ul>
{analyses.map((analysis, i) => {
if (!analysis.targets) return null
let { nodeValue, dottedName } = analysis.targets[0],
name = simulationConfig.branches[i].nom
return (
<li
style={{
color: colours.textColour,
background: `linear-gradient(
60deg,
${colours.darkColour} 0%,
${colours.colour} 100%
)`
}}
key={name}>
<span className="title">{name}</span>
<span className="figure">
<span className="value">
<AnimatedTargetValue value={nodeValue} />
</span>{' '}
</span>
<Link
title="Quel est calcul ?"
style={{ color: this.props.colours.colour }}
to={'/règle/' + dottedName}
className="explanation">
{emoji('📖')}
</Link>
</li>
)
})}
</ul>
</div>
)
}
}
)