This seems like a simple task, but I haven’t been able to find instructions that have worked.
I have an inquiry screen with a simple Filter DAC for the header and a Details DAC for the grid. The grid contains a column “Commission”, and I need a summary field to display “Total Commission” either in the header or on the grid footer.
I’ve found an article Calculating Grid Totals on an Inquiry Form - Acumatica Developers Blog and followed the last (most advanced) example and I’m still getting inconsistent results when I have a mixture of header filters, shared filter tabs, and ad-hoc user filters applied. I’ve been working on this for a few days and trying many different things, but always with mixed results. If nothing else works, I’m willing to consider adding an action button that has to be clicked to refresh the total.
In a regular Generic Inquiry, a summary field can be defined for the footer, and the column total will reflect the total for all records in the grid view, regardless of how filters are applied to it. When paging is enabled, it will still show the total for all pages, not only records on the current page.
I want to apply this same type of calculation on my custom screen so that the total displays the sum for ALL records in the currently filtered data set.
Is there no object I can access that holds all the records in the filtered data set? The counter at the bottom displays total number of records and if paging is turned on, it displays for example, (1-200 of 12345 records). So I know the system knows which records are in the data set.
This screen also has a number of actions that can be performed on multiple selected records, which is why we’re not using a Generic Inquiry screen.
As it was made quickly just for proof-of-concept purposes, it lacks more controls expected for inquiry screen, but should be enough to get things going.
Let me know if I’m missing something and this is not the result you’re expecting.
Have you considered using an event handler, something like FilterDAC RowUpdated, so whenever the filter changes, it uses some logic to loop through the records that are now visible to set your field in the header equal to the sum of the Commission column?
@josiahl64 Yes, but unfortunately this will not help me because the event will not fire when a user switches to a different shared filter on the grid, or adds an ad-hoc column filter.
In a regular Generic Inquiry, a summary field can be defined for the footer, and the column total will reflect the total for all records in the grid view, regardless of how filters are applied to it.
I’ve wanted to know how to do this with a custom grid for a very long time.
Here’s what I know so far:
Enable the grid footer:
Enable the column footer type:
Sigh / cry because although the footer shows and has sections for each column, nothing displays. I’ve tried change multiple grid settings to cause the update but no joy yet.
We’ve done something similar by calculating and setting the header field value in the details Dataview delegate method - while also using an additional action button that simply calls Details.View.RequestRefresh();.
I believe there’s also a call to the HeaderFilter.View.RequestRefresh() in the grid Row Selected event
Sometimes the header value gets set in code, but does not always update in the UI - so the action button updates the total field. It’s not the most ideal solution, but it seems to work well with quick filters in the grid.
Curious to see if anyone has a better method of handling this.
@mbridges00 The majority of my time was spent on attempting to implement this via a calculation in the Details Dataview delegate method like you mentioned. It makes logical sense, that since the delegate method gets called when the view is refreshed, I should be able to do some calculation with the “results” object right before it’s returned.
I really wish we could get some answers on this from someone on the Acumatica development team.
As it was made quickly just for proof-of-concept purposes, it lacks more controls expected for inquiry screen, but should be enough to get things going.
Let me know if I’m missing something and this is not the result you’re expecting.
@andriitkachenko Thank you for the detailed example! I see a few things in here that are different from my attempts. I will try this today and let you know the results!
Your C# code was almost identical to one of the things I had tried, but the auto-callback in your ASPX was a bit different from the example I was following from the article I linked in my question. I’m guessing that was the difference, but either way, it is working now!
This will work for our use case, but one thing for others to take note of is that after removing a quick filter, the calculated value doesn’t update until the user performs some other action on the screen (even clicking on the grid). There’s probably a way also trigger a refresh after the filter is removed, but I don’t have time to dig into it now.
One thing that I have found to be useful is the StatusField property of the grid and tying it to an unbound/calculated field in the DAC. This allows you some formatting/flexibility in what/how you display the data but isn’t exactly what you asked for. It also seems to respect the “filtering” options that may be applied.
We use 3 different kinds of cookies. You can choose which cookies you want to accept. We need basic cookies to make this site work, therefore these are the minimum you can select. Learn more about our cookies.