Wednesday, May 14, 2014

Set Value On a Control in List Page through ListPage Interaction class (Dynamics AX 2012)

I recently had a requirement to display sum of total volume (a display method) of all the selected records on a List page form. There were two major development tasks in this requirement

  1. To loop through all records that user has selected on List Page.
  2. To set value on a custom control of List Page after calculation.
You can easily loop through list of selected records with in interaction class by using MultiSelectionHelper class. However, I found it a bit tricky in setting up the control value of List page as previously I only used this class to enable/disable or make visible true false of controls or buttons on list page.

Here is the code for your reference if you ever need to do the same.
For sure there will be many other more effective ways of doing this. If you ever had to do and know the best way please share with me as well.

protected void setSumOfTotalVolume()
{
    ReqPO               reqPO;
    Volume              totalVolume;
    Common              externalRecord;
    FormDataSource      frmDs;
    FormRun             formRun;
    FormRealControl     frmCtrl;
    MultiSelectionHelper helper = MultiSelectionHelper::construct();

    helper.parmDatasource(this.listPage().activeRecord('ReqPO').dataSource());

    reqPO = helper.getFirst();
    while (reqPO.RecId != 0)
    {
        totalVolume += reqPO.totalVolume();
        reqPO = helper.getNext();
    }

    //Assign value to control on list page
    externalRecord = this.listPage().activeRecord('ReqPO');

    if(externalRecord.isFormDataSource())
    {
        frmDs   = externalRecord.dataSource();
        formRun = frmDs.formRun();
        if(formRun)
        {
            frmCtrl = formRun.design().controlName(formControlStr(ReqTransPOListPage,TotalVolumeField));
            if(frmCtrl)
            {
                frmCtrl.realValue(totalVolume);
            }
        }
    }
}

You should also call this method from interactionclass.selectionchanged() method to update value on every record selection.

Hope it will be help full for if you have a similar requirement in future.

Happy DAXing !!

7 comments:

Anonymous said...

louis vuitton, christian louboutin outlet, ugg boots, prada outlet, longchamp outlet, kate spade outlet, nike free, nike air max, oakley sunglasses, ralph lauren pas cher, burberry, longchamp outlet, nike outlet, oakley sunglasses, michael kors, louis vuitton outlet, ray ban sunglasses, louboutin, louis vuitton, ugg boots, louboutin shoes, oakley sunglasses, replica watches, sac longchamp, louboutin outlet, polo ralph lauren outlet, uggs on sale, cheap oakley sunglasses, louis vuitton outlet, replica watches, longchamp pas cher, ray ban sunglasses, tiffany and co, polo ralph lauren outlet, tiffany jewelry, longchamp, air jordan pas cher, tory burch outlet, jordan shoes, nike roshe run, gucci outlet, chanel handbags, air max, louboutin pas cher, prada handbags, nike air max, ray ban sunglasses, nike free, louis vuitton, oakley sunglasses

Anonymous said...

north face, true religion jeans, tn pas cher, oakley pas cher, michael kors, coach outlet, ralph lauren uk, michael kors, vanessa bruno, hollister, nike air max, true religion outlet, hermes, michael kors, coach purses, kate spade handbags, michael kors, michael kors outlet, nike air max, nike blazer, true religion jeans, converse pas cher, replica handbags, michael kors outlet, hogan, ugg boots, coach outlet, air force, mulberry, michael kors outlet, true religion jeans, burberry outlet online, new balance pas cher, ugg boots, north face, ray ban pas cher, hollister pas cher, burberry, michael kors outlet, nike roshe, ray ban uk, nike free run uk, sac guess, michael kors outlet, lacoste pas cher, vans pas cher, timberland, nike air max, abercrombie and fitch, lululemon

Anonymous said...

babyliss, insanity workout, mac cosmetics, hollister, converse outlet, hollister, valentino shoes, giuseppe zanotti, louboutin, reebok shoes, nike roshe, beats by dre, gucci, new balance, bottega veneta, nike air max, longchamp, soccer jerseys, north face outlet, ghd, nike trainers, chi flat iron, celine handbags, asics running shoes, jimmy choo shoes, nike huarache, lululemon, nike air max, ferragamo shoes, vans, wedding dresses, birkin bag, mcm handbags, mont blanc, abercrombie and fitch, baseball bats, instyler, ray ban, converse, oakley, p90x workout, timberland boots, iphone cases, north face outlet, hollister, herve leger, soccer shoes, nfl jerseys, vans shoes, ralph lauren

Anonymous said...

ugg,ugg australia,ugg italia, supra shoes, barbour, pandora charms, montre pas cher, moncler, canada goose, canada goose outlet, lancel, louis vuitton, sac louis vuitton pas cher, moncler, pandora charms, swarovski crystal, wedding dresses, ugg boots uk, pandora jewelry, replica watches, moncler, canada goose uk, juicy couture outlet, coach outlet, links of london, canada goose, canada goose outlet, doudoune canada goose, canada goose, barbour jackets, bottes ugg, swarovski, moncler outlet, marc jacobs, moncler, louis vuitton, canada goose, hollister, toms shoes, moncler, ugg pas cher, moncler, karen millen, louis vuitton, pandora jewelry, ugg,uggs,uggs canada, moncler, louis vuitton, juicy couture outlet, thomas sabo

Sivakarthik said...

thanks, finally its working :)

yanmaneee said...

christian louboutin outlet
golden goose sneakers
baseball jerseys
off white shoes
kyrie 5 shoes
yeezy boost 350
jordan 12
kobe 11
moncler
moncler jacket

Anonymous said...

useful link replica ysl handbags redirected here additional resources the original source Learn More Here