Dynamics AX :: Bill of Lading when Sales Order is Posted

Posted on 2008-10-07
Last Modified: 2012-05-05
Dear Experts,

I need to produce a Bill of Lading when a Sales Order is posted.
As you should know by now that I am really new to AX development and would like some advise on how to accomplish this. Where will the code be, on which event?

Question by:Marius0188
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 8
  • 5

Expert Comment

ID: 22666801
If you want to produce it when the invoice is posted, put the code in SalesFormLetter_Invoice.UpdateNow().  Similarly, for picking list posting, use SalesFormLetter_PickingList.UpdateNow() etc.

Author Comment

ID: 22668616
Hi thanks for the quick reply.

Can you please give some more help and advise.
Will I have to generate the report in X++ code?
or AutoDesignSpec / GeneratedDesign?

Where will I have to start.
Most of the fiels on the Sales Invoice can be used just as is for the Bill of Lading.


Author Comment

ID: 22668816
Is there a way that you build a AutoDesignSpec report and then simply execute the report from X++ code.

What I was thinking was to basically design the report the normal easy (hope so) way and then just call the report from X++ code...
SharePoint Admin?

Enable Your Employees To Focus On The Core With Intuitive Onscreen Guidance That is With You At The Moment of Need.


Author Comment

ID: 22676308
Hi can someone please assist.
What is the best approach to start this project?
Please advise.


Expert Comment

ID: 22676577
Use, and modify as necessary, an existing report, or create your own in the AOT.  If you create your own report, add a new output-type menu item that calls your report.  If not, find the menu item that calls the existing report.

Add the following code to the method that you need to call your report from:

    MenuFunction mf = new MenuFunction(menuItemOutputStr(/*Menu item name goes here*/), MenuItemType::Output);
    Args args = new Args();
    //add args as necessary...;

You should use the tables CustInvoiceJour and CustInvoiceTrans to generate the bill of lading, and especially use the delivery and invoice name and addresses from CustInvoiceJour.  The point here is that these tables are a snapshot of what is actually delivered and invoiced.  The SalesTable and SalesLine may have items that are backordered, out of stock etc.  Also, the customer's name and address may change at any time after the order is shipoped, so if you use CustTable to retrieve the name and address, you will not be able to go back and generate an exact copy later if/when this becomes necessary.  There may also be legal issues WRT this.

Author Comment

ID: 22678599
Hi Maxi84,

I receive the following compiler error: "The operand for the function is not an element."
On line:
 MenuFunction mf = new MenuFunction(menuItemOutputStr(/*Menu item name goes here*/), MenuItemType::Output);

I have replaced the comment with the actual Report name.
Please advise

Author Comment

ID: 22678821
The first param for MenuFunction(), is this the Name property for the report menu item?
Should you write in in single / double quotes?


Author Comment

ID: 22684594
Hi Experts,

Please someone assist me.

The following code compiles well but I get a runtime error when running the job:
Please see attached screenshot for the error.

Please advise...
static void Execute_Report2(Args _args)
    Args            args;
    ReportRun       reportRun;
    args = new Args();
    reportRun = new MenuFunction(ReportStr(MyReports), 

Open in new window


Expert Comment

ID: 22684873
Don't use the report name.  As I wrote, create a new menu item in the AOS:  AOS/Menu Items/Output.  Right click on the Output node and select [New  menu item].  Set the 'Object type' to 'Report', and 'Object' to the name of your report.  Then use the name of your new menu item as the argument for menuItemOutputStr()

Author Comment

ID: 22684937
That is what I did at first.
But in the Job I used to make the call to the menu item I receive a compiler error:

"The operand for the function is not an element."

The line the error occurrs on is:
"menuFunction = new MenuFunction(MenuItemOutputStr(MvT_MenuItem), MenuItemType::Output);"

Accepted Solution

Maxi84 earned 500 total points
ID: 22684980
If you want to call the report directly, without going through a menu item, this code sample calls the 'Cust' report.

    Args       args = new Args();
    ReportRun  reportRun;

    reportRun = classfactory.reportRunClass(args);;


Author Comment

ID: 22685208
Ok, thanks.
That last example of yours worked.

But I am still curious why the example which calls a MenuItem did not want to work?
I have created the menu item, set the object and output.
But like I said the compiler error I received....

Thanks a million!

Expert Comment

ID: 22685894
Dunno, misspelling of the menu item name perhaps?

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

This is a walkthrough guide I wrote whilst upgrading my on-premise MS Dynamics CRM 3.0 deployment to 4.0. This covers the actual installation of the product to a working level for my system, I ran into a lot of issues that the steps below fixed so h…
Having trouble getting your hands on Dynamics 365 Field Service or Project Service trial? Worry No More!!!
Nobody understands Phishing better than an anti-spam company. That’s why we are providing Phishing Awareness Training to our customers. According to a report by Verizon, only 3% of targeted users report malicious emails to management. With compan…

763 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question