PSDORD ;BIR/JPW,LTL - Nurse CS Order Request Entry DIR style ;8 Aug 94
;;3.0;CONTROLLED SUBSTANCES ;**51,79**;13 Feb 97;Build 20
;Any requests not ordered?
K PSD,PSDA,PSDB S PSD=0
W !,"Searching for ",$P($G(^VA(200,DUZ,.1)),U,4),"'s pending requests."
F S PSD=$O(^PSD(58.8,"AC",.5,+NAOU,PSD)) Q:'PSD D
.S PSD(1)=0 F S PSD(1)=$O(^PSD(58.8,"AC",.5,+NAOU,PSD,PSD(1))) Q:'PSD(1) W "." S:$P($G(^PSD(58.8,+NAOU,1,+PSD,3,PSD(1),0)),U,4)=DUZ PSDA(PSD,PSD(1))=$G(^(0))
I $O(PSDA(0)) D ^PSDORD1 G:$G(PSDOUT) END
W:'$O(PSDA(0)) " No pending requests.",!
DRUG ;select drug
S MSG=0 ;; PSD*3*51 - RJS
K DA,DIC,PSDR S DIC("W")="W:$P(^PSDRUG(Y,0),""^"",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,"
;one time requests not 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:$D(DTOUT)!($D(DUOUT)) END G:Y<1&($O(PSDA(0))) ^PSDORD1 G:Y<1 END S PSDR=+Y,PSDRN=$S($P(^PSDRUG(PSDR,0),"^")]"":$P(^(0),"^"),1:"DRUG NAME MISSING")
I $S('$D(^PSD(58.8,NAOU,1,PSDR,0)):1,$P(^(0),U,14)&($P(^(0),U,14)'>DT):1,1:0) D ^PSDORD4 G:$D(DIRUT) END G DRUG
I '$D(^PSD(58.8,NAOU,1,PSDR,0)) D MSG G END
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) ^PSDORD3
QTY K ORD S PSDOUT=0 S DIR(0)="58.800118,5A"
S DIR("A")="QUANTITY ("_NBKU_"/"_NPKG_"): ",DIR("B")=NPKG
D ^DIR K DIR G:$D(DIRUT) END G:Y<1 DRUG
I Y=NPKG S PSDQTY=Y D DIE W ! G DRUG
I X["?"!(X'?1.N)!(X#NPKG)!('X) W !!,"Quantity must be "_NPKG_" or a multiple of "_NPKG,! G QTY
S CNT=X/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.",! S PSDQTY=NPKG D W ! G DRUG
.F ORD=1:1:CNT W !!,"Creating your order request # "_ORD_" of "_CNT_" for "_PSDRN D DIE S PSDA(+PSDR,PSDA)=$G(^PSD(58.8,+NAOU,1,+PSDR,3,+PSDA,0))
I '$G(PSDOUT) W ! G 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 NAOU,NAOUN,NBKU,NPKG,OK,OKTYP,ORD,PSD,PSDA,PSDB,PSDOUT,PSDQTY,PSDRD,PSDR,PSDRN,PSDS,PSDT,PSDUZ,PSDUZN,REQD,TEXT,TYPE,WORD,X,Y
Q
DIE ;create the order request
F L +^PSD(58.8,NAOU,1,PSDR,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q
S:'$D(^PSD(58.8,NAOU,1,PSDR,3,0)) ^(0)="^58.800118A^^"
DIE2 S PSDA=$P(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)+1 I $D(^PSD(58.8,NAOU,1,PSDR,3,PSDA)) S $P(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)=$P(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)+1 G DIE2
K DA,DIC,DIE,DD,DR,DO S DIC(0)="L",(DIC,DIE)="^PSD(58.8,"_NAOU_",1,"_PSDR_",3,",DA(2)=NAOU,DA(1)=PSDR,(X,DINUM)=PSDA D FILE^DICN K DIC
D NOW^%DTC S PSDT=+$E(%,1,12) W ?10,!!,"processing now..."
S DA=PSDA,DA(1)=PSDR,DA(2)=NAOU,DR="1////"_PSDT_";2////"_+PSDS_";3////"_PSDUZ_";10////.5;5////"_PSDQTY_";13" D ^DIE K DIE,DR
S PSDA(+PSDR,+PSDA)=$G(^PSD(58.8,+NAOU,1,+PSDR,3,PSDA,0))
L -^PSD(58.8,NAOU,1,PSDR,0)
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
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDORD 4162 printed Dec 13, 2024@01:47:28 Page 2
PSDORD ;BIR/JPW,LTL - Nurse CS Order Request Entry DIR style ;8 Aug 94
+1 ;;3.0;CONTROLLED SUBSTANCES ;**51,79**;13 Feb 97;Build 20
+2 ;Any requests not ordered?
+3 KILL PSD,PSDA,PSDB
SET PSD=0
+4 WRITE !,"Searching for ",$PIECE($GET(^VA(200,DUZ,.1)),U,4),"'s pending requests."
+5 FOR
SET PSD=$ORDER(^PSD(58.8,"AC",.5,+NAOU,PSD))
if 'PSD
QUIT
Begin DoDot:1
+6 SET PSD(1)=0
FOR
SET PSD(1)=$ORDER(^PSD(58.8,"AC",.5,+NAOU,PSD,PSD(1)))
if 'PSD(1)
QUIT
WRITE "."
if $PIECE($GET(^PSD(58.8,+NAOU,1,+PSD,3,PSD(1),0)),U,4)=DUZ
SET PSDA(PSD,PSD(1))=$GET(^(0))
End DoDot:1
+7 IF $ORDER(PSDA(0))
DO ^PSDORD1
if $GET(PSDOUT)
GOTO END
+8 if '$ORDER(PSDA(0))
WRITE " No pending requests.",!
DRUG ;select drug
+1 ;; PSD*3*51 - RJS
SET MSG=0
+2 KILL DA,DIC,PSDR
SET DIC("W")="W:$P(^PSDRUG(Y,0),""^"",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 ;one time requests not 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 $DATA(DTOUT)!($DATA(DUOUT))
GOTO END
if Y<1&($ORDER(PSDA(0)))
GOTO ^PSDORD1
if Y<1
GOTO END
SET PSDR=+Y
SET PSDRN=$SELECT($PIECE(^PSDRUG(PSDR,0),"^")]"":$PIECE(^(0),"^"),1:"DRUG NAME MISSING")
+11 IF $SELECT('$DATA(^PSD(58.8,NAOU,1,PSDR,0)):1,$PIECE(^(0),U,14)&($PIECE(^(0),U,14)'>DT):1,1:0)
DO ^PSDORD4
if $DATA(DIRUT)
GOTO END
GOTO DRUG
+12 IF '$DATA(^PSD(58.8,NAOU,1,PSDR,0))
DO MSG
GOTO END
+13 IF '$DATA(^PSD(58.8,+PSDS,1,PSDR,0))
SET MSG=2
DO MSG
GOTO END
+14 SET NBKU=$PIECE(^PSD(58.8,+PSDS,1,PSDR,0),"^",8)
SET NPKG=+$PIECE(^(0),"^",9)
+15 IF NBKU']""
SET MSG1=3
DO MSG
GOTO END
+16 IF 'NPKG
SET MSG1=4
DO MSG
GOTO END
+17 DO LIST^PSDORL
+18 ;Perpetual?
+19 if $PIECE($GET(^PSD(58.8,+NAOU,2)),U,5)
GOTO ^PSDORD3
QTY KILL ORD
SET PSDOUT=0
SET DIR(0)="58.800118,5A"
+1 SET DIR("A")="QUANTITY ("_NBKU_"/"_NPKG_"): "
SET DIR("B")=NPKG
+2 DO ^DIR
KILL DIR
if $DATA(DIRUT)
GOTO END
if Y<1
GOTO DRUG
+3 IF Y=NPKG
SET PSDQTY=Y
DO DIE
WRITE !
GOTO DRUG
+4 IF X["?"!(X'?1.N)!(X#NPKG)!('X)
WRITE !!,"Quantity must be "_NPKG_" or a multiple of "_NPKG,!
GOTO QTY
+5 SET CNT=X/NPKG
WRITE !!,"This will be "_CNT_" separate order requests. The quantity is "_NPKG_" per request."
+6 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,"
+7 SET DIR("?")="Answer 'NO' to edit your comments or '^' to quit."
DO ^DIR
KILL DIR
if $DATA(DIRUT)
GOTO END
+8 IF 'Y
WRITE !,"No order request created. You must edit quantity.",!
GOTO QTY
+9 IF Y
WRITE !!,"The "_CNT_" requests are being created.",!
SET PSDQTY=NPKG
Begin DoDot:1
+10 FOR ORD=1:1:CNT
WRITE !!,"Creating your order request # "_ORD_" of "_CNT_" for "_PSDRN
DO DIE
SET PSDA(+PSDR,PSDA)=$GET(^PSD(58.8,+NAOU,1,+PSDR,3,+PSDA,0))
End DoDot:1
WRITE !
GOTO DRUG
+11 IF '$GET(PSDOUT)
WRITE !
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 NAOU,NAOUN,NBKU,NPKG,OK,OKTYP,ORD,PSD,PSDA,PSDB,PSDOUT,PSDQTY,PSDRD,PSDR,PSDRN,PSDS,PSDT,PSDUZ,PSDUZN,REQD,TEXT,TYPE,WORD,X,Y
+2 QUIT
DIE ;create the order request
+1 FOR
LOCK +^PSD(58.8,NAOU,1,PSDR,0):$SELECT($GET(DILOCKTM)>0:DILOCKTM,1:3)
IF $TEST
QUIT
+2 if '$DATA(^PSD(58.8,NAOU,1,PSDR,3,0))
SET ^(0)="^58.800118A^^"
DIE2 SET PSDA=$PIECE(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)+1
IF $DATA(^PSD(58.8,NAOU,1,PSDR,3,PSDA))
SET $PIECE(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)=$PIECE(^PSD(58.8,NAOU,1,PSDR,3,0),"^",3)+1
GOTO DIE2
+1 KILL DA,DIC,DIE,DD,DR,DO
SET DIC(0)="L"
SET (DIC,DIE)="^PSD(58.8,"_NAOU_",1,"_PSDR_",3,"
SET DA(2)=NAOU
SET DA(1)=PSDR
SET (X,DINUM)=PSDA
DO FILE^DICN
KILL DIC
+2 DO NOW^%DTC
SET PSDT=+$EXTRACT(%,1,12)
WRITE ?10,!!,"processing now..."
+3 SET DA=PSDA
SET DA(1)=PSDR
SET DA(2)=NAOU
SET DR="1////"_PSDT_";2////"_+PSDS_";3////"_PSDUZ_";10////.5;5////"_PSDQTY_";13"
DO ^DIE
KILL DIE,DR
+4 SET PSDA(+PSDR,+PSDA)=$GET(^PSD(58.8,+NAOU,1,+PSDR,3,PSDA,0))
+5 LOCK -^PSD(58.8,NAOU,1,PSDR,0)
+6 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