Automatic Calculating an end date based on new records
I'm quite new in Ninox and have a question on how to let Ninox calculate an end-date based on newly added records in a table
I have created a trigger whenever I change the status of a cow to add a record in a table which need to keep track of the status of the cow (Pregnant, Sick, etc).
I have now 3 columns: Date, Name Cow and New Status. All are takes from the action of changing the status of the cow in the Cow table.
Is there a way of adding a formula field as 'End Date' which can find the first earlier date of the same cow in that table and take this date as End date?
For example:
Date Name Cow New Status End Date
07-01-2024 Alisha Pregnant ?
07-22-2024 Alisha Normal ?
I want to let the End date column to be populated now by '07-22-2024'.
If it cannot find a next date it can show 'N/A' or something and if it can find a next available date, I needs to show this date.
Is there a way to accomplish this? Any help would be welcome.
2 replies
-
Hi,
You can achive this directly from the trigger by modifing your code as below:
let i := this; let previousStatus := last(select 'History of Status' where 'Cow table' = i); (create 'History of Status').( Date := today(); 'Name Cow' := i.Name; 'New Status' := text(i.Status); 'Cow table' := i ); previousStatus.('End Date' := today())
In the above code it is supposed that the 'table' you mentioned is a subtable of the Cow table (named 'History of Status').
Can you please share with us the code you use inside the trigger after update field in order to make the changes directly there?
Content aside
- Status Answered
- 1 mth agoLast active
- 2Replies
- 45Views
-
2
Following