Modèle de transitions
Maarch Digital Flow permet de définir des circuits pour les entités gérées dans l'application, afin de modéliser les différentes étapes de leur cycle de vie au plus près des besoins des différents métiers.
Tous les objets gérés dans l'application possèdent un circuit par défaut qui comporte 4 états de base qui autorisent 5 transitions.
Dans Maarch Digital Flow, la description du circuit des objets et les contraintes applicables sont décrites par des modèles de transitions gérés par l'administrateur. Ces définitions sont ensuite utilisées dans les différentes sections d'administrations des entités.
Accès aux modèles
La section Modèles de transitions de l'administration permet de créer et gérer les modèles. L'administrateur habilité l'utilise pour lister les modèles existants, les gérer et en ajouter de nouveaux.
Propriétés des modèles de transitions
| Champ | Type | Description |
|---|---|---|
| Identifiant métier | texte |
Le nom utilisé par le système pour identifier le modèle. Il ne peut être changé quand le modèle est en cours d'utilisation |
| Libellé | texte |
Le nom affiché aux utilisateurs lorsqu'ils utilisent le modèle |
| Description | texte |
Description du modèle |

Contenu du modèle
Le modèle de circuit personnalisé permet de définir les status que peuvent prendre les entités, les sous-statuts éventuellement associés, les conditions qui doivent être remplies pour permettre les transitions ainsi que les actions complémentaires réalisées lors des événements.
On y trouve donc les éléments suivants :
- à la racine, 1 à 4 des états principaux fournis par l'application :
Copie de travail,Courant,ConservéetRésiduel, - des sous-états de ces états principaux, pour préciser les circuits et décrire les transitions possibles,
- des événements, qui peuvent consister en transitions vers d'autres états ou sous-états,
- des tâches associées aux événements

Statut
| Champ | Type | Description |
|---|---|---|
| Nom | texte |
Le nom du statut parmi les 4 statuts fournis par le système |
| Libellé | texte |
Libellé du statut affiché aux utilisateurs. |
| Description | texte |
Description du statut |
| Sous-statut initial | identifiant |
L'identification du sous-statut attribué si aucun sous-statut n'est fourni à l'application lors de l'entrée de l'entité dans ce statut. |
| Final | indicateur |
Indique si le statut est final et accepte que les entités porteuses soient détruites de manière irréversible. |
| Sous-statuts | liste de sous-statuts |
La définition des sous-statuts que peuvent prendre les entités utilisant le modèle lorsqu'elles sont dans ce statut. |
| Evénements | liste d'événements |
La définition des événements et transitions associés au statuts. |
Sous-statut
| Champ | Type | Description |
|---|---|---|
| Nom | texte |
Le nom du sous-statut défini par l'utilisateur, qui doit être unique dans le statut. |
| Libellé | texte |
Libellé du sous-statut affiché aux utilisateurs. |
| Description | texte |
Description du sous-statut |
| Final | indicateur |
Indique si le sous-statut est final et accepte que les entités porteuses sortent du statut. |
| Evénements | liste d'événements |
La définition des événements et transitions associés au statuts. |
Transition
Une transition est l'événement de passage d'un statut ou d'un sous-statut à un autre.
| Champ | Type | Description |
|---|---|---|
| Nom | texte |
Identification de la transition. Pour les statuts, les noms des transitions sont fixes par le système (publier, clore, supprimer, rouvrir, restaurer). Pour les sous-statut, l'utilisateur doit fournir un identifiant unique dans le statut d'appartenance. |
| Libellé | texte |
Libellé de la transition affiché aux utilisateurs. |
| Condition | condition |
La définition d'une condition de garde qui doit être remplie afin que la transition soit possible. |
| Tâches | liste de tâches |
La définition des tâches exécutées lorsque la transition a lieu. |
Evénement
Un événement peut être vu comme une transition d'un statut vers lui-même.
| Champ | Type | Description |
|---|---|---|
| Nom | identifiant |
Identification d'un événement survenant dans l'application et impactant l'entité porteurse du statut ou sous-statut de rattachement, par exemple l'entrée dans le statut ou sous-statut, sortie du statut ou sous-statut, mise à jour des données, changement de propriétaire, annotation, etc. |
| Libellé | texte |
Libellé de l'événement affiché aux utilisateurs. |
| Condition | condition |
La définition d'une condition de garde qui doit être remplie afin que l'évènement soit pris en compte. |
| Tâches | liste de tâches |
La définition des tâches exécutées lorsque l'événement survient. |
Tâche
Une tâche est une opération réalisée automatiquement par l'application lorsqu'un événement ou une transition survient et que les conditions nécessaires sont remplies.
| Champ | Type | Description |
|---|---|---|
| Libellé | texte |
Libellé de la tâche affiché aux utilisateurs. |
| Condition | condition |
La définition d'une condition de garde qui doit être remplie afin que la tâche soit exécutée. |
Condition
Une condition est la définition d'un état de l'entité ou du système qui doit être contrôlé afin de permettre la survenue de l'événement. Elle prend la forme d'un arbre de logique booléenne reprenant dans une certaine mesure le formalisme utilisé pour les requêtes sur les données.
{
"workingCopy": {
"initial": "nouveau_dossier",
"final": false,
"subStatuses": [
{
"name": "nouveau_dossier",
"displayName": "Nouveau dossier",
"description": "Nouveau dossier de Ressources Humaines",
"final": false,
"events": [
{
"name": "activer",
"target": "current.dossier_actif",
"displayName": "Activer le contrat",
"description": "Vous allez activer le contrat",
"position": 1,
"beforeTasks": [
{
"identifier": "ask_create_self_evaluated_matricule",
"sequence": 1,
"blocking": true,
"filter": null
}
],
"afterTasks": [],
"canRun": [
"ressources_humaines"
],
"mandatoryAnnotation": false
}
]
}
]
},
"current": {
"initial": "dossier_actif",
"final": false,
"subStatuses": [
{
"name": "dossier_actif",
"displayName": "Dossier actif",
"description": "Dossier actif de Ressources Humaines",
"final": false,
"events": [
{
"name": "cloturer",
"target": "preserved.dossier_cloture",
"displayName": "Clôturer le dossier",
"description": "Vous allez clôturer le dossier",
"position": 1,
"beforeTasks": [],
"afterTasks": [],
"canRun": [
"ressources_humaines"
],
"mandatoryAnnotation": true
}
]
}
]
},
"preserved": {
"initial": "dossier_cloture",
"final": false,
"subStatuses": [
{
"name": "dossier_cloture",
"displayName": "Dossier clôturé",
"description": "Dossier clôturé (preserved)",
"final": true,
"events": []
}
]
},
"residual": null
}