OCXODSP1 ;SLC/RJS,CLA - Rule Display (Display a Rule) ;3/26/01 15:03
;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,105**;Dec 17,1997
;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
;
EN(OCXD0,OCXTAB,OCXRM) ;
;
N OCXD1,OCXD,OCXRD,OCXE,OCXSUB
;
S OCXTAB=+$G(OCXTAB) S:'$G(OCXD0) OCXD0=+$$DIC("^OCXS(860.2,","AEMQ") Q:'OCXD0
;
S OCXRD="" D DIQ("^OCXS(860.2,",OCXD0,.OCXRD)
F OCXSUB="C","R" S OCXD1=0 F S OCXD1=$O(^OCXS(860.2,OCXD0,OCXSUB,OCXD1)) Q:'OCXD1 D
.S OCXD(0)=OCXD0,OCXD=OCXD1 D DIQ("^OCXS(860.2,"_OCXD0_","""_OCXSUB_""",",.OCXD,.OCXRD)
;
W !
W ! D FIELD("Rule:",$G(OCXRD(860.2,OCXD0,.01,"E"))_" ("_$G(OCXRD(860.2,OCXD0,.02,"E"),"ACTIVE")_" Status)",OCXTAB,OCXRM)
;
S OCXD1=0 F S OCXD1=$O(OCXRD(860.21,OCXD1)) Q:'OCXD1 D
.N OUTSTR,OCXE
.W !
.W ! D FIELD("Rule Element Label:",$G(OCXRD(860.21,OCXD1,.01,"E")),OCXTAB,OCXRM)
.I $G(OCXRD(860.21,OCXD1,.02,"I")) D Q
..W ! D FIELD(" Expression:",$G(OCXRD(860.21,OCXD1,2,"E")),OCXTAB,OCXRM)
..I ($G(OCXRD(860.21,OCXD1,2,"E"))["|") D
...N PTR,EXPVAL,DFLD
...S EXPVAL=$G(OCXRD(860.21,OCXD1,2,"E")) F PTR=2:2:$L(EXPVAL,"|") S DFLD=$P(EXPVAL,"|",PTR) D GETDF(DFLD)
.;
.S OUTSTR=$G(OCXRD(860.21,OCXD1,1,"E"))
.W ! D FIELD(" Element:",OUTSTR,OCXTAB,OCXRM)
.S OCXE=+$G(OCXRD(860.21,OCXD1,1,"I")) I +OCXE D EN^OCXODSP2(OCXE,OCXTAB+OCXOFF,OCXRM)
;
S OCXD1=0 F S OCXD1=$O(OCXRD(860.22,OCXD1)) Q:'OCXD1 D
.N EXPVAL,DFLD,PTR S DFLD=""
.W !
.W ! D FIELD("Relation Expression:",$G(OCXRD(860.22,OCXD1,1,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,2,"E")) W ! D FIELD(" Order Check:",$G(OCXRD(860.22,OCXD1,2,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,3,"E")) W ! D FIELD(" Notification:",$G(OCXRD(860.22,OCXD1,3,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,4,"E")) W ! D FIELD(" Report Device:",$G(OCXRD(860.22,OCXD1,4,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,5,"E")) W ! D FIELD(" Notification Message:",$G(OCXRD(860.22,OCXD1,5,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,6,"E")) W ! D FIELD(" Order Check Message:",$G(OCXRD(860.22,OCXD1,6,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,7,"E")) W ! D FIELD(" Schedule Action:",$G(OCXRD(860.22,OCXD1,7,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,8,"E")) W ! D FIELD(" Schedule Frequency:",$G(OCXRD(860.22,OCXD1,8,"E")),OCXTAB,OCXRM)
.I $D(OCXRD(860.22,OCXD1,9,"E")) W ! D FIELD(" Execute Code:",$G(OCXRD(860.22,OCXD1,9,"E")),OCXTAB,OCXRM)
.I ($G(OCXRD(860.22,OCXD1,5,"E"))["|") S EXPVAL=$G(OCXRD(860.22,OCXD1,5,"E")) F PTR=2:2:$L(EXPVAL,"|") S DFLD=$P(EXPVAL,"|",PTR) S:$L(DFLD) DFLD(DFLD)=""
.I ($G(OCXRD(860.22,OCXD1,6,"E"))["|") S EXPVAL=$G(OCXRD(860.22,OCXD1,6,"E")) F PTR=2:2:$L(EXPVAL,"|") S DFLD=$P(EXPVAL,"|",PTR) S:$L(DFLD) DFLD(DFLD)=""
.S DFLD="" F S DFLD=$O(DFLD(DFLD)) Q:'$L(DFLD) D GETDF(DFLD)
;
Q
;
;
GETDF(DFLD) ;
;
N DFLDN,DCONT,DELEM,DELEMN
I (DFLD[".") D Q
.S DELEM=$P(DFLD,".",1),DFLD=$P(DFLD,".",2)
.S DFLDN=$O(^OCXS(860.4,"C",DFLD,0))
.I 'DFLDN S DFLDN=0 F S DFLDN=$O(^OCXS(860.4,"B",$E(DFLD,1,30),DFLDN)) Q:'DFLDN Q:($P(^OCXS(860.4,DFLDN,0),U,1)=DFLD)
.S DELEMN=0 F S DELEMN=$O(OCXRD(860.21,DELEMN)) Q:'DELEMN Q:(OCXRD(860.21,DELEMN,.01,"E")=DELEM)
.Q:'DELEMN S DELEM=+$G(OCXRD(860.21,DELEMN,1,"I")) Q:'DELEM
.S DCONT=+$P($G(^OCXS(860.3,DELEM,0)),U,2) Q:'DCONT
.D EN^OCXODSP3(DFLDN,OCXTAB+OCXOFF,OCXRM,DCONT)
;
I '(DFLD[".") D
.S DFLDN=$O(^OCXS(860.4,"C",DFLD,0))
.I 'DFLDN S DFLDN=0 F S DFLDN=$O(^OCXS(860.4,"B",$E(DFLD,1,30),DFLDN)) Q:'DFLDN Q:($P(^OCXS(860.4,DFLDN,0),U,1)=DFLD)
.S DELEMN=0 F S DELEMN=$O(OCXRD(860.21,DELEMN)) Q:'DELEMN D
..S DELEM=+$G(OCXRD(860.21,DELEMN,1,"I")) Q:'DELEM
..S DCONT=+$P($G(^OCXS(860.3,DELEM,0)),U,2) Q:'DCONT
..S DCONT(DCONT)=""
.S DCONT=0 F S DCONT=$O(DCONT(DCONT)) Q:'DCONT D EN^OCXODSP3(DFLDN,OCXTAB+OCXOFF,OCXRM,DCONT)
;
Q
;
FIELD(TITLE,STRING,TAB,MARGIN) ;
;
W ?TAB,TITLE
;
N PTR,SUBSTR,STRLEN
;
S STRLEN=MARGIN-($L(TITLE)+TAB)-5
S SUBSTR="" F PTR=1:1:$L(STRING," ") D
.I ($L(SUBSTR)>STRLEN) W ?(TAB+$L(TITLE)+1),SUBSTR W:$L($P(STRING," ",PTR+1)) ! S SUBSTR=""
.S:$L(SUBSTR) SUBSTR=SUBSTR_" " S SUBSTR=SUBSTR_$P(STRING," ",PTR)
W:$L(SUBSTR) ?(TAB+$L(TITLE)+1),SUBSTR
Q
;
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,OCXARY) ;
;
N DR,DIQ S DR=".01:99999",DIQ="OCXARY(",DIQ(0)="IEN" D EN^DIQ1
Q
;
OCXODSP1 ;SLC/RJS,CLA - Rule Display (Display a Rule) ;3/26/01 15:03
+1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**32,105**;Dec 17,1997
+2 ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
+3 ;
EN(OCXD0,OCXTAB,OCXRM) ;
+1 ;
+2 NEW OCXD1,OCXD,OCXRD,OCXE,OCXSUB
+3 ;
+4 SET OCXTAB=+$GET(OCXTAB)
IF '$GET(OCXD0)
SET OCXD0=+$$DIC("^OCXS(860.2,","AEMQ")
IF 'OCXD0
QUIT
+5 ;
+6 SET OCXRD=""
DO DIQ("^OCXS(860.2,",OCXD0,.OCXRD)
+7 FOR OCXSUB="C","R"
SET OCXD1=0
FOR
SET OCXD1=$ORDER(^OCXS(860.2,OCXD0,OCXSUB,OCXD1))
IF 'OCXD1
QUIT
Begin DoDot:1
+8 SET OCXD(0)=OCXD0
SET OCXD=OCXD1
DO DIQ("^OCXS(860.2,"_OCXD0_","""_OCXSUB_""",",.OCXD,.OCXRD)
End DoDot:1
+9 ;
+10 WRITE !
+11 WRITE !
DO FIELD("Rule:",$GET(OCXRD(860.2,OCXD0,.01,"E"))_" ("_$GET(OCXRD(860.2,OCXD0,.02,"E"),"ACTIVE")_" Status)",OCXTAB,OCXRM)
+12 ;
+13 SET OCXD1=0
FOR
SET OCXD1=$ORDER(OCXRD(860.21,OCXD1))
IF 'OCXD1
QUIT
Begin DoDot:1
+14 NEW OUTSTR,OCXE
+15 WRITE !
+16 WRITE !
DO FIELD("Rule Element Label:",$GET(OCXRD(860.21,OCXD1,.01,"E")),OCXTAB,OCXRM)
+17 IF $GET(OCXRD(860.21,OCXD1,.02,"I"))
Begin DoDot:2
+18 WRITE !
DO FIELD(" Expression:",$GET(OCXRD(860.21,OCXD1,2,"E")),OCXTAB,OCXRM)
+19 IF ($GET(OCXRD(860.21,OCXD1,2,"E"))["|")
Begin DoDot:3
+20 NEW PTR,EXPVAL,DFLD
+21 SET EXPVAL=$GET(OCXRD(860.21,OCXD1,2,"E"))
FOR PTR=2:2:$LENGTH(EXPVAL,"|")
SET DFLD=$PIECE(EXPVAL,"|",PTR)
DO GETDF(DFLD)
End DoDot:3
End DoDot:2
QUIT
+22 ;
+23 SET OUTSTR=$GET(OCXRD(860.21,OCXD1,1,"E"))
+24 WRITE !
DO FIELD(" Element:",OUTSTR,OCXTAB,OCXRM)
+25 SET OCXE=+$GET(OCXRD(860.21,OCXD1,1,"I"))
IF +OCXE
DO EN^OCXODSP2(OCXE,OCXTAB+OCXOFF,OCXRM)
End DoDot:1
+26 ;
+27 SET OCXD1=0
FOR
SET OCXD1=$ORDER(OCXRD(860.22,OCXD1))
IF 'OCXD1
QUIT
Begin DoDot:1
+28 NEW EXPVAL,DFLD,PTR
SET DFLD=""
+29 WRITE !
+30 WRITE !
DO FIELD("Relation Expression:",$GET(OCXRD(860.22,OCXD1,1,"E")),OCXTAB,OCXRM)
+31 IF $DATA(OCXRD(860.22,OCXD1,2,"E"))
WRITE !
DO FIELD(" Order Check:",$GET(OCXRD(860.22,OCXD1,2,"E")),OCXTAB,OCXRM)
+32 IF $DATA(OCXRD(860.22,OCXD1,3,"E"))
WRITE !
DO FIELD(" Notification:",$GET(OCXRD(860.22,OCXD1,3,"E")),OCXTAB,OCXRM)
+33 IF $DATA(OCXRD(860.22,OCXD1,4,"E"))
WRITE !
DO FIELD(" Report Device:",$GET(OCXRD(860.22,OCXD1,4,"E")),OCXTAB,OCXRM)
+34 IF $DATA(OCXRD(860.22,OCXD1,5,"E"))
WRITE !
DO FIELD(" Notification Message:",$GET(OCXRD(860.22,OCXD1,5,"E")),OCXTAB,OCXRM)
+35 IF $DATA(OCXRD(860.22,OCXD1,6,"E"))
WRITE !
DO FIELD(" Order Check Message:",$GET(OCXRD(860.22,OCXD1,6,"E")),OCXTAB,OCXRM)
+36 IF $DATA(OCXRD(860.22,OCXD1,7,"E"))
WRITE !
DO FIELD(" Schedule Action:",$GET(OCXRD(860.22,OCXD1,7,"E")),OCXTAB,OCXRM)
+37 IF $DATA(OCXRD(860.22,OCXD1,8,"E"))
WRITE !
DO FIELD(" Schedule Frequency:",$GET(OCXRD(860.22,OCXD1,8,"E")),OCXTAB,OCXRM)
+38 IF $DATA(OCXRD(860.22,OCXD1,9,"E"))
WRITE !
DO FIELD(" Execute Code:",$GET(OCXRD(860.22,OCXD1,9,"E")),OCXTAB,OCXRM)
+39 IF ($GET(OCXRD(860.22,OCXD1,5,"E"))["|")
SET EXPVAL=$GET(OCXRD(860.22,OCXD1,5,"E"))
FOR PTR=2:2:$LENGTH(EXPVAL,"|")
SET DFLD=$PIECE(EXPVAL,"|",PTR)
IF $LENGTH(DFLD)
SET DFLD(DFLD)=""
+40 IF ($GET(OCXRD(860.22,OCXD1,6,"E"))["|")
SET EXPVAL=$GET(OCXRD(860.22,OCXD1,6,"E"))
FOR PTR=2:2:$LENGTH(EXPVAL,"|")
SET DFLD=$PIECE(EXPVAL,"|",PTR)
IF $LENGTH(DFLD)
SET DFLD(DFLD)=""
+41 SET DFLD=""
FOR
SET DFLD=$ORDER(DFLD(DFLD))
IF '$LENGTH(DFLD)
QUIT
DO GETDF(DFLD)
End DoDot:1
+42 ;
+43 QUIT
+44 ;
+45 ;
GETDF(DFLD) ;
+1 ;
+2 NEW DFLDN,DCONT,DELEM,DELEMN
+3 IF (DFLD[".")
Begin DoDot:1
+4 SET DELEM=$PIECE(DFLD,".",1)
SET DFLD=$PIECE(DFLD,".",2)
+5 SET DFLDN=$ORDER(^OCXS(860.4,"C",DFLD,0))
+6 IF 'DFLDN
SET DFLDN=0
FOR
SET DFLDN=$ORDER(^OCXS(860.4,"B",$EXTRACT(DFLD,1,30),DFLDN))
IF 'DFLDN
QUIT
IF ($PIECE(^OCXS(860.4,DFLDN,0),U,1)=DFLD)
QUIT
+7 SET DELEMN=0
FOR
SET DELEMN=$ORDER(OCXRD(860.21,DELEMN))
IF 'DELEMN
QUIT
IF (OCXRD(860.21,DELEMN,.01,"E")=DELEM)
QUIT
+8 IF 'DELEMN
QUIT
SET DELEM=+$GET(OCXRD(860.21,DELEMN,1,"I"))
IF 'DELEM
QUIT
+9 SET DCONT=+$PIECE($GET(^OCXS(860.3,DELEM,0)),U,2)
IF 'DCONT
QUIT
+10 DO EN^OCXODSP3(DFLDN,OCXTAB+OCXOFF,OCXRM,DCONT)
End DoDot:1
QUIT
+11 ;
+12 IF '(DFLD[".")
Begin DoDot:1
+13 SET DFLDN=$ORDER(^OCXS(860.4,"C",DFLD,0))
+14 IF 'DFLDN
SET DFLDN=0
FOR
SET DFLDN=$ORDER(^OCXS(860.4,"B",$EXTRACT(DFLD,1,30),DFLDN))
IF 'DFLDN
QUIT
IF ($PIECE(^OCXS(860.4,DFLDN,0),U,1)=DFLD)
QUIT
+15 SET DELEMN=0
FOR
SET DELEMN=$ORDER(OCXRD(860.21,DELEMN))
IF 'DELEMN
QUIT
Begin DoDot:2
+16 SET DELEM=+$GET(OCXRD(860.21,DELEMN,1,"I"))
IF 'DELEM
QUIT
+17 SET DCONT=+$PIECE($GET(^OCXS(860.3,DELEM,0)),U,2)
IF 'DCONT
QUIT
+18 SET DCONT(DCONT)=""
End DoDot:2
+19 SET DCONT=0
FOR
SET DCONT=$ORDER(DCONT(DCONT))
IF 'DCONT
QUIT
DO EN^OCXODSP3(DFLDN,OCXTAB+OCXOFF,OCXRM,DCONT)
End DoDot:1
+20 ;
+21 QUIT
+22 ;
FIELD(TITLE,STRING,TAB,MARGIN) ;
+1 ;
+2 WRITE ?TAB,TITLE
+3 ;
+4 NEW PTR,SUBSTR,STRLEN
+5 ;
+6 SET STRLEN=MARGIN-($LENGTH(TITLE)+TAB)-5
+7 SET SUBSTR=""
FOR PTR=1:1:$LENGTH(STRING," ")
Begin DoDot:1
+8 IF ($LENGTH(SUBSTR)>STRLEN)
WRITE ?(TAB+$LENGTH(TITLE)+1),SUBSTR
IF $LENGTH($PIECE(STRING," ",PTR+1))
WRITE !
SET SUBSTR=""
+9 IF $LENGTH(SUBSTR)
SET SUBSTR=SUBSTR_" "
SET SUBSTR=SUBSTR_$PIECE(STRING," ",PTR)
End DoDot:1
+10 IF $LENGTH(SUBSTR)
WRITE ?(TAB+$LENGTH(TITLE)+1),SUBSTR
+11 QUIT
+12 ;
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 ;
+10 ;
DIQ(DIC,DA,OCXARY) ;
+1 ;
+2 NEW DR,DIQ
SET DR=".01:99999"
SET DIQ="OCXARY("
SET DIQ(0)="IEN"
DO EN^DIQ1
+3 QUIT
+4 ;