5.8 KiB
API
IMPORTANT : publicodes est encore en version beta, et l'API peut-être sujette à des changements cassants lors de prochaines version. Pour plus d'informations, se référer à la feuille de route v1.0
new Engine(rules)
Crée un moteur d'évaluation avec les règles publicodes données en argument.
Arguments
rules
: les règles publicodes utilisée. Ces dernières peuvent-être sous la forme d'une chaine de caractèreyaml
publicodes (ou d'un object javascript correspondant). Elle peuvent aussi être sous la forme de règles publicodes déjà parsées
Retourne Un moteur d'évaluation qui expose les fonctions suivantes :
- setSituation
- evaluate
- getRules
- getRule
method engine.setSituation(situation)
Permet de spécifier une situation en entrée. Toutes les prochaines évaluations seront effectuées en se basant sur ces valeurs plutôt que les valeurs présentes dans la base de règle.
C'est le point d'entrée principal pour adapter les calculs de règles générales à
une situation particulière. La situation est gardée en mémoire, et chaque appel
à setSituation
remplace la situation précédente. Le moteur
contient donc un état interne. Cela permet d'obtenir de meilleure performance,
avec une gestion plus fine du cache de calcul. En revanche, il faut prêter une
grande attention à la bonne gestion de cet état interne.
Arguments
situation
: un objet javascript qui associe le nom complet d'une règle à sa valeur. Cette valeur peut être n'importe quelle expression publicodes bien formée. Elle sera évaluée par le moteur. Cela permet de spécifier des nombre avec unité, des expressions, des références vers d'autres règles ou même d'utiliser des mécanismes.
Retourne
L'objet engine (this
) sur lequel la fonction a été appelée, afin de pouvoir
utiliser une écriture chaînée (engine.setSituation(situation).evaluate()
).
method engine.evaluate(expression)
Évalue l'expression dans le contexte du moteur (règle et situation).
Pour des raisons de performance, les résultats intermédiaires sont enregistrés dans un cache. Par conséquent, les appels suivants seront plus rapides.
Arguments
expression
: la valeur à évaluer. Cela peut-être n'importe quelle expression publicodes bien formée (expression arithmétique, mécanisme, réference vers une règle)
Retourne
Un objet javascript de type EvaluatedNode
contenant la valeur calculée.
Attention ! Il est déconseillé d'utiliser directement les valeurs présentes dans l'objet retourné, étant donné que leur forme va très probablement changer au cours des prochaines versions du moteur. Utilisez la fonction
formatNode(evaluationResult)
autant que possible pour afficher la valeur retournée.
missingVariables
: contient les règles dont la valeur est manquante dans la situationnodeValue
: la valeur calculée (typestring
,number
,boolean
, ounull
)unit
: sinodeValue
est un nombre, contient l'unité associée
function formatValue(evaluatedNode, \[options\])
Formate la valeur evaluée.
Arguments
evaluatedNode
: l'objet retourné lors de l'appel à la fonction d'évaluation du moteurevaluate(expression)
options
: configuration pour le formatagelanguage
: le langage utilisé pour le formatage (par défautfr
)precision
: le nombre de chiffre après la virgule pour le formatage des nombres (par défaut2
)displayedUnit
: l'unité à afficher pour le formatage des nombres. Outrepasse l'unité définie dans le calcul (on peut donc forcer l'unité affichée à une autre que celle retournée par le calcul, même si elle ne sont pas compatibles)
Retourne
La chaîne de caractère correspondant à la valeur bien formatée.
Composants react
Publicodes exporte des composants react permettant d'afficher une documentation explorable des calculs. Cette documentation est auto-générée en s'appuyant sur les données descriptives contenues dans les règles publicodes (description, références, titre, note, etc.) et en affichant pour chaque règle les étapes intermédiaires qui permettent d'aboutir au résultat affiché.
Voir un exemple sur mon-entreprise.fr
<Documentation />
Composant react permettant d'afficher une documentation explorable d'une base de règles publicodes. Se base sur react-router pour créer une arborescence de pages correspondant aux espaces de noms existants dans les règles.
Voir le bac à sable pour voir le composant en action (il est affiché sur l'écran de droite).
Props
engine
: l'objet moteur dont on veut afficher les calculs.documentationPath
: (string
) le chemin de base sur lequel la documentation sera montée. Par exemple, si c'est/documentation
l'url de la règlerémunération . primes
sera/documentation/rémunération/primes
language
: le language dans lequel afficher la documentation (pour l'instant, seulsfr
eten
sont supportés).
<RuleLink />
Composant react permettant de faire un lien vers une page de la documentation. Par défaut, le texte affiché est le nom de la règle.
Props
engine
: l'objet moteur dont on veut afficher la règle.documentationPath
: (string
) le chemin de base sur lequel la documentation est montée. Doit correspondre à celui précisé pour le composant<Documentation />
dottedName
: le nom de la règle à afficherdisplayIcon
: affiche l'icône de la règle dans le lien (par défaut àfalse
)children
: un noeud react quelconque. Par défaut, c'est le nom de la règle qui est utilisé.