Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSODGDGI

PSODGDGI.m

Go to the documentation of this file.
  1. PSODGDGI ;BIR/SAB - drug drug interaction checker ;05-Jun-2013 08:41;DU
  1. ;;7.0;OUTPATIENT PHARMACY;**10,27,48,130,144,132,188,207,243,274,1015**;DEC 1997;Build 62
  1. ;External reference to ^PS(56 supported by DBIA 2229
  1. ;External reference to ^PSDRUG supported by DBIA 221
  1. ;External references PSOL and PSOUL^PSSLOCK supported by DBIA 2789
  1. ;External reference to DDIEX^PSNAPIS supported by DBIA 2574
  1. ;External references to ^ORRDI1 supported by DBIA 4659
  1. ;External reference ^XTMP("ORRDI" supported by DBIA 4660
  1. ;IHS/MSC/MGH - Compound med modifications and check line label added
  1. Q:$$DDIEX^PSNAPIS($P(PSODRUG("NDF"),"A"),$P(PSODRUG("NDF"),"A",2))
  1. N PSOICT,CMP,TDRG,CMPDR,CDRG
  1. S (CRIT,DRG,LSI,DGI,DGS,SER,SERS,STA,PSOICT)=""
  1. F S STA=$O(PSOSD(STA)) Q:STA=""!($G(PSORX("DFLG"))) F S DRG=$O(PSOSD(STA,DRG)) Q:DRG=""!($G(PSORX("DFLG"))) I $P(PSOSD(STA,DRG),"^",2)<10 D
  1. .;IHS/MSC/MGH check for compound medications
  1. .S CMP=0
  1. .S TDRG=$O(^PSDRUG("B",$P(DRG,U),""))
  1. .I +TDRG S CMP=$P($G(^PSDRUG(TDRG,999999935)),U,1)
  1. .I CMP=1 D
  1. ..N CMPDR,SAVE,CDRG,CNDF
  1. ..S CMPDR=0
  1. ..F S CMPDR=$O(^PSDRUG(TDRG,999999936,CMPDR)) Q:'+CMPDR D
  1. ...S CDRG=$P($G(^PSDRUG(TDRG,999999936,CMPDR,0)),U,1)
  1. ...S NDF=$S($G(^PSDRUG(CDRG,"ND"))]"":+^("ND")_"A"_$P(^("ND"),"^",3),1:0)
  1. ...D CHECK(NDF)
  1. .E D
  1. ..Q:$P(PSOSD(STA,DRG),"^",7)']""
  1. ..S NDF=$P(PSOSD(STA,DRG),"^",7)
  1. ..D CHECK(NDF)
  1. I '$D(^XUSEC("PSORPH",DUZ)),$G(DGI)]"" S:+CRIT PSONEW("STATUS")=4 W $C(7),!,"DRUG INTERACTION WITH RX #s: "_LSI,! K LSI,DRG,IT,NDF,PSOICT
  1. K IT
  1. ; CHECK FOR REMOTE DRUG INTERACTIONS
  1. I +$G(PSORX("DFLG")) Q
  1. I $T(HAVEHDR^ORRDI1)']"" Q
  1. I '$$HAVEHDR^ORRDI1 Q
  1. I $D(^XTMP("ORRDI","OUTAGE INFO","DOWN")) D Q
  1. .I $T(REMOTE^PSORX1)]"" Q
  1. .W !,"Remote data not available - Only local order checks processed." D PAUSE^PSOORRD2
  1. I $P($G(^XTMP("ORRDI","PSOO",PSODFN,0)),"^",3)<0 W !,"Remote data not available - Only local order checks processed." D PAUSE^PSOORRD2 Q
  1. I $D(^TMP($J,"DI"_PSODFN)) K ^TMP($J,"DI") M ^TMP($J,"DI")=^TMP($J,"DI"_PSODFN) D DRGINT^PSOORRD2
  1. K ^TMP($J,"DI"_PSODFN),^TMP($J,"DI")
  1. Q
  1. CHECK(NDF) ; check drug interations
  1. ;New logic to Loop All interactions and filter-up a critical if it exists
  1. ;Moved into separate subroutine to process multiples
  1. S IT=0,PSOICT=""
  1. F S IT=$O(^PS(56,"APD",NDF,PSODRUG("NDF"),IT)) Q:'IT D
  1. .Q:$$DDIEX^PSNAPIS($P(NDF,"A"),$P(NDF,"A",2))
  1. .Q:$P(^PS(56,IT,0),"^",7)&($P(^PS(56,IT,0),"^",7)<DT)
  1. .I 'PSOICT S PSOICT=IT Q
  1. .I $P($G(^PS(56,IT,0)),"^",4)=1 S PSOICT=IT Q
  1. .Q
  1. I 'PSOICT Q
  1. S IT=PSOICT
  1. I STA="ZNONVA" S DNM=DRG W ! D NVA^PSODRDU1 K DNM,IT,PSOICT Q
  1. D BLD Q:+$G(PSORX("DFLG"))
  1. Q
  1. TECH ;add tech entry to RX VERIFY file (#52.4)
  1. I +CRIT S PSODI=1,DIC="^PS(52.4,",DLAYGO=52.4,DIC(0)="L",(DINUM,X)=PSOX("IRXN"),DIC("DR")="1////"_PSODFN_";2////"_DUZ_";4///"_DT_";7///"_1_";7.1///"_SER_";7.2///"_DGI K DD,DO D FILE^DICN K DD,DO
  1. S:$G(DGS)'="" $P(^PSRX(PSOX("IRXN"),"DRI"),"^")=SERS,$P(^PSRX(PSOX("IRXN"),"DRI"),"^",2)=DGS K PSODI,CRIT,DIC,DLAYGO,DINUM,DGI,DGS,SER,SERS Q
  1. BLD I $D(^XUSEC("PSORPH",DUZ)) D PHARM Q
  1. S LSI=$P(^PSRX(+PSOSD(STA,DRG),0),"^")_"/"_$P(^PSDRUG($P(^(0),"^",6),0),"^")_","_LSI,DGI=$P(PSOSD(STA,DRG),"^")_","_DGI,SER=IT_","_SER I $P(PSOSD(STA,DRG),"^",9),$P(^PS(56,IT,0),"^",4)=1 S $P(^PSRX(+PSOSD(STA,DRG),"STA"),"^")=4
  1. I $P(^PS(56,IT,0),"^",4)=2 S SERS=IT_","_SERS,DGS=$P(PSOSD(STA,DRG),"^")_","_DGS
  1. S:$P(^PS(56,IT,0),"^",4)=1 CRIT=1 Q
  1. PHARM ;pharmacist verification of drug interaction
  1. D PSOL^PSSLOCK($P(PSOSD(STA,DRG),"^")) I '$G(PSOMSG) D K PSOMSG S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR S PSORX("DFLG")=1 Q
  1. .I $P($G(PSOMSG),"^",2)'="" W !!,$P(PSOMSG,"^",2) D Q
  1. ..W !,"Rx: "_$P($G(^PSRX($P(PSOSD(STA,DRG),"^"),0)),"^")_" Drug: "_$P($G(^PSDRUG(+$P($G(^(0)),"^",6),0)),"^")
  1. ..W !,"which interacts with the drug you are entering!",!
  1. .W !!,"Another person is editing Rx "_$P($G(^PSRX($P(PSOSD(STA,DRG),"^"),0)),"^")_",",!,"which interacts with the drug you are entering!",!
  1. S PSODGRLX=$P(PSOSD(STA,DRG),"^")
  1. S SER=^PS(56,IT,0),DIR("?",1)="Answer 'YES' if you DO want to "_$S($P(SER,"^",4)=1:"continue processing",1:"enter an intervention for")_" this medication,"
  1. S DIR("?")=" 'NO' if you DON'T want to "_$S($P(SER,"^",4)=1:"continue processing",1:"enter an intervention for")_" this medication,"
  1. W $C(7),$C(7) S DIR("A",1)="***"_$S($P(SER,"^",4)=1:"CRITICAL",1:"SIGNIFICANT")_"*** "_"Drug Interaction with RX #"_$P(^PSRX($P(PSOSD(STA,DRG),"^"),0),"^"),DIR("A",2)="DRUG: "_$P(DRG,"^")
  1. S DIR(0)="SA^1:YES;0:NO",DIR("A")="Do you want to "_$S($P(SER,"^",4)=1:"Continue? ",1:"Intervene? "),DIR("B")="Y" D ^DIR
  1. I 'Y,$P(SER,"^",4)=1 S PSORX("DFLG")=1,DGI="" K DIR,DTOUT,DIRUT,DIROUT,DUOUT
  1. I Y,$P(SER,"^",4)=1 S PSORX("INTERVENE")=1,DGI="" K DIR,DTOUT,DIRUT,DIROUT,DUOUT G CRI Q
  1. I 'Y,$P(SER,"^",4)=2 K DIR,DTOUT,DIRUT,DIROUT,DUOUT D ULRX Q
  1. I Y,$P(SER,"^",4)=2 S PSORX("INTERVENE")=2,DGI="" K DIR,DTOUT,DIRUT,DIROUT,DUOUT
  1. D ULRX
  1. Q
  1. CRI ;process new drug interactions entered by pharmacist
  1. K DIR G:$P(PSOSD(STA,DRG),"^",9) CRITN S DIR("A",1)="",DIR("A",2)="Do you want to Process medication",DIR("A")=PSODRUG("NAME")_": ",DIR(0)="SA^1:PROCESS;0:ABORT ORDER ENTRY",DIR("B")="P"
  1. S DIR("?",1)="Enter '1' or 'P' to Activate medication",DIR("?")=" '0' or 'A' to Abort Order Entry process" D ^DIR K X1,DIR I 'Y S PSORX("DFLG")=1,DGI="" K DTOUT,DIRUT,DIROUT,DUOUT,PSORX("INTERVENE") D ULRX Q
  1. I $P(SER,"^",4)=1 D
  1. .D SIG^XUSESIG I X1="" K PSORX("INTERVENE") S PSORX("DFLG")=1 Q
  1. .S PSORX("INTERVENE")=$P(SER,"^",4)
  1. K DUOUT,DTOUT,DIRUT,DIROUT D ULRX Q
  1. CRITN ;process multiple new drug interactions
  1. K X1,DIR S DIR("A",1)="",DIR("A",2)="Do you want to: ",DIR("A",3)=" 1. Delete NEW medication "_PSODRUG("NAME"),DIR("A",4)=" 2. Cancel ACTIVE New Rx #"_$P(^PSRX($P(PSOSD(STA,DRG),"^"),0),"^")_" DRUG: "_$P(DRG,"^")
  1. S DIR("A",5)=" 3. Delete 1 and Cancel 2",DIR("A")=" 4. Continue ?: ",DIR(0)="SA^1:NEW MEDICATION;2:ACTIVE New Rx "_$P(DRG,"^")_";3:BOTH;4:CONTINUE"
  1. S DIR("?",1)="Enter '1' or 'N' to Delete New Medication and Dispense Rx #"_$P(^PSRX(+PSOSD(STA,DRG),0),"^")
  1. S DIR("?",2)=" '2' or 'A' to Cancel Active Rx #"_$P(^PSRX(+PSOSD(STA,DRG),0),"^")_" and Dispense New Rx"
  1. S DIR("?",3)=" '3' or 'B' to Delete 1 and Cancel 2",DIR("?")=" '4' or 'C' to do nothing to either Rx" D ^DIR K DIR
  1. I Y=1 S PSORX("DFLG")=1,DGI="",PSHLDDRG=PSODRUG("IEN") D D ULRX Q
  1. .I $G(PSORXED) D Q
  1. ..D NOOR^PSOCAN4 I $D(DIRUT) W $C(7)," ACTION NOT TAKEN!",! S PSORX("DFLG")=1 K PSORX("INTERVENE") Q
  1. ..S DA=$P(PSOLST(ORN),"^",2) D MESS,ENQ^PSORXDL,FULL^VALM1
  1. ..K PSOSD($P(PSOLST(ORN),"^",3),PSODRUG("NAME")),DTOUT,DIROUT,DIRUT,DUOUT S:$G(PSOSD) PSOSD=PSOSD-1 S ZONE=1
  1. .S PSODRUG("IEN")=$P(^PSRX($P(PSOSD(STA,DRG),"^"),0),"^",6) D FULL^VALM1,^PSORXI
  1. .S PSODRUG("IEN")=PSHLDDRG,VALMBCK="R"
  1. .K DTOUT,DIRUT,DIROUT,DUOUT,PSHLDDRG
  1. .I $G(OR0) D
  1. ..D NOOR^PSOCAN4 I $D(DIRUT) D Q
  1. ...W $C(7)," ACTION NOT TAKEN!",! K PSORX("INTERVENE") S PSORX("DFLG")=1
  1. ..D DC^PSOORFI2
  1. I Y=2 S (DA,PSOHOLDA)=+PSOSD(STA,DRG) D D ULRX Q
  1. .D NOOR^PSOCAN4 I $D(DIRUT) D Q
  1. ..W $C(7)," ACTION NOT TAKEN!",! K PSORX("INTERVENE") S PSORX("DFLG")=1
  1. .D MESS,ENQ^PSORXDL
  1. .S DA=PSOHOLDA D FULL^VALM1,EN1^PSORXI(.DA),PPL
  1. .K PSOSD(STA,DRG),DTOUT,DIROUT,DIRUT,DUOUT,PSOHOLDA
  1. .S:$G(PSOSD) PSOSD=PSOSD-1 S VALMBCK="R"
  1. I Y=3 S (DA,PSOHOLDA)=+PSOSD(STA,DRG) D S VALMBCK="R"
  1. .D NOOR^PSOCAN4 I $D(DIRUT) D Q
  1. ..W $C(7)," ACTION NOT TAKEN!",! K PSORX("INTERVENE") S PSORX("DFLG")=1
  1. .S:$G(PSOSD) PSOSD=PSOSD-1 S PSORX("DFLG")=1 D MESS,ENQ^PSORXDL
  1. .I $G(OR0) D DC^PSOORFI2
  1. .S DA=PSOHOLDA D FULL^VALM1,EN1^PSORXI(.DA),PPL K PSOSD(STA,DRG),PSOHOLDA
  1. .I $G(PSORXED) D
  1. ..S DA=$P(PSOLST(ORN),"^",2) D MESS,ENQ^PSORXDL,FULL^VALM1
  1. ..K PSOSD($P(PSOLST(ORN),"^",3),PSODRUG("NAME")),DTOUT,DIROUT,DIRUT,DUOUT S:$G(PSOSD) PSOSD=PSOSD-1 S ZONE=1
  1. K DTOUT,DIROUT,DIRUT,DUOUT
  1. D ULRX
  1. Q
  1. MESS W !!,"Canceling Rx: "_$P($G(^PSRX(DA,0)),"^")_" "_"Drug: "_$P($G(^PSDRUG($P(^PSRX(DA,0),"^",6),0)),"^"),! Q
  1. PPL F PSOSL=0:0 S PSOSL=$O(PSORX("PSOL",PSOSL)) Q:'PSOSL S PSOX2=PSOSL
  1. I $G(PSOX2) D
  1. .F PSOSL=0:1:PSOX2 S PSOSL=$O(PSORX("PSOL",PSOSL)) Q:'PSOSL F ENT=1:1:$L(PSORX("PSOL",PSOSL),",") I $P(PSORX("PSOL",PSOSL),",",ENT)=$P(PSOSD(STA,DRG),"^") S PSOL(PSOSL,ENT)=""
  1. .F PSOL=0:0 S PSOL=$O(PSOL(PSOL)) Q:'PSOL F ENT=0:0 S ENT=$O(PSOL(PSOL,ENT)) Q:'ENT D
  1. ..I ENT=1,'$P(PSORX("PSOL",PSOL),",",2) K PSORX("PSOL",PSOL) Q
  1. ..I ENT=1,$P(PSORX("PSOL",PSOL),",",2) S PSORX("PSOL",PSOL)=$P(PSORX("PSOL",PSOL),",",2,99) Q
  1. ..S PSORX("PSOL",PSOL)=$P(PSORX("PSOL",PSOL),",",1,ENT-1)_","_$P(PSORX("PSOL",PSOL),",",ENT+1,99)
  1. K PSOX2,PSOSL,PSOL,ENT Q
  1. ULRX ;
  1. I '$G(PSODGRLX) Q
  1. D PSOUL^PSSLOCK(PSODGRLX) K PSODGRLX
  1. Q