Tuesday, 15 October 2013

Adding Financial Dimension to Form


How add financial dimension on forms inside Ax2012


1.      Perform
a)      Open AOT>>Data Dictionary>>Extended Data Types type/select DimensionDefault and drag it in table which will be used further as a datasource in form where you have to show the Dimensions. Do Remember  that you have to drag it in table not at DataSource.
b)     Open Table in the Data, Dictionary which will be used as a Datasource, and create a realtion with table DimensionAttributeValueSet .
c)      Right Click the Relations. Select ‘New Realation’.  Select properties. Set name as DimensionAttributeValueSet, Table as DimensionAttributeValueSet.
d)     Right Click the this newly created Relation DimensionAttributeValueSet, select New>>Normal.
e)      Set the properties of Normal Realtion as:  Field=TheFieldwhichwillsaveDimensionNumberInYourTable
Source EDT= DimensionDefault
Related Field=RecId

2.      Verify that the table that will hold the foreign key to the DimensionAttributeValueSet table is a
data source on the form(the one on which you have to show dimensions).
3.      Create a tab that will contain the financial dimensions control. This control is often the only
data shown on the tab because the number of financial dimensions can be large.
4.   set properties of Tab as under
a)      Set the Name metadata of the tab to TabFinancialDimensions.
b)     Set the AutoDeclaration metadata of the tab to Yes.
c)      Set the Caption metadata of the tab to @SYS101181 (Financial dimensions).
d)     Set the NeedPermission metadata of the tab to Manual.
e)      Set the HideIfEmpty metadata of the tab to No.
       5.  Override the pageActivated method on the new tab
public void pageActivated()
{
    dimDefaultingController.pageActivated();

    super();
}
      6.   Override the following methods on the form.
class declaration
public class FormRun extends ObjectRun
{
    DimensionDefaultingController dimDefaultingController;
}
init (for the form):
public void init()
{
    super();
    dimDefaultingController=DimensionDefaultingController::constructInTabWithValues(
      true, 
      true, 
      true, 
      0, 
      this, 
      tabFinancialDimensions, 
      "@SYS138487");

    dimDefaultingController.parmAttributeValueSetDataSource(myTable_ds,
    fieldstr(myTable, DefaultingDimension));
}
    7.      Override the following methods on the form data source
            public int active()
{
    int ret;
    ret = super();
    dimDefaultingController.activated();
    return ret;
}
public void write()
{
    dimDefaultingController.writing();
    super();
}
public void delete()
{
    
    super();
  dimDefaultingController.deleted();
}


==================================================

How to add the ledger account (ledger dimension ) in form in AX 2012(show the ledger dimension lookup in field)


How to add the ledger account (ledger dimension ) in form in AX 2012(show the ledger dimension lookup in field)

A ledger account contains the main account, account structure, and each financial dimension value needed to fulfill the related account structure and account rule structures.A foreign key representing a ledger account is a 64 bit integer field that contains the data from the corresponding RecId field the DimensionAttributeValueCombination (LedgerDimension) table.
The ledger account control uses the LedgerDimensionAccountController class as its controller class.  This control handles the entry and display of ledger accounts in AX forms.
In simple scenarios the changes needed on an AX form are as follows:
1.    Verify that the table that holds the Foreign Key to the DimensionAttributeValueCombination table is a data source on the form.
2.    Drag the LedgerDimension field from the data source to the desired location on form design. This creates a SegmentedEntry control with the appropriate DataSource and ReferenceField property values. Alternatively this can be done by adding a SegmentedEntry control to the design and manually setting the DataSource and ReferenceField properties.
3.    Override the following methods on the form.  If the methods already exist just add the code to the methods.  Be sure to denote where the super () call is for the init () method.

classDeclaration():
public class FormRun extends ObjectRun
{
LedgerDimensionAccountController ledgerDimensionAccountController;
}
Init():
public void init()
{
super();
ledgerDimensionAccountController    =LedgerDimensionAccountController::construct(InventParameters_ds,fieldstr(InventParameters,LedgerDimension));
}

Overload the following methods on the SegmentedEntry control instance in the form design
jumpRef():
public void jumpRef()
{
ledgerDimensionAccountController.jumpRef();
}

validate():
public boolean validate()
{
boolean isValid;
isValid = super();
isValid = ledgerDimensionAccountController.validate() && isValid;
return isValid;
}
segmentValueChanged():
public void segmentValueChanged(SegmentValueChangedEventArgs _e)
{
super(_e);
ledgerDimensionAccountController.segmentValueChanged(_e);
}
loadSegments():
public void loadSegments()
{
super();
ledgerDimensionAccountController.parmControl(this);
// The valueof this parameter varies depending on the type of form.
// See the Additional options section for more detail.
ledgerDimensionAccountController.loadSegments();
}
loadAutoCompleteData():
public void loadAutoCompleteData(LoadAutoCompleteDataEventArgs _e)
{
super(_e);
ledgerDimensionAccountController.loadAutoCompleteData(_e)
}

After that go to datasource of form –datasource-field(ledgerdimension)
Overload the below on the data source field that backs the SegmentedEntry control
resolveReference():
public Common resolveReference(FormReferenceControl _formReferenceControl)
{
return ledgerDimensionAccountController.resolveReference();

}
===============================================================

No comments:

Post a Comment