Testing a due date from the Global Trigger after open
I want to test for a table (jobDockets) for any occurance where the dispatch date (DispatchBy) is due within 2 days of today upon opening the database at the start of each day. Thus if I put the following into the "Trigger after open" in global options i would have expected it to work but it does nothing!
if (select JobDockets).DispatchBy = today() + 2 then
alert("WARNING - SOME PROMISED JOBS ARE FALLING DUE FOR DISPATCH")
end
also tried now() command etc...
Yet if i ignore the ref to the table etc (JobDockets) and do a simple test of the alert on its own
if today() then alert ("TEST") - this works
so I know the global does handle alerts
Any suggestions Please ?
16 replies
-
Arrgh..... sorted it myself
being stupid- got this omplety wrong - Pleaase ignore me
I need .... select JobDockets where = DispatchBy = today() + 2 etc.... ;
-
Nope .. I'm making a pigs ear of this..
the following is what I am trying to achieve ... in Global Trigger
select JobDockets where DispatchBy = today() + 2;
sendEmail({
from: "mel@testemail.co.uk",
to: "mel2@TestemailJobs.co.uk",
subject: "Promised jobs are soon due for dispatch",
text: "Promised",
html: "REMINDER - Some promised jobs will soon be due be dispatched"
})It works and sends the email if the 1st line is true, but still send sthe email even if it is false.
I can see why cos send is simply following on from the first line.
However I have tried to wrap it all in an if then else but ninox is not playing ball
how can i stop the email from firing if the select where is false ?
-
also tried
if (select JobDockets).DispatchBy = today() + 2 then
etc etc
but this is ignored completely ?
-
Ninox changed the above script wher i had the brackets so should have read like this
if (select JobDockets.DispatchBy = today() + 2) then etc
even so script is still ignored
-
Hi Mel
A select will always return an array, unless it is wrapped in an aggregate function, so your if statement would work better like this
if cnt(select JobDockets where DispatchBy = today() + 2) > 0
Regards John
-
Hi John
Okay that makes sense thank you.
I have tried your line but it still ignored thus i tge case of this test below no alert pops up
if cnt(select JobDockets where DispatchBy = now()+ 2) > 0 then
alert("Sending Email")
endBearing in mind I am setting this up in the global trigger..
I can't see if any value is being picked up :-)
Testing just the alert on its own works
in essense as long as any jockdocket has a dispatch date that is 2 days away from today I want the alert to fire (using alert for testing but will actually finally uase the SendEmail to my dispatch guy)
just can't get it to work as it either ignores the test and fites every time or as in tha cse of last test stops working
-
Hi Mel
Not sure why you swapped today() for now(). now()+2 does not add two days to it's value and comparing a date and a timestamp will always return false. Revert back to today() and you should start to get somewhere.
Regards John
-
Hi John
Sorry tested a variation and copied the wrong one to above.
Thank you but even with your suggestion - I'm still stuck...- If i put this script onto a button directly on the form the alert fires (but it appears to ignoring the dispatch date as assumes everthing is true. so not good! i Can null date fields and it still fires!
format(DispatchBy, "DDMMYY") = format(today() + 2, "DDMMYY");
if cnt(DispatchBy = today() + 2) then
alert("Sending Email")
endalso tried adding in line 1 re format to see if that helps but it don't
However - I don't want this on a button on a form I want it to work from GLOBAL scripts on logging in
Hence the need for the "select" to go find job Dockets table and gather the info
if cnt(select JobDockets where DispatchBy = today() + 2) > 0 then
alert("Sending Email")
endBut this is not doing anything - ie just refuses work? :-(
All it has to do is check to see if ANY job has a dispatchby date due in 2 days time and if so alert (once working I will change alert to sendEmail.)
-
Have you already tried to make a variable of the date first?:
let d := today() + 2
if cnt(select JobDockets where DispatchBy = d) > 0 then
alert("Sending Email")
endor with square brackets...
if cnt(select JobDockets [DispatchBy = today() + 2]) > 0 then
alert("Sending Email")
endSteven
-
Hi Mel
After a while playing in the console I have found that date > today() works and date < today() works but date = today() does not. I have also found that, as Steven has said, storing today() into a variable first does work. I have also tested this in a Trigger after open: script
let a := today() + 1;
let b := cnt(select Routines where 'Next Case' = a);
if b > 0 then alert(b) endRegards John
-
Hi Steve
Both of your suggested methods WORK !!!
albeit the second seems slower to perform
so going with the first option
Thank you both John/Steven for the hlep on this:-)
-
Yes John I was finding that some time I could trigger and not others when testing greater than - less than and equals
In the end i tried so many variations that i got tottally confused ! ha ha
I also could get it to trigger every time on a button on table form.
-
Okay - so ther is an obvious flaw in my logic
in loggin in today (Monday) then the promised date check is 2 days awy (wednesday) great
that is until I get to thursday or friday when it will try to check saturday and sunday (when we are closed)
to make matters worse I woukd need to log in on the wekkend to check promise dates on Monday and Tues
so all in all - I did not think this through very well!
So i am guessing that somehow I need to build in some kind of test to trap the weekday or weekdayindex function
which I think monday is 0 and Sunday is 6 so i have to test and omit day 5 & 6 out fof my logic
am i on the right track or is there a better way to do this?
-
I can't seem to get global scripts to accept weekday without an error
so had a thought and decided that what if I set the code out aas follows!
let d := today() + 2;
let e := today() + 3;
let f := today() + 4;
if cnt(select JobDockets where DispatchBy = d) > 0 then
alert("Sending Email") or
if cnt(select JobDockets where DispatchBy = e) > 0 then
alert("Sending Email") or
if cnt(select JobDockets where DispatchBy = f) > 0 then
alert("Sending Email")
endI'm sure there is a better way of scripting this but .... Ninox accepts this
the when the script runs after loggin in.. if today is 21st it will look for the first occurance of the promisedby date of 25th (d) or 26th(e) or 27th(f)
However - When I run the script it actually only finds the first if statement works the last two are ignored.
if i make e first it works and same for f.
I'm not sure how to tackle this now without help.
for clarity i want to do one of either
Option 1 - Login today and test promisedby date in 2 days time
when logging in on either on Thursday or Friday - skip the weekend (hence change variable d from 2 days to 3 or 4 days so it moved to Monday/Tues promisedby date.
Option 2 - Login and test what day it is ie Monday test for promisedby date due on Wednesday (2 days ahead)
However avoid weekend so thursday must test following Monday and Friday must test following tues
in all cases the script olny need to find the first occurance of a promisedby date that is valid to trigger the alert message or a sendMail message
err help please :-)
-
Something like:
let d := if weekday(today()) = 3 then
today() + 4
else
if weekday(today()) = 4 then today() + 4 else today() + 2 end
end;
if cnt(select JobDockets where DispatchBy = d) > 0 then
alert("Sending Email")
end -
Steven/John
Applogies for late reply but I wanted to test logging in a few days to ensure that above skips the weekend to look for mon/tues promise dispatchby dates.
WORKS PERFECTLY - Thank you!
Really appreciated :-)
Content aside
- 3 yrs agoLast active
- 16Replies
- 866Views