2019-01-14 17:53:18 +00:00
|
|
|
/* @flow */
|
2019-01-15 17:36:04 +00:00
|
|
|
import { setSituationBranch } from 'Actions/actions'
|
2019-01-15 18:04:29 +00:00
|
|
|
import {
|
|
|
|
companyIsMicroenterprise,
|
|
|
|
defineDirectorStatus
|
|
|
|
} from 'Actions/companyStatusActions'
|
2019-01-15 16:22:27 +00:00
|
|
|
import RuleLink from 'Components/RuleLink'
|
2019-01-15 17:36:04 +00:00
|
|
|
import withSitePaths from 'Components/utils/withSitePaths'
|
2018-12-11 12:50:53 +00:00
|
|
|
import React from 'react'
|
|
|
|
import { connect } from 'react-redux'
|
2019-01-15 17:01:53 +00:00
|
|
|
import { Link } from 'react-router-dom'
|
2019-01-14 17:53:18 +00:00
|
|
|
import { config } from 'react-spring'
|
2019-01-17 09:14:44 +00:00
|
|
|
import { branchAnalyseSelector } from 'Selectors/analyseSelectors'
|
2019-01-15 17:01:53 +00:00
|
|
|
import {
|
|
|
|
règleAvecMontantSelector,
|
|
|
|
règleAvecValeurSelector
|
|
|
|
} from 'Selectors/regleSelectors'
|
2019-01-14 17:53:18 +00:00
|
|
|
import Animate from 'Ui/animate'
|
2019-01-15 17:01:53 +00:00
|
|
|
import Montant from 'Ui/Montant'
|
2019-01-08 19:43:57 +00:00
|
|
|
import './ComparativeTargets.css'
|
2019-01-14 17:53:18 +00:00
|
|
|
import SchemeCard from './ui/SchemeCard'
|
2019-01-04 18:24:49 +00:00
|
|
|
|
2019-01-15 17:01:53 +00:00
|
|
|
const connectRègles = (situationBranchName: string) =>
|
2019-01-15 17:36:04 +00:00
|
|
|
connect(
|
|
|
|
state => ({
|
|
|
|
revenuDisponible: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName
|
|
|
|
})('revenu disponible'),
|
|
|
|
prélèvements: règleAvecValeurSelector(state, {
|
|
|
|
situationBranchName
|
2019-01-16 17:41:39 +00:00
|
|
|
})('ratio de prélèvements'),
|
|
|
|
analysis: branchAnalyseSelector(state, {
|
|
|
|
situationBranchName
|
|
|
|
})
|
2019-01-15 17:36:04 +00:00
|
|
|
}),
|
2019-01-15 18:04:29 +00:00
|
|
|
{
|
|
|
|
setSituationBranch,
|
|
|
|
companyIsMicroenterprise,
|
|
|
|
defineDirectorStatus
|
|
|
|
}
|
2019-01-15 17:36:04 +00:00
|
|
|
)
|
2019-01-14 17:53:18 +00:00
|
|
|
|
|
|
|
const ComparativeTargets = () => (
|
2019-01-15 16:22:27 +00:00
|
|
|
<Animate.fromBottom config={config.gentle}>
|
|
|
|
<div
|
|
|
|
className="ui__ full-width"
|
|
|
|
style={{
|
|
|
|
display: 'flex',
|
|
|
|
flexWrap: 'wrap',
|
|
|
|
justifyContent: 'center',
|
|
|
|
alignItems: 'stretch'
|
|
|
|
}}>
|
2019-01-15 17:36:04 +00:00
|
|
|
<MicroEntreprise branchIndex={0} />
|
2019-01-15 18:04:29 +00:00
|
|
|
<AssimiléSalarié branchIndex={2} />
|
|
|
|
<Indépendant branchIndex={1} />
|
2019-01-15 16:22:27 +00:00
|
|
|
</div>
|
|
|
|
</Animate.fromBottom>
|
2018-12-11 12:50:53 +00:00
|
|
|
)
|
2019-01-14 17:53:18 +00:00
|
|
|
|
2019-01-15 17:01:53 +00:00
|
|
|
const Indépendant = connectRègles('Indépendant')(
|
2019-01-15 18:04:29 +00:00
|
|
|
({
|
|
|
|
revenuDisponible,
|
|
|
|
prélèvements,
|
|
|
|
branchIndex,
|
|
|
|
setSituationBranch,
|
|
|
|
defineDirectorStatus,
|
|
|
|
companyIsMicroenterprise
|
|
|
|
}) => (
|
2019-01-15 17:01:53 +00:00
|
|
|
<SchemeCard
|
|
|
|
title="Indépendants"
|
|
|
|
subtitle="La protection à la carte"
|
2019-01-15 18:04:29 +00:00
|
|
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
2019-01-15 17:01:53 +00:00
|
|
|
amount={revenuDisponible.montant}
|
|
|
|
amountNotice={<PrélèvementNotice prélèvements={prélèvements} />}
|
|
|
|
icon="👩🔧"
|
|
|
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
|
|
|
features={[
|
|
|
|
'Régime des indépendants',
|
2019-01-16 17:41:39 +00:00
|
|
|
'Complémentaire santé et prévoyance non incluses',
|
2019-01-15 17:01:53 +00:00
|
|
|
'Accidents du travail non couverts',
|
2019-01-16 17:41:39 +00:00
|
|
|
'Retraite faible (41% du dernier brut)',
|
2019-01-15 17:01:53 +00:00
|
|
|
'Indemnités journalières plus faibles',
|
|
|
|
'Montant minimum de cotisations',
|
2019-01-16 17:41:39 +00:00
|
|
|
'Cotisations en décalage de deux ans'
|
2019-01-15 17:01:53 +00:00
|
|
|
]}
|
2019-01-15 18:04:29 +00:00
|
|
|
onSchemeChoice={() => {
|
|
|
|
defineDirectorStatus('SELF_EMPLOYED')
|
|
|
|
companyIsMicroenterprise(false)
|
|
|
|
}}
|
2019-01-15 17:01:53 +00:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
)
|
2019-01-14 17:53:18 +00:00
|
|
|
|
2019-01-15 17:01:53 +00:00
|
|
|
const AssimiléSalarié = connectRègles('Assimilé salarié')(
|
2019-01-15 18:04:29 +00:00
|
|
|
({
|
|
|
|
revenuDisponible,
|
|
|
|
prélèvements,
|
|
|
|
branchIndex,
|
|
|
|
setSituationBranch,
|
|
|
|
defineDirectorStatus
|
|
|
|
}) => (
|
2019-01-15 17:01:53 +00:00
|
|
|
<SchemeCard
|
|
|
|
title="Assimilé salarié"
|
2019-01-15 18:04:29 +00:00
|
|
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
2019-01-15 17:01:53 +00:00
|
|
|
subtitle="Le régime tout compris"
|
|
|
|
amount={revenuDisponible.montant}
|
|
|
|
amountNotice={<PrélèvementNotice prélèvements={prélèvements} />}
|
2019-01-16 17:41:39 +00:00
|
|
|
featured="Le choix de 58% des dirigeants de sociétés"
|
2019-01-15 17:01:53 +00:00
|
|
|
icon="☂"
|
|
|
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
|
|
|
features={[
|
|
|
|
'Régime général',
|
2019-01-16 17:41:39 +00:00
|
|
|
'Complémentaires santé et prévoyance incluses',
|
2019-01-15 17:01:53 +00:00
|
|
|
'Accidents du travail couverts',
|
2019-01-16 17:41:39 +00:00
|
|
|
'Retraite élevée (62 % du dernier brut)',
|
|
|
|
'Pas de cotisations minimales',
|
2019-01-15 17:01:53 +00:00
|
|
|
"Seuil pour l'activation des droits (4000€/an)",
|
2019-01-16 17:41:39 +00:00
|
|
|
'Fiches de paie mensuelles',
|
|
|
|
'Prélèvement des cotisations à la source'
|
2019-01-15 17:01:53 +00:00
|
|
|
]}
|
2019-01-17 09:47:46 +00:00
|
|
|
onSchemeChoice={() => {
|
|
|
|
defineDirectorStatus('SALARIED')
|
|
|
|
companyIsMicroenterprise(false)
|
|
|
|
}}
|
2019-01-15 17:01:53 +00:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
)
|
2019-01-14 17:53:18 +00:00
|
|
|
|
2019-01-15 17:01:53 +00:00
|
|
|
const MicroEntreprise = connectRègles('Micro-entreprise')(
|
2019-01-15 18:04:29 +00:00
|
|
|
({
|
|
|
|
revenuDisponible,
|
|
|
|
prélèvements,
|
|
|
|
setSituationBranch,
|
|
|
|
companyIsMicroenterprise,
|
2019-01-16 17:41:39 +00:00
|
|
|
branchIndex,
|
2019-01-17 09:14:44 +00:00
|
|
|
analysis
|
|
|
|
}) => {
|
|
|
|
const disabledMessage = (
|
|
|
|
(analysis.controls &&
|
|
|
|
analysis.controls.find(({ test }) =>
|
|
|
|
test.includes('base des cotisations > plafond')
|
|
|
|
)) ||
|
|
|
|
{}
|
|
|
|
).message
|
|
|
|
return (
|
|
|
|
<SchemeCard
|
|
|
|
title="Micro-entreprise"
|
|
|
|
subtitle="Pour les petites activités"
|
|
|
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
|
|
|
disabled={
|
|
|
|
disabledMessage && (
|
|
|
|
<a href="https://www.service-public.fr/professionnels-entreprises/vosdroits/F32353">
|
|
|
|
{disabledMessage}
|
|
|
|
</a>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
|
|
|
icon="🚶♂️"
|
|
|
|
amountNotice={<PrélèvementNotice prélèvements={prélèvements} />}
|
|
|
|
amount={revenuDisponible.montant}
|
|
|
|
features={[
|
|
|
|
'Régime des indépendants',
|
|
|
|
'Pas de déduction des charges',
|
|
|
|
'Pas de déduction fiscale pour la mutuelle (Madelin)',
|
|
|
|
"Seuil de chiffre d'affaires",
|
|
|
|
"Durée de l'ACCRE plus élevée",
|
|
|
|
'Comptabilité réduite au minimum'
|
|
|
|
]}
|
2019-01-17 09:47:46 +00:00
|
|
|
onSchemeChoice={() => {
|
|
|
|
defineDirectorStatus('SELF_EMPLOYED')
|
|
|
|
companyIsMicroenterprise(true)
|
|
|
|
}}
|
2019-01-17 09:14:44 +00:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
2019-01-15 17:01:53 +00:00
|
|
|
)
|
|
|
|
|
2019-01-15 17:36:04 +00:00
|
|
|
const PrélèvementNotice = withSitePaths(({ prélèvements, sitePaths }) => (
|
2019-01-15 17:01:53 +00:00
|
|
|
<>
|
|
|
|
soit{' '}
|
|
|
|
<Montant
|
|
|
|
style={{ fontFamily: 'inherit' }}
|
|
|
|
type="percent"
|
|
|
|
numFractionDigit={0}>
|
|
|
|
{prélèvements.valeur}
|
|
|
|
</Montant>{' '}
|
2019-01-15 17:36:04 +00:00
|
|
|
de{' '}
|
|
|
|
<Link to={sitePaths.documentation.index + '/' + prélèvements.lien}>
|
|
|
|
prélèvements
|
|
|
|
</Link>
|
2019-01-15 17:01:53 +00:00
|
|
|
</>
|
2019-01-15 17:36:04 +00:00
|
|
|
))
|
2019-01-14 17:53:18 +00:00
|
|
|
export default ComparativeTargets
|