ORKCHK4 ; slc/CLA - Support routine called by ORKCHK to do SELECT mode order checks ;3/6/97 9:35
;;3.0;ORDER ENTRY/RESULTS REPORTING;**6,32,74,87,94,123,162,190,249**;Dec 17, 1997
Q
;
EN(ORKS,ORKDFN,ORKA,ORENT,ORKTMODE) ;perform order checking for orderable item selection
Q:$$GET^XPAR("DIV^SYS^PKG","ORK SYSTEM ENABLE/DISABLE",1,"I")="D"
;
N OI,ORKDG,HL7,ODT,ORNUM,HL7NPTR,HL7NTXT,HL7NCOD,HL7LPTR,HL7LTXT,HL7LCOD
N ORKMSG,ORKT,ORKTXT
;
S OI=$P(ORKA,"|"),ORKDG=$P(ORKA,"|",2)
S HL7=$P(ORKA,"|",3),ODT=$P(ORKA,"|",4),ORNUM=$P(ORKA,"|",5)
S HL7NPTR=$P(HL7,U),HL7NTXT=$P(HL7,U,2),HL7NCOD=$P(HL7,U,3)
S HL7LPTR=$P(HL7,U,4),HL7LTXT=$P(HL7,U,5),HL7LCOD=$P(HL7,U,6)
;
I $E(ORKDG,1,2)="PS" D PHARM
I $E(ORKDG,1,2)'="PS" D MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
Q
;
PHARM ;process pharmacy order checks:
N ORPSPKG,ORPSA,ORKDD
N ORCRITN,ORCRITF,ORCRITD,ORSIGN,ORSIGF,ORSIGD,ORDUPN,ORDUPF,ORDUPD,ORDUPCN,ORDUPCF,ORDUPCD
;
D PARAMS("CRITICAL DRUG INTERACTION",.ORCRITN,.ORCRITF,.ORCRITD)
D PARAMS("SIGNIFICANT DRUG INTERACTION",.ORSIGN,.ORSIGF,.ORSIGD)
D PARAMS("DUPLICATE DRUG ORDER",.ORDUPN,.ORDUPF,.ORDUPD)
D PARAMS("DUPLICATE DRUG CLASS ORDER",.ORDUPCN,.ORDUPCF,.ORDUPCD)
;
;dispense drug selected:
I $L($G(HL7LPTR)),($G(HL7LCOD)="99PSD") D
.D RXOCS
.D MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
;
;dispense drug NOT selected, split OI into dispense drugs:
I '$L($G(HL7LPTR)) D
.S ORPSPKG=$E(ORKDG,3)
.I ORPSPKG="H" S ORPSPKG="X" ;change to "X" if "H"erbal/non-VA med
.I "IOX"[ORPSPKG D OI2DD(.ORPSA,OI,ORPSPKG)
.S ORKDD=0 F S ORKDD=$O(ORPSA(ORKDD)) Q:'ORKDD D
..S HL7LTXT=ORPSA(ORKDD)
..S HL7NPTR=$P(ORKDD,";",2)
..S HL7LPTR=+ORKDD
..S HL7LCOD="99PSD",HL7NCOD="99NDF"
..S $P(HL7,U)=HL7NPTR,$P(HL7,U,3)=HL7NCOD
..S $P(HL7,U,4)=HL7LPTR,$P(HL7,U,5)=HL7LTXT,$P(HL7,U,6)=HL7LCOD
..S $P(ORKA,"|",3)=HL7 ;set these for MLM OCX call
..D RXOCS
..D MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
Q
;
RXOCS ;drug-drug interaction, duplicate drug order, duplicate drug class
Q:ORCRITF_ORSIGF_ORDUPF_ORDUPCF'["E" ;quit if none are "E"nabled
N ORKRX,ORPSNUM
D CHECK^ORKPS(.ORKRX,ORKDFN,HL7LPTR,OI,ORKDG)
N CHK,XX S CHK=0,XX=""
F S CHK=$O(ORKRX(CHK)) Q:'CHK D
.S XX=ORKRX(CHK)
.;
.;critical drug interaction:
.I $P(XX,U)="DI",$P(XX,U,5)="CRITICAL" D ;,(ORKTMODE'="ALL") D
..Q:ORCRITF="D"
..S ORPSNUM=$P(XX,U,8) ;get the associated order number
..I $L(ORPSNUM),$G(^OR(100,+ORPSNUM,0)) S ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM),ORKTXT=$P(ORKT,U)_" ["_$P(ORKT,U,2)_"]"
..E S ORKTXT=$P(XX,U,3)
..S ORKMSG=$P(XX,U,5)_" drug-drug interaction: "_$P(XX,U,6)_" & "_$P(XX,U,7)
..S ORKS("ORK",ORCRITD_","_$G(ORNUM)_","_ORPSNUM_","_$E(ORKMSG,1,225))=ORNUM_U_ORCRITN_U_ORCRITD_U_ORKMSG_" ("_ORKTXT_")"_U_$G(ORPSNUM)
.;
.;significant drug interaction:
.I $P(XX,U)="DI",$P(XX,U,5)="SIGNIFICANT" D ;,(ORKTMODE'="ALL") D
..Q:ORSIGF="D"
..S ORPSNUM=$P(XX,U,8) ;get the associated order number
..I $L(ORPSNUM),$G(^OR(100,+ORPSNUM,0)) S ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM),ORKTXT=$P(ORKT,U)_" ["_$P(ORKT,U,2)_"]"
..E S ORKTXT=$P(XX,U,3)
..S ORKMSG=$P(XX,U,5)_" drug-drug interaction: "_$P(XX,U,6)_" & "_$P(XX,U,7)
..S ORKS("ORK",ORSIGD_","_$G(ORNUM)_","_ORPSNUM_","_$E(ORKMSG,1,225))=ORNUM_U_ORSIGN_U_ORSIGD_U_ORKMSG_" ("_ORKTXT_")"_U_$G(ORPSNUM)
.;
.;duplicate drug:
.I $P(XX,U)="DD" D ;,(ORKTMODE'="ALL") D
..Q:ORDUPF="D"
..S ORPSNUM=$P(XX,U,4) ;get the associated order number
..I $L(ORPSNUM),$G(^OR(100,+ORPSNUM,0)) S ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM),ORKTXT=$P(ORKT,U)_" ["_$P(ORKT,U,2)_"]"
..E S ORKTXT=$P(XX,U,3)
..S ORKMSG="Duplicate drug order: "_ORKTXT
..S ORKS("ORK",ORDUPD_","_$G(ORNUM)_","_ORPSNUM_",Duplicate drug order: "_$P(XX,U,3))=ORNUM_U_ORDUPN_U_ORDUPD_U_ORKMSG_U_$G(ORPSNUM)
.;
.;duplicate class:
.I $P(XX,U)="DC" D ;,(ORKTMODE'="ALL") D
..Q:ORDUPCF="D"
..S ORPSNUM=$P(XX,U,6) ;get the associated order number
..I $L(ORPSNUM),$G(^OR(100,+ORPSNUM,0)) S ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM),ORKTXT=$P(ORKT,U)_" ["_$P(ORKT,U,2)_"]"
..E S ORKTXT=$P(XX,U,5)
..S ORKMSG="Duplicate drug class order: "_$P(XX,U,3)
..S ORKS("ORK",ORDUPCD_","_$G(ORNUM)_","_ORPSNUM_","_$E(ORKMSG,1,225))=ORNUM_U_ORDUPCN_U_ORDUPCD_U_ORKMSG_" ("_ORKTXT_")"_U_$G(ORPSNUM)
Q
;
OI2DD(ORPSA,OROI,ORPSPKG) ;rtn dispense drugs for a PS OI
N PSOI
Q:'$D(^ORD(101.43,OROI,0))
S PSOI=$P($P(^ORD(101.43,OROI,0),U,2),";")
Q:+$G(PSOI)<1
D DRG^PSSUTIL1(.ORPSA,PSOI,ORPSPKG)
Q
;
PARAMS(ORKNAME,ORKNUM,ORKFLAG,ORKDNGR) ; get parameter values for an order chk
S ORKNUM=0,ORKNUM=$O(^ORD(100.8,"B",ORKNAME,ORKNUM))
S ORKFLAG=$$GET^XPAR(ORENT,"ORK PROCESSING FLAG",ORKNUM,"I")
S ORKDNGR=$$GET^XPAR("DIV^SYS^PKG","ORK CLINICAL DANGER LEVEL",ORKNUM,"I")
Q
ORKCHK4 ; slc/CLA - Support routine called by ORKCHK to do SELECT mode order checks ;3/6/97 9:35
+1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**6,32,74,87,94,123,162,190,249**;Dec 17, 1997
+2 QUIT
+3 ;
EN(ORKS,ORKDFN,ORKA,ORENT,ORKTMODE) ;perform order checking for orderable item selection
+1 IF $$GET^XPAR("DIV^SYS^PKG","ORK SYSTEM ENABLE/DISABLE",1,"I")="D"
QUIT
+2 ;
+3 NEW OI,ORKDG,HL7,ODT,ORNUM,HL7NPTR,HL7NTXT,HL7NCOD,HL7LPTR,HL7LTXT,HL7LCOD
+4 NEW ORKMSG,ORKT,ORKTXT
+5 ;
+6 SET OI=$PIECE(ORKA,"|")
SET ORKDG=$PIECE(ORKA,"|",2)
+7 SET HL7=$PIECE(ORKA,"|",3)
SET ODT=$PIECE(ORKA,"|",4)
SET ORNUM=$PIECE(ORKA,"|",5)
+8 SET HL7NPTR=$PIECE(HL7,U)
SET HL7NTXT=$PIECE(HL7,U,2)
SET HL7NCOD=$PIECE(HL7,U,3)
+9 SET HL7LPTR=$PIECE(HL7,U,4)
SET HL7LTXT=$PIECE(HL7,U,5)
SET HL7LCOD=$PIECE(HL7,U,6)
+10 ;
+11 IF $EXTRACT(ORKDG,1,2)="PS"
DO PHARM
+12 IF $EXTRACT(ORKDG,1,2)'="PS"
DO MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
+13 QUIT
+14 ;
PHARM ;process pharmacy order checks:
+1 NEW ORPSPKG,ORPSA,ORKDD
+2 NEW ORCRITN,ORCRITF,ORCRITD,ORSIGN,ORSIGF,ORSIGD,ORDUPN,ORDUPF,ORDUPD,ORDUPCN,ORDUPCF,ORDUPCD
+3 ;
+4 DO PARAMS("CRITICAL DRUG INTERACTION",.ORCRITN,.ORCRITF,.ORCRITD)
+5 DO PARAMS("SIGNIFICANT DRUG INTERACTION",.ORSIGN,.ORSIGF,.ORSIGD)
+6 DO PARAMS("DUPLICATE DRUG ORDER",.ORDUPN,.ORDUPF,.ORDUPD)
+7 DO PARAMS("DUPLICATE DRUG CLASS ORDER",.ORDUPCN,.ORDUPCF,.ORDUPCD)
+8 ;
+9 ;dispense drug selected:
+10 IF $LENGTH($GET(HL7LPTR))
IF ($GET(HL7LCOD)="99PSD")
Begin DoDot:1
+11 DO RXOCS
+12 DO MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
End DoDot:1
+13 ;
+14 ;dispense drug NOT selected, split OI into dispense drugs:
+15 IF '$LENGTH($GET(HL7LPTR))
Begin DoDot:1
+16 SET ORPSPKG=$EXTRACT(ORKDG,3)
+17 ;change to "X" if "H"erbal/non-VA med
IF ORPSPKG="H"
SET ORPSPKG="X"
+18 IF "IOX"[ORPSPKG
DO OI2DD(.ORPSA,OI,ORPSPKG)
+19 SET ORKDD=0
FOR
SET ORKDD=$ORDER(ORPSA(ORKDD))
IF 'ORKDD
QUIT
Begin DoDot:2
+20 SET HL7LTXT=ORPSA(ORKDD)
+21 SET HL7NPTR=$PIECE(ORKDD,";",2)
+22 SET HL7LPTR=+ORKDD
+23 SET HL7LCOD="99PSD"
SET HL7NCOD="99NDF"
+24 SET $PIECE(HL7,U)=HL7NPTR
SET $PIECE(HL7,U,3)=HL7NCOD
+25 SET $PIECE(HL7,U,4)=HL7LPTR
SET $PIECE(HL7,U,5)=HL7LTXT
SET $PIECE(HL7,U,6)=HL7LCOD
+26 ;set these for MLM OCX call
SET $PIECE(ORKA,"|",3)=HL7
+27 DO RXOCS
+28 DO MLM^ORKCHK2(.ORKS,ORKDFN,ORKA,ORENT,"SELECT")
End DoDot:2
End DoDot:1
+29 QUIT
+30 ;
RXOCS ;drug-drug interaction, duplicate drug order, duplicate drug class
+1 ;quit if none are "E"nabled
IF ORCRITF_ORSIGF_ORDUPF_ORDUPCF'["E"
QUIT
+2 NEW ORKRX,ORPSNUM
+3 DO CHECK^ORKPS(.ORKRX,ORKDFN,HL7LPTR,OI,ORKDG)
+4 NEW CHK,XX
SET CHK=0
SET XX=""
+5 FOR
SET CHK=$ORDER(ORKRX(CHK))
IF 'CHK
QUIT
Begin DoDot:1
+6 SET XX=ORKRX(CHK)
+7 ;
+8 ;critical drug interaction:
+9 ;,(ORKTMODE'="ALL") D
IF $PIECE(XX,U)="DI"
IF $PIECE(XX,U,5)="CRITICAL"
Begin DoDot:2
+10 IF ORCRITF="D"
QUIT
+11 ;get the associated order number
SET ORPSNUM=$PIECE(XX,U,8)
+12 IF $LENGTH(ORPSNUM)
IF $GET(^OR(100,+ORPSNUM,0))
SET ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM)
SET ORKTXT=$PIECE(ORKT,U)_" ["_$PIECE(ORKT,U,2)_"]"
+13 IF '$TEST
SET ORKTXT=$PIECE(XX,U,3)
+14 SET ORKMSG=$PIECE(XX,U,5)_" drug-drug interaction: "_$PIECE(XX,U,6)_" & "_$PIECE(XX,U,7)
+15 SET ORKS("ORK",ORCRITD_","_$GET(ORNUM)_","_ORPSNUM_","_$EXTRACT(ORKMSG,1,225))=ORNUM_U_ORCRITN_U_ORCRITD_U_ORKMSG_" ("_ORKTXT_")"_U_$GET(ORPSNUM)
End DoDot:2
+16 ;
+17 ;significant drug interaction:
+18 ;,(ORKTMODE'="ALL") D
IF $PIECE(XX,U)="DI"
IF $PIECE(XX,U,5)="SIGNIFICANT"
Begin DoDot:2
+19 IF ORSIGF="D"
QUIT
+20 ;get the associated order number
SET ORPSNUM=$PIECE(XX,U,8)
+21 IF $LENGTH(ORPSNUM)
IF $GET(^OR(100,+ORPSNUM,0))
SET ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM)
SET ORKTXT=$PIECE(ORKT,U)_" ["_$PIECE(ORKT,U,2)_"]"
+22 IF '$TEST
SET ORKTXT=$PIECE(XX,U,3)
+23 SET ORKMSG=$PIECE(XX,U,5)_" drug-drug interaction: "_$PIECE(XX,U,6)_" & "_$PIECE(XX,U,7)
+24 SET ORKS("ORK",ORSIGD_","_$GET(ORNUM)_","_ORPSNUM_","_$EXTRACT(ORKMSG,1,225))=ORNUM_U_ORSIGN_U_ORSIGD_U_ORKMSG_" ("_ORKTXT_")"_U_$GET(ORPSNUM)
End DoDot:2
+25 ;
+26 ;duplicate drug:
+27 ;,(ORKTMODE'="ALL") D
IF $PIECE(XX,U)="DD"
Begin DoDot:2
+28 IF ORDUPF="D"
QUIT
+29 ;get the associated order number
SET ORPSNUM=$PIECE(XX,U,4)
+30 IF $LENGTH(ORPSNUM)
IF $GET(^OR(100,+ORPSNUM,0))
SET ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM)
SET ORKTXT=$PIECE(ORKT,U)_" ["_$PIECE(ORKT,U,2)_"]"
+31 IF '$TEST
SET ORKTXT=$PIECE(XX,U,3)
+32 SET ORKMSG="Duplicate drug order: "_ORKTXT
+33 SET ORKS("ORK",ORDUPD_","_$GET(ORNUM)_","_ORPSNUM_",Duplicate drug order: "_$PIECE(XX,U,3))=ORNUM_U_ORDUPN_U_ORDUPD_U_ORKMSG_U_$GET(ORPSNUM)
End DoDot:2
+34 ;
+35 ;duplicate class:
+36 ;,(ORKTMODE'="ALL") D
IF $PIECE(XX,U)="DC"
Begin DoDot:2
+37 IF ORDUPCF="D"
QUIT
+38 ;get the associated order number
SET ORPSNUM=$PIECE(XX,U,6)
+39 IF $LENGTH(ORPSNUM)
IF $GET(^OR(100,+ORPSNUM,0))
SET ORKT=$$FULLTEXT^ORQOR1(+ORPSNUM)
SET ORKTXT=$PIECE(ORKT,U)_" ["_$PIECE(ORKT,U,2)_"]"
+40 IF '$TEST
SET ORKTXT=$PIECE(XX,U,5)
+41 SET ORKMSG="Duplicate drug class order: "_$PIECE(XX,U,3)
+42 SET ORKS("ORK",ORDUPCD_","_$GET(ORNUM)_","_ORPSNUM_","_$EXTRACT(ORKMSG,1,225))=ORNUM_U_ORDUPCN_U_ORDUPCD_U_ORKMSG_" ("_ORKTXT_")"_U_$GET(ORPSNUM)
End DoDot:2
End DoDot:1
+43 QUIT
+44 ;
OI2DD(ORPSA,OROI,ORPSPKG) ;rtn dispense drugs for a PS OI
+1 NEW PSOI
+2 IF '$DATA(^ORD(101.43,OROI,0))
QUIT
+3 SET PSOI=$PIECE($PIECE(^ORD(101.43,OROI,0),U,2),";")
+4 IF +$GET(PSOI)<1
QUIT
+5 DO DRG^PSSUTIL1(.ORPSA,PSOI,ORPSPKG)
+6 QUIT
+7 ;
PARAMS(ORKNAME,ORKNUM,ORKFLAG,ORKDNGR) ; get parameter values for an order chk
+1 SET ORKNUM=0
SET ORKNUM=$ORDER(^ORD(100.8,"B",ORKNAME,ORKNUM))
+2 SET ORKFLAG=$$GET^XPAR(ORENT,"ORK PROCESSING FLAG",ORKNUM,"I")
+3 SET ORKDNGR=$$GET^XPAR("DIV^SYS^PKG","ORK CLINICAL DANGER LEVEL",ORKNUM,"I")
+4 QUIT