Solved

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

Posted on 2008-10-07
13
2,090 Views
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?

Thanks!
0
Comment
Question by:Marius0188
  • 8
  • 5
13 Comments
 
LVL 4

Expert Comment

by:Maxi84
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.
0
 

Author Comment

by:Marius0188
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.

0
 

Author Comment

by:Marius0188
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...
0
 

Author Comment

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

Thanks.
0
 
LVL 4

Expert Comment

by:Maxi84
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...
    mf.run(args);

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.
0
 

Author Comment

by:Marius0188
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
0
How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

 

Author Comment

by:Marius0188
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?

0
 

Author Comment

by:Marius0188
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), 

       MenuItemType::Output).create(Args);

    reportRun.run();

}

Open in new window

AX-Error.jpg
0
 
LVL 4

Expert Comment

by:Maxi84
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()
0
 

Author Comment

by:Marius0188
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);"
0
 
LVL 4

Accepted Solution

by:
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;
    ;

    args.name(reportstr(Cust));

    reportRun = classfactory.reportRunClass(args);
    reportRun.run();

0
 

Author Comment

by:Marius0188
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!
0
 
LVL 4

Expert Comment

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

Featured Post

What Should I Do With This Threat Intelligence?

Are you wondering if you actually need threat intelligence? The answer is yes. We explain the basics for creating useful threat intelligence.

Join & Write a Comment

Suggested Solutions

Title # Comments Views Activity
Dynamics CRM 2016 - Auto-numbering 2 66
CRM 2011 MultiLine Field Problem 3 46
SSRS Problems 9 26
Dynamics CRM 2 8
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…
Automatically creating a Trello card using data from a Microsoft Dynamics CRM record turned out to be an easy project that yielded great results.  Here's how I did this for an internal team at General Code.
Here's a very brief overview of the methods PRTG Network Monitor (https://www.paessler.com/prtg) offers for monitoring bandwidth, to help you decide which methods you´d like to investigate in more detail.  The methods are covered in more detail in o…
This video gives you a great overview about bandwidth monitoring with SNMP and WMI with our network monitoring solution PRTG Network Monitor (https://www.paessler.com/prtg). If you're looking for how to monitor bandwidth using netflow or packet s…

757 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

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now