OCXOED02 ;SLC/RJS,CLA - Rule Editor (Rule Options) ;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
;
;
;
;
Q
EN(OCXR0,OCXRD,OCXACT) ;
;
;
N OCXTHLN,OCXTNLN,OCXTRLN,OCXTULN,OCXTNLN
;
;
S OCXOPT=$$GETOPT^OCXOEDT(.OCXACT) Q:(OCXOPT=U) 1 X:$L(OCXOPT) OCXOPT
;
Q:'$D(^OCXS(860.2,OCXR0)) 1
;
Q 0
;
;
EDRULE(OCXR0) ;
N X S X=$$DIE("^OCXS(860.2,",OCXR0,".01;.02")
Q
;
EDRELE(OCXR0,OCXR1) ;
D EN^OCXOED03(OCXR0,OCXR1)
Q
;
EDRREL(OCXR0,OCXR1) ;
D EN^OCXOED05(OCXR0,OCXR1)
Q
;
EOPT(OCXMODE,OCXR0) ;
;
I OCXMODE="ADD" D Q
.S:'$D(^OCXS(860.2,OCXR0,"C",0)) ^OCXS(860.2,OCXR0,"C",0)="^860.21I^^"
.N OCXD1,OCXDA S OCXDA(1)=OCXR0,OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""C"",","AEMQLN","Select Element Label: ","","","",.OCXDA) Q:(OCXD1<0)
.D EDRELE(OCXR0,OCXD1)
I OCXMODE="DEL" D Q
.S:'$D(^OCXS(860.2,OCXR0,"C",0)) ^OCXS(860.2,OCXR0,"C",0)="^860.21I^^"
.N OCXD1,DA S DA(1)=OCXR0,OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""C"",","AEMQN","Select Element Label: ") Q:(OCXD1<0)
.Q:'$$READ("Y","Are you sure you want to Delete ?","YES")
.Q:'$$DIE("^OCXS(860.2,"_(+OCXR0)_",""C"",",OCXD1,"S DA(1)="_(+OCXR0)_";.01///@")
.W !!,"Deleted..." H 1
Q
;
ROPT(OCXMODE,OCXR0) ;
;
I OCXMODE="ADD" D Q
.S:'$D(^OCXS(860.2,OCXR0,"R",0)) ^OCXS(860.2,OCXR0,"R",0)="^860.22I^^"
.N OCXD1 S OCXD1=$O(^OCXS(860.2,OCXR0,"R","@"),-1)+1
.S ^OCXS(860.2,OCXR0,"R",OCXD1,0)=OCXD1,^OCXS(860.2,OCXR0,"R","B",OCXD1,OCXD1)=""
.D EDRREL(OCXR0,OCXD1)
I OCXMODE="DEL" D Q
.S:'$D(^OCXS(860.2,OCXR0,"R",0)) ^OCXS(860.2,OCXR0,"R",0)="^860.22I^^"
.N OCXD1,DA S DA(1)=OCXR0,OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""R"",","AEMQN","Select Relation Expression Index Number: ") Q:(OCXD1<0)
.Q:'$$READ("Y","Are you sure you want to Delete ?","YES")
.Q:'$$DIE("^OCXS(860.2,"_(+OCXR0)_",""R"",",OCXD1,"S DA(1)="_(+OCXR0)_";.01///@")
.W !!,"Deleted..." H 1
Q
;
;
READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
N OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
Q:'$L($G(OCXZ0)) U
S DIR(0)=OCXZ0
S:$L($G(OCXZA)) DIR("A")=OCXZA
S:$L($G(OCXZB)) DIR("B")=OCXZB
F OCXLINE=1:1:($G(OCXZL)-1) W !
D ^DIR
I $D(DTOUT)!$D(DUOUT)!$D(DIRUT)!$D(DIROUT) Q U
Q Y
;
DIE(DIE,DA,DR) ;
;
D RM(IOM) N DUOUT,DTOUT,DIC S DIC=DIE D ^DIE D RM(0) Q:$G(DTOUT) 0 Q:$G(DUOUT) 0 Q 1
;
RM(X) X ^%ZOSF("RM") Q
;
DIC(OCXDIC,OCXDIC0,OCXDICA,OCXX,OCXDICS,OCXDR,DA) ;
;
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
;
OCXOED02 ;SLC/RJS,CLA - Rule Editor (Rule Options) ;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 ;
+5 ;
+6 ;
+7 QUIT
EN(OCXR0,OCXRD,OCXACT) ;
+1 ;
+2 ;
+3 NEW OCXTHLN,OCXTNLN,OCXTRLN,OCXTULN,OCXTNLN
+4 ;
+5 ;
+6 SET OCXOPT=$$GETOPT^OCXOEDT(.OCXACT)
IF (OCXOPT=U)
QUIT 1
IF $LENGTH(OCXOPT)
XECUTE OCXOPT
+7 ;
+8 IF '$DATA(^OCXS(860.2,OCXR0))
QUIT 1
+9 ;
+10 QUIT 0
+11 ;
+12 ;
EDRULE(OCXR0) ;
+1 NEW X
SET X=$$DIE("^OCXS(860.2,",OCXR0,".01;.02")
+2 QUIT
+3 ;
EDRELE(OCXR0,OCXR1) ;
+1 DO EN^OCXOED03(OCXR0,OCXR1)
+2 QUIT
+3 ;
EDRREL(OCXR0,OCXR1) ;
+1 DO EN^OCXOED05(OCXR0,OCXR1)
+2 QUIT
+3 ;
EOPT(OCXMODE,OCXR0) ;
+1 ;
+2 IF OCXMODE="ADD"
Begin DoDot:1
+3 IF '$DATA(^OCXS(860.2,OCXR0,"C",0))
SET ^OCXS(860.2,OCXR0,"C",0)="^860.21I^^"
+4 NEW OCXD1,OCXDA
SET OCXDA(1)=OCXR0
SET OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""C"",","AEMQLN","Select Element Label: ","","","",.OCXDA)
IF (OCXD1<0)
QUIT
+5 DO EDRELE(OCXR0,OCXD1)
End DoDot:1
QUIT
+6 IF OCXMODE="DEL"
Begin DoDot:1
+7 IF '$DATA(^OCXS(860.2,OCXR0,"C",0))
SET ^OCXS(860.2,OCXR0,"C",0)="^860.21I^^"
+8 NEW OCXD1,DA
SET DA(1)=OCXR0
SET OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""C"",","AEMQN","Select Element Label: ")
IF (OCXD1<0)
QUIT
+9 IF '$$READ("Y","Are you sure you want to Delete ?","YES")
QUIT
+10 IF '$$DIE("^OCXS(860.2,"_(+OCXR0)_",""C"",",OCXD1,"S DA(1)="_(+OCXR0)_";.01///@")
QUIT
+11 WRITE !!,"Deleted..."
HANG 1
End DoDot:1
QUIT
+12 QUIT
+13 ;
ROPT(OCXMODE,OCXR0) ;
+1 ;
+2 IF OCXMODE="ADD"
Begin DoDot:1
+3 IF '$DATA(^OCXS(860.2,OCXR0,"R",0))
SET ^OCXS(860.2,OCXR0,"R",0)="^860.22I^^"
+4 NEW OCXD1
SET OCXD1=$ORDER(^OCXS(860.2,OCXR0,"R","@"),-1)+1
+5 SET ^OCXS(860.2,OCXR0,"R",OCXD1,0)=OCXD1
SET ^OCXS(860.2,OCXR0,"R","B",OCXD1,OCXD1)=""
+6 DO EDRREL(OCXR0,OCXD1)
End DoDot:1
QUIT
+7 IF OCXMODE="DEL"
Begin DoDot:1
+8 IF '$DATA(^OCXS(860.2,OCXR0,"R",0))
SET ^OCXS(860.2,OCXR0,"R",0)="^860.22I^^"
+9 NEW OCXD1,DA
SET DA(1)=OCXR0
SET OCXD1=+$$DIC("^OCXS(860.2,"_OCXR0_",""R"",","AEMQN","Select Relation Expression Index Number: ")
IF (OCXD1<0)
QUIT
+10 IF '$$READ("Y","Are you sure you want to Delete ?","YES")
QUIT
+11 IF '$$DIE("^OCXS(860.2,"_(+OCXR0)_",""R"",",OCXD1,"S DA(1)="_(+OCXR0)_";.01///@")
QUIT
+12 WRITE !!,"Deleted..."
HANG 1
End DoDot:1
QUIT
+13 QUIT
+14 ;
+15 ;
READ(OCXZ0,OCXZA,OCXZB,OCXZL) ;
+1 NEW OCXLINE,DIR,DTOUT,DUOUT,DIRUT,DIROUT
+2 IF '$LENGTH($GET(OCXZ0))
QUIT U
+3 SET DIR(0)=OCXZ0
+4 IF $LENGTH($GET(OCXZA))
SET DIR("A")=OCXZA
+5 IF $LENGTH($GET(OCXZB))
SET DIR("B")=OCXZB
+6 FOR OCXLINE=1:1:($GET(OCXZL)-1)
WRITE !
+7 DO ^DIR
+8 IF $DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIRUT)!$DATA(DIROUT)
QUIT U
+9 QUIT Y
+10 ;
DIE(DIE,DA,DR) ;
+1 ;
+2 DO RM(IOM)
NEW DUOUT,DTOUT,DIC
SET DIC=DIE
DO ^DIE
DO RM(0)
IF $GET(DTOUT)
QUIT 0
IF $GET(DUOUT)
QUIT 0
QUIT 1
+3 ;
RM(X) XECUTE ^%ZOSF("RM")
QUIT
+1 ;
DIC(OCXDIC,OCXDIC0,OCXDICA,OCXX,OCXDICS,OCXDR,DA) ;
+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 ;