172 lines
4.4 KiB
JavaScript
172 lines
4.4 KiB
JavaScript
|
/* @flow */
|
||
|
import { setSituationBranch } from 'Actions/actions'
|
||
|
import {
|
||
|
defineDirectorStatus,
|
||
|
isAutoentrepreneur
|
||
|
} from 'Actions/companyStatusActions'
|
||
|
import RuleLink from 'Components/RuleLink'
|
||
|
import React from 'react'
|
||
|
import { connect } from 'react-redux'
|
||
|
import { config } from 'react-spring'
|
||
|
import {
|
||
|
noUserInputSelector,
|
||
|
getRuleFromAnalysis,
|
||
|
branchAnalyseSelector
|
||
|
} from 'Selectors/analyseSelectors'
|
||
|
import Animate from 'Ui/animate'
|
||
|
import './ComparativeTargets.css'
|
||
|
import SchemeCard from './ui/SchemeCard'
|
||
|
|
||
|
import type { RègleAvecMontant } from 'Types/RegleTypes'
|
||
|
|
||
|
const connectRègles = (situationBranchName: string) =>
|
||
|
connect(
|
||
|
state => {
|
||
|
return ({
|
||
|
revenuDisponible:
|
||
|
!noUserInputSelector(state) &&
|
||
|
getRuleFromAnalysis(
|
||
|
branchAnalyseSelector(state, { situationBranchName })
|
||
|
)('revenu net')
|
||
|
}: {
|
||
|
revenuDisponible: boolean | RègleAvecMontant
|
||
|
})
|
||
|
},
|
||
|
{
|
||
|
setSituationBranch,
|
||
|
isAutoentrepreneur,
|
||
|
defineDirectorStatus
|
||
|
}
|
||
|
)
|
||
|
|
||
|
type ComparativeTargetsProps = {
|
||
|
plafondAutoEntrepreneurDépassé: ?{ message: string }
|
||
|
}
|
||
|
const ComparativeTargets: React$ComponentType<{}> = connect(state => {
|
||
|
const analyse = branchAnalyseSelector(state, {
|
||
|
situationBranchName: 'Auto-entrepreneur'
|
||
|
})
|
||
|
return {
|
||
|
plafondAutoEntrepreneurDépassé:
|
||
|
analyse.controls &&
|
||
|
analyse.controls.find(({ test }) =>
|
||
|
test.includes('base des cotisations > plafond')
|
||
|
)
|
||
|
}
|
||
|
})(({ plafondAutoEntrepreneurDépassé }: ComparativeTargetsProps) => (
|
||
|
<Animate.fromBottom config={config.gentle}>
|
||
|
<div className="comparative-targets ui__ full-width">
|
||
|
<AutoEntrepreneur
|
||
|
branchIndex={0}
|
||
|
plafondDépassé={
|
||
|
plafondAutoEntrepreneurDépassé &&
|
||
|
plafondAutoEntrepreneurDépassé.message
|
||
|
}
|
||
|
/>
|
||
|
<AssimiléSalarié branchIndex={2} />
|
||
|
<Indépendant branchIndex={1} />
|
||
|
</div>
|
||
|
</Animate.fromBottom>
|
||
|
))
|
||
|
|
||
|
const Indépendant = connectRègles('Indépendant')(
|
||
|
({
|
||
|
revenuDisponible,
|
||
|
branchIndex,
|
||
|
setSituationBranch,
|
||
|
defineDirectorStatus,
|
||
|
isAutoentrepreneur
|
||
|
}) => (
|
||
|
<SchemeCard
|
||
|
title="Indépendant"
|
||
|
subtitle="La protection à la carte"
|
||
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
||
|
amount={revenuDisponible.montant}
|
||
|
icon="👩🔧"
|
||
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
||
|
features={[
|
||
|
'Régime des indépendants',
|
||
|
'Complémentaire santé et prévoyance non incluses',
|
||
|
'Accidents du travail non couverts',
|
||
|
'Retraite faible (41% du dernier brut)',
|
||
|
'Indemnités journalières plus faibles',
|
||
|
'Montant minimum de cotisations',
|
||
|
'Cotisations en décalage de deux ans'
|
||
|
]}
|
||
|
onSchemeChoice={() => {
|
||
|
defineDirectorStatus('SELF_EMPLOYED')
|
||
|
isAutoentrepreneur(false)
|
||
|
}}
|
||
|
/>
|
||
|
)
|
||
|
)
|
||
|
|
||
|
const AssimiléSalarié = connectRègles('Assimilé salarié')(
|
||
|
({
|
||
|
revenuDisponible,
|
||
|
branchIndex,
|
||
|
setSituationBranch,
|
||
|
defineDirectorStatus
|
||
|
}) => (
|
||
|
<SchemeCard
|
||
|
title="Assimilé salarié"
|
||
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
||
|
subtitle="Le régime tout compris"
|
||
|
amount={revenuDisponible.montant}
|
||
|
featured="Le choix de 58% des dirigeants de sociétés"
|
||
|
icon="☂"
|
||
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
||
|
features={[
|
||
|
'Régime général',
|
||
|
'Complémentaires santé et prévoyance incluses',
|
||
|
'Accidents du travail couverts',
|
||
|
'Retraite élevée (62 % du dernier brut)',
|
||
|
'Pas de cotisations minimales',
|
||
|
"Seuil pour l'activation des droits (4000€/an)",
|
||
|
'Fiches de paie mensuelles',
|
||
|
'Prélèvement des cotisations à la source'
|
||
|
]}
|
||
|
onSchemeChoice={() => {
|
||
|
defineDirectorStatus('SALARIED')
|
||
|
isAutoentrepreneur(false)
|
||
|
}}
|
||
|
/>
|
||
|
)
|
||
|
)
|
||
|
|
||
|
const AutoEntrepreneur = connectRègles('Auto-entrepreneur')(
|
||
|
({
|
||
|
revenuDisponible,
|
||
|
setSituationBranch,
|
||
|
isAutoentrepreneur,
|
||
|
branchIndex,
|
||
|
plafondDépassé
|
||
|
}) => {
|
||
|
return (
|
||
|
<SchemeCard
|
||
|
title="Auto-entrepreneur"
|
||
|
subtitle="Pour les petites activités"
|
||
|
onAmountClick={() => setSituationBranch(branchIndex)}
|
||
|
disabled={plafondDépassé}
|
||
|
amountDesc={<RuleLink {...revenuDisponible} />}
|
||
|
icon="🚶♂️"
|
||
|
amount={revenuDisponible.montant}
|
||
|
features={[
|
||
|
'Régime des indépendants',
|
||
|
'Pas de déduction des charges',
|
||
|
'Pas de déduction fiscale pour la mutuelle (Madelin)',
|
||
|
"Chiffre d'affaires plafonné",
|
||
|
"Durée de l'ACRE plus élevée",
|
||
|
'Comptabilité réduite au minimum'
|
||
|
]}
|
||
|
onSchemeChoice={() => {
|
||
|
defineDirectorStatus('SELF_EMPLOYED')
|
||
|
isAutoentrepreneur(true)
|
||
|
}}
|
||
|
/>
|
||
|
)
|
||
|
}
|
||
|
)
|
||
|
|
||
|
export default ComparativeTargets
|