Créer un champ de recherche pour une dimension financière dans Dynamics 365
Publié : 16 février 2025 à 11 h 39 min 42 s UTC
Cet article explique comment créer un champ de recherche pour une dimension financière dans Dynamics 365 for Operations, y compris un exemple de code X++.
Creating a Lookup Field for a Financial Dimension in Dynamics 365
Les informations contenues dans cet article sont basées sur Dynamics 365 pour les opérations, mais la plupart d'entre elles fonctionneront également pour Dynamics AX 2012 (voir ci-dessous).
J'ai récemment été chargé de créer un nouveau champ dans lequel il devrait être possible de spécifier une seule dimension financière, dans ce cas Produit. Bien sûr, le nouveau champ devrait aussi pouvoir rechercher les valeurs valides de cette dimension.
C'est un peu plus compliqué qu'une recherche classique dans une table, mais si vous savez comment faire, ce n'est pas si mal.
Heureusement, l'application standard fournit un formulaire de recherche pratique (DimensionLookup) qui peut être utilisé à cette fin, si vous lui indiquez simplement quel attribut de dimension rechercher.
Tout d'abord, vous devez créer le champ de formulaire lui-même. Cela peut être basé sur un champ de table ou une méthode d'édition, cela n'a pas d'importance pour la recherche elle-même, mais d'une manière ou d'une autre, il doit utiliser le type de données étendu DimensionValue.
Vous devez ensuite créer un gestionnaire d'événements OnLookup pour le champ. Pour créer un gestionnaire d'événements, cliquez avec le bouton droit sur l'événement OnLookup pour le champ, puis choisissez « Copier la méthode du gestionnaire d'événements ». Vous pouvez ensuite coller une méthode de gestionnaire d'événements vide dans une classe et la modifier à partir de là.
Remarque : la plupart de ces fonctionnalités fonctionnent également pour Dynamics AX 2012, mais au lieu de créer un gestionnaire d'événements, vous pouvez remplacer la méthode de recherche du champ de formulaire.
Le gestionnaire d'événements devrait ressembler à ceci (remplacez le nom du formulaire et le nom du champ au besoin) :
FormControlEventHandler(formControlStr( MyForm,
MyProductDimField),
FormControlEventType::Lookup)
]
public static void MyProductDimField_OnLookup( FormControl _sender,
FormControlEventArgs _e)
{
FormStringControl control;
Args args;
FormRun formRun;
DimensionAttribute dimAttribute;
;
dimAttribute = DimensionAttribute::findByName('Product');
args = new Args();
args.record(dimAttribute);
args.caller(_sender);
args.name(formStr(DimensionLookup));
formRun = classFactory.formRunClass(args);formRun.init();
control = _sender as FormStringControl;
control.performFormLookup(formRun);
}