70fb5d7d24 | ||
---|---|---|
règles | ||
source | ||
test | ||
.gitignore | ||
200.html | ||
CONTRIBUTION.md | ||
LICENSE | ||
README.md | ||
brouillon | ||
circle.yml | ||
drawing.svg | ||
finsvg.svg | ||
icônes-CDD.svg | ||
index.html | ||
maison2.svg | ||
package.json |
README.md
syso
Introduction
L'idée, c'est d'augmenter les textes de loi avec des jeux de donnée qui décrivent l'architecture et les calculs de ses éléments, permettant par exemple à un citoyen ou une entreprise (deux entités différentes du système) de calculer ses obligations et ses droits ainsi que leur articulation (ex. comment je calcule la CSG sur mon salaire ? est-ce que j'appartiens au régime Alsace-Moselle ?).
Des moteurs interprèteront ces données pour en faire des formulaires de simulation, des outils pédagogiques (par ex. augmenter la fiche de paie simplifiée avec des explications, vue alternatives...), voir de la transaction, et soyons fous, des outils politiques.
Le premier moteur et produit utilisable concerne le sujet pratique du différentiel des cotisations et indemnités dues pour un CDD. La suite sera l'intégration de toutes les cotisations d'un contrat CDI/CDD (sans le droit conventionnel). Puis les principales réductions et aides à l'embauche. Suivront peut-être les formes de travail différentes...
Développé au SGMAP et encore très expérimental.
Pour les développeurs
npm install
npm start
C'est une appli en React, Redux, ES6-ES7, Webpack, qui exploite la loi codée en YAML.
Les fichiers YAML sont principalement du code préfixé : opérateur puis list ou objet d'opérandes. Les feuilles de cet arbre par contre sont en style infixe et parsées avec Nearley.js.
Ce gros AST est traversé, cela représente le moteur JS, qui utilise Ramda.
Des bouts de code marqués avec TODO perf
peuvent être améliorés si l'appli devient lente.
Note : vous ne trouverez pas de
const
dans l'appli, tous leslet
se comportant comme desconst
(ne sont pas réassignés), sauf pour les vraies constantes dansactions.js
.