/* @flow */
import { setSituationBranch } from 'Actions/actions'
import {
companyIsMicroenterprise,
defineDirectorStatus
} from 'Actions/companyStatusActions'
import RuleLink from 'Components/RuleLink'
import PeriodSwitch from 'Components/PeriodSwitch'
import withSitePaths from 'Components/utils/withSitePaths'
import React from 'react'
import { connect } from 'react-redux'
import { Link } from 'react-router-dom'
import { config } from 'react-spring'
import {
branchAnalyseSelector,
noUserInputSelector
} from 'Selectors/analyseSelectors'
import {
règleAvecMontantSelector,
règleAvecValeurSelector
} from 'Selectors/regleSelectors'
import Animate from 'Ui/animate'
import Montant from 'Ui/Montant'
import './ComparativeTargets.css'
import SchemeCard from './ui/SchemeCard'
const connectRègles = (situationBranchName: string) =>
connect(
state => ({
revenuDisponible:
!noUserInputSelector(state) &&
règleAvecMontantSelector(state, {
situationBranchName
})('revenu disponible'),
prélèvements:
!noUserInputSelector(state) &&
règleAvecValeurSelector(state, {
situationBranchName
})('ratio de prélèvements')
}),
{
setSituationBranch,
companyIsMicroenterprise,
defineDirectorStatus
}
)
const ComparativeTargets = connect(state => {
const analyse = branchAnalyseSelector(state, {
situationBranchName: 'Micro-entreprise'
})
return {
plafondMicroEntrepriseDépassé:
analyse.controls &&
analyse.controls.find(({ test }) =>
test.includes('base des cotisations > plafond')
)
}
})(({ plafondMicroEntrepriseDépassé }) => (
))
const Indépendant = connectRègles('Indépendant')(
({
revenuDisponible,
prélèvements,
branchIndex,
setSituationBranch,
defineDirectorStatus,
companyIsMicroenterprise
}) => (
setSituationBranch(branchIndex)}
amount={revenuDisponible.montant}
amountNotice={}
icon="👩🔧"
amountDesc={}
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')
companyIsMicroenterprise(false)
}}
/>
)
)
const AssimiléSalarié = connectRègles('Assimilé salarié')(
({
revenuDisponible,
prélèvements,
branchIndex,
setSituationBranch,
defineDirectorStatus
}) => (
setSituationBranch(branchIndex)}
subtitle="Le régime tout compris"
amount={revenuDisponible.montant}
amountNotice={}
featured="Le choix de 58% des dirigeants de sociétés"
icon="☂"
amountDesc={}
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')
companyIsMicroenterprise(false)
}}
/>
)
)
const MicroEntreprise = connectRègles('Micro-entreprise')(
({
revenuDisponible,
prélèvements,
setSituationBranch,
companyIsMicroenterprise,
branchIndex,
plafondDépassé
}) => {
return (
setSituationBranch(branchIndex)}
disabled={plafondDépassé}
amountDesc={}
icon="🚶♂️"
amountNotice={}
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'ACCRE plus élevée",
'Comptabilité réduite au minimum'
]}
onSchemeChoice={() => {
defineDirectorStatus('SELF_EMPLOYED')
companyIsMicroenterprise(true)
}}
/>
)
}
)
const PrélèvementNotice = withSitePaths(({ prélèvements, sitePaths }) => (
<>
soit{' '}
{prélèvements.valeur}
{' '}
de{' '}
prélèvements
>
))
export default ComparativeTargets