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-08-27 14:16:51 +00:00
|
|
|
import Value from 'Components/Value'
|
|
|
|
import { encodeRuleName, getRuleFromAnalysis } from 'Engine/rules.js'
|
2019-06-11 15:08:04 +00:00
|
|
|
import revenusSVG from 'Images/revenus.svg'
|
2019-07-02 16:22:31 +00:00
|
|
|
import { compose } 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-24 16:11:51 +00:00
|
|
|
import {
|
2019-08-27 14:16:51 +00:00
|
|
|
analysisWithDefaultsSelector,
|
|
|
|
branchAnalyseSelector
|
2019-07-02 16:22:31 +00:00
|
|
|
} from 'Selectors/analyseSelectors'
|
2019-05-09 14:31:11 +00:00
|
|
|
import Animate from 'Ui/animate'
|
2019-05-24 14:48:40 +00:00
|
|
|
import InfoBulle from 'Ui/InfoBulle'
|
2019-05-09 14:31:11 +00:00
|
|
|
import './SchemeComparaison.css'
|
|
|
|
|
|
|
|
type OwnProps = {
|
|
|
|
hideAutoEntrepreneur?: boolean,
|
|
|
|
hideAssimiléSalarié?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
type Props = OwnProps & {
|
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
|
|
|
|
}
|
|
|
|
|
2019-07-02 16:22:31 +00:00
|
|
|
let getBranchIndex = branch =>
|
2019-09-11 14:58:18 +00:00
|
|
|
({ assimilé: 0, indépendant: 1, 'auto-entrepreneur': 2 }[branch])
|
2019-07-02 16:22:31 +00:00
|
|
|
let getRuleFrom = analyses => (branch, dottedName) => {
|
|
|
|
let i = getBranchIndex(branch)
|
|
|
|
return getRuleFromAnalysis(analyses[i])(dottedName)
|
2019-05-09 14:31:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const SchemeComparaison = ({
|
|
|
|
/* Own Props */
|
|
|
|
hideAutoEntrepreneur = false,
|
|
|
|
hideAssimiléSalarié = false,
|
|
|
|
/* Injected Props */
|
2019-05-20 15:01:47 +00:00
|
|
|
|
2019-07-02 16:22:31 +00:00
|
|
|
plafondAutoEntrepreneurDépassé,
|
2019-05-09 14:31:11 +00:00
|
|
|
defineDirectorStatus,
|
|
|
|
isAutoentrepreneur,
|
2019-07-02 16:22:31 +00:00
|
|
|
analyses
|
2019-05-09 14:31:11 +00:00
|
|
|
}: Props) => {
|
2019-07-02 16:22:31 +00:00
|
|
|
let getRule = getRuleFrom(analyses)
|
2019-05-09 14:31:11 +00:00
|
|
|
const [showMore, setShowMore] = useState(false)
|
2019-06-13 16:29:08 +00:00
|
|
|
const [conversationStarted, setConversationStarted] = useState(
|
2019-07-02 16:22:31 +00:00
|
|
|
!!getRule('assimilé', 'revenu net après impôt')?.nodeValue
|
2019-06-13 16:29:08 +00:00
|
|
|
)
|
2019-05-20 16:04:39 +00:00
|
|
|
const startConversation = useCallback(() => setConversationStarted(true), [
|
|
|
|
setConversationStarted
|
|
|
|
])
|
2019-07-02 16:22:31 +00:00
|
|
|
|
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-07-02 16:22:31 +00:00
|
|
|
{conversationStarted &&
|
2019-07-09 14:36:39 +00:00
|
|
|
!!getRule('assimilé', 'revenu net après impôt')?.nodeValue && (
|
2019-07-02 16:22:31 +00:00
|
|
|
<>
|
|
|
|
<T k="comparaisonRégimes.revenuNetApresImpot">
|
|
|
|
<h3 className="legend">Revenu net après impôt</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
|
|
|
<Animate.appear className="ui__ plain card">
|
|
|
|
<RuleValueLink
|
|
|
|
branch="assimilé"
|
|
|
|
rule="revenu net après impôt"
|
|
|
|
/>
|
|
|
|
</Animate.appear>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
<Animate.appear className="ui__ plain card">
|
|
|
|
<RuleValueLink
|
|
|
|
branch="indépendant"
|
|
|
|
rule="revenu net après impôt"
|
|
|
|
/>
|
|
|
|
</Animate.appear>
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
<Animate.appear
|
|
|
|
className={classnames(
|
|
|
|
'ui__ plain card',
|
|
|
|
plafondAutoEntrepreneurDépassé && 'disabled'
|
|
|
|
)}>
|
|
|
|
{plafondAutoEntrepreneurDépassé ? (
|
|
|
|
'Plafond de CA dépassé'
|
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
2019-09-11 14:58:18 +00:00
|
|
|
branch="auto-entrepreneur"
|
2019-07-02 16:22:31 +00:00
|
|
|
rule="revenu net après impôt"
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</Animate.appear>
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.revenuNetAvantImpot">
|
|
|
|
<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
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="assimilé"
|
2019-08-27 14:16:51 +00:00
|
|
|
rule="contrat salarié . rémunération . net"
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
2019-06-11 15:08:04 +00:00
|
|
|
<RuleValueLink
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="indépendant"
|
|
|
|
rule="indépendant . revenu net de cotisations"
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
{plafondAutoEntrepreneurDépassé ? (
|
|
|
|
'—'
|
2019-06-11 15:08:04 +00:00
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
2019-09-11 14:58:18 +00:00
|
|
|
branch="auto-entrepreneur"
|
|
|
|
rule="auto-entrepreneur . revenu net de cotisations"
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
|
|
|
)}
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
2019-06-11 09:05:10 +00:00
|
|
|
<h3 className="legend">
|
2019-07-02 16:22:31 +00:00
|
|
|
<T k="comparaisonRégimes.retraiteEstimation.legend">
|
|
|
|
<span>Pension de retraite</span>
|
|
|
|
<small>(avant impôts)</small>
|
|
|
|
</T>
|
2019-06-11 09:05:10 +00:00
|
|
|
</h3>
|
2019-07-02 16:22:31 +00:00
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<span>
|
2019-05-22 15:22:42 +00:00
|
|
|
<RuleValueLink
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="assimilé"
|
|
|
|
rule="protection sociale . retraite"
|
2019-06-11 15:08:04 +00:00
|
|
|
/>{' '}
|
|
|
|
<InfoBulle>
|
2019-07-02 16:22:31 +00:00
|
|
|
<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.
|
2019-06-11 15:08:04 +00:00
|
|
|
</T>
|
|
|
|
</InfoBulle>
|
|
|
|
</span>
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
{getRule('indépendant', 'protection sociale . retraite')
|
|
|
|
.applicable !== false ? (
|
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
branch="indépendant"
|
|
|
|
rule="protection sociale . 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>
|
|
|
|
) : (
|
|
|
|
<span className="ui__ notice">
|
|
|
|
<T>Pas implémenté</T>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
{plafondAutoEntrepreneurDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : getRule(
|
2019-09-11 14:58:18 +00:00
|
|
|
'auto-entrepreneur',
|
2019-07-02 16:22:31 +00:00
|
|
|
'protection sociale . retraite'
|
|
|
|
).applicable !== false ? (
|
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
2019-09-11 14:58:18 +00:00
|
|
|
branch="auto-entrepreneur"
|
2019-07-02 16:22:31 +00:00
|
|
|
rule="protection sociale . 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>
|
|
|
|
) : (
|
|
|
|
<span className="ui__ notice">
|
|
|
|
<T>Pas implémenté</T>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.trimestreValidés">
|
|
|
|
<h3 className="legend">
|
|
|
|
Nombre de trimestres validés <small>(pour la retraite)</small>
|
|
|
|
</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<RuleValueLink
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="assimilé"
|
|
|
|
rule="protection sociale . retraite . trimestres validés par an"
|
2019-06-11 15:08:04 +00:00
|
|
|
appendText={<T>trimestres</T>}
|
2019-07-02 16:22:31 +00:00
|
|
|
unit={null}
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
|
|
|
<div className="indep">
|
2019-06-11 15:08:04 +00:00
|
|
|
<RuleValueLink
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="indépendant"
|
|
|
|
rule="protection sociale . retraite . trimestres validés par an"
|
|
|
|
appendText={<T>trimestres</T>}
|
|
|
|
unit={null}
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
2019-07-02 16:22:31 +00:00
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
{plafondAutoEntrepreneurDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : (
|
|
|
|
<RuleValueLink
|
2019-09-11 14:58:18 +00:00
|
|
|
branch="auto-entrepreneur"
|
2019-07-02 16:22:31 +00:00
|
|
|
rule="protection sociale . retraite . trimestres validés par an"
|
|
|
|
appendText={<T>trimestres</T>}
|
|
|
|
unit={null}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
<T k="comparaisonRégimes.indemnités">
|
|
|
|
<h3 className="legend">
|
|
|
|
Indemnités journalières{' '}
|
|
|
|
<small>(en cas d'arrêt maladie)</small>
|
|
|
|
</h3>
|
|
|
|
</T>
|
|
|
|
<div className="AS">
|
2019-06-11 15:08:04 +00:00
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
2019-07-02 16:22:31 +00:00
|
|
|
branch="assimilé"
|
2019-06-11 15:08:04 +00:00
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
2019-07-02 16:22:31 +00:00
|
|
|
rule="protection sociale . santé . indemnités journalières"
|
2019-06-11 15:08:04 +00:00
|
|
|
/>
|
|
|
|
</span>
|
2019-07-02 16:22:31 +00:00
|
|
|
<small>
|
|
|
|
(
|
|
|
|
<RuleValueLink
|
|
|
|
branch="assimilé"
|
|
|
|
rule="protection sociale . accidents du travail et maladies professionnelles"
|
|
|
|
/>{' '}
|
|
|
|
<T>pour les accidents de trajet/travail et maladie pro</T>)
|
|
|
|
</small>
|
|
|
|
</div>
|
|
|
|
<div className="indep">
|
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
branch="indépendant"
|
|
|
|
rule="protection sociale . santé . indemnités journalières"
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
<div className="auto">
|
|
|
|
{plafondAutoEntrepreneurDépassé ? (
|
|
|
|
'—'
|
|
|
|
) : (
|
|
|
|
<span>
|
|
|
|
<RuleValueLink
|
2019-09-11 14:58:18 +00:00
|
|
|
branch="auto-entrepreneur"
|
2019-07-02 16:22:31 +00:00
|
|
|
rule="protection sociale . santé . indemnités journalières"
|
|
|
|
appendText={
|
|
|
|
<>
|
|
|
|
/ <T>jour</T>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
)}
|
|
|
|
</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-07-02 16:22:31 +00:00
|
|
|
const RuleValueLink = compose(
|
|
|
|
withSitePaths,
|
|
|
|
connect(
|
|
|
|
state => ({
|
|
|
|
analyses: analysisWithDefaultsSelector(state)
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
setSituationBranch
|
|
|
|
}
|
2019-05-10 17:12:21 +00:00
|
|
|
)
|
2019-07-02 16:22:31 +00:00
|
|
|
)(
|
|
|
|
({
|
|
|
|
analyses,
|
|
|
|
branch,
|
|
|
|
rule: dottedName,
|
|
|
|
sitePaths,
|
|
|
|
appendText,
|
|
|
|
setSituationBranch,
|
|
|
|
unit
|
|
|
|
}) => {
|
|
|
|
let rule = getRuleFrom(analyses)(branch, dottedName)
|
|
|
|
return !rule ? null : (
|
|
|
|
<Link
|
|
|
|
onClick={() => setSituationBranch(getBranchIndex(branch))}
|
|
|
|
to={
|
|
|
|
sitePaths.documentation.index + '/' + encodeRuleName(rule.dottedName)
|
|
|
|
}>
|
|
|
|
<Value
|
2019-07-20 16:30:41 +00:00
|
|
|
maximumFractionDigits={0}
|
2019-07-02 16:22:31 +00:00
|
|
|
{...rule}
|
|
|
|
unit={
|
2019-07-09 14:36:39 +00:00
|
|
|
/* //TODO the unit should be integrated in the leaf rules of base.yaml and infered by mecanisms. Will be done in a future release*/
|
|
|
|
unit !== undefined ? unit : '€'
|
|
|
|
}
|
2019-07-02 16:22:31 +00:00
|
|
|
/>
|
|
|
|
{appendText && <> {appendText}</>}
|
|
|
|
</Link>
|
|
|
|
)
|
|
|
|
}
|
2019-05-10 17:12:21 +00:00
|
|
|
)
|
|
|
|
|
🔥 Migration vers TypeScript
Outils
======
Ce commit retire le tooling de Flow, et ajoute le support de TypeScript
pour les fichiers .ts et .tsx. Il n'est pas nécessaire de tout migrer
d'un coup ce qui facilite la transition. On garde en effet le
compilateur Babel avec un preset TypeScript (ce qui permet donc de
retirer à la fois les types Flow et TypeScript) plutôt que d'utiliser le
compilateur standard pour la conversion du code. Cela permet aussi de
mieux s'intégrer avec d'autres outils, notamment les test-runners.
Ajout d'une nouvelle commande `yarn run type-check`, intégrée dans
CircleCI.
Par ailleurs ajout du support de l'opérateur ?? pour donner des valeurs
par défaut (nullish-coalescing-operator).
Typage des libraires tierces
============================
Les principales libraires que nous utilisons ont un typage TypeScript de
bon niveau, ce qui facilite l'intégration. J'ai mis à jour react-i18next
et i18next afin de corriger un problème de typage.
Typage du code
==============
Le typage est loin d'être complet dans ce commit, en particulier il
manque les types relatifs au state Redux, ainsi qu'au moteur (règle,
explication). Néanmoins le typage des contextes fonctionne, en
particulier sitePaths (avec un type récursif non trivial !) qui a déjà
permis de détecter un lien mort.
Le typage des "paths" (Components/, Règles/, etc.) fonctionne bien, y
compris avec l'auto-complétion automatique des import par Typescript.
TypeScript se révèle déjà bien agréable dans VSCode (auto-complétion,
refacto, etc.) ! Reste à migrer progressivement le reste du code !
2019-10-26 16:21:09 +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-07-02 16:22:31 +00:00
|
|
|
state => ({
|
|
|
|
analyses: analysisWithDefaultsSelector(state),
|
|
|
|
plafondAutoEntrepreneurDépassé: branchAnalyseSelector(state, {
|
|
|
|
situationBranchName: 'Auto-entrepreneur'
|
|
|
|
}).controls?.find(
|
|
|
|
({ test }) =>
|
|
|
|
test.includes && test.includes('base des cotisations > plafond')
|
|
|
|
)
|
|
|
|
}),
|
2019-05-10 17:12:21 +00:00
|
|
|
{
|
|
|
|
defineDirectorStatus,
|
|
|
|
isAutoentrepreneur,
|
|
|
|
setSituationBranch
|
|
|
|
}
|
|
|
|
)
|
🔥 Migration vers TypeScript
Outils
======
Ce commit retire le tooling de Flow, et ajoute le support de TypeScript
pour les fichiers .ts et .tsx. Il n'est pas nécessaire de tout migrer
d'un coup ce qui facilite la transition. On garde en effet le
compilateur Babel avec un preset TypeScript (ce qui permet donc de
retirer à la fois les types Flow et TypeScript) plutôt que d'utiliser le
compilateur standard pour la conversion du code. Cela permet aussi de
mieux s'intégrer avec d'autres outils, notamment les test-runners.
Ajout d'une nouvelle commande `yarn run type-check`, intégrée dans
CircleCI.
Par ailleurs ajout du support de l'opérateur ?? pour donner des valeurs
par défaut (nullish-coalescing-operator).
Typage des libraires tierces
============================
Les principales libraires que nous utilisons ont un typage TypeScript de
bon niveau, ce qui facilite l'intégration. J'ai mis à jour react-i18next
et i18next afin de corriger un problème de typage.
Typage du code
==============
Le typage est loin d'être complet dans ce commit, en particulier il
manque les types relatifs au state Redux, ainsi qu'au moteur (règle,
explication). Néanmoins le typage des contextes fonctionne, en
particulier sitePaths (avec un type récursif non trivial !) qui a déjà
permis de détecter un lien mort.
Le typage des "paths" (Components/, Règles/, etc.) fonctionne bien, y
compris avec l'auto-complétion automatique des import par Typescript.
TypeScript se révèle déjà bien agréable dans VSCode (auto-complétion,
refacto, etc.) ! Reste à migrer progressivement le reste du code !
2019-10-26 16:21:09 +00:00
|
|
|
)(SchemeComparaison)
|