/* @flow */ import type { FicheDePaie } from 'Types/ResultViewTypes' import withColours from 'Components/utils/withColours' import withLanguage from 'Components/utils/withLanguage' import { compose } from 'ramda' import React, { Fragment } from 'react' import { Trans } from 'react-i18next' import { connect } from 'react-redux' import { analysisToCotisationsSelector } from 'Selectors/ficheDePaieSelectors' import { getRuleFromAnalysis, analysisWithDefaultsSelector, parsedRulesSelector } from 'Selectors/analyseSelectors' import Value from 'Components/Value' import './PaySlip.css' import RuleLink from './RuleLink' import { Line, SalaireNetSection, SalaireBrutSection } from './PaySlipSections' import { findRuleByDottedName } from 'Engine/rules' type ConnectedPropTypes = ?FicheDePaie & { colours: { lightestColour: string } } export default compose( withColours, connect(state => ({ cotisations: analysisToCotisationsSelector(state), analysis: analysisWithDefaultsSelector(state), parsedRules: parsedRulesSelector(state) })), withLanguage )( ({ colours: { lightestColour }, cotisations, analysis, parsedRules }: ConnectedPropTypes) => { let getRule = getRuleFromAnalysis(analysis) return (