/* @flow */
import { setSituationBranch } from 'Actions/actions'
import {
defineDirectorStatus,
isAutoentrepreneur
} from 'Actions/companyStatusActions'
import PeriodSwitch from 'Components/PeriodSwitch'
import RuleLink from 'Components/RuleLink'
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 } from 'Selectors/analyseSelectors'
import {
règleAvecMontantSelector,
règleAvecValeurSelector
} from 'Selectors/regleSelectors'
import Animate from 'Ui/animate'
import Montant from 'Ui/Montant'
import { validInputEnteredSelector } from '../selectors/analyseSelectors'
import './ComparativeTargets.css'
import SchemeCard from './ui/SchemeCard'
import type {
Règle,
RègleAvecMontant,
RègleValeur,
RègleAvecValeur
} from 'Types/RegleTypes'
const connectRègles = (situationBranchName: string) =>
connect(
state => {
return ({
revenuDisponible:
validInputEnteredSelector(state) &&
règleAvecMontantSelector(state, {
situationBranchName
})('revenu net'),
prélèvements:
validInputEnteredSelector(state) &&
règleAvecValeurSelector(state, {
situationBranchName
})('ratio de prélèvements')
}: {
revenuDisponible: RègleAvecMontant,
prélèvements: RègleAvecValeur
})
},
{
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) => (
))
const Indépendant = connectRègles('Indépendant')(
({
revenuDisponible,
prélèvements,
branchIndex,
setSituationBranch,
defineDirectorStatus,
isAutoentrepreneur
}) => (
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')
isAutoentrepreneur(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')
isAutoentrepreneur(false)
}}
/>
)
)
const AutoEntrepreneur = connectRègles('Auto-entrepreneur')(
({
revenuDisponible,
prélèvements,
setSituationBranch,
isAutoentrepreneur,
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')
isAutoentrepreneur(true)
}}
/>
)
}
)
type PrélèvementNoticeProps = {
prélèvements: ?RègleAvecValeur,
sitePaths: Object
}
const PrélèvementNotice = withSitePaths(
({ prélèvements, sitePaths }: PrélèvementNoticeProps) =>
!!prélèvements && (
<>
soit{' '}
{prélèvements.valeur}
{' '}
de{' '}
prélèvements
>
)
)
export default ComparativeTargets