PSDORN ;BIR/JPW,LTL-Nurse CS Order Request Entry ;12/14/99 16:04
;;3.0; CONTROLLED SUBSTANCES ;**20**;13 Feb 97
;
; Reference to PSD(58.8 supported by DBIA # 2711
; Reference to XUSEC( supported by DBIA # 10076
; Reference to VA(200 supported by DBIA # 10060
; Reference to DD("DD" supported by DBIA # 10017
; Reference to PSDRUG( supported by DBIA # 221
; Line tag EN^XQH supported by DBIA # 10074
;
I '$D(PSDSITE) D ^PSDSET Q:'$D(PSDSITE)
S OK=$S($D(^XUSEC("PSJ RNURSE",DUZ)):1,$D(^XUSEC("PSJ RPHARM",DUZ)):2,$D(^XUSEC("PSJ PHARM TECH",DUZ)):2,1:0)
I 'OK W $C(7),!!,?9,"** Please contact your Coordinator for access to order",!,?12,"narcotic supplies.",!!,"PSJ RNURSE, PSJ RPHARM, or PSJ PHARM TECH security key required.",! K OK Q
I $P($G(^VA(200,DUZ,20)),U,4)']"" N XQH S XQH="PSD ESIG" D EN^XQH G END
G:OK=2 ^PSDORP
S PSDUZ=DUZ,(MSG,MSG1)=0,Y=DT X ^DD("DD") S REQD=Y
NAOU ;select NAOU to order supplies for
K DA,DIC S DIC=58.8,DIC(0)="QEA",DIC("A")="Select Ordering NAOU: "
S DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S('$D(^(""I"")):1,'^(""I""):1,+^(""I"")>DT:1,1:0),$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)"
W ! D ^DIC K DIC G:Y<0 END S NAOU=+Y,NAOUN=$P(Y,"^",2)
I '$D(^PSD(58.8,NAOU,0)) S MSG=1 D MSG G END
I '$O(^PSD(58.8,NAOU,1,0)) S MSG=1,MSG1=2 D MSG G END
S PSDS=+$P(^PSD(58.8,NAOU,0),"^",4)
S:PSDS PSDS=PSDS_"^"_+$P(^PSD(58.8,+PSDS,0),"^",5)
I '+PSDS S (MSG,MSG1)=1 D MSG G END
I '$D(^PSD(58.8,+PSDS,0)) S MSG=2 D MSG G END
I '$O(^PSD(58.8,+PSDS,1,0)) S MSG=2,MSG1=2 D MSG G END
S TYPE=$P(^PSD(58.8,+PSDS,0),"^",2),OKTYP=$S(TYPE="M":1,TYPE="S":1,1:0) I 'OKTYP W !!,"Contact your Pharmacy Coordinator.",!,"The Pharmacy Dispensing Site is invalid for this NAOU." G END
K ^UTILITY($J,"W") W ! N X,DIWL,DIWR,DIWF,PSD
S PSD=0,DIWL=1,DIWR=80,DIWF="W",X="IORVON;IORVOFF" D ENDR^%ZISS W IORVON
F S PSD=$O(^PSD(58.8,+PSDS,5,PSD)) Q:'PSD S X=$G(^PSD(58.8,+PSDS,5,PSD,0)) D ^DIWP
D ^DIWW W IORVOFF D KILL^%ZISS
TYPE S DIR(0)="SAM^S:Scheduled Delivery;U:Priority Pick Up"
S DIR("A")="Scheduled Delivery or Priority Pick Up (S/U): "
S DIR("B")="Scheduled Delivery"
S DIR("?")="^N XQH S XQH=""PSD ORDER ENTRY"" D EN^XQH"
D ^DIR K DIR G:$D(DIRUT) END W ! G:Y="S" ^PSDORD
DRUG ;select drug
K DA,DIC,PSDR
S DIC("W")="W:$P(^PSDRUG(Y,0),U,9) "" N/F"" W $S('$G(^PSD(58.8,NAOU,1,Y,0)):"" NOT STOCKED BY ""_NAOUN,$P(^(0),U,14)&($P(^(0),U,14)'>DT):"" INACTIVE on ""_NAOUN,1:"""")"
S DIC("S")="I '$P($G(^(7)),U,2),$S('$P(^(0),""^"",14):1,+$P(^(0),""^"",14)>DT:1,1:0)"
S DA(1)=+PSDS,DIC(0)="QEAM",DIC="^PSD(58.8,"_+PSDS_",1,"
;no one-time requests allowed by dispensing site
D:'$P($G(^PSD(58.8,+PSDS,0)),U,13)
.S DIC("W")="W:$P(^PSDRUG(Y,0),U,9) "" N/F"" I $P(^PSD(58.8,NAOU,1,Y,0),U,14)]"""",$P(^(0),U,14)'>DT W $C(7),"" *** INACTIVE ***"""
.S DIC("S")="I $S('$P(^(0),U,14):1,+$P(^(0),U,14)>DT:1,1:0)"
.S DA(1)=+NAOU,DIC="^PSD(58.8,"_NAOU_",1,"
D ^DIC K DIC G:Y<0 END S PSDR=+Y,PSDRN=$S($P(^PSDRUG(PSDR,0),"^")]"":$P(^(0),"^"),1:"DRUG NAME MISSING")
;zero balance in vault
I '$P($G(^PSD(58.8,+PSDS,1,PSDR,0)),U,4) D ENS^%ZISS W IOBON,!!,?20,"ZERO BALANCE IN PHARMACY",IOBOFF D KILL^%ZISS
I $S('$D(^PSD(58.8,NAOU,1,PSDR,0)):1,$P(^(0),U,14)&($P(^(0),U,14)'>DT):1,1:0) D ^PSDORNO G:$D(DIRUT) END G TYPE
I '$D(^PSD(58.8,+PSDS,1,PSDR,0)) S MSG=2 D MSG G END
S NBKU=$P(^PSD(58.8,+PSDS,1,PSDR,0),"^",8),NPKG=+$P(^(0),"^",9)
I NBKU']"" S MSG1=3 D MSG G END
I 'NPKG S MSG1=4 D MSG G END
D LIST^PSDORL
;Perpetual?
G:$P($G(^PSD(58.8,+NAOU,2)),U,5) ^PSDOR2
QTY K ORD S PSDOUT=0 W !!,"QUANTITY ("_NBKU_"/"_NPKG_"): "_NPKG_"// " R X:DTIME S PSDT(8)=X I '$T!(X["^") G END
S DIR(0)="DA^NOW::AEFT",DIR("A")="Date/time required: "
S DIR("?",1)="You are on the verge of creating a priority order."
S DIR("?",2)="If this is a mistake, enter ""^"" to create a scheduled order, otherwise,"
S DIR("?")="Pharmacy needs to know how soon you need this order."
W ! D ^DIR K DIR G:$D(DIRUT) TYPE X ^DD("DD") S PSDT(9)=Y
S:PSDT(8)="" PSDT(8)=NPKG I PSDT(8)=NPKG S PSDQTY=NPKG,CNT=0 D DIE^PSDORN0 G:$G(PSDOUT) END D ASK^PSDORN1 K PSDEM G:PSDOUT END G DRUG
I PSDT(8)["?"!(PSDT(8)'?1.N)!(PSDT(8)#NPKG)!('PSDT(8)) W !!,"Quantity must be "_NPKG_" or a multiple of "_NPKG,! G QTY
S CNT=PSDT(8)/NPKG W !!,"This will be "_CNT_" separate order requests. The quantity is "_NPKG_" per request."
W ! K DA,DIR,DIRUT S DIR(0)="Y",DIR("A")="Do you want me to generate the "_CNT_" separate order requests",DIR("B")="YES",DIR("?",1)="Answer 'YES' to create the multiple order requests,"
S DIR("?")="Answer 'NO' to edit your comments or '^' to quit." D ^DIR K DIR G:$D(DIRUT) END
I 'Y W !,"No order request created. You must edit quantity.",! G QTY
I Y W !!,"The "_CNT_" requests are being created. You must review every request.",! S PSDQTY=NPKG D G:$G(PSDOUT) END D ^PSDORN1
.F ORD=1:1:CNT W !!,"Creating your order request # "_ORD_" of "_CNT_" for "_PSDRN D DIE^PSDORN0 Q:$G(PSDOUT) S ORD(ORD)=PSDA
G:'PSDOUT DRUG
END K %,%DT,%H,%I,CNT,CNT1,DA,DIC,DIE,DINUM,DIR,DIROUT,DIRUT,DIWF,DIWL,DIWR,DR,DTOUT,DUOUT,LN,MSG,MSG1
K NBKU,NPKG,OK,OKTYP,ORD,PSDA,PSDEM,PSDOUT,PSDQTY,PSDRD,PSDR,PSDRN,PSDT,REQD,TEXT,TYPE,WORD,X,Y
Q
MSG ;display error message
W $C(7),!!,?10,"Contact your Pharmacy Coordinator.",!,?10,"This "_$S(MSG=2:"Dispensing Site",MSG=1:"NAOU",1:"Drug")_" is missing "
W $S(MSG1=1:"Primary Disp. Site",MSG1=2:"stocked drugs",MSG1=3:"narcotic breakdown unit",MSG1=4:"narcotic package size",1:"data")_".",!
Q
PSDORN ;BIR/JPW,LTL-Nurse CS Order Request Entry ;12/14/99 16:04
+1 ;;3.0; CONTROLLED SUBSTANCES ;**20**;13 Feb 97
+2 ;
+3 ; Reference to PSD(58.8 supported by DBIA # 2711
+4 ; Reference to XUSEC( supported by DBIA # 10076
+5 ; Reference to VA(200 supported by DBIA # 10060
+6 ; Reference to DD("DD" supported by DBIA # 10017
+7 ; Reference to PSDRUG( supported by DBIA # 221
+8 ; Line tag EN^XQH supported by DBIA # 10074
+9 ;
+10 IF '$DATA(PSDSITE)
DO ^PSDSET
IF '$DATA(PSDSITE)
QUIT
+11 SET OK=$SELECT($DATA(^XUSEC("PSJ RNURSE",DUZ)):1,$DATA(^XUSEC("PSJ RPHARM",DUZ)):2,$DATA(^XUSEC("PSJ PHARM TECH",DUZ)):2,1:0)
+12 IF 'OK
WRITE $CHAR(7),!!,?9,"** Please contact your Coordinator for access to order",!,?12,"narcotic supplies.",!!,"PSJ RNURSE, PSJ RPHARM, or PSJ PHARM TECH security key required.",!
KILL OK
QUIT
+13 IF $PIECE($GET(^VA(200,DUZ,20)),U,4)']""
NEW XQH
SET XQH="PSD ESIG"
DO EN^XQH
GOTO END
+14 IF OK=2
GOTO ^PSDORP
+15 SET PSDUZ=DUZ
SET (MSG,MSG1)=0
SET Y=DT
XECUTE ^DD("DD")
SET REQD=Y
NAOU ;select NAOU to order supplies for
+1 KILL DA,DIC
SET DIC=58.8
SET DIC(0)="QEA"
SET DIC("A")="Select Ordering NAOU: "
+2 SET DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S('$D(^(""I"")):1,'^(""I""):1,+^(""I"")>DT:1,1:0),$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)"
+3 WRITE !
DO ^DIC
KILL DIC
IF Y<0
GOTO END
SET NAOU=+Y
SET NAOUN=$PIECE(Y,"^",2)
+4 IF '$DATA(^PSD(58.8,NAOU,0))
SET MSG=1
DO MSG
GOTO END
+5 IF '$ORDER(^PSD(58.8,NAOU,1,0))
SET MSG=1
SET MSG1=2
DO MSG
GOTO END
+6 SET PSDS=+$PIECE(^PSD(58.8,NAOU,0),"^",4)
+7 IF PSDS
SET PSDS=PSDS_"^"_+$PIECE(^PSD(58.8,+PSDS,0),"^",5)
+8 IF '+PSDS
SET (MSG,MSG1)=1
DO MSG
GOTO END
+9 IF '$DATA(^PSD(58.8,+PSDS,0))
SET MSG=2
DO MSG
GOTO END
+10 IF '$ORDER(^PSD(58.8,+PSDS,1,0))
SET MSG=2
SET MSG1=2
DO MSG
GOTO END
+11 SET TYPE=$PIECE(^PSD(58.8,+PSDS,0),"^",2)
SET OKTYP=$SELECT(TYPE="M":1,TYPE="S":1,1:0)
IF 'OKTYP
WRITE !!,"Contact your Pharmacy Coordinator.",!,"The Pharmacy Dispensing Site is invalid for this NAOU."
GOTO END
+12 KILL ^UTILITY($JOB,"W")
WRITE !
NEW X,DIWL,DIWR,DIWF,PSD
+13 SET PSD=0
SET DIWL=1
SET DIWR=80
SET DIWF="W"
SET X="IORVON;IORVOFF"
DO ENDR^%ZISS
WRITE IORVON
+14 FOR
SET PSD=$ORDER(^PSD(58.8,+PSDS,5,PSD))
IF 'PSD
QUIT
SET X=$GET(^PSD(58.8,+PSDS,5,PSD,0))
DO ^DIWP
+15 DO ^DIWW
WRITE IORVOFF
DO KILL^%ZISS
TYPE SET DIR(0)="SAM^S:Scheduled Delivery;U:Priority Pick Up"
+1 SET DIR("A")="Scheduled Delivery or Priority Pick Up (S/U): "
+2 SET DIR("B")="Scheduled Delivery"
+3 SET DIR("?")="^N XQH S XQH=""PSD ORDER ENTRY"" D EN^XQH"
+4 DO ^DIR
KILL DIR
IF $DATA(DIRUT)
GOTO END
WRITE !
IF Y="S"
GOTO ^PSDORD
DRUG ;select drug
+1 KILL DA,DIC,PSDR
+2 SET DIC("W")="W:$P(^PSDRUG(Y,0),U,9) "" N/F"" W $S('$G(^PSD(58.8,NAOU,1,Y,0)):"" NOT STOCKED BY ""_NAOUN,$P(^(0),U,14)&($P(^(0),U,14)'>DT):"" INACTIVE on ""_NAOUN,1:"""")"
+3 SET DIC("S")="I '$P($G(^(7)),U,2),$S('$P(^(0),""^"",14):1,+$P(^(0),""^"",14)>DT:1,1:0)"
+4 SET DA(1)=+PSDS
SET DIC(0)="QEAM"
SET DIC="^PSD(58.8,"_+PSDS_",1,"
+5 ;no one-time requests allowed by dispensing site
+6 IF '$PIECE($GET(^PSD(58.8,+PSDS,0)),U,13)
Begin DoDot:1
+7 SET DIC("W")="W:$P(^PSDRUG(Y,0),U,9) "" N/F"" I $P(^PSD(58.8,NAOU,1,Y,0),U,14)]"""",$P(^(0),U,14)'>DT W $C(7),"" *** INACTIVE ***"""
+8 SET DIC("S")="I $S('$P(^(0),U,14):1,+$P(^(0),U,14)>DT:1,1:0)"
+9 SET DA(1)=+NAOU
SET DIC="^PSD(58.8,"_NAOU_",1,"
End DoDot:1
+10 DO ^DIC
KILL DIC
IF Y<0
GOTO END
SET PSDR=+Y
SET PSDRN=$SELECT($PIECE(^PSDRUG(PSDR,0),"^")]"":$PIECE(^(0),"^"),1:"DRUG NAME MISSING")
+11 ;zero balance in vault
+12 IF '$PIECE($GET(^PSD(58.8,+PSDS,1,PSDR,0)),U,4)
DO ENS^%ZISS
WRITE IOBON,!!,?20,"ZERO BALANCE IN PHARMACY",IOBOFF
DO KILL^%ZISS
+13 IF $SELECT('$DATA(^PSD(58.8,NAOU,1,PSDR,0)):1,$PIECE(^(0),U,14)&($PIECE(^(0),U,14)'>DT):1,1:0)
DO ^PSDORNO
IF $DATA(DIRUT)
GOTO END
GOTO TYPE
+14 IF '$DATA(^PSD(58.8,+PSDS,1,PSDR,0))
SET MSG=2
DO MSG
GOTO END
+15 SET NBKU=$PIECE(^PSD(58.8,+PSDS,1,PSDR,0),"^",8)
SET NPKG=+$PIECE(^(0),"^",9)
+16 IF NBKU']""
SET MSG1=3
DO MSG
GOTO END
+17 IF 'NPKG
SET MSG1=4
DO MSG
GOTO END
+18 DO LIST^PSDORL
+19 ;Perpetual?
+20 IF $PIECE($GET(^PSD(58.8,+NAOU,2)),U,5)
GOTO ^PSDOR2
QTY KILL ORD
SET PSDOUT=0
WRITE !!,"QUANTITY ("_NBKU_"/"_NPKG_"): "_NPKG_"// "
READ X:DTIME
SET PSDT(8)=X
IF '$TEST!(X["^")
GOTO END
+1 SET DIR(0)="DA^NOW::AEFT"
SET DIR("A")="Date/time required: "
+2 SET DIR("?",1)="You are on the verge of creating a priority order."
+3 SET DIR("?",2)="If this is a mistake, enter ""^"" to create a scheduled order, otherwise,"
+4 SET DIR("?")="Pharmacy needs to know how soon you need this order."
+5 WRITE !
DO ^DIR
KILL DIR
IF $DATA(DIRUT)
GOTO TYPE
XECUTE ^DD("DD")
SET PSDT(9)=Y
+6 IF PSDT(8)=""
SET PSDT(8)=NPKG
IF PSDT(8)=NPKG
SET PSDQTY=NPKG
SET CNT=0
DO DIE^PSDORN0
IF $GET(PSDOUT)
GOTO END
DO ASK^PSDORN1
KILL PSDEM
IF PSDOUT
GOTO END
GOTO DRUG
+7 IF PSDT(8)["?"!(PSDT(8)'?1.N)!(PSDT(8)#NPKG)!('PSDT(8))
WRITE !!,"Quantity must be "_NPKG_" or a multiple of "_NPKG,!
GOTO QTY
+8 SET CNT=PSDT(8)/NPKG
WRITE !!,"This will be "_CNT_" separate order requests. The quantity is "_NPKG_" per request."
+9 WRITE !
KILL DA,DIR,DIRUT
SET DIR(0)="Y"
SET DIR("A")="Do you want me to generate the "_CNT_" separate order requests"
SET DIR("B")="YES"
SET DIR("?",1)="Answer 'YES' to create the multiple order requests,"
+10 SET DIR("?")="Answer 'NO' to edit your comments or '^' to quit."
DO ^DIR
KILL DIR
IF $DATA(DIRUT)
GOTO END
+11 IF 'Y
WRITE !,"No order request created. You must edit quantity.",!
GOTO QTY
+12 IF Y
WRITE !!,"The "_CNT_" requests are being created. You must review every request.",!
SET PSDQTY=NPKG
Begin DoDot:1
+13 FOR ORD=1:1:CNT
WRITE !!,"Creating your order request # "_ORD_" of "_CNT_" for "_PSDRN
DO DIE^PSDORN0
IF $GET(PSDOUT)
QUIT
SET ORD(ORD)=PSDA
End DoDot:1
IF $GET(PSDOUT)
GOTO END
DO ^PSDORN1
+14 IF 'PSDOUT
GOTO DRUG
END KILL %,%DT,%H,%I,CNT,CNT1,DA,DIC,DIE,DINUM,DIR,DIROUT,DIRUT,DIWF,DIWL,DIWR,DR,DTOUT,DUOUT,LN,MSG,MSG1
+1 KILL NBKU,NPKG,OK,OKTYP,ORD,PSDA,PSDEM,PSDOUT,PSDQTY,PSDRD,PSDR,PSDRN,PSDT,REQD,TEXT,TYPE,WORD,X,Y
+2 QUIT
MSG ;display error message
+1 WRITE $CHAR(7),!!,?10,"Contact your Pharmacy Coordinator.",!,?10,"This "_$SELECT(MSG=2:"Dispensing Site",MSG=1:"NAOU",1:"Drug")_" is missing "
+2 WRITE $SELECT(MSG1=1:"Primary Disp. Site",MSG1=2:"stocked drugs",MSG1=3:"narcotic breakdown unit",MSG1=4:"narcotic package size",1:"data")_".",!
+3 QUIT