2019-05-09 14:31:11 +00:00
|
|
|
/* @flow */
|
2019-05-20 15:01:47 +00:00
|
|
|
import { setSituationBranch } from 'Actions/actions'
|
2019-05-09 14:31:11 +00:00
|
|
|
import {
|
|
|
|
defineDirectorStatus,
|
|
|
|
isAutoentrepreneur
|
|
|
|
} from 'Actions/companyStatusActions'
|
|
|
|
import classnames from 'classnames'
|
2019-05-09 16:40:14 +00:00
|
|
|
import { T } from 'Components'
|
2019-05-20 15:01:47 +00:00
|
|
|
import Conversation from 'Components/conversation/Conversation'
|
2019-06-06 14:33:06 +00:00
|
|
|
import SeeAnswersButton from 'Components/conversation/SeeAnswersButton'
|
2019-05-09 14:31:11 +00:00
|
|
|
import PeriodSwitch from 'Components/PeriodSwitch'
|
|
|
|
// $FlowFixMe
|
|
|
|
import ComparaisonConfig from 'Components/simulationConfigs/rémunération-dirigeant.yaml'
|
|
|
|
import withSimulationConfig from 'Components/simulationConfigs/withSimulationConfig'
|
2019-05-10 17:12:21 +00:00
|
|
|
import withSitePaths from 'Components/utils/withSitePaths'
|
2019-06-11 15:08:04 +00:00
|
|
|
import revenusSVG from 'Images/revenus.svg'
|
2019-05-13 13:35:04 +00:00
|
|
|
import { compose, tryCatch } from 'ramda'
|
2019-05-20 16:04:39 +00:00
|
|
|
import React, { useCallback, useState } from 'react'
|
2019-05-09 14:31:11 +00:00
|
|
|
import emoji from 'react-easy-emoji'
|
|
|
|
import { connect } from 'react-redux'
|
2019-05-10 17:12:21 +00:00
|
|
|
import { Link } from 'react-router-dom'
|
2019-05-09 14:31:11 +00:00
|
|
|
import { branchAnalyseSelector } from 'Selectors/analyseSelectors'
|
2019-05-24 16:11:51 +00:00
|
|
|
import {
|
|
|
|
règleAvecMontantSelector,
|
|
|
|
règleAvecValeurSelector
|
|
|
|
} from 'Selectors/regleSelectors'
|
2019-05-09 14:31:11 +00:00
|
|
|
import Animate from 'Ui/animate'
|
|
|
|
import AnimatedTargetValue from 'Ui/AnimatedTargetValue'
|
2019-05-24 14:48:40 +00:00
|
|
|
import InfoBulle from 'Ui/InfoBulle'
|
2019-05-24 16:11:51 +00:00
|
|
|
import Montant from 'Ui/Montant'
|
2019-05-09 14:31:11 +00:00
|
|
|
import './SchemeComparaison.css'
|
|
|
|
|
2019-05-24 16:11:51 +00:00
|
|
|
import type { RègleAvecMontant, RègleAvecValeur } from 'Types/RegleTypes'
|
2019-05-09 14:31:11 +00:00
|
|
|
|
|
|
|
type OwnProps = {
|
|
|
|
hideAutoEntrepreneur?: boolean,
|
|
|
|
hideAssimiléSalarié?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
type Props = OwnProps & {
|
2019-06-11 15:08:04 +00:00
|
|
|
assimiléSalarié: SimulationResult,
|
|
|
|
indépendant: SimulationResult,
|
|
|
|
autoEntrepreneur: SimulationResult,
|
2019-05-10 17:12:21 +00:00
|
|
|
setSituationBranch: number => void,
|
2019-05-09 14:31:11 +00:00
|
|
|
defineDirectorStatus: string => void,
|
2019-05-10 17:12:21 +00:00
|
|
|
sitePaths: any,
|
2019-05-09 14:31:11 +00:00
|
|
|
isAutoentrepreneur: boolean => void,
|
|
|
|
plafondAutoEntrepreneurDépassé: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
type SimulationResult = {
|
|
|
|
retraite: RègleAvecMontant,
|
2019-05-24 16:11:51 +00:00
|
|
|
trimestreValidés: RègleAvecValeur,
|
2019-05-22 15:22:42 +00:00
|
|
|
indemnitésJournalières: RègleAvecMontant,
|
|
|
|
indemnitésJournalièresATMP?: RègleAvecMontant,
|
2019-05-13 13:35:04 +00:00
|
|
|
revenuNetAvantImpôts: RègleAvecMontant,
|
|
|
|
revenuNetAprèsImpôts: RègleAvecMontant,
|
|
|
|
plafondDépassé?: boolean
|
2019-05-09 14:31:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const SchemeComparaison = ({
|
|
|
|
/* Own Props */
|
|
|
|
hideAutoEntrepreneur = false,
|
|
|
|
hideAssimiléSalarié = false,
|
|
|
|
/* Injected Props */
|
|
|
|
assimiléSalarié,
|
|
|
|
indépendant,
|
|
|
|
autoEntrepreneur,
|
2019-05-20 15:01:47 +00:00
|
|
|
|
2019-05-09 14:31:11 +00:00
|
|
|
defineDirectorStatus,
|
|
|
|
isAutoentrepreneur,
|
2019-05-20 15:01:47 +00:00
|
|
|
setSituationBranch
|
2019-05-09 14:31:11 +00:00
|
|
|
}: Props) => {
|
|
|
|
const [showMore, setShowMore] = useState(false)
|
2019-06-13 16:29:08 +00:00
|
|
|
const [conversationStarted, setConversationStarted] = useState(
|
|
|
|
!!assimiléSalarié.revenuNetAprèsImpôts.montant
|
|
|
|
)
|
2019-05-20 16:04:39 +00:00
|
|
|
const startConversation = useCallback(() => setConversationStarted(true), [
|
|
|
|
setConversationStarted
|
|
|
|
])
|
2019-05-09 14:31:11 +00:00
|
|
|
return (
|
2019-06-11 09:05:10 +00:00
|
|
|
<>
|
|
|
|
<div
|
|
|
|
className={classnames('comparaison-grid', {
|
|
|
|
hideAutoEntrepreneur,
|
|
|
|
hideAssimiléSalarié
|
|
|
|
})}>
|
|
|
|
<h2 className="AS">
|
|
|
|
{emoji('☂')} <T>Assimilé salarié</T>
|
|
|
|
<small>
|
|
|
|
<T k="comparaisonRégimes.AS.tagline">Le régime tout compris</T>
|
|
|
|
</small>
|
|
|
|
</h2>
|
|
|
|
<h2 className="indep">
|
|
|
|
{emoji('👩🔧')}{' '}
|
2019-05-21 12:48:06 +00:00
|
|
|
{hideAssimiléSalarié ? (
|
2019-06-11 09:05:10 +00:00
|
|
|
<T>Entreprise Individuelle</T>
|
2019-05-21 12:48:06 +00:00
|
|
|
) : (
|
2019-06-11 09:05:10 +00:00
|
|
|
<T>Indépendant</T>
|
2019-05-21 12:48:06 +00:00
|
|
|
)}
|
2019-06-11 09:05:10 +00:00
|
|
|
<small>
|
|
|
|
<T k="comparaisonRégimes.indep.tagline">
|
|
|
|
La protection sociale à la carte
|
|
|
|
</T>
|
|
|
|
</small>
|
|
|
|
</h2>
|
|
|
|
<h2 className="auto">
|
|
|
|
{emoji('🚶♂️')} <T>Auto-entrepreneur</T>
|
|
|
|
<small>
|
|
|
|
<T k="comparaisonRégimes.auto.tagline">
|
|
|
|
Pour commencer sans risques
|
|
|
|
</T>
|
|
|
|
</small>
|
|
|
|
</h2>
|
2019-05-22 09:48:45 +00:00
|
|
|
|
2019-05-21 12:48:06 +00:00
|
|
|
<h3 className="legend">
|
2019-06-11 09:05:10 +00:00
|
|
|
<T k="comparaisonRégimes.status.legend">
|
|
|
|
Statuts juridiques possibles
|
2019-05-09 16:40:14 +00:00
|
|
|
</T>
|
2019-06-11 09:05:10 +00:00
|
|
|
</h3>
|
|
|
|
<div className="AS">
|
|
|
|
<div>
|
|
|
|
<T k="comparaisonRégimes.status.AS">
|
|
|
|
SAS, SASU ou SARL avec gérant minoritaire
|
|
|
|
</T>
|
2019-05-09 14:31:11 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
<div>
|
|
|
|
{hideAssimiléSalarié ? (
|
|
|
|
<T k="comparaisonRégimes.status.indep.2">EI ou EIRL</T>
|
|
|
|
) : (
|
|
|
|
<T k="comparaisonRégimes.status.indep.1">
|
|
|
|
EI, EIRL, EURL ou SARL avec gérant majoritaire
|
|
|
|
</T>
|
2019-05-13 13:35:04 +00:00
|
|
|
)}
|
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
<T k="comparaisonRégimes.status.auto">Auto-entreprise</T>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<T k="comparaisonRégimes.sécuritéSociale">
|
|
|
|
<h3 className="legend">Sécurité sociale</h3>
|
2019-05-13 13:35:04 +00:00
|
|
|
<div className="AS">
|
2019-06-11 09:05:10 +00:00
|
|
|
Régime général <small />
|
2019-05-13 13:35:04 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
<div className="indep-et-auto">
|
|
|
|
Sécurité sociale des indépendants <small />
|
2019-05-09 14:31:11 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</T>
|
|
|
|
<T k="comparaisonRégimes.AT">
|
|
|
|
<h3 className="legend">Couverture accidents du travail</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
|
|
|
<T>
|
|
|
|
<T>Oui</T>
|
|
|
|
</T>
|
|
|
|
</div>
|
|
|
|
<div className="indep-et-auto">
|
|
|
|
<T>Non</T>
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.assuranceMaladie">
|
2019-05-27 16:23:44 +00:00
|
|
|
<h3 className="legend">
|
2019-06-11 09:05:10 +00:00
|
|
|
Assurance maladie{' '}
|
|
|
|
<small>(médicaments, soins, hospitalisations)</small>
|
2019-05-27 16:23:44 +00:00
|
|
|
</h3>
|
2019-06-11 09:05:10 +00:00
|
|
|
<div className="AS-indep-et-auto">Identique pour tous</div>
|
|
|
|
</T>
|
|
|
|
<T k="comparaisonRégimes.mutuelle">
|
|
|
|
<h3 className="legend">
|
|
|
|
Mutuelle santé
|
|
|
|
<small />
|
|
|
|
</h3>
|
|
|
|
<div className="AS">Obligatoire</div>
|
|
|
|
<div className="indep-et-auto">Fortement conseillée</div>
|
|
|
|
</T>
|
|
|
|
|
|
|
|
<T k="comparaisonRégimes.indemnités">
|
|
|
|
<h3 className="legend">Indemnités journalières</h3>
|
|
|
|
</T>
|
|
|
|
<div className="green AS">++</div>
|
|
|
|
<div className="green indep">++</div>
|
|
|
|
<div className="green auto">+</div>
|
|
|
|
<T k="comparaisonRégimes.retraite">
|
|
|
|
<h3 className="legend">Retraite</h3>
|
|
|
|
</T>
|
|
|
|
<div className="green AS">+++</div>
|
|
|
|
<div className="green indep">++</div>
|
|
|
|
<div className="green auto">+</div>
|
|
|
|
|
|
|
|
{showMore ? (
|
|
|
|
<>
|
|
|
|
<T k="comparaisonRégimes.ACRE">
|
|
|
|
<h3 className="legend">ACRE</h3>
|
|
|
|
<div className="AS-et-indep">
|
|
|
|
1 an <small>(exonération partielle de cotisations)</small>
|
2019-05-24 16:11:51 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
<div className="auto">
|
|
|
|
3 ans
|
|
|
|
<small>(application de taux réduits de cotisations)</small>
|
|
|
|
</div>
|
|
|
|
</T>
|
|
|
|
<T k="comparaisonRégimes.déduction">
|
|
|
|
<h3 className="legend">Déduction des charges</h3>
|
|
|
|
<div className="AS-et-indep">
|
|
|
|
Oui <small>(régime fiscal du réel)</small>
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
Non
|
|
|
|
<small>
|
|
|
|
(mais abattement forfaitaire pour le calcul de l'impôt sur le
|
|
|
|
revenu)
|
|
|
|
</small>
|
|
|
|
</div>
|
|
|
|
</T>
|
|
|
|
|
|
|
|
<T k="comparaisonRégimes.cotisations">
|
|
|
|
<h3 className="legend">Paiement des cotisations</h3>
|
|
|
|
<div className="AS">Mensuel</div>
|
|
|
|
<div className="indep">
|
2019-06-11 13:28:46 +00:00
|
|
|
Provision mensuelle ou trimestrielle
|
2019-06-11 09:05:10 +00:00
|
|
|
<small>
|
|
|
|
(avec régularisation après coup en fonction du revenu réel)
|
|
|
|
</small>
|
|
|
|
</div>
|
|
|
|
<div className="auto">Mensuel ou trimestriel</div>
|
|
|
|
</T>
|
|
|
|
<T k="comparaisonRégimes.complémentaireDeductible">
|
|
|
|
<h3 className="legend">
|
|
|
|
Contrats prévoyance et retraite facultatives déductibles
|
|
|
|
</h3>
|
|
|
|
<div className="AS">
|
|
|
|
Oui <small>(sous certaines conditions)</small>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
Oui <small>(Loi Madelin)</small>
|
|
|
|
</div>
|
|
|
|
</T>
|
|
|
|
<div className="auto">
|
|
|
|
<T>Non</T>
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.cotisationMinimale">
|
|
|
|
<h3 className="legend">Paiement de cotisations minimales</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
|
|
|
<T>Non</T>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
<T>Oui</T>
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
<T>Non</T>
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.seuil">
|
|
|
|
<h3 className="legend">
|
|
|
|
Revenu minimum pour l'ouverture des droits aux prestations
|
|
|
|
</h3>
|
|
|
|
<div className="AS">Oui</div>
|
|
|
|
<div className="indep">
|
|
|
|
Non <small>(cotisations minimales obligatoires)</small>
|
|
|
|
</div>
|
|
|
|
<div className="auto">Oui</div>
|
|
|
|
</T>
|
|
|
|
{!hideAutoEntrepreneur && (
|
|
|
|
<T k="comparaisonRégimes.plafondCA">
|
|
|
|
<h3 className="legend">Plafond de chiffre d'affaires</h3>
|
|
|
|
<div className="AS-et-indep">
|
|
|
|
<T>Non</T>
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
<T>Oui</T>
|
2019-05-24 16:11:51 +00:00
|
|
|
<small>
|
2019-06-11 09:05:10 +00:00
|
|
|
(70 000 € en services / 170 000 € en vente de biens,
|
|
|
|
restauration ou hébergement)
|
2019-05-24 16:11:51 +00:00
|
|
|
</small>
|
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</T>
|
2019-05-09 14:31:11 +00:00
|
|
|
)}
|
2019-06-11 09:05:10 +00:00
|
|
|
<T k="comparaisonRégimes.comptabilité">
|
|
|
|
<h3 className="legend">
|
|
|
|
Gestion comptable, sociale, juridique...
|
|
|
|
</h3>
|
|
|
|
<div className="AS-et-indep">
|
|
|
|
Accompagnement fortement conseillé
|
|
|
|
<small>
|
|
|
|
(expert comptable, comptable, centre de gestion agrée...)
|
|
|
|
</small>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className="auto">
|
|
|
|
Simplifiée{' '}
|
|
|
|
<small>(peut être gérée par l'auto-entrepreneur)</small>
|
|
|
|
</div>
|
|
|
|
</T>
|
|
|
|
</>
|
|
|
|
) : (
|
|
|
|
<T k="comparaisonRégimes.comparaisonDétaillée">
|
|
|
|
<div className="all">
|
|
|
|
<button
|
|
|
|
onClick={() => setShowMore(true)}
|
|
|
|
className="ui__ simple small button">
|
|
|
|
Afficher plus d'informations
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</T>
|
|
|
|
)}
|
|
|
|
{conversationStarted && (
|
|
|
|
<>
|
|
|
|
<T k="comparaisonRégimes.période">
|
|
|
|
<h3 className="legend">Période</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS-indep-et-auto" style={{ alignSelf: 'start' }}>
|
|
|
|
<PeriodSwitch />
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
<div className="all colored">
|
|
|
|
{!conversationStarted ? (
|
2019-06-11 15:08:04 +00:00
|
|
|
<>
|
|
|
|
<T k="comparaisonRégimes.simulationText">
|
|
|
|
<h3>
|
|
|
|
Comparer mes revenus, pension de retraite et indemnité maladie
|
|
|
|
</h3>
|
|
|
|
<img src={revenusSVG} css="height: 8rem" />
|
|
|
|
<button
|
|
|
|
className="ui__ cta plain button"
|
|
|
|
onClick={startConversation}>
|
|
|
|
Lancer la simulation
|
|
|
|
</button>
|
|
|
|
</T>
|
|
|
|
</>
|
2019-06-11 09:05:10 +00:00
|
|
|
) : (
|
|
|
|
<div className="ui__ container">
|
|
|
|
<SeeAnswersButton />
|
|
|
|
<Conversation />
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
|
2019-06-11 15:08:04 +00:00
|
|
|
{conversationStarted && !!assimiléSalarié.revenuNetAprèsImpôts.montant && (
|
2019-06-11 09:05:10 +00:00
|
|
|
<>
|
|
|
|
<T k="comparaisonRégimes.revenuNetApresImpots">
|
|
|
|
<h3 className="legend">Revenu net après impôts</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<Animate.appear className="ui__ plain card">
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
{...assimiléSalarié.revenuNetAprèsImpôts}
|
|
|
|
/>
|
|
|
|
</Animate.appear>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
2019-06-11 15:08:04 +00:00
|
|
|
<Animate.appear className="ui__ plain card">
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(1)}
|
|
|
|
{...indépendant.revenuNetAprèsImpôts}
|
|
|
|
/>
|
|
|
|
</Animate.appear>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
2019-06-11 15:08:04 +00:00
|
|
|
<Animate.appear
|
|
|
|
className={classnames(
|
|
|
|
'ui__ plain card',
|
|
|
|
autoEntrepreneur.plafondDépassé && 'disabled'
|
|
|
|
)}>
|
|
|
|
{autoEntrepreneur.plafondDépassé ? (
|
|
|
|
'Plafond de CA dépassé'
|
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(2)}
|
|
|
|
{...autoEntrepreneur.revenuNetAprèsImpôts}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</Animate.appear>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.revenuNetAvantImpots">
|
|
|
|
<h3 className="legend">
|
|
|
|
Revenu net de cotisations <small>(avant impôts)</small>
|
|
|
|
</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
{...assimiléSalarié.revenuNetAvantImpôts}
|
|
|
|
/>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
2019-06-11 15:08:04 +00:00
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(1)}
|
|
|
|
{...indépendant.revenuNetAvantImpôts}
|
|
|
|
/>
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
2019-06-11 15:08:04 +00:00
|
|
|
{autoEntrepreneur.plafondDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(2)}
|
|
|
|
{...autoEntrepreneur.revenuNetAvantImpôts}
|
|
|
|
/>
|
2019-06-11 09:05:10 +00:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
<h3 className="legend">
|
2019-06-11 15:08:04 +00:00
|
|
|
<T k="comparaisonRégimes.retraiteEstimation.legend">
|
|
|
|
<span>Pension de retraite</span>
|
2019-06-11 09:05:10 +00:00
|
|
|
<small>(avant impôts)</small>
|
|
|
|
</T>
|
|
|
|
</h3>
|
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
{...assimiléSalarié.retraite}
|
|
|
|
/>{' '}
|
|
|
|
<InfoBulle>
|
|
|
|
<T k="comparaisonRégimes.retraiteEstimation.infobulles.AS">
|
|
|
|
Pension calculée pour 172 trimestres cotisés au régime
|
|
|
|
général sans variations de revenus.
|
|
|
|
</T>
|
|
|
|
</InfoBulle>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
{indépendant.retraite.applicable !== false ? (
|
|
|
|
<span>
|
2019-05-24 16:11:51 +00:00
|
|
|
<RuleValueLink
|
2019-06-11 15:08:04 +00:00
|
|
|
onClick={() => setSituationBranch(1)}
|
|
|
|
{...indépendant.retraite}
|
|
|
|
/>{' '}
|
|
|
|
<InfoBulle>
|
|
|
|
<T k="comparaisonRégimes.retraiteEstimation.infobulles.indep">
|
|
|
|
Pension calculée pour 172 trimestres cotisés au régime des
|
|
|
|
indépendants sans variations de revenus.
|
|
|
|
</T>
|
|
|
|
</InfoBulle>
|
|
|
|
</span>
|
2019-05-13 13:35:04 +00:00
|
|
|
) : (
|
2019-05-23 15:26:41 +00:00
|
|
|
<span className="ui__ notice">
|
|
|
|
<T>Pas implémenté</T>
|
|
|
|
</span>
|
2019-06-11 09:05:10 +00:00
|
|
|
)}
|
|
|
|
</div>
|
2019-06-11 15:08:04 +00:00
|
|
|
<div className="auto">
|
|
|
|
{autoEntrepreneur.plafondDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : autoEntrepreneur.retraite.applicable !== false ? (
|
|
|
|
<span>
|
2019-05-22 15:22:42 +00:00
|
|
|
<RuleValueLink
|
2019-06-11 15:08:04 +00:00
|
|
|
onClick={() => setSituationBranch(2)}
|
|
|
|
{...autoEntrepreneur.retraite}
|
|
|
|
/>{' '}
|
|
|
|
<InfoBulle>
|
|
|
|
<T k="comparaisonRégimes.retraiteEstimation.infobulles.auto">
|
|
|
|
Pension calculée pour 172 trimestres cotisés en
|
|
|
|
auto-entrepreneur sans variations de revenus.
|
|
|
|
</T>
|
|
|
|
</InfoBulle>
|
|
|
|
</span>
|
2019-05-22 16:46:28 +00:00
|
|
|
) : (
|
2019-06-11 09:05:10 +00:00
|
|
|
<span className="ui__ notice">
|
|
|
|
<T>Pas implémenté</T>
|
|
|
|
</span>
|
|
|
|
)}
|
2019-05-23 15:26:41 +00:00
|
|
|
</div>
|
2019-06-11 15:08:04 +00:00
|
|
|
<T k="comparaisonRégimes.trimestreValidés">
|
|
|
|
<h3 className="legend">
|
|
|
|
Nombre de trimestres validés <small>(pour la retraite)</small>
|
|
|
|
</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
appendText={<T>trimestres</T>}
|
|
|
|
{...assimiléSalarié.trimestreValidés}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(1)}
|
|
|
|
appendText={<T>trimestres</T>}
|
|
|
|
{...indépendant.trimestreValidés}
|
|
|
|
/>
|
|
|
|
</div>
|
2019-05-23 15:26:41 +00:00
|
|
|
<div className="auto">
|
2019-06-11 15:08:04 +00:00
|
|
|
{autoEntrepreneur.plafondDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(2)}
|
|
|
|
appendText={<T>trimestres</T>}
|
|
|
|
{...autoEntrepreneur.trimestreValidés}
|
|
|
|
/>
|
|
|
|
)}
|
2019-05-22 09:11:53 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
<T k="comparaisonRégimes.indemnités">
|
|
|
|
<h3 className="legend">
|
|
|
|
Indemnités journalières <small>(en cas d'arrêt maladie)</small>
|
|
|
|
</h3>
|
|
|
|
</T>
|
2019-05-22 09:11:53 +00:00
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
{...assimiléSalarié.indemnitésJournalières}
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
<small>
|
|
|
|
(
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(0)}
|
|
|
|
{...assimiléSalarié.indemnitésJournalièresATMP}
|
|
|
|
/>{' '}
|
|
|
|
<T>pour les accidents de trajet/travail et maladie pro</T>)
|
|
|
|
</small>
|
2019-05-22 09:11:53 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
2019-06-11 15:08:04 +00:00
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(1)}
|
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
{...indépendant.indemnitésJournalières}
|
|
|
|
/>
|
|
|
|
</span>
|
2019-06-07 11:44:53 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
2019-06-11 15:08:04 +00:00
|
|
|
{autoEntrepreneur.plafondDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : (
|
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
onClick={() => setSituationBranch(2)}
|
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
{...autoEntrepreneur.indemnitésJournalières}
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
)}
|
2019-06-07 11:44:53 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
<div className="ui__ container">
|
2019-06-11 15:08:04 +00:00
|
|
|
<br />
|
|
|
|
<h3>
|
|
|
|
<T k="comparaisonRégimes.titreSelection">
|
|
|
|
Créer mon entreprise en tant que :
|
|
|
|
</T>
|
|
|
|
</h3>
|
2019-06-11 09:05:10 +00:00
|
|
|
<div className="ui__ answer-group">
|
|
|
|
{!hideAssimiléSalarié && (
|
2019-05-09 14:31:11 +00:00
|
|
|
<button
|
2019-06-11 09:05:10 +00:00
|
|
|
className="ui__ button"
|
|
|
|
onClick={() => {
|
|
|
|
defineDirectorStatus('SALARIED')
|
|
|
|
!hideAutoEntrepreneur && isAutoentrepreneur(false)
|
|
|
|
}}>
|
|
|
|
<T k="comparaisonRégimes.choix.AS">Assimilé salarié</T>
|
2019-05-09 14:31:11 +00:00
|
|
|
</button>
|
2019-06-11 09:05:10 +00:00
|
|
|
)}
|
|
|
|
<button
|
|
|
|
className="ui__ button"
|
|
|
|
onClick={() => {
|
|
|
|
!hideAssimiléSalarié && defineDirectorStatus('SELF_EMPLOYED')
|
|
|
|
!hideAutoEntrepreneur && isAutoentrepreneur(false)
|
|
|
|
}}>
|
|
|
|
{hideAssimiléSalarié ? (
|
|
|
|
<T k="comparaisonRégimes.choix.EI">Entreprise individuelle</T>
|
|
|
|
) : (
|
|
|
|
<T k="comparaisonRégimes.choix.indep">Indépendant</T>
|
|
|
|
)}
|
|
|
|
</button>
|
|
|
|
{!hideAutoEntrepreneur && (
|
2019-06-07 11:44:53 +00:00
|
|
|
<button
|
2019-06-11 09:05:10 +00:00
|
|
|
className="ui__ button"
|
|
|
|
onClick={() => {
|
|
|
|
!hideAssimiléSalarié && defineDirectorStatus('SELF_EMPLOYED')
|
|
|
|
isAutoentrepreneur(true)
|
|
|
|
}}>
|
|
|
|
<T k="comparaisonRégimes.choix.auto">Auto-entrepreneur</T>
|
2019-06-07 11:44:53 +00:00
|
|
|
</button>
|
2019-05-10 14:53:11 +00:00
|
|
|
)}
|
2019-06-11 09:05:10 +00:00
|
|
|
</div>
|
2019-05-09 14:31:11 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
</>
|
2019-05-09 14:31:11 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2019-05-10 17:12:21 +00:00
|
|
|
const RuleValueLink = withSitePaths(
|
2019-06-11 15:08:04 +00:00
|
|
|
({ lien, montant, valeur, sitePaths, onClick, appendText }) => (
|
2019-05-10 17:12:21 +00:00
|
|
|
<Link onClick={onClick} to={sitePaths.documentation.index + '/' + lien}>
|
2019-05-24 16:11:51 +00:00
|
|
|
{montant != undefined && <AnimatedTargetValue value={montant} />}
|
|
|
|
{valeur != undefined && (
|
|
|
|
<Montant numFractionDigit={0} type="decimal">
|
|
|
|
{valeur}
|
|
|
|
</Montant>
|
|
|
|
)}
|
2019-06-11 15:08:04 +00:00
|
|
|
{appendText && <> {appendText}</>}
|
2019-05-10 17:12:21 +00:00
|
|
|
</Link>
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
2019-05-09 14:31:11 +00:00
|
|
|
export default (compose(
|
2019-05-10 17:12:21 +00:00
|
|
|
withSimulationConfig(ComparaisonConfig),
|
2019-05-09 14:31:11 +00:00
|
|
|
connect(
|
2019-05-13 13:35:04 +00:00
|
|
|
tryCatch(
|
|
|
|
state => ({
|
|
|
|
autoEntrepreneur: {
|
|
|
|
retraite: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Auto-entrepreneur'
|
|
|
|
})('protection sociale . retraite'),
|
2019-05-24 16:11:51 +00:00
|
|
|
trimestreValidés: règleAvecValeurSelector(state, {
|
|
|
|
situationBranchName: 'Auto-entrepreneur'
|
|
|
|
})('protection sociale . retraite . trimestres validés par an'),
|
2019-05-22 15:22:42 +00:00
|
|
|
indemnitésJournalières: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Auto-entrepreneur'
|
|
|
|
})('protection sociale . santé . indemnités journalières'),
|
2019-05-13 13:35:04 +00:00
|
|
|
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(
|
2019-05-10 14:53:11 +00:00
|
|
|
({ test }) =>
|
|
|
|
test.includes && test.includes('base des cotisations > plafond')
|
2019-05-13 13:35:04 +00:00
|
|
|
)
|
|
|
|
},
|
|
|
|
indépendant: {
|
|
|
|
retraite: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Indépendant'
|
|
|
|
})('protection sociale . retraite'),
|
2019-05-24 16:11:51 +00:00
|
|
|
trimestreValidés: règleAvecValeurSelector(state, {
|
|
|
|
situationBranchName: 'Indépendant'
|
|
|
|
})('protection sociale . retraite . trimestres validés par an'),
|
2019-05-22 15:22:42 +00:00
|
|
|
indemnitésJournalières: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Indépendant'
|
|
|
|
})('protection sociale . santé . indemnités journalières'),
|
2019-05-13 13:35:04 +00:00
|
|
|
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'),
|
2019-05-24 16:11:51 +00:00
|
|
|
trimestreValidés: règleAvecValeurSelector(state, {
|
|
|
|
situationBranchName: 'Assimilé salarié'
|
|
|
|
})('protection sociale . retraite . trimestres validés par an'),
|
2019-05-22 15:22:42 +00:00
|
|
|
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'
|
|
|
|
),
|
2019-05-13 13:35:04 +00:00
|
|
|
revenuNetAprèsImpôts: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Assimilé salarié'
|
|
|
|
})('revenu net'),
|
|
|
|
revenuNetAvantImpôts: règleAvecMontantSelector(state, {
|
|
|
|
situationBranchName: 'Assimilé salarié'
|
|
|
|
})('contrat salarié . salaire . net')
|
|
|
|
}
|
|
|
|
}),
|
2019-06-05 13:33:57 +00:00
|
|
|
e => console.log(e) || {}
|
2019-05-13 13:35:04 +00:00
|
|
|
),
|
2019-05-09 14:31:11 +00:00
|
|
|
|
2019-05-10 17:12:21 +00:00
|
|
|
{
|
|
|
|
defineDirectorStatus,
|
|
|
|
isAutoentrepreneur,
|
|
|
|
setSituationBranch
|
|
|
|
}
|
|
|
|
)
|
2019-05-09 14:31:11 +00:00
|
|
|
)(SchemeComparaison): React$Component<OwnProps>)
|