2018-06-06 08:22:46 +00:00
|
|
|
/* @flow */
|
2018-07-12 08:09:41 +00:00
|
|
|
import type { FicheDePaie } from 'Types/ResultViewTypes'
|
|
|
|
import withColours from 'Components/utils/withColours'
|
2019-03-06 14:00:44 +00:00
|
|
|
import withLanguage from 'Components/utils/withLanguage'
|
2018-06-12 10:21:36 +00:00
|
|
|
import { compose } from 'ramda'
|
2018-06-18 12:53:07 +00:00
|
|
|
import React, { Fragment } from 'react'
|
2018-06-06 08:22:46 +00:00
|
|
|
import { Trans } from 'react-i18next'
|
|
|
|
import { connect } from 'react-redux'
|
2019-03-06 14:00:44 +00:00
|
|
|
import { analysisToCotisationsSelector } from 'Selectors/ficheDePaieSelectors'
|
|
|
|
import {
|
|
|
|
getRuleFromAnalysis,
|
2019-07-01 15:59:57 +00:00
|
|
|
analysisWithDefaultsSelector,
|
|
|
|
parsedRulesSelector
|
2019-03-06 14:00:44 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2019-06-20 16:51:40 +00:00
|
|
|
import Value from 'Components/Value'
|
2018-06-06 08:22:46 +00:00
|
|
|
import './PaySlip.css'
|
2018-06-12 10:21:36 +00:00
|
|
|
import RuleLink from './RuleLink'
|
2019-03-06 14:00:44 +00:00
|
|
|
import { Line, SalaireNetSection, SalaireBrutSection } from './PaySlipSections'
|
2019-07-01 15:59:57 +00:00
|
|
|
import { findRuleByDottedName } from 'Engine/rules'
|
2018-06-18 09:10:26 +00:00
|
|
|
|
2018-08-28 12:16:57 +00:00
|
|
|
type ConnectedPropTypes = ?FicheDePaie & {
|
2018-06-18 08:49:02 +00:00
|
|
|
colours: { lightestColour: string }
|
|
|
|
}
|
2018-06-06 08:22:46 +00:00
|
|
|
|
2019-03-06 14:00:44 +00:00
|
|
|
export default compose(
|
|
|
|
withColours,
|
|
|
|
connect(state => ({
|
|
|
|
cotisations: analysisToCotisationsSelector(state),
|
2019-07-01 15:59:57 +00:00
|
|
|
analysis: analysisWithDefaultsSelector(state),
|
|
|
|
parsedRules: parsedRulesSelector(state)
|
2019-03-06 14:00:44 +00:00
|
|
|
})),
|
|
|
|
withLanguage
|
|
|
|
)(
|
|
|
|
({
|
|
|
|
colours: { lightestColour },
|
2018-08-28 12:16:57 +00:00
|
|
|
cotisations,
|
2019-07-01 15:59:57 +00:00
|
|
|
analysis,
|
|
|
|
parsedRules
|
2019-03-06 14:00:44 +00:00
|
|
|
}: ConnectedPropTypes) => {
|
|
|
|
let getRule = getRuleFromAnalysis(analysis)
|
|
|
|
|
|
|
|
return (
|
2019-07-01 15:59:57 +00:00
|
|
|
<div
|
|
|
|
className="payslip__container"
|
|
|
|
css={`
|
|
|
|
.value {
|
|
|
|
display: flex;
|
|
|
|
align-items: flex-end;
|
|
|
|
justify-content: flex-end;
|
|
|
|
padding-right: 0.2em;
|
|
|
|
}
|
|
|
|
`}>
|
2019-03-06 14:00:44 +00:00
|
|
|
<div className="payslip__hourSection">
|
|
|
|
<Trans i18nKey="payslip.heures">Heures travaillées par mois : </Trans>
|
|
|
|
<span className="montant">
|
|
|
|
{Math.round(
|
|
|
|
getRule('contrat salarié . temps partiel . heures par semaine')
|
|
|
|
.nodeValue * 4.33
|
|
|
|
)}
|
|
|
|
</span>
|
2018-08-28 12:16:57 +00:00
|
|
|
</div>
|
2019-03-06 14:00:44 +00:00
|
|
|
<SalaireBrutSection getRule={getRule} />
|
|
|
|
{/* Section cotisations */}
|
|
|
|
<div className="payslip__cotisationsSection">
|
|
|
|
<h4>
|
|
|
|
<Trans>Cotisations sociales</Trans>
|
|
|
|
</h4>
|
|
|
|
<h4>
|
|
|
|
<Trans>Part employeur</Trans>
|
|
|
|
</h4>
|
|
|
|
<h4>
|
|
|
|
<Trans>Part salariale</Trans>
|
|
|
|
</h4>
|
2019-07-01 15:59:57 +00:00
|
|
|
{cotisations.map(([brancheDottedName, cotisationList]) => {
|
|
|
|
let branche = findRuleByDottedName(parsedRules, brancheDottedName)
|
|
|
|
return (
|
|
|
|
<Fragment key={branche.dottedName}>
|
|
|
|
<h5 className="payslip__cotisationTitle">
|
|
|
|
<RuleLink {...branche} />
|
|
|
|
</h5>
|
|
|
|
{cotisationList.map(cotisation => (
|
|
|
|
<Fragment key={cotisation.dottedName}>
|
|
|
|
<RuleLink
|
|
|
|
style={{ backgroundColor: lightestColour }}
|
|
|
|
{...cotisation}
|
|
|
|
/>
|
|
|
|
<Value
|
|
|
|
nilValueSymbol="—"
|
|
|
|
style={{ backgroundColor: lightestColour }}>
|
|
|
|
{cotisation.montant.partPatronale}
|
|
|
|
</Value>
|
|
|
|
<Value
|
|
|
|
nilValueSymbol="—"
|
|
|
|
style={{ backgroundColor: lightestColour }}>
|
|
|
|
{cotisation.montant.partSalariale}
|
|
|
|
</Value>
|
|
|
|
</Fragment>
|
|
|
|
))}
|
|
|
|
</Fragment>
|
|
|
|
)
|
|
|
|
})}
|
2019-03-06 14:00:44 +00:00
|
|
|
<h5 className="payslip__cotisationTitle">
|
|
|
|
<Trans>Réductions</Trans>
|
|
|
|
</h5>
|
|
|
|
<Line
|
2019-06-20 16:51:40 +00:00
|
|
|
negative
|
2019-03-06 14:00:44 +00:00
|
|
|
rule={getRule('contrat salarié . réductions de cotisations')}
|
|
|
|
/>
|
2019-07-01 15:59:57 +00:00
|
|
|
<Value nilValueSymbol="—">{0}</Value>
|
2019-03-06 14:00:44 +00:00
|
|
|
{/* Total cotisation */}
|
|
|
|
<div className="payslip__total">
|
|
|
|
<Trans>Total des retenues</Trans>
|
|
|
|
</div>
|
2019-06-20 16:51:40 +00:00
|
|
|
<Value
|
2019-07-01 15:59:57 +00:00
|
|
|
nilValueSymbol="—"
|
2019-06-20 16:51:40 +00:00
|
|
|
{...getRule('contrat salarié . cotisations . patronales à payer')}
|
|
|
|
className="payslip__total"
|
|
|
|
/>
|
|
|
|
<Value
|
2019-07-01 15:59:57 +00:00
|
|
|
nilValueSymbol="—"
|
2019-06-20 16:51:40 +00:00
|
|
|
{...getRule('contrat salarié . cotisations . salariales')}
|
|
|
|
className="payslip__total"
|
|
|
|
/>
|
2019-03-06 14:00:44 +00:00
|
|
|
{/* Salaire chargé */}
|
|
|
|
<Line rule={getRule('contrat salarié . rémunération . total')} />
|
2019-07-01 15:59:57 +00:00
|
|
|
<Value nilValueSymbol="—">{0}</Value>
|
2019-03-06 14:00:44 +00:00
|
|
|
</div>
|
|
|
|
{/* Section salaire net */}
|
|
|
|
<SalaireNetSection getRule={getRule} />
|
|
|
|
<br />
|
|
|
|
<p className="ui__ notice">
|
|
|
|
<Trans i18nKey="payslip.notice">
|
|
|
|
Le simulateur vous aide à comprendre votre bulletin de paie, sans
|
|
|
|
lui être opposable. Pour plus d'informations, rendez vous
|
|
|
|
sur
|
|
|
|
<a
|
|
|
|
alt="service-public.fr"
|
|
|
|
href="https://www.service-public.fr/particuliers/vosdroits/F559">
|
|
|
|
service-public.fr
|
|
|
|
</a>
|
|
|
|
.
|
|
|
|
</Trans>
|
|
|
|
</p>
|
|
|
|
<p className="ui__ notice">
|
|
|
|
<Trans i18nKey="payslip.disclaimer">
|
|
|
|
Il ne prend pour l'instant pas en compte les accords et conventions
|
|
|
|
collectives, ni la myriade d'aides aux entreprises. Trouvez votre
|
|
|
|
convention collective{' '}
|
|
|
|
<a href="https://socialgouv.github.io/conventions-collectives">
|
|
|
|
ici
|
|
|
|
</a>
|
|
|
|
, et explorez les aides sur
|
|
|
|
<a href="https://www.aides-entreprises.fr">aides-entreprises.fr</a>.
|
|
|
|
</Trans>
|
|
|
|
</p>
|
2018-08-28 12:16:57 +00:00
|
|
|
</div>
|
2019-03-06 14:00:44 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
)
|