164 lines
4.6 KiB
JavaScript
164 lines
4.6 KiB
JavaScript
/* @flow */
|
|
import type { FicheDePaie } from 'Types/ResultViewTypes'
|
|
import withColours from 'Components/utils/withColours'
|
|
import { compose } from 'ramda'
|
|
import React, { Fragment } from 'react'
|
|
import { Trans } from 'react-i18next'
|
|
import { connect } from 'react-redux'
|
|
import FicheDePaieSelectors from 'Selectors/ficheDePaieSelectors'
|
|
import Montant from './Montant'
|
|
import './PaySlip.css'
|
|
import RuleLink from './RuleLink'
|
|
|
|
type ConnectedPropTypes = FicheDePaie & {
|
|
colours: { lightestColour: string }
|
|
}
|
|
|
|
const PaySlip = ({
|
|
salaireBrut,
|
|
avantagesEnNature,
|
|
salaireNet,
|
|
salaireDeBase,
|
|
salaireChargé,
|
|
salaireNetImposable,
|
|
nombreHeuresTravaillées,
|
|
salaireNetàPayer,
|
|
réductionsDeCotisations,
|
|
cotisations,
|
|
colours: { lightestColour },
|
|
totalCotisations
|
|
}: ConnectedPropTypes) => (
|
|
<div className="payslip__container">
|
|
<div className="payslip__hourSection">
|
|
<Trans i18nKey="payslip.heures">
|
|
Nombre d'heures travaillées :{' '}
|
|
</Trans>
|
|
<span className="montant"> {nombreHeuresTravaillées}</span>
|
|
</div>
|
|
{/* Section salaire brut */}
|
|
<div className="payslip__salarySection">
|
|
<h4 className="payslip__salaryTitle">
|
|
<Trans>Salaire</Trans>
|
|
</h4>
|
|
{avantagesEnNature.montant !== 0 ? (
|
|
<>
|
|
<RuleLink {...salaireDeBase} />
|
|
<Montant>{salaireDeBase.montant}</Montant>
|
|
<RuleLink {...avantagesEnNature} />
|
|
<Montant>{avantagesEnNature.montant}</Montant>
|
|
</>
|
|
) : null}
|
|
<RuleLink className="payslip__brut" {...salaireBrut} />
|
|
<Montant className="payslip__brut">{salaireBrut.montant}</Montant>
|
|
</div>
|
|
{/* Section cotisations */}
|
|
<div className="payslip__cotisationsSection">
|
|
<h4>
|
|
<Trans>Cotisations sociales</Trans>
|
|
</h4>
|
|
<h4>
|
|
<Trans>Part employeur</Trans>
|
|
</h4>
|
|
<h4>
|
|
<Trans>Part salariale</Trans>
|
|
</h4>
|
|
{cotisations.map(([section, cotisationList]) => (
|
|
<Fragment key={section}>
|
|
<h5 className="payslip__cotisationTitle">
|
|
<Trans>{section}</Trans>
|
|
</h5>
|
|
{cotisationList.map(cotisation => (
|
|
<Fragment key={cotisation.lien}>
|
|
<RuleLink
|
|
style={{ backgroundColor: lightestColour }}
|
|
{...cotisation}
|
|
/>
|
|
<Montant style={{ backgroundColor: lightestColour }}>
|
|
{cotisation.montant.partPatronale}
|
|
</Montant>
|
|
<Montant style={{ backgroundColor: lightestColour }}>
|
|
{cotisation.montant.partSalariale}
|
|
</Montant>
|
|
</Fragment>
|
|
))}
|
|
</Fragment>
|
|
))}
|
|
<h5 className="payslip__cotisationTitle">
|
|
<Trans>Réductions</Trans>
|
|
</h5>
|
|
<RuleLink {...réductionsDeCotisations} />
|
|
<Montant>{-réductionsDeCotisations.montant}</Montant>
|
|
<Montant>{0}</Montant>
|
|
{/* Total cotisation */}
|
|
<div className="payslip__total">
|
|
<Trans>Total des retenues</Trans>
|
|
</div>
|
|
<Montant className="payslip__total">
|
|
{totalCotisations.partPatronale}
|
|
</Montant>
|
|
<Montant className="payslip__total">
|
|
{totalCotisations.partSalariale}
|
|
</Montant>
|
|
{/* Salaire chargé */}
|
|
<RuleLink {...salaireChargé} />
|
|
<Montant>{salaireChargé.montant}</Montant>
|
|
<Montant>{0}</Montant>
|
|
</div>
|
|
{/* Section salaire net */}
|
|
<div className="payslip__salarySection">
|
|
<h4 className="payslip__salaryTitle">
|
|
<Trans>Salaire net</Trans>
|
|
</h4>
|
|
{/* Salaire net */}
|
|
<RuleLink {...salaireNet} />
|
|
<Montant>{salaireNet.montant}</Montant>
|
|
{avantagesEnNature.montant !== 0 ? (
|
|
<>
|
|
{/* Avantages en nature */}
|
|
<RuleLink {...avantagesEnNature} />
|
|
<Montant>{-avantagesEnNature.montant}</Montant>
|
|
{/* Salaire net à payer */}
|
|
<RuleLink
|
|
className="payslip__salaireNetàPayer"
|
|
{...salaireNetàPayer}
|
|
/>
|
|
<Montant className="payslip__salaireNetàPayer">
|
|
{salaireNetàPayer.montant}
|
|
</Montant>
|
|
</>
|
|
) : null}
|
|
{/* Salaire net imposable */}
|
|
<RuleLink {...salaireNetImposable} />
|
|
<Montant>{salaireNetImposable.montant}</Montant>
|
|
</div>
|
|
<br />
|
|
<p className="payslip__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="payslip__notice">
|
|
<Trans i18nKey="payslip.disclaimer">
|
|
Il ne prend pour l'instant pas en compte les conventions et accords
|
|
collectifs, ni la myriade d'aides à explorer sur <a href="https://www.aides-entreprises.fr">
|
|
aides-entreprises.fr
|
|
</a>.
|
|
</Trans>
|
|
</p>
|
|
</div>
|
|
)
|
|
|
|
export default compose(
|
|
withColours,
|
|
connect(
|
|
FicheDePaieSelectors,
|
|
{}
|
|
)
|
|
)(PaySlip)
|