Actions on Forms: To Add an Action to Run a Report
The following activity will walk you through the process of adding an action that a user can invoke to run a report.
Story
Suppose that management has determined that MYOB Acumatica would better fit the needs of your company if from the Sales Orders (SO301000) form, employees could quickly access the Sales Order Details by Customer (SO611000) report for the selected customer. You need to add to the form the action that runs this report.
Process Overview
On the Customized Screens page, you will add the Sales Orders (SO301000) form so that it can be customized. On the Actions page, you will add a new action that runs the Sales Order Details by Customer (SO611000) report. You will then publish the customization project. On the Sales Orders form, you will test the added action.
System Preparation
Before you begin performing the steps of this activity, do the following:
- Prepare an MYOB Acumatica instance by performing the Customization Projects: To Deploy an Instance prerequisite activity.
- Create the Yogifon customization project by performing the Customization Projects: To Create a Customization Project prerequisite activity.
Step 1: Modifying the List of Customized Screens
To add a new tab on the Customers (AR303000) form, you first need to add the form to the list of customized screens. Do the following:
- On the Customization Projects (SM204505) form, click Yogifon to open the Customization Project Editor for this customization project.
- In the navigation pane of the Customization Project Editor,
click Screens.
The Customized Screens page opens.
- On the page toolbar, click Customize Existing
Screen.
The Customize Existing Screen dialog box opens.
- In the Select Screen box of the dialog box, click the magnifier button. In the lookup table, type SO301000 in the Search box, and double-click the Sales Orders form.
- Click OK to close the dialog box.
The Sales Orders form is added to the list of forms on the Customized Screens page, and the Screen Editor: SO301000 (Sales Orders) page opens.
Step 2: Adding the Action
To add the action to the Sales Orders (SO301000) form, perform the following instructions:
- In the navigation pane of the Customization Project Editor, click
The SO301000 (Sales Orders) Actions page opens.
. - On the page toolbar, click Create New Action.
- In the Action Properties dialog box, which opens, specify
the following settings (see the screenshot below):
- Action Name:
SalesOrdersByCustomerAttention:This box does not contain the name that is displayed on the UI; it contains the internal name of the action that will be used in the automatically generated code of the action. The name should not be the same as the name of any existing action and should not contain spaces or the @ symbol.
- Display Name: Sales Orders By
Customer
This is the name of the action that will be displayed on the UI.
- Action Type: Run Report
This type of action provides redirection to a report. For details on other types of actions, see Actions on Forms: General Information.
- Category: Other
The command associated with the action will be displayed under the Other category of the More menu.
- Destination Screen: SO611000
This is the screen that should open when the action is invoked.
- Window Mode: New Tab
This setting indicates that if a user clicks the Sales Orders By Customer button or menu command, this report opens in a new browser tab.
- Rights to Enable Action: Select
This setting indicates that a user should have the rights to view the report form that the action will open (Sales Orders in this case) for the action to be available.
- Display on Toolbar: If Available
With this option selected, the button associated with the action will be displayed on the form toolbar if the action is available for the selected record based on its state (status), in addition to the associated menu command being displayed on the More menu.
- Action Name:
SalesOrdersByCustomer
- On the Navigation Parameters tab, add two rows with the
following settings (also shown in the following screenshot).
Active Parameter Name From Schema Value Selected Customer ID Cleared [Customer] Selected Start Date Selected @YearStart These settings indicate that when a user clicks the button or menu command, the report should open for the customer specified in the sales order, and the dates of the sales orders should be January 1 of the current year. (By default, the report displays the sales orders placed within the current month.)
- Click OK to close the dialog box.
Notice that the new action has been added to the list of actions, and that its status is New (which means that this action has not been inherited from a predefined action, but has instead been created from scratch).
- On the main menu of the Customization Project Editor, click .
- Wait until the Website updated row appears in the Compilation pane, and click Close Compilation Pane.
Step 3: Testing the New Action
In MYOB Acumatica, test your changes as follows:
- On the Company and Branch Selection menu on the top pane of the MYOB Acumatica screen, make sure that the MyStore branch is selected.
If it is not selected, click the selection menu to view the list of branches that you have access to, and then click MyStore.
- In the info area, in the upper-right corner of the top pane of the MYOB Acumatica screen, make sure that the business date in your system is set to 10/31/2023. If a different date is displayed, click the Business Date menu button, and select 10/31/2023 from the calendar.
- On the Sales Orders (SO301000)
form, select the sales order with the 000002 ID. (It has the Open
status.)
Notice the customer specified for this sales order (C00000008).
- Notice that the form toolbar now contains the Sales Orders By Customer button, based on the settings that you have specified for the action. On the More menu, notice that the Other category also contains the command associated with this action.
- Click the Sales Orders By Customer command.
The Sales Order Details by Customer (SO611000) report opens for the current customer in a new browser tab.