- 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