/* @flow */ import { setSituationBranch } from 'Actions/actions' import { defineDirectorStatus, isAutoentrepreneur } from 'Actions/companyStatusActions' import classnames from 'classnames' import { T } from 'Components' import Conversation from 'Components/conversation/Conversation' import SeeAnswersButton from 'Components/conversation/SeeAnswersButton' import PeriodSwitch from 'Components/PeriodSwitch' // $FlowFixMe import ComparaisonConfig from 'Components/simulationConfigs/rémunération-dirigeant.yaml' import withSimulationConfig from 'Components/simulationConfigs/withSimulationConfig' import withSitePaths from 'Components/utils/withSitePaths' import { compose, tryCatch } from 'ramda' import React, { useCallback, useState } from 'react' import emoji from 'react-easy-emoji' import { connect } from 'react-redux' import { Link } from 'react-router-dom' import { branchAnalyseSelector } from 'Selectors/analyseSelectors' import { règleAvecMontantSelector, règleAvecValeurSelector } from 'Selectors/regleSelectors' import Animate from 'Ui/animate' import AnimatedTargetValue from 'Ui/AnimatedTargetValue' import InfoBulle from 'Ui/InfoBulle' import Montant from 'Ui/Montant' import './SchemeComparaison.css' import type { RègleAvecMontant, RègleAvecValeur } from 'Types/RegleTypes' type OwnProps = { hideAutoEntrepreneur?: boolean, hideAssimiléSalarié?: boolean } type Props = OwnProps & { assimiléSalarié?: SimulationResult, indépendant?: SimulationResult, autoEntrepreneur?: SimulationResult, setSituationBranch: number => void, defineDirectorStatus: string => void, sitePaths: any, isAutoentrepreneur: boolean => void, plafondAutoEntrepreneurDépassé: boolean } type SimulationResult = { retraite: RègleAvecMontant, trimestreValidés: RègleAvecValeur, indemnitésJournalières: RègleAvecMontant, indemnitésJournalièresATMP?: RègleAvecMontant, revenuNetAvantImpôts: RègleAvecMontant, revenuNetAprèsImpôts: RègleAvecMontant, plafondDépassé?: boolean } const SchemeComparaison = ({ /* Own Props */ hideAutoEntrepreneur = false, hideAssimiléSalarié = false, /* Injected Props */ assimiléSalarié, indépendant, autoEntrepreneur, defineDirectorStatus, isAutoentrepreneur, setSituationBranch }: Props) => { const [showMore, setShowMore] = useState(false) const [conversationStarted, setConversationStarted] = useState(false) const startConversation = useCallback(() => setConversationStarted(true), [ setConversationStarted ]) return (

{emoji('☂')} Assimilé salarié Le régime tout compris

{emoji('👩‍🔧')}{' '} {hideAssimiléSalarié ? ( Entreprise Individuelle ) : ( Indépendant )} La protection sociale à la carte

{emoji('🚶‍♂️')} Auto-entrepreneur Pour commencer sans risques

Statuts juridiques possibles

SAS, SASU ou SARL avec gérant minoritaire
{hideAssimiléSalarié ? ( EI ou EIRL ) : ( EI, EIRL, EURL ou SARL avec gérant majoritaire )}
Auto-entreprise

Sécurité sociale

Régime général
Sécurité sociale des indépendants

Couverture accidents du travail

Oui
Non

Assurance maladie{' '} (médicaments, soins, hospitalisations)

Identique pour tous

Mutuelle santé

Obligatoire
Fortement conseillée

Indemnités journalières

++
++
+

Retraite

+++
++
+
{conversationStarted && ( <>

Période

)}
{!conversationStarted ? (

Comparez vos revenus, votre retraite et vos indemnités maladies en 1 minute

) : (
)}
{conversationStarted && ( <>

Revenu net après impôts

{assimiléSalarié && ( setSituationBranch(0)} {...assimiléSalarié.revenuNetAprèsImpôts} /> )}
{indépendant && ( setSituationBranch(1)} {...indépendant.revenuNetAprèsImpôts} /> )}
{autoEntrepreneur && ( {autoEntrepreneur.plafondDépassé ? ( 'Plafond de CA dépassé' ) : ( setSituationBranch(2)} {...autoEntrepreneur.revenuNetAprèsImpôts} /> )} )}

Revenu net de cotisations (avant impôts)

{assimiléSalarié && ( setSituationBranch(0)} {...assimiléSalarié.revenuNetAvantImpôts} /> )}
{indépendant && ( setSituationBranch(1)} {...indépendant.revenuNetAvantImpôts} /> )}
{autoEntrepreneur && ( {autoEntrepreneur.plafondDépassé ? ( '—' ) : ( setSituationBranch(2)} {...autoEntrepreneur.revenuNetAvantImpôts} /> )} )}

Pension de retraite{' '} calculée pour 172 trimestres cotisés dans ce régime sans variations de revenus (avant impôts)

