2018-06-12 10:21:36 +00:00
|
|
|
/* @flow */
|
|
|
|
|
|
|
|
import Observer from '@researchgate/react-intersection-observer'
|
2018-07-12 08:09:41 +00:00
|
|
|
import withColours from 'Components/utils/withColours'
|
2018-06-12 10:21:36 +00:00
|
|
|
import React, { Component } from 'react'
|
|
|
|
import emoji from 'react-easy-emoji'
|
|
|
|
import { Trans } from 'react-i18next'
|
|
|
|
import { connect } from 'react-redux'
|
2018-06-18 09:10:26 +00:00
|
|
|
import { config, Spring } from 'react-spring'
|
|
|
|
import { compose } from 'redux'
|
2018-07-25 14:07:53 +00:00
|
|
|
import répartitionSelector from 'Selectors/repartitionSelectors'
|
2018-07-27 14:47:58 +00:00
|
|
|
import { isIE } from '../utils'
|
2018-06-12 10:21:36 +00:00
|
|
|
import './Distribution.css'
|
|
|
|
import Montant from './Montant'
|
2018-06-18 09:10:26 +00:00
|
|
|
import './PaySlip'
|
2018-06-12 10:21:36 +00:00
|
|
|
import RuleLink from './RuleLink'
|
2018-11-30 11:46:19 +00:00
|
|
|
import type { Répartition } from 'Types/ResultViewTypes.js'
|
2018-06-12 10:21:36 +00:00
|
|
|
|
2018-08-28 12:16:57 +00:00
|
|
|
type Props = ?Répartition & {
|
2018-06-18 09:10:26 +00:00
|
|
|
colours: { colour: string }
|
2018-06-12 10:21:36 +00:00
|
|
|
}
|
|
|
|
type State = {
|
2018-11-30 11:46:19 +00:00
|
|
|
branchesInViewport: Array<string>
|
2018-06-12 10:21:36 +00:00
|
|
|
}
|
|
|
|
|
2018-06-18 12:53:07 +00:00
|
|
|
const ANIMATION_SPRING = config.gentle
|
2018-06-12 10:21:36 +00:00
|
|
|
class Distribution extends Component<Props, State> {
|
|
|
|
elementRef = null
|
|
|
|
state = {
|
|
|
|
branchesInViewport: []
|
|
|
|
}
|
|
|
|
handleBrancheInViewport = branche => (event, unobserve) => {
|
|
|
|
if (!event.isIntersecting) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
unobserve()
|
|
|
|
this.setState(({ branchesInViewport }) => ({
|
|
|
|
branchesInViewport: [branche, ...branchesInViewport]
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2018-08-28 12:16:57 +00:00
|
|
|
const {
|
|
|
|
colours: { colour },
|
|
|
|
...distribution
|
|
|
|
} = this.props
|
|
|
|
if (!Object.values(distribution).length) {
|
|
|
|
return null
|
|
|
|
}
|
2018-06-18 09:10:26 +00:00
|
|
|
const {
|
|
|
|
répartition,
|
|
|
|
cotisationMaximum,
|
|
|
|
total,
|
|
|
|
salaireChargé,
|
2018-08-28 12:16:57 +00:00
|
|
|
salaireNet
|
|
|
|
} = distribution
|
2018-06-12 10:21:36 +00:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<div className="distribution-chart__container">
|
|
|
|
{répartition.map(([branche, { partPatronale, partSalariale }]) => {
|
|
|
|
const brancheInViewport =
|
2018-11-30 11:46:19 +00:00
|
|
|
this.state.branchesInViewport.indexOf(branche.id) !== -1
|
2018-06-12 10:21:36 +00:00
|
|
|
const montant = brancheInViewport
|
|
|
|
? partPatronale + partSalariale
|
|
|
|
: 0
|
|
|
|
return (
|
|
|
|
<Observer
|
2018-11-30 11:46:19 +00:00
|
|
|
key={branche.id}
|
2018-07-27 14:47:58 +00:00
|
|
|
threshold={[0.33]}
|
2018-11-30 11:46:19 +00:00
|
|
|
onChange={this.handleBrancheInViewport(branche.id)}>
|
2018-06-12 10:21:36 +00:00
|
|
|
<Spring
|
|
|
|
config={ANIMATION_SPRING}
|
|
|
|
to={{
|
2018-06-18 13:56:07 +00:00
|
|
|
flex: montant / cotisationMaximum,
|
2018-06-12 10:21:36 +00:00
|
|
|
opacity: montant ? 1 : 0
|
|
|
|
}}>
|
2018-06-18 09:10:26 +00:00
|
|
|
{styles => (
|
2018-06-12 10:21:36 +00:00
|
|
|
<div
|
|
|
|
className="distribution-chart__item"
|
|
|
|
style={{
|
|
|
|
opacity: styles.opacity
|
|
|
|
}}>
|
2018-11-30 11:46:19 +00:00
|
|
|
<BranchIcône icône={branche.icône} />
|
2018-06-27 16:15:25 +00:00
|
|
|
<div className="distribution-chart__item-content">
|
|
|
|
<p className="distribution-chart__counterparts">
|
|
|
|
<span className="distribution-chart__branche-name">
|
2018-11-30 11:46:19 +00:00
|
|
|
<RuleLink {...branche} />
|
2018-06-27 16:15:25 +00:00
|
|
|
</span>
|
2018-11-30 11:46:19 +00:00
|
|
|
{' : '}
|
|
|
|
{branche.descriptionCourte}
|
2018-06-27 16:15:25 +00:00
|
|
|
</p>
|
|
|
|
<ChartItemBar {...{ styles, colour, montant, total }} />
|
2018-06-12 10:21:36 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</Spring>
|
|
|
|
</Observer>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</div>
|
|
|
|
<div className="distribution-chart__total">
|
2018-06-18 09:10:26 +00:00
|
|
|
<span />
|
|
|
|
<RuleLink {...salaireNet} />
|
2018-06-28 19:23:59 +00:00
|
|
|
<Montant numFractionDigit={0}>{salaireNet.montant}</Montant>
|
2018-06-18 09:10:26 +00:00
|
|
|
<span>+</span>
|
|
|
|
<Trans>Cotisations</Trans>
|
2018-06-28 19:23:59 +00:00
|
|
|
<Montant numFractionDigit={0}>
|
2018-06-27 16:15:25 +00:00
|
|
|
{total.partPatronale + total.partSalariale}
|
2018-06-18 09:54:18 +00:00
|
|
|
</Montant>
|
2018-06-18 09:10:26 +00:00
|
|
|
<span />
|
|
|
|
<div className="distribution-chart__total-border" />
|
|
|
|
<span>=</span>
|
|
|
|
<RuleLink {...salaireChargé} />
|
2018-06-28 19:23:59 +00:00
|
|
|
<Montant numFractionDigit={0}>{salaireChargé.montant}</Montant>
|
2018-06-12 10:21:36 +00:00
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
2018-06-18 09:10:26 +00:00
|
|
|
export default compose(
|
|
|
|
withColours,
|
2018-06-12 10:21:36 +00:00
|
|
|
connect(
|
|
|
|
répartitionSelector,
|
|
|
|
{}
|
2018-06-18 09:10:26 +00:00
|
|
|
)
|
|
|
|
)(Distribution)
|
2018-06-27 16:15:25 +00:00
|
|
|
|
|
|
|
let ChartItemBar = ({ styles, colour, montant, total }) => (
|
|
|
|
<div className="distribution-chart__bar-container">
|
|
|
|
<div
|
|
|
|
className="distribution-chart__bar"
|
|
|
|
style={{
|
2018-07-18 13:14:55 +00:00
|
|
|
backgroundColor: colour,
|
2018-07-27 14:47:58 +00:00
|
|
|
...(!isIE()
|
|
|
|
? { flex: styles.flex }
|
|
|
|
: { minWidth: styles.flex * 500 + 'px' })
|
2018-06-27 16:15:25 +00:00
|
|
|
}}
|
|
|
|
/>
|
2018-07-18 13:14:55 +00:00
|
|
|
<div>
|
2018-06-27 16:15:25 +00:00
|
|
|
<Montant
|
|
|
|
className="distribution-chart__amount"
|
|
|
|
numFractionDigit={0}
|
|
|
|
style={{ color: colour }}>
|
|
|
|
{montant}
|
|
|
|
</Montant>
|
|
|
|
<Montant
|
|
|
|
numFractionDigit={0}
|
|
|
|
type="percent"
|
|
|
|
className="distribution-chart__percent">
|
|
|
|
{montant / (total.partPatronale + total.partSalariale)}
|
|
|
|
</Montant>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
|
2018-11-30 11:46:19 +00:00
|
|
|
let BranchIcône = ({ icône }) => (
|
2018-06-27 16:15:25 +00:00
|
|
|
<div className="distribution-chart__legend">
|
2018-11-30 11:46:19 +00:00
|
|
|
<span className="distribution-chart__icon">{emoji(icône)}</span>
|
2018-06-27 16:15:25 +00:00
|
|
|
</div>
|
|
|
|
)
|