Skip to main content

My first Dynamics AX 2012 Windows 8 App

I have recently created my first Windows 8 App and I thought I would write about my experience.

My first starting point is to download this Starter Kit.

Dynamics AX 2012 Windows 8 App Developer Starter Kit

Then before you do this I would suggested you have a look at Martin’s blog. He has made some fixes.

Create a custom web service

First task was to create a web service. I didn’t want to use a Document service. So, I created a custom service.

I wont go through the details of creating a contract or anything but I will show what the method I need is.


Create a windows 8 app

With visual studio 2012 (latest update 3 installed) I created a new project of type Windows Store.

This Grid view will create 3 *.xmal pages. See the screenshot below there is a preview on the right hand side. It shows a Grid view, a Group view, and a Item detailed view.


This is where we call the web service to retrieve the list. In my code I have not gotten into the detail but that is already in the sample. The sample uses a document service but I wanted some thing a bit more tightly coupled (custom web service).


Now when you run it it will look like this below. The 3 *.xmal pages will work with the default code provided.




The ease of creating the web service and external applications is leaps and bounds better than before. If you have people that are very capable with Win8 apps / mobile etc. Then they would love what there is to offer.

The other thing you have to realise also is – windows 8 is a lot more stronger with design aspect. They have rules and quality bars that you have to meet to release into the app store. I think this is a good step.


Detail on creating a custom web service in AX.

Dynamics AX 2012 Windows 8 App Developer Starter Kit

Then before you do this I would suggested you have a look at Martin’s blog. He has made some fixes.

For secure web service via Azure follow these articles.
Developing Secure Mobile Apps for Dynamics AX 2012 - Connector
Developing Secure Mobile Apps for Dynamics AX 2012

Demo video with technical aspects – Interesting because they talk about the standard solution and what they did.

They used HTML file to make it flexible cross platform using their own libraries. Wish they released these libraries and projects the same way AX is open.

Sample App with Code

Popular posts from this blog

AX - How to use Map and MapEnumerator

Similar to Set class, Map class allows you to associate one value (the key) with another value. Both the key and value can be any valid X++ type, including objects. The types of the key and the value are specified in the declaration of the map. The way in which maps are implemented means that access to the values is very fast. Below is a sample code that sets and retrieves values from a map. static void checkItemNameAliasDuplicate(Args _args) { inventTable inventTable; Map map; MapEnumerator mapEnumerator; NameAlias nameAlias; int counter = 0; ; map = new Map(Types::String, Types::Integer); //store into map while select inventTable { nameAlias = inventTable.NameAlias; if (!map.exists(nameAlias)) { map.insert(nameAlias, 1); } else { map.insert(nameAlias, map.lookup(nameAlias) + 1); } } //retrieve fro

AX - How to use Set and SetEnumerator

The Set class is used for the storage and retrieval of data from a collection in which the values of the elements contained are unique and serve as the key values according to which the data is automatically ordered. You can create a set of primitive data types or complex data types such as a Class, Record or Container. Below is sample of a set of records. static void _Set(Args _args) {     CustTable       custTable;     Set             set = new Set(Types::Record);     SetEnumerator   setEnumerator;     ;     while select custTable     {         if (custTable && !         {             set.add(custTable);         }     }     if (!set.empty())     {         setEnumerator = set.getEnumerator();         setEnumerator.reset();         while (setEnumerator.moveNext())         {             custTable = setEnumerator.current();             info(strfmt("Customer: %1",custTable.AccountNum));         }     } } Common mistake when creating a set of recIds

Import document handling (attachment) files #MSDyn365FO

Out of the box you have limited data entities for migrating attachments. If you search what is already in the AOT, you will see a few various examples. I suggest you look at the LedgerJournalAttachmentsEntity as it is the simplest and cleans to copy from. I wont go into detail but I will give a quick run down of what it looks like. Use the DocuRefEntity as your main datasource. It does most of the work for you. Set your table you want to import for as the child datasource Add the Key You will need to add the postLoad method. There is minor code to update the virtual field FileContents. Below is an export I did for the general journal attachments. The import zip structure should be the same way. It will create the usual artifacts such as the excel, manifest and package header xml files. You will see a Resources folder under that. If you drill down to the resources you will see the attachments. This is an export and it used the document GUID for uniqueness. The other thing is the extensi