PSOORNE1 ;BIR/SAB - Display new orders from backdoor ;29-May-2012 14:58;PLS
;;7.0;OUTPATIENT PHARMACY;**11,21,27,32,37,46,71,94,104,117,133,1005,148,279,1015**;DEC 1997;Build 62
;External reference to ^PS(55 is supported by DBIA 2228
; Modified - IHS/CIA/PLS - 01/27/04 - Added ability to select 0 for IHS Fields
EN(PSONEW) D DSPL^PSOORNE3,^PSOLMPO2
Q
; IHS/CIA/PLS - 01/27/04 - Commented out next to extend range to include zero
EDT ;N FLD,LST K DIR,DUOUT,DIRUT S DIR("A")="Select Field to Edit by number",DIR(0)="LO^1:14" D ^DIR I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DTOUT S VALMBCK="" Q
N FLD,LST K DIR,DUOUT,DIRUT S DIR("A")="Select Field to Edit by number",DIR(0)="LO^0:14" D ^DIR I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DTOUT S VALMBCK="" Q
EDTSEL S:'$G(COPY) PSOEDIT=1 S (PSONEW("DFLG"),PSONEW("FIELD"),PSONEW3)=0
; IHS/CIA/PLS - 01/27/04 - Changed to $L to include zero value
;I +Y S LST=Y D HLDHDR^PSOLMUTL D Q:$G(PSORX("DFLG"))!($G(PSORX("QFLG"))) S VALMBCK="R" G DSPL^PSOORNE3
I $L(Y) S LST=Y D HLDHDR^PSOLMUTL D Q:$G(PSORX("DFLG"))!($G(PSORX("QFLG"))) S VALMBCK="R" G DSPL^PSOORNE3
.F FLD=1:1:$L(LST,",") Q:$P(LST,",",FLD)']"" D @(+$P(LST,",",FLD)) Q:$G(PSODIR("DFLG"))!($G(PSODIR("QFLG")))
E S VALMBCK="" D FULL^VALM1
D RDSPL G DSPL^PSOORNE3
Q
ACP K VALMSG,DIR,PSORX("DFLG") D VER I $G(PSONEW2("QFLG"))!($G(PSORX("DFLG"))) S VALMBCK="Q" K PSONEW2 Q
N PSONOBCK S PSONOBCK=$S($G(PSOSIGFL):1,1:0)
D NOOR^PSONEW I $D(DIRUT) S PSONEW("DFLG")=1 K DIR,X,Y,DIRUT,DUOUT,DTOUT Q
D RXNCHK,RDSPL
I $G(PSONEW("QFLG")) S PSONEW("DFLG")=1 K DIR,X,Y,DIRUT,DUOUT,DTOUT Q
D DISPLAY^PSONEW2
D ^PSONEWG I $G(PSOCPZ("DFLG")) S PSONEW("DFLG")=1 K PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT,PSOCPZ("DFLG"),PSOANSQD Q
K PSOCPZ("DFLG")
K DIR,DIRUT,X,Y S DIR(0)="Y",DIR("B")="YES",DIR("A")="Is this correct" D ^DIR
I $D(DIRUT) S PSONEW("DFLG")=1 K PSOANSQ,PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT Q
I 'Y S VALMBCK="R" K PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT D DSPL^PSOORNE3 Q
W "..." K PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT D DCORD^PSONEW2
I $G(NCPDPFLG) D NCPDP^PSOORED6
K:$G(COPY)!($G(PSOSIGFL)) PRC,PHI
S:'$G(PSOID) PSOID=DT S (PSORX("FN"),PSONEW("POE"))=1 D EN^PSON52(.PSONEW) ; Files entry in File 52
I $G(PSOBEDT) D
.I '$D(^TMP("PSOBEDT",$J,PSODFN,0)) S ^TMP("PSOBEDT",$J,PSODFN,0)=PSORXED("IRXN") S:$G(PSONEW("MAIL/WINDOW"))["W" ^TMP("PSOBEDT",$J,PSODFN,1)=1 Q
.S ^TMP("PSOBEDT",$J,PSODFN,0)=^TMP("PSOBEDT",$J,PSODFN,0)_","_PSORXED("IRXN")
.I $G(PSONEW("MAIL/WINDOW"))["W" S ^TMP("PSOBEDT",$J,PSODFN,1)=1
D NPSOSD^PSOUTIL(.PSONEW) ; Adds newly added rx to PSOSD array
D ^PSOBUILD S VALMBCK="Q"
K PSONEW("# OF REFILLS"),PSONEW("DAYS SUPPLY"),SDA,SEG1,SSN1,STA,Z4,ZDA
Q:$G(COPY) S PSONEW("DFLG")=0
Q
VER I $G(PSOAC),$G(PSODRUG("NAME"))']"" D FULL^VALM1,2^PSOORNW1
I $G(PSODRUG("NAME"))']"" S VALMSG="A Dispense Drug Must be Chosen!" S PSONEW2("QFLG")=1 Q
I '$G(PSONEW("ENT")) W !,"Dosing Instruction Missing!!",! D I PSONEW("DFLG")=1 S PSONEW2("QFLG")=1 Q
.S PSOORRNW=1
.K VALMSG D FULL^VALM1 W !,"Drug: "_PSODRUG("NAME")
.I $O(SIG(0)) F I=1:1 Q:$G(SIG(I))']"" W !,SIG(I)
.E I $G(^PSRX(PSONEW("OIRXN"),"SIG"))]"" S X=$P(^PSRX(PSONEW("OIRXN"),"SIG"),"^") D SIGONE^PSOHELP W !,$E($G(INS1),2,250)
.W ! D 5 K PSOORRNW I PSONEW("DFLG")=1 D M3 Q
.D 6 D:PSONEW("DFLG")=1 M3
D:$G(COPY) PROV^PSOUTIL(.PSORENW) I PSONEW("DFLG")=1 S PSONEW2("QFLG")=1 Q
D FULL^VALM1,POST^PSODRG:'$G(PSOSIGFL) K PSONOOR I $G(PSORX("DFLG")) S VALMBCK="Q" Q
I +$G(PSEXDT) D
.D FULL^VALM1 S:$G(PSONEW("MAIL/WINDOW"))["W" BINGCRT="Y",BINGRTE="W"
.D:+$G(PSEXDT)
..S Y=PSONEW("FILL DATE") X ^DD("DD") W !!,$C(7),Y_" fill date is greater than possible expiration date of " S Y=$P(PSEXDT,"^",2) X ^DD("DD") W Y_"."
.S PSONEW2("QFLG")=1,VALMBCK="R" D PAUSE^VALM1
Q
0 ; EP - IHS/CIA/PLS - 01/26/04 - Prompt IHS Fields
D IHSFLDS^APSPDIR(.PSONEW) Q
;
1 I $G(PSOSIGFL) S PSOAC=1 D 2^PSOORNW1 K PSOAC D RDSPL G DSPL^PSOORNE3 Q
D 6^PSOBKDED D RDSPL G DSPL^PSOORNE3 Q
;
2 D 3^PSOBKDED Q
;
3 D 1^PSOBKDED Q
;
4 D 2^PSOBKDED Q
;
5 I '$G(PSODRUG("IEN")) W !,"DRUG NAME REQUIRED!" D 2^PSOORNW1 I '$G(PSODRUG("IEN")) S VALMSG="No Dispense Drug Selected" Q
W !!,"Drug: "_PSODRUG("NAME") D 10^PSOBKDED Q
;
6 D INS^PSOBKDED Q:$G(PSONEW("DFLG")) I $P($G(^PS(55,PSODFN,"LAN")),"^") D SINS^PSODIR(.PSONEW)
Q
;
7 D 8^PSOBKDED Q
;
8 D 7^PSOBKDED Q
;
9 D 9^PSOBKDED Q
;
10 D 12^PSOBKDED Q
;
11 D 5^PSOBKDED Q
;
12 D 4^PSOBKDED Q
;
13 D 11^PSOBKDED Q
;
14 D 13^PSOBKDED Q
;
SUMM ;print break down of orders to be finished
K ^TMP($J,"PSOCZT"),^TMP($J,"PSODPAT"),PAT,RT,DIR,DUOUT,DIRUT,PSZLQUIT
S DIR("A")="Do you want an Order Summary",DIR(0)="Y",DIR("B")="No"
D ^DIR K DIR I 'Y!($D(DIRUT)) K Y,X,DIRUT Q
K PSOINPRT,DIQ,^UTILITY("DIQ1",$J) I $G(PSOPINST) S DA=PSOPINST,DIC=4,DIQ(0)="E",DR=".01" D EN^DIQ1 S PSOINPRT=$G(^UTILITY("DIQ1",$J,4,DA,.01,"E")) K ^UTILITY("DIQ1",$J),DA,DR,DIC,DIQ
I $D(^PS(52.41,"ACL")) N PSOCLSUM D SUMMCL I $G(PSOCLSUM) K PSOINPRT Q
F PSI=0:0 S PSI=$O(^PS(52.41,"AOR",PSI)) Q:'PSI F PSID=0:0 S PSID=$O(^PS(52.41,"AOR",PSI,PSID)) Q:'PSID F PIN=0:0 S PIN=$O(^PS(52.41,"AOR",PSI,PSID,PIN)) Q:'PIN D
.I '$D(^TMP($J,"PSOCZT",PSID,"PAT")) F PZA="PAT","WIN","MAIL","CLIN" S ^TMP($J,"PSOCZT",PSID,PZA)=0
.I '$D(^TMP($J,"PSODPAT",PSID,PSI)) S ^TMP($J,"PSODPAT",PSID,PSI)=1,^TMP($J,"PSOCZT",PSID,"PAT")=^TMP($J,"PSOCZT",PSID,"PAT")+1
.S PZROUT=$P($G(^PS(52.41,PIN,0)),"^",17) I PZROUT'="" S ^TMP($J,"PSOCZT",PSID,$S(PZROUT="C":"CLIN",PZROUT="M":"MAIL",1:"WIN"))=^TMP($J,"PSOCZT",PSID,$S(PZROUT="C":"CLIN",PZROUT="M":"MAIL",1:"WIN"))+1
W @IOF W !?20,"Pending Outpatient Medication Orders",! I $G(PSZCNT)>1 W ?20,"(signed in under "_$G(PSOINPRT)_")",!
F PSOINL=0:0 S PSOINL=$O(^TMP($J,"PSOCZT",PSOINL)) Q:'PSOINL!($G(PSZLQUIT)) D
.I ($Y+6)>IOSL K DIR S DIR(0)="E" D ^DIR K DIR D:$G(Y) I '$G(Y) S PSZLQUIT=1 W ! Q
..W @IOF W !?20,"Pending Outpatient Medication Orders",! I $G(PSZCNT)>1 W ?20,"(signed in under "_$G(PSOINPRT)_")",!
.K ^UTILITY("DIQ1",$J),DIQ,PSOINPRX S DA=$G(PSOINL),DIC=4,DIQ(0)="E",DR=".01" D EN^DIQ1 S PSOINPRX=$G(^UTILITY("DIQ1",$J,4,DA,.01,"E")) K ^UTILITY("DIQ1",$J),DA,DR,DIC,DIQ
.;PSO*7*279 Change division to Institution
.W !,"Institution: ",$G(PSOINPRX)
.W !,"Patients: "_$G(^TMP($J,"PSOCZT",PSOINL,"PAT"))_" Window: "_$G(^("WIN"))_" Mail: "_$G(^("MAIL"))_" Clinic: "_$G(^("CLIN")),!
K DIR S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR
K ^TMP($J,"PSOCZT"),^TMP($J,"PSODPAT"),RT,PSOINPRT,PSOINPRX,PSI,PSID,PIN,PZA,PZROUT,PSOINL,PSZLQUIT
Q
SUMMCL ;
;PSO*7*279 Change Division to Institution
W ! K DIR S DIR(0)="SMB^I:INSTITUTION;C:CLINIC",DIR("A")="Do you want the summary by Institution or Clinic",DIR("B")="Institution",DIR("?")=" "
S DIR("?",1)="Enter 'I' to see the summary by Institution, and within Institution the orders",DIR("?",2)="shown by Mail, Window, or Administered in Clinic.",DIR("?",3)="Enter 'C' to see the summary by Clinic, along with Clinic Sort Groups."
D ^DIR K DIR I $D(DTOUT)!($D(DUOUT)) S PSOCLSUM=1 Q
Q:$G(Y)="I"
S PSOCLSUM=1
K ^TMP($J,"PSOLOC"),^TMP($J,"PSOLOCP") N PSCX,PSCXL,PSLX,PSCIN,PSCPT,PSCNDE,PSNCL,PSNPAT,PSCLOUT,PSCSFLAG,PCCNT,PSOCAG
F PSCX=0:0 S PSCX=$O(^PS(52.41,"ACL",PSCX)) Q:'PSCX F PSLX=0:0 S PSLX=$O(^PS(52.41,"ACL",PSCX,PSLX)) Q:'PSLX F PSCIN=0:0 S PSCIN=$O(^PS(52.41,"ACL",PSCX,PSLX,PSCIN)) Q:'PSCIN S PSCPT=+$P($G(^PS(52.41,PSCIN,0)),"^",2) D:PSCPT
.S PSCNDE=$G(^PS(52.41,PSCIN,0))
.I $P(PSCNDE,"^",3)'="NW",$P(PSCNDE,"^",3)'="RNW",$P(PSCNDE,"^",3)'="RF" Q
.I $P(PSCNDE,"^",13)="" Q
.S PSNCL=+$P(PSCNDE,"^",13),PSNPAT=+$P(PSCNDE,"^",2)
.I '$D(^TMP($J,"PSOLOC",PSNCL)) S ^TMP($J,"PSOLOC",PSNCL)="1^1",^TMP($J,"PSOLOCP",PSNCL,PSNPAT)="" Q
.S $P(^TMP($J,"PSOLOC",PSNCL),"^",2)=$P(^TMP($J,"PSOLOC",PSNCL),"^",2)+1
.I '$D(^TMP($J,"PSOLOCP",PSNCL,PSNPAT)) S $P(^TMP($J,"PSOLOC",PSNCL),"^")=$P(^TMP($J,"PSOLOC",PSNCL),"^")+1
.S ^TMP($J,"PSOLOCP",PSNCL,PSNPAT)=""
I '$O(^TMP($J,"PSOLOC",0)) G SUMMQ
W @IOF W !?20,"Pending Outpatient Medication Orders" I $G(PSZCNT)>1 W !?20,"(signed in under "_$G(PSOINPRT)_")"
F PSCXL=0:0 S PSCXL=$O(^TMP($J,"PSOLOC",PSCXL)) Q:'PSCXL!($G(PSCLOUT)) D
.I ($Y+7)>IOSL D CLDIR Q:$G(PSCLOUT)
.W !!,"Clinic: ",$P($G(^SC(+PSCXL,0)),"^")
.W !,"Patients: ",$P($G(^TMP($J,"PSOLOC",PSCXL)),"^"),?16,"Orders: ",$P($G(^TMP($J,"PSOLOC",PSCXL)),"^",2)
.W !,"In Sort Groups:"
.S (PCCNT,PSCSFLAG)=0 F PSCSORT=0:0 S PSCSORT=$O(^PS(59.8,PSCSORT)) Q:'PSCSORT!($G(PSCLOUT)) I $D(^PS(59.8,PSCSORT,1,"B",PSCXL)) S PSOCAG=0 D
..S PSCSFLAG=1 S:($Y+5)>IOSL&(PCCNT) PSOCAG=1 D:($Y+5)>IOSL&(PCCNT) CLDIR Q:$G(PSCLOUT) W:$G(PSOCAG) !,"Clinic: "_$P($G(^SC(PSCXL,0)),"^")_" cont." W:$G(PCCNT)>0 ! W ?16,$P($G(^PS(59.8,PSCSORT,0)),"^") S PCCNT=1
.I '$G(PSCSFLAG) W ?16,"*** NO CLINIC SORT GROUPS ***"
I '$G(PSCLOUT) K DIR S DIR(0)="E",DIR("A")="Press <RET> to continue" D ^DIR K DIR
SUMMQ K ^TMP($J,"PSOLOC"),^TMP($J,"PSOLOCP")
Q
CLDIR K DIR S DIR(0)="E",DIR("A")="Press <RET> to continue, '^' to exit" D ^DIR K DIR I Y'=1 S PSCLOUT=1 Q
W @IOF
Q
RXNCHK I $G(PSONEW("RX #"))']"" D RXNCHK^PSOORNE5
Q
RDSPL D RDSPL^PSOORNE5
Q
M3 D M3^PSOOREDX
Q
PSOORNE1 ;BIR/SAB - Display new orders from backdoor ;29-May-2012 14:58;PLS
+1 ;;7.0;OUTPATIENT PHARMACY;**11,21,27,32,37,46,71,94,104,117,133,1005,148,279,1015**;DEC 1997;Build 62
+2 ;External reference to ^PS(55 is supported by DBIA 2228
+3 ; Modified - IHS/CIA/PLS - 01/27/04 - Added ability to select 0 for IHS Fields
EN(PSONEW) DO DSPL^PSOORNE3
DO ^PSOLMPO2
+1 QUIT
+2 ; IHS/CIA/PLS - 01/27/04 - Commented out next to extend range to include zero
EDT ;N FLD,LST K DIR,DUOUT,DIRUT S DIR("A")="Select Field to Edit by number",DIR(0)="LO^1:14" D ^DIR I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DTOUT S VALMBCK="" Q
+1 NEW FLD,LST
KILL DIR,DUOUT,DIRUT
SET DIR("A")="Select Field to Edit by number"
SET DIR(0)="LO^0:14"
DO ^DIR
IF $DATA(DTOUT)!($DATA(DUOUT))
KILL DIR,DIRUT,DTOUT,DTOUT
SET VALMBCK=""
QUIT
EDTSEL IF '$GET(COPY)
SET PSOEDIT=1
SET (PSONEW("DFLG"),PSONEW("FIELD"),PSONEW3)=0
+1 ; IHS/CIA/PLS - 01/27/04 - Changed to $L to include zero value
+2 ;I +Y S LST=Y D HLDHDR^PSOLMUTL D Q:$G(PSORX("DFLG"))!($G(PSORX("QFLG"))) S VALMBCK="R" G DSPL^PSOORNE3
+3 IF $LENGTH(Y)
SET LST=Y
DO HLDHDR^PSOLMUTL
Begin DoDot:1
+4 FOR FLD=1:1:$LENGTH(LST,",")
IF $PIECE(LST,",",FLD)']""
QUIT
DO @(+$PIECE(LST,",",FLD))
IF $GET(PSODIR("DFLG"))!($GET(PSODIR("QFLG")))
QUIT
End DoDot:1
IF $GET(PSORX("DFLG"))!($GET(PSORX("QFLG")))
QUIT
SET VALMBCK="R"
GOTO DSPL^PSOORNE3
+5 IF '$TEST
SET VALMBCK=""
DO FULL^VALM1
+6 DO RDSPL
GOTO DSPL^PSOORNE3
+7 QUIT
ACP KILL VALMSG,DIR,PSORX("DFLG")
DO VER
IF $GET(PSONEW2("QFLG"))!($GET(PSORX("DFLG")))
SET VALMBCK="Q"
KILL PSONEW2
QUIT
+1 NEW PSONOBCK
SET PSONOBCK=$SELECT($GET(PSOSIGFL):1,1:0)
+2 DO NOOR^PSONEW
IF $DATA(DIRUT)
SET PSONEW("DFLG")=1
KILL DIR,X,Y,DIRUT,DUOUT,DTOUT
QUIT
+3 DO RXNCHK
DO RDSPL
+4 IF $GET(PSONEW("QFLG"))
SET PSONEW("DFLG")=1
KILL DIR,X,Y,DIRUT,DUOUT,DTOUT
QUIT
+5 DO DISPLAY^PSONEW2
+6 DO ^PSONEWG
IF $GET(PSOCPZ("DFLG"))
SET PSONEW("DFLG")=1
KILL PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT,PSOCPZ("DFLG"),PSOANSQD
QUIT
+7 KILL PSOCPZ("DFLG")
+8 KILL DIR,DIRUT,X,Y
SET DIR(0)="Y"
SET DIR("B")="YES"
SET DIR("A")="Is this correct"
DO ^DIR
+9 IF $DATA(DIRUT)
SET PSONEW("DFLG")=1
KILL PSOANSQ,PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT
QUIT
+10 IF 'Y
SET VALMBCK="R"
KILL PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT
DO DSPL^PSOORNE3
QUIT
+11 WRITE "..."
KILL PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT
DO DCORD^PSONEW2
+12 IF $GET(NCPDPFLG)
DO NCPDP^PSOORED6
+13 IF $GET(COPY)!($GET(PSOSIGFL))
KILL PRC,PHI
+14 ; Files entry in File 52
IF '$GET(PSOID)
SET PSOID=DT
SET (PSORX("FN"),PSONEW("POE"))=1
DO EN^PSON52(.PSONEW)
+15 IF $GET(PSOBEDT)
Begin DoDot:1
+16 IF '$DATA(^TMP("PSOBEDT",$JOB,PSODFN,0))
SET ^TMP("PSOBEDT",$JOB,PSODFN,0)=PSORXED("IRXN")
IF $GET(PSONEW("MAIL/WINDOW"))["W"
SET ^TMP("PSOBEDT",$JOB,PSODFN,1)=1
QUIT
+17 SET ^TMP("PSOBEDT",$JOB,PSODFN,0)=^TMP("PSOBEDT",$JOB,PSODFN,0)_","_PSORXED("IRXN")
+18 IF $GET(PSONEW("MAIL/WINDOW"))["W"
SET ^TMP("PSOBEDT",$JOB,PSODFN,1)=1
End DoDot:1
+19 ; Adds newly added rx to PSOSD array
DO NPSOSD^PSOUTIL(.PSONEW)
+20 DO ^PSOBUILD
SET VALMBCK="Q"
+21 KILL PSONEW("# OF REFILLS"),PSONEW("DAYS SUPPLY"),SDA,SEG1,SSN1,STA,Z4,ZDA
+22 IF $GET(COPY)
QUIT
SET PSONEW("DFLG")=0
+23 QUIT
VER IF $GET(PSOAC)
IF $GET(PSODRUG("NAME"))']""
DO FULL^VALM1
DO 2^PSOORNW1
+1 IF $GET(PSODRUG("NAME"))']""
SET VALMSG="A Dispense Drug Must be Chosen!"
SET PSONEW2("QFLG")=1
QUIT
+2 IF '$GET(PSONEW("ENT"))
WRITE !,"Dosing Instruction Missing!!",!
Begin DoDot:1
+3 SET PSOORRNW=1
+4 KILL VALMSG
DO FULL^VALM1
WRITE !,"Drug: "_PSODRUG("NAME")
+5 IF $ORDER(SIG(0))
FOR I=1:1
IF $GET(SIG(I))']""
QUIT
WRITE !,SIG(I)
+6 IF '$TEST
IF $GET(^PSRX(PSONEW("OIRXN"),"SIG"))]""
SET X=$PIECE(^PSRX(PSONEW("OIRXN"),"SIG"),"^")
DO SIGONE^PSOHELP
WRITE !,$EXTRACT($GET(INS1),2,250)
+7 WRITE !
DO 5
KILL PSOORRNW
IF PSONEW("DFLG")=1
DO M3
QUIT
+8 DO 6
IF PSONEW("DFLG")=1
DO M3
End DoDot:1
IF PSONEW("DFLG")=1
SET PSONEW2("QFLG")=1
QUIT
+9 IF $GET(COPY)
DO PROV^PSOUTIL(.PSORENW)
IF PSONEW("DFLG")=1
SET PSONEW2("QFLG")=1
QUIT
+10 DO FULL^VALM1
IF '$GET(PSOSIGFL)
DO POST^PSODRG
KILL PSONOOR
IF $GET(PSORX("DFLG"))
SET VALMBCK="Q"
QUIT
+11 IF +$GET(PSEXDT)
Begin DoDot:1
+12 DO FULL^VALM1
IF $GET(PSONEW("MAIL/WINDOW"))["W"
SET BINGCRT="Y"
SET BINGRTE="W"
+13 IF +$GET(PSEXDT)
Begin DoDot:2
+14 SET Y=PSONEW("FILL DATE")
XECUTE ^DD("DD")
WRITE !!,$CHAR(7),Y_" fill date is greater than possible expiration date of "
SET Y=$PIECE(PSEXDT,"^",2)
XECUTE ^DD("DD")
WRITE Y_"."
End DoDot:2
+15 SET PSONEW2("QFLG")=1
SET VALMBCK="R"
DO PAUSE^VALM1
End DoDot:1
+16 QUIT
0 ; EP - IHS/CIA/PLS - 01/26/04 - Prompt IHS Fields
+1 DO IHSFLDS^APSPDIR(.PSONEW)
QUIT
+2 ;
1 IF $GET(PSOSIGFL)
SET PSOAC=1
DO 2^PSOORNW1
KILL PSOAC
DO RDSPL
GOTO DSPL^PSOORNE3
QUIT
+1 DO 6^PSOBKDED
DO RDSPL
GOTO DSPL^PSOORNE3
QUIT
+2 ;
2 DO 3^PSOBKDED
QUIT
+1 ;
3 DO 1^PSOBKDED
QUIT
+1 ;
4 DO 2^PSOBKDED
QUIT
+1 ;
5 IF '$GET(PSODRUG("IEN"))
WRITE !,"DRUG NAME REQUIRED!"
DO 2^PSOORNW1
IF '$GET(PSODRUG("IEN"))
SET VALMSG="No Dispense Drug Selected"
QUIT
+1 WRITE !!,"Drug: "_PSODRUG("NAME")
DO 10^PSOBKDED
QUIT
+2 ;
6 DO INS^PSOBKDED
IF $GET(PSONEW("DFLG"))
QUIT
IF $PIECE($GET(^PS(55,PSODFN,"LAN")),"^")
DO SINS^PSODIR(.PSONEW)
+1 QUIT
+2 ;
7 DO 8^PSOBKDED
QUIT
+1 ;
8 DO 7^PSOBKDED
QUIT
+1 ;
9 DO 9^PSOBKDED
QUIT
+1 ;
10 DO 12^PSOBKDED
QUIT
+1 ;
11 DO 5^PSOBKDED
QUIT
+1 ;
12 DO 4^PSOBKDED
QUIT
+1 ;
13 DO 11^PSOBKDED
QUIT
+1 ;
14 DO 13^PSOBKDED
QUIT
+1 ;
SUMM ;print break down of orders to be finished
+1 KILL ^TMP($JOB,"PSOCZT"),^TMP($JOB,"PSODPAT"),PAT,RT,DIR,DUOUT,DIRUT,PSZLQUIT
+2 SET DIR("A")="Do you want an Order Summary"
SET DIR(0)="Y"
SET DIR("B")="No"
+3 DO ^DIR
KILL DIR
IF 'Y!($DATA(DIRUT))
KILL Y,X,DIRUT
QUIT
+4 KILL PSOINPRT,DIQ,^UTILITY("DIQ1",$JOB)
IF $GET(PSOPINST)
SET DA=PSOPINST
SET DIC=4
SET DIQ(0)="E"
SET DR=".01"
DO EN^DIQ1
SET PSOINPRT=$GET(^UTILITY("DIQ1",$JOB,4,DA,.01,"E"))
KILL ^UTILITY("DIQ1",$JOB),DA,DR,DIC,DIQ
+5 IF $DATA(^PS(52.41,"ACL"))
NEW PSOCLSUM
DO SUMMCL
IF $GET(PSOCLSUM)
KILL PSOINPRT
QUIT
+6 FOR PSI=0:0
SET PSI=$ORDER(^PS(52.41,"AOR",PSI))
IF 'PSI
QUIT
FOR PSID=0:0
SET PSID=$ORDER(^PS(52.41,"AOR",PSI,PSID))
IF 'PSID
QUIT
FOR PIN=0:0
SET PIN=$ORDER(^PS(52.41,"AOR",PSI,PSID,PIN))
IF 'PIN
QUIT
Begin DoDot:1
+7 IF '$DATA(^TMP($JOB,"PSOCZT",PSID,"PAT"))
FOR PZA="PAT","WIN","MAIL","CLIN"
SET ^TMP($JOB,"PSOCZT",PSID,PZA)=0
+8 IF '$DATA(^TMP($JOB,"PSODPAT",PSID,PSI))
SET ^TMP($JOB,"PSODPAT",PSID,PSI)=1
SET ^TMP($JOB,"PSOCZT",PSID,"PAT")=^TMP($JOB,"PSOCZT",PSID,"PAT")+1
+9 SET PZROUT=$PIECE($GET(^PS(52.41,PIN,0)),"^",17)
IF PZROUT'=""
SET ^TMP($JOB,"PSOCZT",PSID,$SELECT(PZROUT="C":"CLIN",PZROUT="M":"MAIL",1:"WIN"))=^TMP($JOB,"PSOCZT",PSID,$SELECT(PZROUT="C":"CLIN",PZROUT="M":"MAIL",1:"WIN"))+1
End DoDot:1
+10 WRITE @IOF
WRITE !?20,"Pending Outpatient Medication Orders",!
IF $GET(PSZCNT)>1
WRITE ?20,"(signed in under "_$GET(PSOINPRT)_")",!
+11 FOR PSOINL=0:0
SET PSOINL=$ORDER(^TMP($JOB,"PSOCZT",PSOINL))
IF 'PSOINL!($GET(PSZLQUIT))
QUIT
Begin DoDot:1
+12 IF ($Y+6)>IOSL
KILL DIR
SET DIR(0)="E"
DO ^DIR
KILL DIR
IF $GET(Y)
Begin DoDot:2
+13 WRITE @IOF
WRITE !?20,"Pending Outpatient Medication Orders",!
IF $GET(PSZCNT)>1
WRITE ?20,"(signed in under "_$GET(PSOINPRT)_")",!
End DoDot:2
IF '$GET(Y)
SET PSZLQUIT=1
WRITE !
QUIT
+14 KILL ^UTILITY("DIQ1",$JOB),DIQ,PSOINPRX
SET DA=$GET(PSOINL)
SET DIC=4
SET DIQ(0)="E"
SET DR=".01"
DO EN^DIQ1
SET PSOINPRX=$GET(^UTILITY("DIQ1",$JOB,4,DA,.01,"E"))
KILL ^UTILITY("DIQ1",$JOB),DA,DR,DIC,DIQ
+15 ;PSO*7*279 Change division to Institution
+16 WRITE !,"Institution: ",$GET(PSOINPRX)
+17 WRITE !,"Patients: "_$GET(^TMP($JOB,"PSOCZT",PSOINL,"PAT"))_" Window: "_$GET(^("WIN"))_" Mail: "_$GET(^("MAIL"))_" Clinic: "_$GET(^("CLIN")),!
End DoDot:1
+18 KILL DIR
SET DIR(0)="E"
SET DIR("A")="Press Return to Continue"
DO ^DIR
KILL DIR
+19 KILL ^TMP($JOB,"PSOCZT"),^TMP($JOB,"PSODPAT"),RT,PSOINPRT,PSOINPRX,PSI,PSID,PIN,PZA,PZROUT,PSOINL,PSZLQUIT
+20 QUIT
SUMMCL ;
+1 ;PSO*7*279 Change Division to Institution
+2 WRITE !
KILL DIR
SET DIR(0)="SMB^I:INSTITUTION;C:CLINIC"
SET DIR("A")="Do you want the summary by Institution or Clinic"
SET DIR("B")="Institution"
SET DIR("?")=" "
+3 SET DIR("?",1)="Enter 'I' to see the summary by Institution, and within Institution the orders"
SET DIR("?",2)="shown by Mail, Window, or Administered in Clinic."
SET DIR("?",3)="Enter 'C' to see the summary by Clinic, along with Clinic Sort Groups."
+4 DO ^DIR
KILL DIR
IF $DATA(DTOUT)!($DATA(DUOUT))
SET PSOCLSUM=1
QUIT
+5 IF $GET(Y)="I"
QUIT
+6 SET PSOCLSUM=1
+7 KILL ^TMP($JOB,"PSOLOC"),^TMP($JOB,"PSOLOCP")
NEW PSCX,PSCXL,PSLX,PSCIN,PSCPT,PSCNDE,PSNCL,PSNPAT,PSCLOUT,PSCSFLAG,PCCNT,PSOCAG
+8 FOR PSCX=0:0
SET PSCX=$ORDER(^PS(52.41,"ACL",PSCX))
IF 'PSCX
QUIT
FOR PSLX=0:0
SET PSLX=$ORDER(^PS(52.41,"ACL",PSCX,PSLX))
IF 'PSLX
QUIT
FOR PSCIN=0:0
SET PSCIN=$ORDER(^PS(52.41,"ACL",PSCX,PSLX,PSCIN))
IF 'PSCIN
QUIT
SET PSCPT=+$PIECE($GET(^PS(52.41,PSCIN,0)),"^",2)
IF PSCPT
Begin DoDot:1
+9 SET PSCNDE=$GET(^PS(52.41,PSCIN,0))
+10 IF $PIECE(PSCNDE,"^",3)'="NW"
IF $PIECE(PSCNDE,"^",3)'="RNW"
IF $PIECE(PSCNDE,"^",3)'="RF"
QUIT
+11 IF $PIECE(PSCNDE,"^",13)=""
QUIT
+12 SET PSNCL=+$PIECE(PSCNDE,"^",13)
SET PSNPAT=+$PIECE(PSCNDE,"^",2)
+13 IF '$DATA(^TMP($JOB,"PSOLOC",PSNCL))
SET ^TMP($JOB,"PSOLOC",PSNCL)="1^1"
SET ^TMP($JOB,"PSOLOCP",PSNCL,PSNPAT)=""
QUIT
+14 SET $PIECE(^TMP($JOB,"PSOLOC",PSNCL),"^",2)=$PIECE(^TMP($JOB,"PSOLOC",PSNCL),"^",2)+1
+15 IF '$DATA(^TMP($JOB,"PSOLOCP",PSNCL,PSNPAT))
SET $PIECE(^TMP($JOB,"PSOLOC",PSNCL),"^")=$PIECE(^TMP($JOB,"PSOLOC",PSNCL),"^")+1
+16 SET ^TMP($JOB,"PSOLOCP",PSNCL,PSNPAT)=""
End DoDot:1
+17 IF '$ORDER(^TMP($JOB,"PSOLOC",0))
GOTO SUMMQ
+18 WRITE @IOF
WRITE !?20,"Pending Outpatient Medication Orders"
IF $GET(PSZCNT)>1
WRITE !?20,"(signed in under "_$GET(PSOINPRT)_")"
+19 FOR PSCXL=0:0
SET PSCXL=$ORDER(^TMP($JOB,"PSOLOC",PSCXL))
IF 'PSCXL!($GET(PSCLOUT))
QUIT
Begin DoDot:1
+20 IF ($Y+7)>IOSL
DO CLDIR
IF $GET(PSCLOUT)
QUIT
+21 WRITE !!,"Clinic: ",$PIECE($GET(^SC(+PSCXL,0)),"^")
+22 WRITE !,"Patients: ",$PIECE($GET(^TMP($JOB,"PSOLOC",PSCXL)),"^"),?16,"Orders: ",$PIECE($GET(^TMP($JOB,"PSOLOC",PSCXL)),"^",2)
+23 WRITE !,"In Sort Groups:"
+24 SET (PCCNT,PSCSFLAG)=0
FOR PSCSORT=0:0
SET PSCSORT=$ORDER(^PS(59.8,PSCSORT))
IF 'PSCSORT!($GET(PSCLOUT))
QUIT
IF $DATA(^PS(59.8,PSCSORT,1,"B",PSCXL))
SET PSOCAG=0
Begin DoDot:2
+25 SET PSCSFLAG=1
IF ($Y+5)>IOSL&(PCCNT)
SET PSOCAG=1
IF ($Y+5)>IOSL&(PCCNT)
DO CLDIR
IF $GET(PSCLOUT)
QUIT
IF $GET(PSOCAG)
WRITE !,"Clinic: "_$PIECE($GET(^SC(PSCXL,0)),"^")_" cont."
IF $GET(PCCNT)>0
WRITE !
WRITE ?16,$PIECE($GET(^PS(59.8,PSCSORT,0)),"^")
SET PCCNT=1
End DoDot:2
+26 IF '$GET(PSCSFLAG)
WRITE ?16,"*** NO CLINIC SORT GROUPS ***"
End DoDot:1
+27 IF '$GET(PSCLOUT)
KILL DIR
SET DIR(0)="E"
SET DIR("A")="Press <RET> to continue"
DO ^DIR
KILL DIR
SUMMQ KILL ^TMP($JOB,"PSOLOC"),^TMP($JOB,"PSOLOCP")
+1 QUIT
CLDIR KILL DIR
SET DIR(0)="E"
SET DIR("A")="Press <RET> to continue, '^' to exit"
DO ^DIR
KILL DIR
IF Y'=1
SET PSCLOUT=1
QUIT
+1 WRITE @IOF
+2 QUIT
RXNCHK IF $GET(PSONEW("RX #"))']""
DO RXNCHK^PSOORNE5
+1 QUIT
RDSPL DO RDSPL^PSOORNE5
+1 QUIT
M3 DO M3^PSOOREDX
+1 QUIT