Alfasith AX

Alfasith AX
اللَّهُمَّ انْفَعْنِي بِمَا عَلَّمْتَنِي، وَعَلِّمْنِي مَا يَنْفَعُنِي، وَزِدْنِي عِلْمًا

Wednesday, July 10, 2013

Creating a Report using the Query in Dynamic AX (SSRS report using Query Based)

Hi,

1.       Create a query “CustQry” with datasource as CustTable.
2.       In the Visual studio Create report using the query.
a.       Create a project with Installed templates: Microsoft Dynamic AX and select Report Model at last give a name to that report.

  
b.      In the solution explorer right click on the project created add - > reports.

c.       You may find the Dataset right click on that Add Dataset.

 

In the Data source type select : Query and in the Query select the query that you created “CustQry”.
d.       Drop that dataset that you created into design.
e.      Right click on that create precision design.
f.        Customize as per your design. Then right click for preview.


Tuesday, July 9, 2013

Number Sequence in Dynamic AX (for Form level)

1. Create EDT
2. Use that EDT in the Table where it is required
3. Select the Class module which you going to implement this Number seq.
//Consider if we want for HRM then “NumberSeqModuleHRM” class is the target.
//Add below code in the loadModule()
            protected void loadModule()
     {
     NumberSeqDatatype datatype = NumberSeqDatatype::construct();
//Added by Alfasith
     datatype.parmDatatypeId(extendedtypenum(customerID));
//your EDT
     datatype.parmReferenceLabel(literalstr("RES-customerID"));
//Your label
     datatype.parmReferenceHelp(literalstr("RES-customerID"));
     datatype.parmWizardIsContinuous(true);
     datatype.parmWizardIsManual(NoYes::No);
     datatype.parmWizardIsChangeDownAllowed(NoYes::No);
     datatype.parmWizardIsChangeUpAllowed(NoYes::No);
     datatype.parmWizardLowest(1);
     datatype.parmWizardHighest(99999999);
     datatype.parmSortField(15);
//(This 15 is the next number that already in that default list)
     datatype.addParameterType(NumberSeqParameterType::DataArea, true, false);
    this.create(datatype);
    //code end
     }

4. Select the concern table. Create new methods as below
Here we take HRMParameters table 
// table on which that number seq is going to generate.

static client server NumberSequenceReference customer()
{
    return NumberSeqReference::findReference(extendedtypenum(customerID));//Your EDT name
}

5. Create a new job with the following code and run it:

static void NumberSeqLoadAll(Args _args)
{
NumberSeqApplicationModule::loadAll();
}

6. ( Control + W )
Select Organization administration-> Number Sequence-> Number Sequence
Select the module //here we select Human Resources
Select the EDT you created //Surly that EDT you created will be appear here.
Click GENERATE

7. Create a new job with the following code and run it:
static void NetvendNumberSeq(Args _args)
{
    NumberSeq  numberSeq;
    StudentID num;
    ;
    numberSeq = NumberSeq::newGetNum(VendParameters::student());
   
    num = numberSeq.num();
    info(num);
}

8. Select the Form on which that table is required.
Drop the table in to that form Data Source.

8(a). ClassDeclaration. Write the below code.

public class FormRun extends ObjectRun
{
    NumberSeqFormHandler numberSeqFormHandler;
}
/*************************************************************/
8(b). Create new method

NumberSeqFormHandler numberSeqFormHandler()
{
    if (!numberSeqFormHandler)
    {
       numberSeqFormHandler = NumberSeqFormHandler::newForm(NetRMSParameters::customer().NumberSequenceId,
                                                             element,
                                                             Table2_ds,
                                                             fieldNum(Table2, customerID)
                                                            );
    }
    return numberSeqFormHandler;
}

/***********************************************************/
8(c). Override the datasource methods of that table with following method in that form.
public void delete()
{
    ;
    element.numberSeqFormHandler().formMethodDataSourceDelete();
     super();
}
/***********************************************************/
public void write()
{
    super();
    element.numberSeqFormHandler().formMethodDataSourceWrite();
}
/***********************************************************/
public void create(boolean _append = false)
{
    ;
    super(_append);
    element.numberSeqFormHandler().formMethodDataSourceCreate();
}

/***********************************************************/

SQL code to upate one Legal entity banner to all the legal entity in D365

 Hi, update companyimage set  companyimage.Image  = companyimageA.Image  from  ( select Image from companyimage where dataAreaid = 'USF...