/* @flow */ import { setSituationBranch } from 'Actions/actions' import { companyIsMicroenterprise, defineDirectorStatus } from 'Actions/companyStatusActions' 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 './ComparativeTargets.css' import SchemeCard from './ui/SchemeCard' const connectRègles = (situationBranchName: string) => connect( state => ({ revenuDisponible: règleAvecMontantSelector(state, { situationBranchName })('revenu disponible'), prélèvements: règleAvecValeurSelector(state, { situationBranchName })('ratio de prélèvements'), analysis: branchAnalyseSelector(state, { situationBranchName }) }), { setSituationBranch, companyIsMicroenterprise, defineDirectorStatus } ) const ComparativeTargets = () => (
) 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, analysis }) => { const disabledMessage = ( (analysis.controls && analysis.controls.find(({ test }) => test.includes('base des cotisations > plafond') )) || {} ).message return ( setSituationBranch(branchIndex)} disabled={ disabledMessage && ( {disabledMessage} ) } 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)', "Seuil de chiffre d'affaires", "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