Dynamics AX Blog - Dynamics AX 2012 - Beiträge von 2010

RSS-Feed dieser Version
Tipp: Job in Klasse umwandelnWusstet Ihr eigentlich, daß man einen Job einfach dadurch in eine einfache Klasse umwandelt, in dem man den Job per Drag & Drop in den Knoten Classes des AOTs zieht? |
Label in einer bestimmten Sprache auslesen
14.08.2010Microsoft Dynamics AX (Axapta)
Um in X++ ein Label in einer ganz bestimmten Sprache auszugeben, nutzt man am besten die Methode labelId2String2 der SysLabel-Klasse: info(any2str(SysLabel::labelId2String2(literalStr("@SYS14204"),"de-at"))); |
selectMultiple und selectSingle
05.08.2010Microsoft Dynamics AX (Axapta)
Beim Stöbern in den vorgefertigten Methoden in der global-Klasse bin ich auf zwei Funktionen gestossen, die ich schon früher das eine oder andere Mal gebraucht hätte: selectMultiple und selectSingle. Was können diese Funktionen? Man übergibt Ihnen einen Container mit möglichen Werten und als Rückgabewert erhält man ebenfalls einen Container mit den vom Benutzer ausgewählten Werten. Dazwischen wird ein Dialog generiert, der nicht benutzerfreundlicher sein könnte, wie ich finde. |
Palette verlagern per X++Folgend etwas X++ Code, mit dessen Hilfe man eine Palette verlagern kann, also genau das, was die Schaltfläche "Palette verlagern" in Formular Palette tut. WMSPalletMove wmsPalletMove = new wmsPalletMove();
wmsPalletMove.parmWMSPalletId('00000022_117'); wmsPalletMove.parmToInventLocationId('300'); wmsPalletMove.parmToLocationId('01'); if(wmsPalletMove.validate()) { wmsPalletMove.run(); }
|
Liste aller Felder einer Tabelle ausgeben
24.07.2010Microsoft Dynamics AX (Axapta)
Unlängst benötigte ich eine Liste aller Felder einer Tabelle mit deren Datentypen. Dafür habe ich mir den folgenden Job - im Beispiel für die Tabelle custGroup - geschrieben: static void listAllFields4Table(Args _args) { dictTable dictTable = new dictTable(tableNum(custGroup)); int currFieldId = 0; counter c = 0; dictField dictField; counter a = 0; common common; str enumName; ; common = DictTable.makeRecord(); setPrefix(strFmt("Fields of table %1", tableId2name(common.TableId))); currFieldId = 0; c = 0; do { currFieldId = dictTable.fieldNext(currFieldId); if(currFieldId != 0) { dictField = new dictField(common.TableId, currFieldId); if(dictField.arraySize() == 1) { info( strFmt("%1: %2 [%3%4]", dictTable.fieldName(currFieldId), dictField.label(), dictField.baseType(), dictField.enumId() ? strFmt(" %1", enumId2Name(dictField.enumId())) : "") ); } else if(dictField.arraySize() > 1) { for(a=1;a<=dictField.arraySize();a++) { info( strFmt("%1 [%2]: %3 [%4]", dictTable.fieldName(currFieldId), a, dictField.label(), dictField.baseType()) ); } } } c++; } while (c < dictTable.fieldCnt()); } |
Prüfungen durchführen beim/vor dem Schliessen eines Formulares
20.07.2010Microsoft Dynamics AX (Axapta)
Möchte/muß man beim bzw. vor dem Schliessen eines Formulares etwas tun, z.B. Prüfungen durchführen, so stellt Dynamics AX dafür einige Methoden zur Verfügung, die in einer bestimmten Reihenfolge abgearbeitet werden. Da ich selbst mir diese Reihenfolge nicht merke, habe ich sie hier kurz notiert. Beim Schliessen eines Formulares über einen OK-Commandbutton:
Beim Schliessen eines Formulares über einen CANCEL-Commandbutton:
Beim Schliessen eines Formulares über "das rote X" bzw. der ESC-Taste:
|
|
|
|
|
|
|
Manchmal braucht man einfach nur den Label eines Extended Datatypes (EDT), um diesen zum Beispiel als Bestandteil einer Info-/Fehlermeldung ausgeben zu können: