Bonjour, je souhaiterais savoir s’il est possible d’intégrer une étape de confirmation dans un contexte de Création ?
Le but serait d’avoir une popup de ce type :
au moment d’appuyer sur le bouton “Save”.
Ma première piste était de cacher le bouton save, créer une action de type formulaire avec la confirmation activé, et déclencher un validateAndCreate() au “click”.
Cependant, les actions ne semblent pas s’afficher dans un contexte de création.
Tu peux cacher le bouton “Créer” de la liste et en utiliser un custom qui crée un record dans un état Brouillon et affiche le formulaire de celui que tu viens de créer.
Il faudra ensuite cliquer sur un bouton pour valider ou non la création de ce record.
A l’état Brouillon il serait peut-être judicieux de masquer le bouton “Fermer” aussi et de le remplacer par un bouton custom qui supprime le record si le formulaire n’a pas été validé pour création.
Peut-être une cron aussi qui supprime les records qui n’ont pas été validés depuis un certain temps (à définir)
Le problème c’est que cela demande de créer un record :
si l’objet à beaucoup d’attributs obligatoires, ils seront donc préremplis à l’affichage du formulaire, cela risque d’embrouiller les utilisateurs
si des traitements se basent sur le nombres de record et/ou les valeurs des attributs obligatoires, cela risque de fausser les résultats
Ce type de demande revient assez régulièrement dans le cas de création de record “sensible”.
Penses tu que ce type de demande pourrais être intégrer de façon native dans une future évolution et de ce fait basculer le post en “Feature request” ?
Tu peux toujours rendre les champs obligatoires uniquement si le statut est différent de Brouillon.
C’est pour ça qu’il faut s’assurer que le record est supprimé si la validation de création n’est pas faite. Tu peux aussi conditionner tes calculs pour exclure tous les records au statut Brouillon.
Quant à la feature request, on va en disputer en interne.
Je passe le besoin en feature request pour ouvrir le débat.
L’action “Créer” est déjà une proposition de création, qui ne crée rien, ouvre un formulaire de création avec N champs obligatoires à remplir, et qui seront confirmés par le bouton “Enregistrer”.
Demander si l’utilisateur veut finalement “créer” au “save” après un tel parcours me semble inutile. L’utilisateur est tout à fait conscient de créer quelque chose à cette étape.
Là où un popup de confirmation peut avoir du sens c’est au moment du 1er click sur le bouton “Créer” / avant d’accéder au formulaire de création.
Au niveau du runtime, le bouton de création n’est pas une Action au sens du paramétrage Simplicité, c’est juste un affichage UI lié à un droit et une option “créer depuis la liste”. Pour le rendre paramétrable, il faudrait pouvoir
créer et habiliter une Action “Créer” qui remplace le bouton natif
L’Action pourrait alors avoir du code front, une confirmation avec un libellé spécifique, des champs à renseigner pour préparer le formulaire de création… bref être une Action
Ce besoin a du sens dans un cas plus général si on introduit une nouvelle notion sur l’Action Simplicité pour remplacer ce que fait l’action de base :
Extend = Create | Delete | Save&Close | Close…
charge à l’implémentation de l’action de remplacer le handler par défaut
ou si l’action n’a pas de code, appeler le handler natif
En attendant, pour répondre au besoin à court terme, il faut faire comme @Alistair propose mais sans créer de record vide = remplacer le bouton “Créer” sur la liste (décocher la case sur la définition de l’objet) avec une Action de confirmation dont le code ne fera qu’ouvrir le formulaire de création (displayForm avec un rowId = “0”).