{assimiléSalarié && assimiléSalarié.retraite.applicable !== false ? (
setSituationBranch(0)} {...assimiléSalarié.retraite} />
setSituationBranch(0)} {...assimiléSalarié.trimestreValidés} />{' '} trimestres validés
) : ( Pas implémenté )}
{indépendant && indépendant.retraite.applicable !== false ? (
setSituationBranch(1)} {...indépendant.retraite} />
setSituationBranch(1)} {...indépendant.trimestreValidés} />{' '} trimestres validés
) : ( Pas implémenté )}
{autoEntrepreneur && (autoEntrepreneur.plafondDépassé ? ( '—' ) : autoEntrepreneur.retraite.applicable !== false ? (
setSituationBranch(2)} {...autoEntrepreneur.retraite} />
setSituationBranch(2)} {...autoEntrepreneur.trimestreValidés} />{' '} trimestres validés
) : ( Pas implémenté ))}

Indemnités journalières (en cas d'arrêt maladie)

{assimiléSalarié && ( <>
setSituationBranch(0)} {...assimiléSalarié.indemnitésJournalières} />{' '} / jour
( setSituationBranch(0)} {...assimiléSalarié.indemnitésJournalièresATMP} />{' '} pour les accidents de trajet/travail et maladie pro) )}
{indépendant && (
setSituationBranch(1)} {...indépendant.indemnitésJournalières} />{' '} / jour
)}
{autoEntrepreneur && (autoEntrepreneur.plafondDépassé ? ( '—' ) : (
setSituationBranch(2)} {...autoEntrepreneur.indemnitésJournalières} />{' '} / jour
))}
)} {showMore ? ( <>

ACRE

1 an (exonération partielle de cotisations)
3 ans (application de taux réduits de cotisations)

Déduction des charges

Oui (régime fiscal du réel)
Non (mais abattement forfaitaire pour le calcul de l'impôt sur le revenu)

Paiement des cotisations

Mensuel
Provision mensuelle (avec régularisation après coup en fonction du revenu réel)
Mensuel ou trimestriel

Contrats prévoyance et retraite facultatives déductibles

Oui (sous certaines conditions)
Oui (Loi Madelin)
Non

Paiement de cotisations minimales

Non
Oui
Non

Revenu minimum pour l'ouverture des droits aux prestations

Oui
Non (cotisations minimales obligatoires)
Oui
) : (

Comparaison détaillée

)} {!hideAutoEntrepreneur && (

Plafond de chiffre d'affaires

Non
Oui (70 000 € en services / 170 000 € en vente de biens, restauration ou hébergement)
)}

Gestion comptable, sociale, juridique...

Accompagnement fortement conseillé (expert comptable, comptable, centre de gestion agrée...)
Simplifiée (peut être gérée par l'auto-entrepreneur)
) } const RuleValueLink = withSitePaths( ({ lien, montant, valeur, sitePaths, onClick }) => ( {montant != undefined && } {valeur != undefined && ( {valeur} )} ) ) export default (compose( withSimulationConfig(ComparaisonConfig), connect( tryCatch( state => ({ autoEntrepreneur: { retraite: règleAvecMontantSelector(state, { situationBranchName: 'Auto-entrepreneur' })('protection sociale . retraite'), trimestreValidés: règleAvecValeurSelector(state, { situationBranchName: 'Auto-entrepreneur' })('protection sociale . retraite . trimestres validés par an'), indemnitésJournalières: règleAvecMontantSelector(state, { situationBranchName: 'Auto-entrepreneur' })('protection sociale . santé . indemnités journalières'), revenuNetAprèsImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Auto-entrepreneur' })('revenu net'), revenuNetAvantImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Auto-entrepreneur' })('auto entrepreneur . revenu net de cotisations'), // $FlowFixMe plafondDépassé: branchAnalyseSelector(state, { situationBranchName: 'Auto-entrepreneur' }).controls?.find( ({ test }) => test.includes && test.includes('base des cotisations > plafond') ) }, indépendant: { retraite: règleAvecMontantSelector(state, { situationBranchName: 'Indépendant' })('protection sociale . retraite'), trimestreValidés: règleAvecValeurSelector(state, { situationBranchName: 'Indépendant' })('protection sociale . retraite . trimestres validés par an'), indemnitésJournalières: règleAvecMontantSelector(state, { situationBranchName: 'Indépendant' })('protection sociale . santé . indemnités journalières'), revenuNetAprèsImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Indépendant' })('revenu net'), revenuNetAvantImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Indépendant' })('indépendant . revenu professionnel') }, assimiléSalarié: { retraite: règleAvecMontantSelector(state, { situationBranchName: 'Assimilé salarié' })('protection sociale . retraite'), trimestreValidés: règleAvecValeurSelector(state, { situationBranchName: 'Assimilé salarié' })('protection sociale . retraite . trimestres validés par an'), indemnitésJournalières: règleAvecMontantSelector(state, { situationBranchName: 'Assimilé salarié' })('protection sociale . santé . indemnités journalières'), indemnitésJournalièresATMP: règleAvecMontantSelector(state, { situationBranchName: 'Assimilé salarié' })( 'protection sociale . accidents du travail et maladies professionnelles' ), revenuNetAprèsImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Assimilé salarié' })('revenu net'), revenuNetAvantImpôts: règleAvecMontantSelector(state, { situationBranchName: 'Assimilé salarié' })('contrat salarié . salaire . net') } }), e => console.log(e) || {} ), { defineDirectorStatus, isAutoentrepreneur, setSituationBranch } ) )(SchemeComparaison): React$Component)