Dynamics AX Blog - Dynamics AX 2012 - lookup - Beiträge von 2015
Momentan angezeigt werden nur Beiträge, welche für die Dynamics AX-Version »Dynamics AX 2012« relevant sind. 
RSS-Feed dieser Version

RSS-Feed dieser Version
Momentan angezeigt werden nur Beiträge von »2015«.
Lookup eines FormControls übersteuern und dabei Feldgruppen verwenden
20.03.2015Microsoft Dynamics AX (Axapta)
Um einen Lookup eines Feldes zu übersteuern oder einen Lookup für ein Feld zu erstellen, welches standardmässig keinen Lookup anbietet, kann man die lookup()-Methode des FormControls überschreiben. So weit nichts wirklich neues. Das folgende Snippet zeigt, wie man in einer solchen lookup()-Methode statt fixen Feldlisten vorhandene Feldgruppen verwenden kann. Dies hat den Vorteil, daß sich auch dieser lookup() dynamisch mitändert, wenn jemand die jeweilige Feldgruppe modifiziert. Display-Methoden werden im folgenden nicht berücksichtigt, da nicht sichergestellt werden kann, daß alle für die Display-Methoden notwendigen Felder Teil der Feldgruppe sind (siehe dazu auch dieser Blog-Beitrag). public void lookup() { SysTableLookup sysTableLookup; Query query; QueryBuildDataSource qbds; SysDictTable sysDictTable = new sysDictTable(tableNum(CustTable)); SysDictFieldGroup sysDictFieldGroup; Counter f; query = new query(); qbds = query.addDataSource(tableNum(CustTable)); sysTableLookup = sysTableLookup::newParameters(tableNum(CustTable), this); sysTableLookup.parmQuery(query); sysDictFieldGroup = new SysDictFieldGroup(tableNum(CustTable), identifierStr(CaseMoreInformation)); for (f=1;f<=sysDictFieldGroup.numberOfFields();f++) { if( !sysDictFieldGroup.methodName(sysDictFieldGroup.field(f))) // no display methods { sysTableLookup.addLookupfield(sysDictFieldGroup.field(f), (sysDictTable.primaryKeyField() == sysDictFieldGroup.field(f))); } } sysTableLookup.performFormLookup(); } |
|
|
|
|
|
|
Mit Hilfe der Klasse SysTableLookup kann man sich den Lookup von Formularfeldern anpassen. Über die Methode addLookupMethod() können in diese Lookup-Formulare auch Display-Methoden eingebunden werden. Wichtig dabei ist lediglich, daß im Lookup alle Felder eingebunden werden (beispielsweise über addSelectionField()), die von der jeweiligen Display-Methode zur Ermittlung benötigt werden.
Will man beispielsweise das Lookupformular der Artikelnummer um den Produktnamen erweitern, kann man dafür die folgende Methode nutzen. Hierbei ist beispielsweise das Feld Product der InventTable nur enthalten, um die Display-Methode itemName() im Lookup verwenden zu können.