- OCXOED09 ;SLC/RJS,CLA - Rule Editor (Element Expression Display) ;10/29/98 12:37
- ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
- ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- ;
- ;
- S ;
- ;
- Q
- EN(OCXD0,OCXD1,OCXR1) ;
- ;
- N OCXACT,OCXRD
- F K OCXRD,OCXACT S (OCXRD,OCXACT)="" D DISP(OCXD0,OCXD1,.OCXRD,.OCXACT) Q:$$EN^OCXOED10(OCXD0,OCXD1,.OCXRD,.OCXACT)
- ;
- Q
- ;
- DISP(OCXD0,OCXD1,OCXRD,OCXACT) ;
- ;
- N OCXTHLN,OCXTNLN,OCXTRLN,OCXTULN,OCXTNLN,OCXOPER
- ;
- S OCXTNLN=$C(27,91,48,109),OCXTRLN=$C(27,91,55,109),OCXTULN=$C(27,91,52,109),OCXTHLN=$C(27,91,49,109)
- ;
- D GETDATA(OCXD0,OCXD1,.OCXRD)
- ;
- W @IOF,OCXTNLN
- W !,$$CENTER($$FIELD("Element Expression Edit Screen"),80),!!
- I $D(OCXRD("ELE",OCXD0,"C",OCXD1,1,"I")) D
- .W " ",$$OPT^OCXOEDT("DF"_OCXRD("ELE",OCXD0,"C",OCXD1,1,"I"),"EDDF","10",.OCXACT,$G(OCXRD("ELE",OCXD0,"C",OCXD1,1,"I")))
- W " ",$$FIELD("Data Field:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,1,"E")),60)
- W !
- S OCXOPER=$G(OCXRD("ELE",OCXD0,"C",OCXD1,2,"I")) I +OCXOPER S OCXOPER=$P($G(^OCXS(863.9,+OCXOPER,0)),U,4) I $L(OCXOPER) W " ",$$FIELD(" Operator:")," ",$$DATA(OCXOPER,30) I 1
- E W " ",$$FIELD(" Operator:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,2,"E")),30)
- I (+$G(OCXRD("ELE",OCXD0,"C",OCXD1,"PARNUM","I"))=2) D
- .W !
- .I $L($G(OCXRD("ELE",OCXD0,"C",OCXD1,3,"E"))) D Q
- ..W " ",$$FIELD(" Value:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,3,"E")),60)
- .W " ",$$OPT^OCXOEDT("DF"_$G(OCXRD("ELE",OCXD0,"C",OCXD1,4,"I")),"EDDF","10",.OCXACT,$G(OCXRD("ELE",OCXD0,"C",OCXD1,4,"I")))
- .W " ",$$FIELD(" Data Field:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,4,"E")),60)
- I (+$G(OCXRD("ELE",OCXD0,"C",OCXD1,"PARNUM","I"))=3) D
- .W !
- .W !,$$CENTER("AND",80)
- .W !
- .I $L($G(OCXRD("ELE",OCXD0,"C",OCXD1,3.1,"E"))) D Q
- ..W " ",$$FIELD(" Value:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,3.1,"E")),60)
- .W " ",$$OPT^OCXOEDT("DF"_OCXRD("ELE",OCXD0,"C",OCXD1,5,"I"),"EDDF","10",.OCXACT,$G(OCXRD("ELE",OCXD0,"C",OCXD1,5,"I")))
- .W " ",$$FIELD(" Data Field:")," ",$$DATA($G(OCXRD("ELE",OCXD0,"C",OCXD1,5,"E")),60)
- W !!," ",$$OPT^OCXOEDT("Edit","EDEXP","10",.OCXACT,OCXD0_","_OCXD1)
- ;
- Q
- ;
- CENTER(X,M) ;
- N SP S SP="",$P(SP," ",80)=" " Q $E(SP,1,((M\2)-($L(X)\2)))_X
- ;
- SEP(OCXHDR) ;
- ;
- N SPACES S SPACES="",$P(SPACES," ",80-$L(OCXHDR))=" " Q OCXTNLN_OCXTHLN_OCXTULN_$G(OCXHDR)_SPACES_OCXTNLN
- ;
- FIELD(OCXHDR) ;
- ;
- Q OCXTHLN_$G(OCXHDR)_OCXTNLN
- ;
- DATA(OCXVAL,OCXLEN) ;
- ;
- N SPACES S SPACES="",$P(SPACES," ",OCXLEN+5)=" ",OCXVAL=$G(OCXVAL)
- I ($L(OCXVAL)>OCXLEN) Q $E(OCXVAL,1,OCXLEN-3)_"..."
- Q $E((OCXVAL_SPACES),1,OCXLEN)
- ;
- GETDATA(OCXD0,OCXD1,OCXD) ;
- ;
- N OCXDIQ,OCXX,OCXDA,OCXOPER,OCXPF,OCXPFN
- S OCXDIQ="",OCXDA=OCXD0 D DIQ("^OCXS(860.3,",.OCXDA,"IEN",.OCXDIQ)
- M OCXD("ELE")=OCXDIQ(860.3) K OCXDIQ S OCXDIQ=""
- S OCXDIQ="",OCXDA=OCXD1,OCXDA(1)=OCXD0 D DIQ("^OCXS(860.3,"_OCXD0_",""COND"",",.OCXDA,"IEN",.OCXDIQ)
- M OCXD("ELE",OCXD0,"C")=OCXDIQ(860.31) K OCXDIQ S OCXDIQ=""
- S OCXD("ELE",OCXD0,"C",OCXD1,"PARNUM","I")=$$PARNUM(+$G(OCXD("ELE",OCXD0,"C",OCXD1,2,"I")))
- Q
- PARNUM(OCXOPER) ;
- ;
- N OCXPF,OCXPFN
- S OCXPF=$O(^OCXS(863.9,+OCXOPER,"PAR","B","OCXO GENERATE CODE FUNCTION",0)) Q:'OCXPF 0
- S OCXPF=$G(^OCXS(863.9,+OCXOPER,"PAR",+OCXPF,"VAL"))
- Q:'$L(OCXPF) 0
- I OCXPF S OCXPFN=OCXPF
- E S OCXPFN=0 F S OCXPFN=$O(^OCXS(863.7,"B",$E(OCXPF,1,30),OCXPFN)) Q:'OCXPFN Q:($P($G(^OCXS(863.7,+OCXPFN,0)),U,1)=OCXPF)
- Q:'OCXPFN 0 Q +$O(^OCXS(863.7,+OCXPFN,"PAR",999),-1)
- ;
- DIC(OCXDIC,OCXDIC0,OCXDICA,OCXX,OCXDICS,OCXDR) ;
- ;
- N DIC,X,Y
- S DIC=$G(OCXDIC) Q:'$L(DIC) -1
- S DIC(0)=$G(OCXDIC0) S:$L($G(OCXX)) X=OCXX
- S:$L($G(OCXDICS)) DIC("S")=OCXDICS
- S:$L($G(OCXDICA)) DIC("A")=OCXDICA
- S:$L($G(OCXDR)) DIC("DR")=OCXDR
- D ^DIC Q:(Y<1) 0 Q Y
- ;
- DIQ(DIC,DA,OCXDIQ0,OCXARY) ;
- N DR,DIQ S DR=".01:99999",DIQ="OCXARY(",DIQ(0)=$G(OCXDIQ0) D EN^DIQ1
- Q
- ;
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HOCXOED09 3977 printed Mar 13, 2025@21:30:20 Page 2
- OCXOED09 ;SLC/RJS,CLA - Rule Editor (Element Expression Display) ;10/29/98 12:37
- +1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
- +2 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
- +3 ;
- +4 ;
- S ;
- +1 ;
- +2 QUIT
- EN(OCXD0,OCXD1,OCXR1) ;
- +1 ;
- +2 NEW OCXACT,OCXRD
- +3 FOR
- KILL OCXRD,OCXACT
- SET (OCXRD,OCXACT)=""
- DO DISP(OCXD0,OCXD1,.OCXRD,.OCXACT)
- if $$EN^OCXOED10(OCXD0,OCXD1,.OCXRD,.OCXACT)
- QUIT
- +4 ;
- +5 QUIT
- +6 ;
- DISP(OCXD0,OCXD1,OCXRD,OCXACT) ;
- +1 ;
- +2 NEW OCXTHLN,OCXTNLN,OCXTRLN,OCXTULN,OCXTNLN,OCXOPER
- +3 ;
- +4 SET OCXTNLN=$CHAR(27,91,48,109)
- SET OCXTRLN=$CHAR(27,91,55,109)
- SET OCXTULN=$CHAR(27,91,52,109)
- SET OCXTHLN=$CHAR(27,91,49,109)
- +5 ;
- +6 DO GETDATA(OCXD0,OCXD1,.OCXRD)
- +7 ;
- +8 WRITE @IOF,OCXTNLN
- +9 WRITE !,$$CENTER($$FIELD("Element Expression Edit Screen"),80),!!
- +10 IF $DATA(OCXRD("ELE",OCXD0,"C",OCXD1,1,"I"))
- Begin DoDot:1
- +11 WRITE " ",$$OPT^OCXOEDT("DF"_OCXRD("ELE",OCXD0,"C",OCXD1,1,"I"),"EDDF","10",.OCXACT,$GET(OCXRD("ELE",OCXD0,"C",OCXD1,1,"I")))
- End DoDot:1
- +12 WRITE " ",$$FIELD("Data Field:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,1,"E")),60)
- +13 WRITE !
- +14 SET OCXOPER=$GET(OCXRD("ELE",OCXD0,"C",OCXD1,2,"I"))
- IF +OCXOPER
- SET OCXOPER=$PIECE($GET(^OCXS(863.9,+OCXOPER,0)),U,4)
- IF $LENGTH(OCXOPER)
- WRITE " ",$$FIELD(" Operator:")," ",$$DATA(OCXOPER,30)
- IF 1
- +15 IF '$TEST
- WRITE " ",$$FIELD(" Operator:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,2,"E")),30)
- +16 IF (+$GET(OCXRD("ELE",OCXD0,"C",OCXD1,"PARNUM","I"))=2)
- Begin DoDot:1
- +17 WRITE !
- +18 IF $LENGTH($GET(OCXRD("ELE",OCXD0,"C",OCXD1,3,"E")))
- Begin DoDot:2
- +19 WRITE " ",$$FIELD(" Value:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,3,"E")),60)
- End DoDot:2
- QUIT
- +20 WRITE " ",$$OPT^OCXOEDT("DF"_$GET(OCXRD("ELE",OCXD0,"C",OCXD1,4,"I")),"EDDF","10",.OCXACT,$GET(OCXRD("ELE",OCXD0,"C",OCXD1,4,"I")))
- +21 WRITE " ",$$FIELD(" Data Field:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,4,"E")),60)
- End DoDot:1
- +22 IF (+$GET(OCXRD("ELE",OCXD0,"C",OCXD1,"PARNUM","I"))=3)
- Begin DoDot:1
- +23 WRITE !
- +24 WRITE !,$$CENTER("AND",80)
- +25 WRITE !
- +26 IF $LENGTH($GET(OCXRD("ELE",OCXD0,"C",OCXD1,3.1,"E")))
- Begin DoDot:2
- +27 WRITE " ",$$FIELD(" Value:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,3.1,"E")),60)
- End DoDot:2
- QUIT
- +28 WRITE " ",$$OPT^OCXOEDT("DF"_OCXRD("ELE",OCXD0,"C",OCXD1,5,"I"),"EDDF","10",.OCXACT,$GET(OCXRD("ELE",OCXD0,"C",OCXD1,5,"I")))
- +29 WRITE " ",$$FIELD(" Data Field:")," ",$$DATA($GET(OCXRD("ELE",OCXD0,"C",OCXD1,5,"E")),60)
- End DoDot:1
- +30 WRITE !!," ",$$OPT^OCXOEDT("Edit","EDEXP","10",.OCXACT,OCXD0_","_OCXD1)
- +31 ;
- +32 QUIT
- +33 ;
- CENTER(X,M) ;
- +1 NEW SP
- SET SP=""
- SET $PIECE(SP," ",80)=" "
- QUIT $EXTRACT(SP,1,((M\2)-($LENGTH(X)\2)))_X
- +2 ;
- SEP(OCXHDR) ;
- +1 ;
- +2 NEW SPACES
- SET SPACES=""
- SET $PIECE(SPACES," ",80-$LENGTH(OCXHDR))=" "
- QUIT OCXTNLN_OCXTHLN_OCXTULN_$GET(OCXHDR)_SPACES_OCXTNLN
- +3 ;
- FIELD(OCXHDR) ;
- +1 ;
- +2 QUIT OCXTHLN_$GET(OCXHDR)_OCXTNLN
- +3 ;
- DATA(OCXVAL,OCXLEN) ;
- +1 ;
- +2 NEW SPACES
- SET SPACES=""
- SET $PIECE(SPACES," ",OCXLEN+5)=" "
- SET OCXVAL=$GET(OCXVAL)
- +3 IF ($LENGTH(OCXVAL)>OCXLEN)
- QUIT $EXTRACT(OCXVAL,1,OCXLEN-3)_"..."
- +4 QUIT $EXTRACT((OCXVAL_SPACES),1,OCXLEN)
- +5 ;
- GETDATA(OCXD0,OCXD1,OCXD) ;
- +1 ;
- +2 NEW OCXDIQ,OCXX,OCXDA,OCXOPER,OCXPF,OCXPFN
- +3 SET OCXDIQ=""
- SET OCXDA=OCXD0
- DO DIQ("^OCXS(860.3,",.OCXDA,"IEN",.OCXDIQ)
- +4 MERGE OCXD("ELE")=OCXDIQ(860.3)
- KILL OCXDIQ
- SET OCXDIQ=""
- +5 SET OCXDIQ=""
- SET OCXDA=OCXD1
- SET OCXDA(1)=OCXD0
- DO DIQ("^OCXS(860.3,"_OCXD0_",""COND"",",.OCXDA,"IEN",.OCXDIQ)
- +6 MERGE OCXD("ELE",OCXD0,"C")=OCXDIQ(860.31)
- KILL OCXDIQ
- SET OCXDIQ=""
- +7 SET OCXD("ELE",OCXD0,"C",OCXD1,"PARNUM","I")=$$PARNUM(+$GET(OCXD("ELE",OCXD0,"C",OCXD1,2,"I")))
- +8 QUIT
- PARNUM(OCXOPER) ;
- +1 ;
- +2 NEW OCXPF,OCXPFN
- +3 SET OCXPF=$ORDER(^OCXS(863.9,+OCXOPER,"PAR","B","OCXO GENERATE CODE FUNCTION",0))
- if 'OCXPF
- QUIT 0
- +4 SET OCXPF=$GET(^OCXS(863.9,+OCXOPER,"PAR",+OCXPF,"VAL"))
- +5 if '$LENGTH(OCXPF)
- QUIT 0
- +6 IF OCXPF
- SET OCXPFN=OCXPF
- +7 IF '$TEST
- SET OCXPFN=0
- FOR
- SET OCXPFN=$ORDER(^OCXS(863.7,"B",$EXTRACT(OCXPF,1,30),OCXPFN))
- if 'OCXPFN
- QUIT
- if ($PIECE($GET(^OCXS(863.7,+OCXPFN,0)),U,1)=OCXPF)
- QUIT
- +8 if 'OCXPFN
- QUIT 0
- QUIT +$ORDER(^OCXS(863.7,+OCXPFN,"PAR",999),-1)
- +9 ;
- DIC(OCXDIC,OCXDIC0,OCXDICA,OCXX,OCXDICS,OCXDR) ;
- +1 ;
- +2 NEW DIC,X,Y
- +3 SET DIC=$GET(OCXDIC)
- if '$LENGTH(DIC)
- QUIT -1
- +4 SET DIC(0)=$GET(OCXDIC0)
- if $LENGTH($GET(OCXX))
- SET X=OCXX
- +5 if $LENGTH($GET(OCXDICS))
- SET DIC("S")=OCXDICS
- +6 if $LENGTH($GET(OCXDICA))
- SET DIC("A")=OCXDICA
- +7 if $LENGTH($GET(OCXDR))
- SET DIC("DR")=OCXDR
- +8 DO ^DIC
- if (Y<1)
- QUIT 0
- QUIT Y
- +9 ;
- DIQ(DIC,DA,OCXDIQ0,OCXARY) ;
- +1 NEW DR,DIQ
- SET DR=".01:99999"
- SET DIQ="OCXARY("
- SET DIQ(0)=$GET(OCXDIQ0)
- DO EN^DIQ1
- +2 QUIT
- +3 ;