| 1 | PSOAFRP1 ;VFA/HMS autofinish rx speed reprint for listman ;1/30/07  19:48 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**208**;DEC 1997;Build 39 | 
|---|
| 3 | ; Copyright (C) 2007 WorldVistA | 
|---|
| 4 | ; | 
|---|
| 5 | ; This program is free software; you can redistribute it and/or modify | 
|---|
| 6 | ; it under the terms of the GNU General Public License as published by | 
|---|
| 7 | ; the Free Software Foundation; either version 2 of the License, or | 
|---|
| 8 | ; (at your option) any later version. | 
|---|
| 9 | ; | 
|---|
| 10 | ; This program is distributed in the hope that it will be useful, | 
|---|
| 11 | ; but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 12 | ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 13 | ; GNU General Public License for more details. | 
|---|
| 14 | ; | 
|---|
| 15 | ; You should have received a copy of the GNU General Public License | 
|---|
| 16 | ; along with this program; if not, write to the Free Software | 
|---|
| 17 | ; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA | 
|---|
| 18 | ;'Modified' MAS Patient Look-up Check Cross-References June 1987 | 
|---|
| 19 | ;External references PSOL and PSOUL^PSSLOCK supported by DBIA 2789 | 
|---|
| 20 | SEL N PSODISP,VALMCNT I '$G(PSOCNT) S VALMSG="This patient has no Prescriptions!" S VALMBCK="" Q | 
|---|
| 21 | S PSOAFYN="Y" | 
|---|
| 22 | S RXCNT=0 K PSOFDR,DIR,DUOUT,DIRUT S DIR("A")="Select Orders by number",DIR(0)="LO^1:"_PSOCNT D ^DIR S LST=Y I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DUOUT S VALMBCK="" Q | 
|---|
| 23 | ; | 
|---|
| 24 | ;F ORD=1:1:$L(LST,",") Q:$P(LST,",",ORD)']""  S ORN=$P(LST,",",ORD),QFLG=0 D:+PSOLST(ORN)=52 | 
|---|
| 25 | ;.S PSORPSRX=$P(PSOLST(ORN),"^",2) | 
|---|
| 26 | ; | 
|---|
| 27 | K DIR,DIRUT,DTOUT,PSOOELSE,PSOREPX I +LST S PSOOELSE=1 D | 
|---|
| 28 | .;D FULL^VALM1 K DIR S DIR("A")="Number of Copies? ",DIR(0)="N^1:99:0",DIR("?")="Enter the number of copies you want (1 TO 99)",DIR("B")=1 | 
|---|
| 29 | .;D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S COPIES=Y | 
|---|
| 30 | .S COPIES=1 | 
|---|
| 31 | .;K DIR S DIR("A")="Print adhesive portion of label only? ",DIR(0)="Y",DIR("B")="No",DIR("?",1)="If entire label, including trailers are to print press RETURN for default." | 
|---|
| 32 | .;S DIR("?")="Else if only bottle and mailing labels are to print enter Y or YES." D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S SIDE=Y | 
|---|
| 33 | .S SIDE=0 | 
|---|
| 34 | .I $P(PSOPAR,"^",30),$$GET1^DIQ(59,PSOSITE_",",105,"I")=2.4 D  Q:$G(PSOREPX) | 
|---|
| 35 | ..;K DIR,DIRUT S DIR("A")="Do you want to resend to Dispensing System Device",DIR(0)="Y",DIR("B")="No" | 
|---|
| 36 | ..;D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S PSODISP=$S(Y:0,1:1) | 
|---|
| 37 | ..S PSODISP=1 | 
|---|
| 38 | .K DIRUT,DIR S DIR("A")="Comments(Required): ",DIR(0)="FA^5:60",DIR("?")="5-60 characters input required for activity log." S:$G(PCOMX)]"" DIR("B")=$G(PCOMX) | 
|---|
| 39 | .D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S (PCOM,PCOMX)=Y | 
|---|
| 40 | .S PSOCLC=DUZ | 
|---|
| 41 | .F ORD=1:1:$L(LST,",") Q:$P(LST,",",ORD)']""  S ORN=$P(LST,",",ORD),QFLG=0 D:+PSOLST(ORN)=52 RX | 
|---|
| 42 | .S VALMBCK="R" | 
|---|
| 43 | I $G(PSOREPX) S VALMBCK="R",VALMSG="No Labels Reprinted." | 
|---|
| 44 | K PSOREPX | 
|---|
| 45 | I '$G(PSOOELSE) S VALMBCK="" | 
|---|
| 46 | D ^PSOBUILD | 
|---|
| 47 | K PSOMSG,PSORPSRX,QFLG,%,DIR,DUOUT,DTOUT,DIROUT,DIRUT,PCOM,PCOMX,C,I,J,JJJ,K,RX,RXF,X,Y,Z,P,PDA,PSPRXN,COPIES,SIDE,PPL,REPRINT,PSOOELSE,ORD,LST,ORN D KVA^VADPT | 
|---|
| 48 | Q | 
|---|
| 49 | ; | 
|---|
| 50 | RX ;process reprint request | 
|---|
| 51 | ; | 
|---|
| 52 | S PSORPSRX=$P(PSOLST(ORN),"^",2) | 
|---|
| 53 | ;S PSOZAF="" S PSOZAF=$O(^VA(200,"B","AUTOFINISH,RX",PSOZAF)) ;vfah | 
|---|
| 54 | S DIC="^VA(200,",DIC(0)="QEZ",X="AUTOFINISH,RX" | 
|---|
| 55 | D ^DIC K DIC | 
|---|
| 56 | S PSOZAF=+Y | 
|---|
| 57 | I $P($G(^PSRX(PSORPSRX,"OR1")),"^",5)'=$G(PSOZAF) S VFANRP=1 ;vfah | 
|---|
| 58 | I $G(VFANRP)=1 W $C(7),!,"Re-Print only available for Autofinished Rxs" D PAUSE^VALM1 K PSORPSRX,VFANRP Q | 
|---|
| 59 | ;Q:$G(VFANRP)=1 | 
|---|
| 60 | ; | 
|---|
| 61 | Q:$P(^PSRX($P(PSOLST(ORN),"^",2),"STA"),"^")>11 | 
|---|
| 62 | S PSORPSRX=$P(PSOLST(ORN),"^",2) D PSOL^PSSLOCK(PSORPSRX) I '$G(PSOMSG) W $C(7),!!,$S($P($G(PSOMSG),"^",2)'="":$P($G(PSOMSG),"^",2),1:"Another person is editing Rx "_$P($G(^PSRX(PSORPSRX,0)),"^")),! D PAUSE^VALM1 K PSORPSRX,PSOMSG Q | 
|---|
| 63 | S RX=$P(PSOLST(ORN),"^",2),STA=$P(^PSRX($P(PSOLST(ORN),"^",2),"STA"),"^") D CHK I $G(QFLG) D ULR Q | 
|---|
| 64 | S RXF=0,ZD(RX)=DT,REPRINT=1 | 
|---|
| 65 | S RXRP($P(PSOLST(ORN),"^",2))=1_"^"_COPIES_"^"_SIDE | 
|---|
| 66 | I $G(PSODISP)=1 S RXRP($P(PSOLST(ORN),"^",2),"RP")=1 | 
|---|
| 67 | S RXFL($P(PSOLST(ORN),"^",2))=0 F ZZZ=0:0 S ZZZ=$O(^PSRX($P(PSOLST(ORN),"^",2),1,ZZZ)) Q:'ZZZ  S RXFL($P(PSOLST(ORN),"^",2))=ZZZ | 
|---|
| 68 | K ZZZ | 
|---|
| 69 | I $G(PSORX("PSOL",1))']"" S PSORX("PSOL",1)=RX_"," S ST="" D ACT1,ULR Q | 
|---|
| 70 | F PSOX1=0:0 S PSOX1=$O(PSORX("PSOL",PSOX1)) Q:'PSOX1  S PSOX2=PSOX1 | 
|---|
| 71 | I $L(PSORX("PSOL",PSOX2))+$L(RX)<220 S PSORX("PSOL",PSOX2)=PSORX("PSOL",PSOX2)_RX_"," | 
|---|
| 72 | E  S PSORX("PSOL",PSOX2+1)=RX_"," | 
|---|
| 73 | S ST="" D ACT1 | 
|---|
| 74 | D ULR | 
|---|
| 75 | Q | 
|---|
| 76 | CHK ;check for valid reprint | 
|---|
| 77 | I DT>$P(^PSRX(RX,2),"^",6) D  S QFLG=1 Q | 
|---|
| 78 | .I $P(^PSRX(RX,"STA"),"^")<11 S $P(^PSRX(RX,"STA"),"^")=11 D | 
|---|
| 79 | ..S COMM="Medication Expired on "_$E($P(^PSRX(RX,2),6),4,5)_"-"_$E($P(^(2),"^",6),6,7)_"-"_$E($P(^(2),"^",6),2,3) D EN^PSOHLSN1(RX,"SC","ZE",COMM) K COMM | 
|---|
| 80 | S DFN=PSODFN D DEM^VADPT I $P(VADM(6),"^",2)]"" D  S QFLG=1 Q | 
|---|
| 81 | .S $P(^PSRX(RX,"STA"),"^")=12,PCOM="Patient Expired "_$P(VADM(6),"^",2),ST="C" D EN^PSOHLSN1(RX,"OD","",PCOM,"A") | 
|---|
| 82 | .D ACT1 | 
|---|
| 83 | I $D(RXPR($P(PSOLST(ORN),"^",2)))!$D(RXRP($P(PSOLST(ORN),"^",2))) S QFLG=1 Q | 
|---|
| 84 | D VALID Q:$G(QFLG) | 
|---|
| 85 | S X=$O(^PS(52.5,"B",RX,0)) I X,'$G(^PS(52.5,X,"P")) S QFLG=1 Q | 
|---|
| 86 | I $G(X)'>0 G GOOD | 
|---|
| 87 | I $P($G(^PS(52.5,X,0)),"^",7)']"" G GOOD | 
|---|
| 88 | I $P($G(^PS(52.5,X,0)),"^",7)="Q" K X,XX S QFLG=1 Q | 
|---|
| 89 | I $P($G(^PS(52.5,X,0)),"^",7)="L" K X,XX S QFLG=1 Q | 
|---|
| 90 | GOOD K X | 
|---|
| 91 | I $D(^PS(52.4,RX)) S QFLG=1 Q | 
|---|
| 92 | I $D(^PS(52.4,"AREF",PSODFN,RX)) S QFLG=1 Q | 
|---|
| 93 | I $G(PSODIV),$D(^PSRX(RX,2)),+$P(^(2),"^",9),+$P(^(2),"^",9)'=PSOSITE S PSPOP=0,PSPRXN=RX D CHK1^PSOUTLA I $G(POERR)&(PSPOP) S QFLG=1 Q | 
|---|
| 94 | I STA=3!(STA=4)!(STA=12) S QFLG=1 Q | 
|---|
| 95 | Q | 
|---|
| 96 | ACT1 S RXF=0 F J=0:0 S J=$O(^PSRX(RX,1,J)) Q:'J  S RXF=J S:J>5 RXF=J+1 | 
|---|
| 97 | S IR=0 F J=0:0 S J=$O(^PSRX(RX,"A",J)) Q:'J  S IR=J | 
|---|
| 98 | S IR=IR+1,^PSRX(RX,"A",0)="^52.3DA^"_IR_"^"_IR | 
|---|
| 99 | D NOW^%DTC S ^PSRX(RX,"A",IR,0)=%_"^"_$S($G(ST)'="C":"W",1:"C")_"^"_DUZ_"^"_RXF_"^"_PCOM_$S($G(ST)'="C":" ("_COPIES_" COPIES)",1:""),PCOMX=PCOM K PC,IR,PS,XX,%,%H,%I,RXF | 
|---|
| 100 | S:$P(^PSRX(RX,2),"^",15)&($G(ST)'="C") $P(^PSRX(RX,2),"^",14)=1 | 
|---|
| 101 | Q | 
|---|
| 102 | VALID ;check for rx in label array | 
|---|
| 103 | I $O(PSORX("PSOL",0)) D | 
|---|
| 104 | .F PSOX1=0:0 S PSOX1=$O(PSORX("PSOL",PSOX1)) Q:'PSOX1  I PSORX("PSOL",PSOX1)[RX_"," S QFLG=1 Q | 
|---|
| 105 | Q | 
|---|
| 106 | ULR ; | 
|---|
| 107 | I $G(PSORPSRX) D PSOUL^PSSLOCK(PSORPSRX) | 
|---|
| 108 | Q | 
|---|