Skip to main content
Solved

How to Retrieve System Time on Form Save and Perform Calculations in Acumatica?


Forum|alt.badge.img

Hi,

I have a requirement in Acumatica to retrieve the system time when a user saves a form for the first time. I need to use this system time to perform a calculation and update a field value on the same form. Is there a method to get the system time in Acumatica? If so, could you please provide detailed steps or guidelines on how to achieve this?

Thank you in advance for your assistance!

Best answer by andriitkachenko

Hi @RKarunarathne51 

var machineTime = DateTime.Now;
var machineTimeUtc = DateTime.UtcNow;
var instanceTime = PXTimeZoneInfo.Now;
var instanceTimeUtc = PXTimeZoneInfo.UtcNow;

Here are multiple options you can use to get the time depending on your use case.

Make sure you understand the difference between server (machine) time and instance (Acumatica) time. It isn’t exactly the same thing (for me they are different most of the time).

I’d also want to stress again what Daryl said before - we are creating Audit fields for that reason in DACs. If you are using your custom DAC, take a look at a standard one (most of Acumatica’s DACs have these audit fields). What you ask sounds exactly like CreatedDateTime.

If you use your custom DAC, I’d urge you to add the full set of audit fields, to avoid stumbling upon issues each time they are required, but not added.

View original
Did this topic help you find an answer to your question?

5 replies

MichaelShirk
Captain II
Forum|alt.badge.img+1
  • Captain II
  • 108 replies
  • July 25, 2024

@RKarunarathne51 

Just a clarifying question.

When you say “System Time”, are you referring to “Acumatica System” time, commonly referred to as “Business Date”, or are you wanting to retrieve the current UTC (Computer) time?


jinin
Pro I
Forum|alt.badge.img+11
  • Pro I
  • 680 replies
  • July 25, 2024

Hi @RKarunarathne51 ,

  • Creating a Custom Field in the DAC: Introduce a new field to store the system time when the form is saved.

  • Overriding the RowPersisting Event: Utilize the RowPersisting event to record the system time when saving the form for the initial instance.

  • Updating the Field Value: Apply the recorded system time for required calculations and field updates.

    Sample code:
     

     protected void YourDAC_RowPersisting(PXCache cache, PXRowPersistingEventArgs e)
        {
            var row = (YourDAC)e.Row;
            if (row == null) return;
    
            // Check if the record is being inserted
            if ((e.Operation & PXDBOperation.Command) == PXDBOperation.Insert)
            {
                // Capture the current system time
                row.newField = PXTimeZoneInfo.Now;
            }
        }

     


darylbowman
Captain II
Forum|alt.badge.img+13

Acumatica already stores the time when a record is created for most records. It’s called CreatedDateTime.

I’ve seen a couple of your recent questions and they are very general. If you want specific and applicable suggestions, we need some details about what you’re trying to accomplish. There is not a one-size fits all in Acumatica. The basic mechanisms of the platform are somewhat universal, but each screen is unique in how those mechanisms have been combined.


Forum|alt.badge.img

@MichaelShirk ,

I want to retrieve the current UTC (Computer) time. Thank you


andriitkachenko
Jr Varsity I
Forum|alt.badge.img+5

Hi @RKarunarathne51 

var machineTime = DateTime.Now;
var machineTimeUtc = DateTime.UtcNow;
var instanceTime = PXTimeZoneInfo.Now;
var instanceTimeUtc = PXTimeZoneInfo.UtcNow;

Here are multiple options you can use to get the time depending on your use case.

Make sure you understand the difference between server (machine) time and instance (Acumatica) time. It isn’t exactly the same thing (for me they are different most of the time).

I’d also want to stress again what Daryl said before - we are creating Audit fields for that reason in DACs. If you are using your custom DAC, take a look at a standard one (most of Acumatica’s DACs have these audit fields). What you ask sounds exactly like CreatedDateTime.

If you use your custom DAC, I’d urge you to add the full set of audit fields, to avoid stumbling upon issues each time they are required, but not added.


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings