| T.R | Title | User | Personal Name
 | Date | Lines | 
|---|
| 383.1 | Use a SCRIPT script with a {TAB} in it | SHALOT::WARFORD | Richard Warford @OPA DTN 393-7495 | Wed Apr 01 1992 04:02 | 12 | 
|  |     No things haven't changed. You still cannot really use the OA$FLD_xxx
    functions in /PRE_FUNCTION and I thought /POST_FUNCTIONs reliably. It
    will almost always result in ALL-IN-1 getting confused about something.
    
    The only real alternative is to issue a SCRIPT script command inside
    the /PRE_FUNCTION. The script called would have a single {TAB} in it.
    So when it got time to do data entry on the field, it would act
    just like a user had pressed the tab key to skip the field. Of course
    you then have to make sure that your validation, if present, handles
    leaving the field blank - which is a trick in and of itself!
    
    Rick
 | 
| 383.2 | What problems? | UTRTSC::BOSMAN | We're just sugar mice in the rain | Wed Apr 01 1992 07:48 | 20 | 
|  |     Hi,
    
    Well, I've made many applications using OA$FLD_PREV and OA$FLD_NEXT to
    skip a particular field and never, ever had problems with that.
    
    But, ofcourse, if it is officialy stated that it could cause problems
    who I'm I to say that it couldn't give problems in another situation.
    
    Sjaak.
    
    prototype:
    
    ;;SPECIFIC_FIELD;;
    
    /PRE_FUNCTION = '
     .IF {key-pressed} EQS "TAB" AND {condition} THEN OA$FLD_NEXT \
     .IF {key-pressed} EQS "BS"  AND {condition} THEN OA$FLD_PREV '
    
    Or something like this. Unfortunatly I don't have a working example on
    this system right now.
 | 
| 383.3 | Plug for OA$VAL_INVALID | AERO::TALLETT | Just one more fix, then we can ship... | Wed Apr 01 1992 08:41 | 14 | 
|  |     
    	I have done it too and found I needed a new function OA$VAL_INVALID
    	to set a field invalid after ALL-IN-1 had validated it. So I put
    	the function in V3.0 (an advantage of working in engineering!).
    	If you don't use this function, then you can screw up the
    	validation by backspacing and entering.
    
    	There is also a problem with empty field validation. If you allow
    	an empty field at any time, then you need /OPTIONAL, but with
    	that, your validation won't get called if its blank, so you have
    	to ALWAYS allow blank.
    
    Regards,
    Paul
 | 
| 383.4 | Since you guys brought it up... | HOTAIR::MADDOX | DIGITAL Alien | Wed Apr 01 1992 18:34 | 28 | 
|  | Okay,
Are you guys telepathic, or what?
Rick and Paul both mentioned another problem I have (unrelated to .0 I
thought).  Can I use /VALID to test whether I want a field left blank or
not?  Paul, I presume your OA$VAL_SET_INVALID function would do the trick
but I don't have 3.0 yet.
I'm aware, as Paul mentioned, that if I put a /OPTIONAL on the field my 
/VALID will not be executed if the field is left blank and if I don't put
a /OPTIONAL the user can never leave the field blank in spite of my /VALID
qualifier.  Is there some trick I don't know?
My current approach is to put a /POST form qualifier on the form and test
all the various conditions which I can't test with /VALID field qualifiers
and do a FORM ./BEGIN=field if a field is blank which shouldn't be, but this
is very cumbersome.
Re: .2
I have used the /PRE='.IF condition THEN OA$FLD_NEXT' succesfully as well, 
but if the field to which I am OA$FLD_NEXTing to has a /PRE on it it is not
invoked.
Thanks,
Joe
 | 
| 383.5 | No, I don't know either | AERO::TALLETT | Just one more fix, then we can ship... | Wed Apr 01 1992 19:12 | 11 | 
|  |     
    	After doing this sort of thing several times, I reached the
    	conclusion that you should avoid using /PRE and /POST for
    	field validation as it is VERY hard to get the desired effect.
    	Spend the time trying to get /VALID to do the job.
    
    	Having said that, I never did figure out how to get around the
    	/OPTIONAL stuff without using /PRE and /POST.
    
    Regards,
    Paul
 | 
| 383.6 | Sure it can be done...carefully | TRCOA::HALSEY | I'd rather be sailing! | Thu Apr 30 1992 23:13 | 23 | 
|  |     Sorry for the late response, but as mentioned in other notes, I'm
    catching up.
    
    I tackled a similiar sort of problem before.  I had to bounce to one
    of several fields depending on what value was being given from
    somewhere else.
    
    If you execute your OA$FLD_STAY with a GET OA$FUNction, then you can
    provide a variable value (provided by your calling script?) for the
    field name.  Immediately after that call though, still in the /PRE
    code, call a miniature little SCRIPT script (as mentioned in .1),
    with the difference that it does a {TAB}{BS}.  This bounces you into
    the field officially, and execute the appropriate /PRE code.
    
    There will likely be a few more complications that are presented here,
    but this is a working basis.
    
    /PRE='GET OA$FUN="OA$FLD_STAY " #FLDNAME "\SCRIPT DOATABBS"'
    
    It may be late, but I hope it helps anyway.
    
    Bob Halsey, Toronto SWS
    
 |