diff --git a/source/engine/mecanismViews/Barème.js b/source/engine/mecanismViews/Barème.js new file mode 100644 index 000000000..25a451d4b --- /dev/null +++ b/source/engine/mecanismViews/Barème.js @@ -0,0 +1,77 @@ +import React from 'react' +import { Node } from './common' +import { makeJsx } from '../evaluation' +import { Trans } from 'react-i18next' + +export default function Barème(nodeValue, explanation) { + return ( + +
  • + + assiette:{' '} + + {makeJsx(explanation.assiette)} +
  • +
  • + + multiplicateur des tranches:{' '} + + + {makeJsx(explanation['multiplicateur des tranches'])} + +
  • + + + + + + + {explanation.tranches.map( + ({ + 'en-dessous de': maxOnly, + 'au-dessus de': minOnly, + de: min, + à: max, + taux + }) => ( + + explanation['multiplicateur des tranches'].nodeValue * + min && + max && + explanation.assiette.nodeValue < + explanation['multiplicateur des tranches'].nodeValue * + max + ? ' bold' + : '' + }}> + + + + ) + )} + +
    + Tranches de l'assiette + + Taux +
    + {maxOnly + ? '< ' + maxOnly + : minOnly + ? '> ' + minOnly + : `${min} - ${max}`} + {makeJsx(taux)}
    + + } + /> + ) +} diff --git a/source/engine/mecanisms.js b/source/engine/mecanisms.js index 2f9817f00..20dcbbc0e 100644 --- a/source/engine/mecanisms.js +++ b/source/engine/mecanisms.js @@ -51,6 +51,7 @@ import { import 'react-virtualized/styles.css' import Somme from './mecanismViews/Somme' import Allègement from './mecanismViews/Allègement' +import Barème from './mecanismViews/Barème' import buildSelectionView from './mecanismViews/Selection' import uniroot from './uniroot' @@ -762,80 +763,9 @@ export let mecanismScale = (recurse, k, v) => { }, evaluate = evaluateObject(objectShape, effect) - let jsx = (nodeValue, explanation) => ( - -
  • - - assiette:{' '} - - {makeJsx(explanation.assiette)} -
  • -
  • - - multiplicateur des tranches:{' '} - - - {makeJsx(explanation['multiplicateur des tranches'])} - -
  • - - - - - - - {explanation.tranches.map( - ({ - 'en-dessous de': maxOnly, - 'au-dessus de': minOnly, - de: min, - à: max, - taux - }) => ( - - explanation['multiplicateur des tranches'].nodeValue * - min && - max && - explanation.assiette.nodeValue < - explanation['multiplicateur des tranches'].nodeValue * - max - ? ' bold' - : '' - }}> - - - - ) - )} - -
    - Tranches de l'assiette - - Taux -
    - {maxOnly - ? '< ' + maxOnly - : minOnly - ? '> ' + minOnly - : `${min} - ${max}`} - {makeJsx(taux)}
    - - } - /> - ) - return { evaluate, - jsx, + jsx: Barème, explanation, category: 'mecanism', name: 'barème',