PSOORUTL ;ISC BHAM/SAB - updates order status from oerr ;29-May-2012 15:03;PLS
;;7.0;OUTPATIENT PHARMACY;**14,46,146,132,1002,1005,1007,118,199,223,148,249,274,225,1015**;DEC 1997;Build 62
;External reference to EN^ORERR - 2187
;External reference to ^PS(55 - 2228
;Input variables, poerr("psofilnm")=pharmacy pointer # from OE/RR, poerr("stat")=Order Control status
;poerr("pharmst")=will contain 'ZE'if rx has expired, poerr("comm")=Comments, poerr("user")=Person placing request
; Modified - IHS/CIA/PLS - 11/11/04 - Line PEXIT+7 and new EP CANDATE (Removed in patch 1010)
; IHS/MSC/PLS - 08/14/08 - Line CAN+2
EN(POERR) ;
N PSZORS,III
F OO=0:0 S OO=$O(MSG(OO)) Q:'OO I $P(MSG(OO),"|")="ZRN" S NVA=1
I $G(NVA) G NVA
G:POERR("PSOFILNM")'["S" RXO S III=+POERR("PSOFILNM")
S ORS=0 I $D(^PS(52.41,III,0)) D G PEXIT
.Q:$P($G(^PS(52.41,III,0)),"^",3)="RF"
.I $G(PDFN),$P($G(^PS(52.41,III,0)),"^",2),PDFN'=$P(^PS(52.41,III,0),"^",2) S ORS=1
RXO S III=POERR("PSOFILNM") I $D(^PSRX(III,0)) D G PEXIT
.I $G(PDFN),$P($G(^PSRX(III,0)),"^",2),PDFN'=$P(^PSRX(III,0),"^",2) S ORS=1
S (ORS,PSZORS)=1
PEXIT I $G(ORS) S POERR("STAT")=$S(POERR("STAT")="CA":"UC",POERR("STAT")="DC":"UD",POERR("STAT")="HD":"UH",1:"UR"),POERR("FILLER")="",POERR("COMM")=$S($G(PSZORS):"Invalid Pharmacy order number",1:"Patient does not match.") K ORS,PSZORS,III Q
S POERR("PHARMST")="" G:POERR("STAT")="HD"!(POERR("STAT")="RL") HD
S ORS=0 I POERR("PSOFILNM")["S" S DA=+POERR("PSOFILNM") I $D(^PS(52.41,DA,0)) D G EXIT
.Q:$P($G(^PS(52.41,DA,0)),"^",3)="RF"
.S $P(^PS(52.41,DA,0),"^",3)="DC",POERR("PLACE")=$P(^(0),"^"),POERR("STAT")="CR",POERR("FILLER")=DA_"^P"
.K ^PS(52.41,"AOR",+$P($G(^PS(52.41,DA,0)),"^",2),+$P($G(^PS(52.41,DA,"INI")),"^"),DA)
.S:$G(POERR("COMM"))']"" POERR("COMM")="Order Canceled by OE/RR before finishing." S ORS=1,$P(^PS(52.41,DA,4),"^")=$G(POERR("COMM"))
S DA=POERR("PSOFILNM") D:$D(^PSRX(DA,0)) REVERSE^PSOBPSU1(DA,,"DC",7)
I $D(^PSRX(DA,0)) D S $P(^PSRX(DA,"STA"),"^")=14,$P(^PSRX(DA,3),"^",5)=DT,$P(^PSRX(DA,3),"^",10)=$P(^PSRX(DA,3),"^") D CAN^PSOTPCAN(DA) G EXIT
.;cancel/discontinue action
.S POERR("PLACE")=+$P($G(^PSRX(DA,"OR1")),"^",2),POERR("STAT")=$S(POERR("STAT")="CA":"CR",1:"DR"),POERR("FILLER")=DA_"^R"
.S:'$D(POERR("COMM")) POERR("COMM")="Prescription DISCONTINUED by OERR"
.S ORS=1 D CAN
EXIT I '$G(ORS) D
.S POERR("STAT")=$S(POERR("STAT")="CA":"UC",POERR("STAT")="DC":"UD",POERR("STAT")="HD":"UH",1:"UR"),POERR("FILLER")="",POERR("COMM")="Order was not located by Pharmacy"
K EXP,ORS,DA,ACOM,RXDA,SUSD,PSUS,RXF,I,FDA,DIC,DIE,DR,Y,X,%,%I,%H,RSDT,ACNT,ACT,DIK,FDT,IR,LFD,NOW,ORD,PSDA,PSCDA,PSODFN,PSUS,RF,RFCNT,RXN,RXP,RXREF,SD,SUB
Q
CAN S ACOM="Discontinued by OE/RR." I $P(^PSRX(DA,"STA"),"^")=3!($P(^("STA"),"^")=16) D
.S ACOM="Discontinued by OE/RR while on hold. " K:$P(^PSRX(DA,"H"),"^") ^PSRX("AH",$P(^PSRX(DA,"H"),"^"),DA) S ^PSRX(DA,"H")=""
.;IHS/MSC/PLS - 08/14/08 - Suppress the setting of the Fill Date for prescriptions on HOLD
.;I $P(^PSRX(DA,0),"^",13),'$O(^PSRX(DA,1,0)) S DIE=52,DR="22///"_$E($P(^PSRX(DA,0),"^",13),1,7) D ^DIE K DIE,DR Q
.S (IFN,SUSD)=0 F S IFN=$O(^PSRX(DA,1,IFN)) Q:'IFN S SUSD=IFN,RFDT=$P(^PSRX(DA,1,IFN,0),"^")
.Q:'$G(SUSD) I '$P(^PSRX(DA,1,SUSD,0),"^",18) S PSDTEST=0 D I 'PSDTEST K ^PSRX(DA,1,SUSD),^PSRX("AD",RFDT,DA,SUSD),^PSRX(DA,1,"B",RFDT,SUSD),IFN,SUSD,RFDT
..F PDA=0:0 S PDA=$O(^PSRX(DA,"L",PDA)) Q:'PDA I $P($G(^PSRX(DA,"L",PDA,0)),"^",2)=SUSD S PSDTEST=1
..K CMOP D ^PSOCMOPA I $G(CMOP(CMOP("L")))="",$G(CMOP("S"))'="L" Q
..S PSDTEST=1
S RXDA=DA,(DA,SUSDA)=$O(^PS(52.5,"B",DA,0)) D:DA
.S SUSD=$P($G(^PS(52.5,DA,0)),"^",2)
.S:+$G(^PS(52.5,DA,"P"))'=1 ACOM="Discontinued by OE/RR while suspended."
.I $O(^PSRX(RXDA,1,0)) S DA=RXDA D:'$G(^PS(52.5,+SUSDA,"P")) REF^PSOCAN2
.S DA=SUSDA,DIK="^PS(52.5," D ^DIK K DIK
K SUSD,SUSDA S DA=RXDA,RXREF=0,PSODFN=+$P(^PSRX(DA,0),"^",2) D
.S ACNT=0 F SUB=0:0 S SUB=$O(^PSRX(DA,"A",SUB)) Q:'SUB S ACNT=SUB
.S RFCNT=0 F RF=0:0 S RF=$O(^PSRX(DA,1,RF)) Q:'RF S RFCNT=RF S:RF>5 RFCNT=RF+1
.D NOW^%DTC S ^PSRX(DA,"A",0)="^52.3DA^"_(ACNT+1)_"^"_(ACNT+1),^PSRX(DA,"A",ACNT+1,0)=%_"^C^"_POERR("USER")_"^"_RFCNT_"^"_$G(ACOM)
.S REA="C" D EXP^PSOHELP1
I $G(^PS(52.4,DA,0))]"" S PSCDA=DA,DIK="^PS(52.4," D ^DIK S DA=PSCDA K DIK,PSCDA
Q
HD ;place order on hold
G:POERR("STAT")="RL" REL^PSOORUT1 S (ACT,ORS)=0 I POERR("PSOFILNM")["S" D G EXIT
.S DA=+POERR("PSOFILNM")
.Q:'$D(^PS(52.41,DA,0)) Q:$P(^PS(52.41,DA,0),"^",3)="RF"
.S $P(^PS(52.41,DA,0),"^",3)="HD",POERR("STAT")="HR",POERR("FILLER")=DA_"^P"
.S:$G(POERR("COMM"))']"" POERR("COMM")="Order PLACED on HOLD by OERR before finished." S $P(^PS(52.41,DA,4),"^")=POERR("COMM"),ORS=1
S DA=POERR("PSOFILNM") I $D(^PSRX(DA,0)) S ORS=1,PSDA=DA D G EXIT
.S POERR("FILLER")=DA_"^R"
.S:'$D(POERR("COMM")) POERR("COMM")="Prescription Placed on HOLD by OERR"
.I DT>$P(^PSRX(DA,2),"^",6) S EXP=$P(^(2),"^",6) S:$P(^PSRX(DA,"STA"),"^")<12 $P(^PSRX(DA,"STA"),"^")=11,PSOEXFLG=1 S POERR("STAT")="UH",POERR("COMM")="Prescription EXPIRED on "_$E(EXP,4,5)_"/"_$E(EXP,6,7)_"/"_$E(EXP,2,3)_"." D Q
..D ECAN^PSOUTL(DA)
.I $P(^PSRX(DA,"STA"),"^")=3!($P(^("STA"),"^")>11) S POERR("STAT")="UH",POERR("COMM")="Unable to place on HOLD" Q
.S $P(^PSRX(DA,"STA"),"^")=16,POERR("STAT")="HR",^PSRX(DA,"H")=99_"^"_POERR("COMM")_"^"_DT
.S (PSUS,RXF)=0 F I=0:0 S I=$O(^PSRX(DA,1,I)) Q:'I S RXF=I S:RXF>1 RSDT=$P(^(RXF-1,0),"^")
.S DA=PSDA D ACT D REVERSE^PSOBPSU1(DA,,"HLD",2)
.S DA=$O(^PS(52.5,"B",PSDA,0)) I DA S DIK="^PS(52.5,",PSUS=1 D ^DIK K DA,DIK
I 'ORS S POERR("COMM")="Unable to place order on HOLD" G EXIT
Q
NVA ;non-va med action
N DIE,DR,DA K NVA
I POERR("PSOFILNM")'["N"!('$D(^PS(55,PDFN,"NVA",+POERR("PSOFILNM"),0))) D EN^ORERR("Order was not located by Pharmacy",.MSG) Q
I $G(OR("STAT"))'="CA",$G(OR("STAT"))'="DC" D EN^ORERR("Invalid Order Control Code",.MSG) Q
XO S ORD=+POERR("PSOFILNM")
N TMP
D NOW^%DTC
K TMP S TMP(55.05,ORD_","_PDFN_",",5)=$S($G(PSODEATH):2,1:1)
S TMP(55.05,ORD_","_PDFN_",",6)=%
D FILE^DIE("","TMP")
S PLACER=$P(^PS(55,PDFN,"NVA",ORD,0),"^",8)
K MSG S NULLFLDS="F JJ=0:1:LIMIT S FIELD(JJ)="""""
K ^UTILITY("DIQ1",$J),DIQ S DA=$P($$SITE^VASITE(),"^")
I $G(DA) S DIC=4,DIQ(0)="I",DR="99" D EN^DIQ1 S PSOHINST=$G(^UTILITY("DIQ1",$J,4,DA,99,"I")) K ^UTILITY("DIQ1",$J),DA,DR,DIQ,DIC
S MSG(1)="MSH|^~\&|PHARMACY|"_$G(PSOHINST)_"|||||ORR"
;
S DFN=PDFN,COUNT=1,LIMIT=5 X NULLFLDS D DEM^VADPT S NAME=$G(VADM(1)) K VADM
S FIELD(0)="PID",FIELD(3)=DFN,FIELD(5)=NAME
D SEG^PSOHLSN1
;
S LIMIT=15 X NULLFLDS
S FIELD(0)="ORC",FIELD(2)=PLACER_"^OR",FIELD(3)=+POERR("PSOFILNM")_"N^PS"
S FIELD(1)="SC",FIELD(5)="DC"
D SEG^PSOHLSN1
I $G(PSODEATH) S MSG(COUNT)=MSG(COUNT)_"|^^^^DATE OF DEATH ENTERED BY MAS.^"
;
D SEND^PSOHLSN1 K FIELDS,LIMIT,PSODSC,PSONVA,OI
Q
;
ACT ;activity log
D NOW^%DTC S NOW=%
S IR=0 F FDA=0:0 S FDA=$O(^PSRX(DA,"A",FDA)) Q:'FDA S IR=FDA
S IR=IR+1,^PSRX(DA,"A",0)="^52.3DA^"_IR_"^"_IR
S RXF=$S(RXF>5:RXF+1,1:RXF)
S ^PSRX(DA,"A",IR,0)=NOW_"^"_$S(ACT:"U",1:"H")_"^"_POERR("USER")_"^"_RXF_"^"_"RX "_$S('ACT:"placed in a",1:"removed from")_" HOLD status "_$S(+$G(PSUS):"and removed from SUSPENSE ",1:"")_"("_$E(DT,4,5)_"-"_$E(DT,6,7)_"-"_$E(DT,2,3)_") by OERR."
Q
PSOORUTL ;ISC BHAM/SAB - updates order status from oerr ;29-May-2012 15:03;PLS
+1 ;;7.0;OUTPATIENT PHARMACY;**14,46,146,132,1002,1005,1007,118,199,223,148,249,274,225,1015**;DEC 1997;Build 62
+2 ;External reference to EN^ORERR - 2187
+3 ;External reference to ^PS(55 - 2228
+4 ;Input variables, poerr("psofilnm")=pharmacy pointer # from OE/RR, poerr("stat")=Order Control status
+5 ;poerr("pharmst")=will contain 'ZE'if rx has expired, poerr("comm")=Comments, poerr("user")=Person placing request
+6 ; Modified - IHS/CIA/PLS - 11/11/04 - Line PEXIT+7 and new EP CANDATE (Removed in patch 1010)
+7 ; IHS/MSC/PLS - 08/14/08 - Line CAN+2
EN(POERR) ;
+1 NEW PSZORS,III
+2 FOR OO=0:0
SET OO=$ORDER(MSG(OO))
IF 'OO
QUIT
IF $PIECE(MSG(OO),"|")="ZRN"
SET NVA=1
+3 IF $GET(NVA)
GOTO NVA
+4 IF POERR("PSOFILNM")'["S"
GOTO RXO
SET III=+POERR("PSOFILNM")
+5 SET ORS=0
IF $DATA(^PS(52.41,III,0))
Begin DoDot:1
+6 IF $PIECE($GET(^PS(52.41,III,0)),"^",3)="RF"
QUIT
+7 IF $GET(PDFN)
IF $PIECE($GET(^PS(52.41,III,0)),"^",2)
IF PDFN'=$PIECE(^PS(52.41,III,0),"^",2)
SET ORS=1
End DoDot:1
GOTO PEXIT
RXO SET III=POERR("PSOFILNM")
IF $DATA(^PSRX(III,0))
Begin DoDot:1
+1 IF $GET(PDFN)
IF $PIECE($GET(^PSRX(III,0)),"^",2)
IF PDFN'=$PIECE(^PSRX(III,0),"^",2)
SET ORS=1
End DoDot:1
GOTO PEXIT
+2 SET (ORS,PSZORS)=1
PEXIT IF $GET(ORS)
SET POERR("STAT")=$SELECT(POERR("STAT")="CA":"UC",POERR("STAT")="DC":"UD",POERR("STAT")="HD":"UH",1:"UR")
SET POERR("FILLER")=""
SET POERR("COMM")=$SELECT($GET(PSZORS):"Invalid Pharmacy order number",1:"Patient does not match.")
KILL ORS,PSZORS,III
QUIT
+1 SET POERR("PHARMST")=""
IF POERR("STAT")="HD"!(POERR("STAT")="RL")
GOTO HD
+2 SET ORS=0
IF POERR("PSOFILNM")["S"
SET DA=+POERR("PSOFILNM")
IF $DATA(^PS(52.41,DA,0))
Begin DoDot:1
+3 IF $PIECE($GET(^PS(52.41,DA,0)),"^",3)="RF"
QUIT
+4 SET $PIECE(^PS(52.41,DA,0),"^",3)="DC"
SET POERR("PLACE")=$PIECE(^(0),"^")
SET POERR("STAT")="CR"
SET POERR("FILLER")=DA_"^P"
+5 KILL ^PS(52.41,"AOR",+$PIECE($GET(^PS(52.41,DA,0)),"^",2),+$PIECE($GET(^PS(52.41,DA,"INI")),"^"),DA)
+6 IF $GET(POERR("COMM"))']""
SET POERR("COMM")="Order Canceled by OE/RR before finishing."
SET ORS=1
SET $PIECE(^PS(52.41,DA,4),"^")=$GET(POERR("COMM"))
End DoDot:1
GOTO EXIT
+7 SET DA=POERR("PSOFILNM")
IF $DATA(^PSRX(DA,0))
DO REVERSE^PSOBPSU1(DA,,"DC",7)
+8 IF $DATA(^PSRX(DA,0))
Begin DoDot:1
+9 ;cancel/discontinue action
+10 SET POERR("PLACE")=+$PIECE($GET(^PSRX(DA,"OR1")),"^",2)
SET POERR("STAT")=$SELECT(POERR("STAT")="CA":"CR",1:"DR")
SET POERR("FILLER")=DA_"^R"
+11 IF '$DATA(POERR("COMM"))
SET POERR("COMM")="Prescription DISCONTINUED by OERR"
+12 SET ORS=1
DO CAN
End DoDot:1
SET $PIECE(^PSRX(DA,"STA"),"^")=14
SET $PIECE(^PSRX(DA,3),"^",5)=DT
SET $PIECE(^PSRX(DA,3),"^",10)=$PIECE(^PSRX(DA,3),"^")
DO CAN^PSOTPCAN(DA)
GOTO EXIT
EXIT IF '$GET(ORS)
Begin DoDot:1
+1 SET POERR("STAT")=$SELECT(POERR("STAT")="CA":"UC",POERR("STAT")="DC":"UD",POERR("STAT")="HD":"UH",1:"UR")
SET POERR("FILLER")=""
SET POERR("COMM")="Order was not located by Pharmacy"
End DoDot:1
+2 KILL EXP,ORS,DA,ACOM,RXDA,SUSD,PSUS,RXF,I,FDA,DIC,DIE,DR,Y,X,%,%I,%H,RSDT,ACNT,ACT,DIK,FDT,IR,LFD,NOW,ORD,PSDA,PSCDA,PSODFN,PSUS,RF,RFCNT,RXN,RXP,RXREF,SD,SUB
+3 QUIT
CAN SET ACOM="Discontinued by OE/RR."
IF $PIECE(^PSRX(DA,"STA"),"^")=3!($PIECE(^("STA"),"^")=16)
Begin DoDot:1
+1 SET ACOM="Discontinued by OE/RR while on hold. "
IF $PIECE(^PSRX(DA,"H"),"^")
KILL ^PSRX("AH",$PIECE(^PSRX(DA,"H"),"^"),DA)
SET ^PSRX(DA,"H")=""
+2 ;IHS/MSC/PLS - 08/14/08 - Suppress the setting of the Fill Date for prescriptions on HOLD
+3 ;I $P(^PSRX(DA,0),"^",13),'$O(^PSRX(DA,1,0)) S DIE=52,DR="22///"_$E($P(^PSRX(DA,0),"^",13),1,7) D ^DIE K DIE,DR Q
+4 SET (IFN,SUSD)=0
FOR
SET IFN=$ORDER(^PSRX(DA,1,IFN))
IF 'IFN
QUIT
SET SUSD=IFN
SET RFDT=$PIECE(^PSRX(DA,1,IFN,0),"^")
+5 IF '$GET(SUSD)
QUIT
IF '$PIECE(^PSRX(DA,1,SUSD,0),"^",18)
SET PSDTEST=0
Begin DoDot:2
+6 FOR PDA=0:0
SET PDA=$ORDER(^PSRX(DA,"L",PDA))
IF 'PDA
QUIT
IF $PIECE($GET(^PSRX(DA,"L",PDA,0)),"^",2)=SUSD
SET PSDTEST=1
+7 KILL CMOP
DO ^PSOCMOPA
IF $GET(CMOP(CMOP("L")))=""
IF $GET(CMOP("S"))'="L"
QUIT
+8 SET PSDTEST=1
End DoDot:2
IF 'PSDTEST
KILL ^PSRX(DA,1,SUSD),^PSRX("AD",RFDT,DA,SUSD),^PSRX(DA,1,"B",RFDT,SUSD),IFN,SUSD,RFDT
End DoDot:1
+9 SET RXDA=DA
SET (DA,SUSDA)=$ORDER(^PS(52.5,"B",DA,0))
IF DA
Begin DoDot:1
+10 SET SUSD=$PIECE($GET(^PS(52.5,DA,0)),"^",2)
+11 IF +$GET(^PS(52.5,DA,"P"))'=1
SET ACOM="Discontinued by OE/RR while suspended."
+12 IF $ORDER(^PSRX(RXDA,1,0))
SET DA=RXDA
IF '$GET(^PS(52.5,+SUSDA,"P"))
DO REF^PSOCAN2
+13 SET DA=SUSDA
SET DIK="^PS(52.5,"
DO ^DIK
KILL DIK
End DoDot:1
+14 KILL SUSD,SUSDA
SET DA=RXDA
SET RXREF=0
SET PSODFN=+$PIECE(^PSRX(DA,0),"^",2)
Begin DoDot:1
+15 SET ACNT=0
FOR SUB=0:0
SET SUB=$ORDER(^PSRX(DA,"A",SUB))
IF 'SUB
QUIT
SET ACNT=SUB
+16 SET RFCNT=0
FOR RF=0:0
SET RF=$ORDER(^PSRX(DA,1,RF))
IF 'RF
QUIT
SET RFCNT=RF
IF RF>5
SET RFCNT=RF+1
+17 DO NOW^%DTC
SET ^PSRX(DA,"A",0)="^52.3DA^"_(ACNT+1)_"^"_(ACNT+1)
SET ^PSRX(DA,"A",ACNT+1,0)=%_"^C^"_POERR("USER")_"^"_RFCNT_"^"_$GET(ACOM)
+18 SET REA="C"
DO EXP^PSOHELP1
End DoDot:1
+19 IF $GET(^PS(52.4,DA,0))]""
SET PSCDA=DA
SET DIK="^PS(52.4,"
DO ^DIK
SET DA=PSCDA
KILL DIK,PSCDA
+20 QUIT
HD ;place order on hold
+1 IF POERR("STAT")="RL"
GOTO REL^PSOORUT1
SET (ACT,ORS)=0
IF POERR("PSOFILNM")["S"
Begin DoDot:1
+2 SET DA=+POERR("PSOFILNM")
+3 IF '$DATA(^PS(52.41,DA,0))
QUIT
IF $PIECE(^PS(52.41,DA,0),"^",3)="RF"
QUIT
+4 SET $PIECE(^PS(52.41,DA,0),"^",3)="HD"
SET POERR("STAT")="HR"
SET POERR("FILLER")=DA_"^P"
+5 IF $GET(POERR("COMM"))']""
SET POERR("COMM")="Order PLACED on HOLD by OERR before finished."
SET $PIECE(^PS(52.41,DA,4),"^")=POERR("COMM")
SET ORS=1
End DoDot:1
GOTO EXIT
+6 SET DA=POERR("PSOFILNM")
IF $DATA(^PSRX(DA,0))
SET ORS=1
SET PSDA=DA
Begin DoDot:1
+7 SET POERR("FILLER")=DA_"^R"
+8 IF '$DATA(POERR("COMM"))
SET POERR("COMM")="Prescription Placed on HOLD by OERR"
+9 IF DT>$PIECE(^PSRX(DA,2),"^",6)
SET EXP=$PIECE(^(2),"^",6)
IF $PIECE(^PSRX(DA,"STA"),"^")<12
SET $PIECE(^PSRX(DA,"STA"),"^")=11
SET PSOEXFLG=1
SET POERR("STAT")="UH"
SET POERR("COMM")="Prescription EXPIRED on "_$EXTRACT(EXP,4,5)_"/"_$EXTRACT(EXP,6,7)_"/"_$EXTRACT(EXP,2,3)_"."
Begin DoDot:2
+10 DO ECAN^PSOUTL(DA)
End DoDot:2
QUIT
+11 IF $PIECE(^PSRX(DA,"STA"),"^")=3!($PIECE(^("STA"),"^")>11)
SET POERR("STAT")="UH"
SET POERR("COMM")="Unable to place on HOLD"
QUIT
+12 SET $PIECE(^PSRX(DA,"STA"),"^")=16
SET POERR("STAT")="HR"
SET ^PSRX(DA,"H")=99_"^"_POERR("COMM")_"^"_DT
+13 SET (PSUS,RXF)=0
FOR I=0:0
SET I=$ORDER(^PSRX(DA,1,I))
IF 'I
QUIT
SET RXF=I
IF RXF>1
SET RSDT=$PIECE(^(RXF-1,0),"^")
+14 SET DA=PSDA
DO ACT
DO REVERSE^PSOBPSU1(DA,,"HLD",2)
+15 SET DA=$ORDER(^PS(52.5,"B",PSDA,0))
IF DA
SET DIK="^PS(52.5,"
SET PSUS=1
DO ^DIK
KILL DA,DIK
End DoDot:1
GOTO EXIT
+16 IF 'ORS
SET POERR("COMM")="Unable to place order on HOLD"
GOTO EXIT
+17 QUIT
NVA ;non-va med action
+1 NEW DIE,DR,DA
KILL NVA
+2 IF POERR("PSOFILNM")'["N"!('$DATA(^PS(55,PDFN,"NVA",+POERR("PSOFILNM"),0)))
DO EN^ORERR("Order was not located by Pharmacy",.MSG)
QUIT
+3 IF $GET(OR("STAT"))'="CA"
IF $GET(OR("STAT"))'="DC"
DO EN^ORERR("Invalid Order Control Code",.MSG)
QUIT
XO SET ORD=+POERR("PSOFILNM")
+1 NEW TMP
+2 DO NOW^%DTC
+3 KILL TMP
SET TMP(55.05,ORD_","_PDFN_",",5)=$SELECT($GET(PSODEATH):2,1:1)
+4 SET TMP(55.05,ORD_","_PDFN_",",6)=%
+5 DO FILE^DIE("","TMP")
+6 SET PLACER=$PIECE(^PS(55,PDFN,"NVA",ORD,0),"^",8)
+7 KILL MSG
SET NULLFLDS="F JJ=0:1:LIMIT S FIELD(JJ)="""""
+8 KILL ^UTILITY("DIQ1",$JOB),DIQ
SET DA=$PIECE($$SITE^VASITE(),"^")
+9 IF $GET(DA)
SET DIC=4
SET DIQ(0)="I"
SET DR="99"
DO EN^DIQ1
SET PSOHINST=$GET(^UTILITY("DIQ1",$JOB,4,DA,99,"I"))
KILL ^UTILITY("DIQ1",$JOB),DA,DR,DIQ,DIC
+10 SET MSG(1)="MSH|^~\&|PHARMACY|"_$GET(PSOHINST)_"|||||ORR"
+11 ;
+12 SET DFN=PDFN
SET COUNT=1
SET LIMIT=5
XECUTE NULLFLDS
DO DEM^VADPT
SET NAME=$GET(VADM(1))
KILL VADM
+13 SET FIELD(0)="PID"
SET FIELD(3)=DFN
SET FIELD(5)=NAME
+14 DO SEG^PSOHLSN1
+15 ;
+16 SET LIMIT=15
XECUTE NULLFLDS
+17 SET FIELD(0)="ORC"
SET FIELD(2)=PLACER_"^OR"
SET FIELD(3)=+POERR("PSOFILNM")_"N^PS"
+18 SET FIELD(1)="SC"
SET FIELD(5)="DC"
+19 DO SEG^PSOHLSN1
+20 IF $GET(PSODEATH)
SET MSG(COUNT)=MSG(COUNT)_"|^^^^DATE OF DEATH ENTERED BY MAS.^"
+21 ;
+22 DO SEND^PSOHLSN1
KILL FIELDS,LIMIT,PSODSC,PSONVA,OI
+23 QUIT
+24 ;
ACT ;activity log
+1 DO NOW^%DTC
SET NOW=%
+2 SET IR=0
FOR FDA=0:0
SET FDA=$ORDER(^PSRX(DA,"A",FDA))
IF 'FDA
QUIT
SET IR=FDA
+3 SET IR=IR+1
SET ^PSRX(DA,"A",0)="^52.3DA^"_IR_"^"_IR
+4 SET RXF=$SELECT(RXF>5:RXF+1,1:RXF)
+5 SET ^PSRX(DA,"A",IR,0)=NOW_"^"_$SELECT(ACT:"U",1:"H")_"^"_POERR("USER")_"^"_RXF_"^"_"RX "_...
... $SELECT('ACT:"placed in a",1:"removed from")_" HOLD status "_$SELECT(+$GET(PSUS):"and removed from SUSPENSE ",1:"")_"("_$EXTRACT(DT,4,5)_"-"_$EXTRACT(DT,6,7)_"-"_$EXTRACT(DT,2,3)_") by OERR."
+6 QUIT