Tap Forms – Organizer Database App for Mac, iPhone, and iPad › Forums › Using Tap Forms › Simple previous
- This topic has 8 replies, 3 voices, and was last updated 1 year, 8 months ago by Daniel Leu.
-
AuthorPosts
-
March 4, 2023 at 3:09 PM #49082
Glen ForisterParticipantI’ve applied your “previous_field” script to several Forms and been quite successful, but this is about as simple as you can get and I can’t figure out what I’ve missed. See attached.
Also, does it matter where the script is used: 1) the script in the field window or 2) the script in the Script tab? Is there any difference between the two in the code?
Attachments:
You must be logged in to view attached files.March 4, 2023 at 9:31 PM #49084
Daniel LeuParticipant1) There is a missing closing curly bracket after
return 0;
.2) This script is a field script and not a form script.
- This reply was modified 1 year, 8 months ago by Daniel Leu.
- This reply was modified 1 year, 8 months ago by Daniel Leu.
March 5, 2023 at 11:13 AM #49087
Glen ForisterParticipantThanks.
That closing bracket did allow it to run.Unfortunately, it returns NaN every record.
I checked and changed $/grp from currency to a number with 2 decimal places and the result is the same.
I checked and made sure all 4 number fields were formatted = number (either 0 or 2 decimal places).Not sure what I’ve forgotten now. See attached.
Attachments:
You must be logged in to view attached files.March 5, 2023 at 8:24 PM #49089
Daniel LeuParticipantI would add
console.log($_dwr);
to see whereNaN
might originate.- This reply was modified 1 year, 8 months ago by Daniel Leu.
March 6, 2023 at 1:08 AM #49092
BrendanKeymasterThe Number Formatter setting you use on your Number fields will make no difference to your script. Tap Forms just sees those values as raw numbers without formatting anyway when being processed in a script.
You are missing a semi-colon at the end of your console.log statement though. Not that that would cause the NaN error.
Does your
$/grp
field return a valid number from its calculation? Is its formula set to return a Number result type?March 6, 2023 at 12:33 PM #49094
Glen ForisterParticipantI played with the script with different changes and it appears I think that,
“Tot$/dwr: ReferenceError: Can’t find variable: previousRecord_total, line:(null)”This is past my diagnostic ability now, so I’ll attach the archive to save us both a lot of time possibly.
Thanks.PS, I think I’m almost done getting my life back on track with functioning forms again after moving from HanDBase to TF. Now, I’ll try to researching JavaScript to see if I can get a handle on the basics which the preliminary videos and files just hinted at. Too much to learn quickly.
Attachments:
You must be logged in to view attached files.March 6, 2023 at 1:34 PM #49097
Daniel LeuParticipantI don’t really understand what you would like to calculate. But here are my 2 cents:
You get the error:
> “Tot$/dwr: ReferenceError: Can’t find variable: previousRecord_total, line:(null)”
because the variable previousRecord_total is not defined. It should bepreviousTotal
and the statement should be a line lower.> var previous_total = previousRecord.getFieldValue($_grp);`
getFieldValue() needs a field id and not a value.For the previous calculation, the field id is the id of the script. You can get it from the form inspector panel > field > select field and look for the ID under the description section.
I would change as well how the first initial value for
currentRecordIndex == 0
is handled:var previous_total = 0; if (currentRecordIndex > 0) { var previousRecord = records[currentRecordIndex-1]; previous_total = previousRecord.getFieldValue(totalId); }
Now
previous_total
is initialized to 0. If there is an earlier record, it is set accordingly.With these changes, my field script now looks like this:
function Add_Previous() { var $_dwr = record.getFieldValue('fld-c1faad7124f8400bbf9e55c477b101ef'); var $_grp = record.getFieldValue('fld-72156bcc2515453d80a4649d30cb938f'); var totalId = 'fld-9bc44cd8a52547fcab897dbfa04afcc2'; var records = form.getRecords(); // calls function getRecords() var currentRecordIndex = records.indexOf(record); var previous_total = 0; if (currentRecordIndex > 0) { var previousRecord = records[currentRecordIndex-1]; previous_total = previousRecord.getFieldValue(totalId); } console.log("dwr: " + $_dwr); console.log("grp: " + $_grp); console.log("previous total: " + previous_total); var total = $_dwr + previous_total; console.log("Total: " + total); return total; } Add_Previous();
Hope this helps!
March 6, 2023 at 2:36 PM #49099
Glen ForisterParticipantYes! You got it right, that is perfect.
Thanks. I’ll study this.March 6, 2023 at 3:52 PM #49101
Daniel LeuParticipantGreat!
-
AuthorPosts
You must be logged in to reply to this topic.