| [623] | 1 | PSORXRP1 ;BIR/SAB-rx speed reprint listman ; 12/10/06 9:50pm
 | 
|---|
 | 2 |  ;;7.0;OUTPATIENT PHARMACY;**11,27,120,156,148,208**;DEC 1997;Build 39
 | 
|---|
 | 3 |  ; Modified from FOIA VISTA,
 | 
|---|
 | 4 |  ; Copyright (C) 2007 WorldVistA
 | 
|---|
 | 5 |  ;
 | 
|---|
 | 6 |  ; This program is free software; you can redistribute it and/or modify
 | 
|---|
 | 7 |  ; it under the terms of the GNU General Public License as published by
 | 
|---|
 | 8 |  ; the Free Software Foundation; either version 2 of the License, or
 | 
|---|
 | 9 |  ; (at your option) any later version.
 | 
|---|
 | 10 |  ;
 | 
|---|
 | 11 |  ; This program is distributed in the hope that it will be useful,
 | 
|---|
 | 12 |  ; but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
|---|
 | 13 |  ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
|---|
 | 14 |  ; GNU General Public License for more details.
 | 
|---|
 | 15 |  ;
 | 
|---|
 | 16 |  ; You should have received a copy of the GNU General Public License
 | 
|---|
 | 17 |  ; along with this program; if not, write to the Free Software
 | 
|---|
 | 18 |  ; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
 | 
|---|
 | 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 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
 | 
|---|
 | 22 |  K DIR,DIRUT,DTOUT,PSOOELSE,PSOREPX I +LST S PSOOELSE=1 D
 | 
|---|
 | 23 |  .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
 | 
|---|
 | 24 |  .D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S COPIES=Y
 | 
|---|
 | 25 |  .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."
 | 
|---|
 | 26 |  .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
 | 
|---|
 | 27 |  .I $P(PSOPAR,"^",30),$$GET1^DIQ(59,PSOSITE_",",105,"I")=2.4 D  Q:$G(PSOREPX)
 | 
|---|
 | 28 |  ..K DIR,DIRUT S DIR("A")="Do you want to resend to Dispensing System Device",DIR(0)="Y",DIR("B")="No"
 | 
|---|
 | 29 |  ..D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S PSODISP=$S(Y:0,1:1)
 | 
|---|
 | 30 |  .K DIRUT,DIR S DIR("A")="Comments: ",DIR(0)="FA^5:60",DIR("?")="5-60 characters input required for activity log." S:$G(PCOMX)]"" DIR("B")=$G(PCOMX)
 | 
|---|
 | 31 |  .D ^DIR K DIR S:$D(DIRUT) PSOREPX=1 Q:$D(DIRUT)  S (PCOM,PCOMX)=Y
 | 
|---|
 | 32 |  .S PSOCLC=DUZ
 | 
|---|
 | 33 |  .F ORD=1:1:$L(LST,",") Q:$P(LST,",",ORD)']""  S ORN=$P(LST,",",ORD),QFLG=0 D:+PSOLST(ORN)=52 RX
 | 
|---|
 | 34 |  .S VALMBCK="R"
 | 
|---|
 | 35 |  I $G(PSOREPX) S VALMBCK="R",VALMSG="No Labels Reprinted."
 | 
|---|
 | 36 |  K PSOREPX
 | 
|---|
 | 37 |  I '$G(PSOOELSE) S VALMBCK=""
 | 
|---|
 | 38 |  D ^PSOBUILD
 | 
|---|
 | 39 |  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
 | 
|---|
 | 40 |  Q
 | 
|---|
 | 41 |  ;
 | 
|---|
 | 42 | RX ;process reprint request
 | 
|---|
 | 43 |  ;
 | 
|---|
 | 44 |  S DIC="^VA(200,",DIC(0)="QEZ",X="AUTOFINISH,RX" ;vfah
 | 
|---|
 | 45 |  D ^DIC K DIC ;vfah
 | 
|---|
 | 46 |  S PSOZAF=+Y ;vfah
 | 
|---|
 | 47 |  I $P($G(^PSRX($P(PSOLST(ORN),"^",2),"OR1")),"^",5)=$G(PSOZAF) W $C(7),!!,"Rx "_$$GET1^DIQ(52,$P(PSOLST(ORN),"^",2),.01)_" is an Autofinish,Rx and labels can not be reprinted." K PSOZAF D PAUSE^VALM1 Q  ;vfah
 | 
|---|
 | 48 |  ;
 | 
|---|
 | 49 |  Q:$P(^PSRX($P(PSOLST(ORN),"^",2),"STA"),"^")>11
 | 
|---|
 | 50 |  I $$LMREJ^PSOREJU1($P(PSOLST(ORN),"^",2)) W $C(7),!!,"Rx "_$$GET1^DIQ(52,$P(PSOLST(ORN),"^",2),.01)_" has OPEN/UNRESOLVED 3rd Party Payer Rejects!" K DIR D PAUSE^VALM1 Q
 | 
|---|
 | 51 |  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
 | 
|---|
 | 52 |  S RX=$P(PSOLST(ORN),"^",2),STA=$P(^PSRX($P(PSOLST(ORN),"^",2),"STA"),"^") D CHK I $G(QFLG) D ULR Q
 | 
|---|
 | 53 |  S RXF=0,ZD(RX)=DT,REPRINT=1
 | 
|---|
 | 54 |  S RXRP($P(PSOLST(ORN),"^",2))=1_"^"_COPIES_"^"_SIDE
 | 
|---|
 | 55 |  I $G(PSODISP)=1 S RXRP($P(PSOLST(ORN),"^",2),"RP")=1
 | 
|---|
 | 56 |  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
 | 
|---|
 | 57 |  K ZZZ
 | 
|---|
 | 58 |  I $G(PSORX("PSOL",1))']"" S PSORX("PSOL",1)=RX_"," S ST="" D ACT1,ULR Q
 | 
|---|
 | 59 |  F PSOX1=0:0 S PSOX1=$O(PSORX("PSOL",PSOX1)) Q:'PSOX1  S PSOX2=PSOX1
 | 
|---|
 | 60 |  I $L(PSORX("PSOL",PSOX2))+$L(RX)<220 S PSORX("PSOL",PSOX2)=PSORX("PSOL",PSOX2)_RX_","
 | 
|---|
 | 61 |  E  S PSORX("PSOL",PSOX2+1)=RX_","
 | 
|---|
 | 62 |  S ST="" D ACT1
 | 
|---|
 | 63 |  D ULR
 | 
|---|
 | 64 |  Q
 | 
|---|
 | 65 | CHK ;check for valid reprint
 | 
|---|
 | 66 |  I DT>$P(^PSRX(RX,2),"^",6) D  S QFLG=1 Q
 | 
|---|
 | 67 |  .I $P(^PSRX(RX,"STA"),"^")<11 S $P(^PSRX(RX,"STA"),"^")=11 D
 | 
|---|
 | 68 |  ..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
 | 
|---|
 | 69 |  S DFN=PSODFN D DEM^VADPT I $P(VADM(6),"^",2)]"" D  S QFLG=1 Q
 | 
|---|
 | 70 |  .S $P(^PSRX(RX,"STA"),"^")=12,PCOM="Patient Expired "_$P(VADM(6),"^",2),ST="C" D EN^PSOHLSN1(RX,"OD","",PCOM,"A")
 | 
|---|
 | 71 |  .D ACT1
 | 
|---|
 | 72 |  I $D(RXPR($P(PSOLST(ORN),"^",2)))!$D(RXRP($P(PSOLST(ORN),"^",2))) S QFLG=1 Q
 | 
|---|
 | 73 |  D VALID Q:$G(QFLG)
 | 
|---|
 | 74 |  S X=$O(^PS(52.5,"B",RX,0)) I X,'$G(^PS(52.5,X,"P")) S QFLG=1 Q
 | 
|---|
 | 75 |  I $G(X)'>0 G GOOD
 | 
|---|
 | 76 |  I $P($G(^PS(52.5,X,0)),"^",7)']"" G GOOD
 | 
|---|
 | 77 |  I $P($G(^PS(52.5,X,0)),"^",7)="Q" K X,XX S QFLG=1 Q
 | 
|---|
 | 78 |  I $P($G(^PS(52.5,X,0)),"^",7)="L" K X,XX S QFLG=1 Q
 | 
|---|
 | 79 | GOOD K X
 | 
|---|
 | 80 |  I $D(^PS(52.4,RX)) S QFLG=1 Q
 | 
|---|
 | 81 |  I $D(^PS(52.4,"AREF",PSODFN,RX)) S QFLG=1 Q
 | 
|---|
 | 82 |  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
 | 
|---|
 | 83 |  I STA=3!(STA=4)!(STA=12) S QFLG=1 Q
 | 
|---|
 | 84 |  Q
 | 
|---|
 | 85 | 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
 | 
|---|
 | 86 |  S IR=0 F J=0:0 S J=$O(^PSRX(RX,"A",J)) Q:'J  S IR=J
 | 
|---|
 | 87 |  S IR=IR+1,^PSRX(RX,"A",0)="^52.3DA^"_IR_"^"_IR
 | 
|---|
 | 88 |  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
 | 
|---|
 | 89 |  S:$P(^PSRX(RX,2),"^",15)&($G(ST)'="C") $P(^PSRX(RX,2),"^",14)=1
 | 
|---|
 | 90 |  Q
 | 
|---|
 | 91 | VALID ;check for rx in label array
 | 
|---|
 | 92 |  I $O(PSORX("PSOL",0)) D
 | 
|---|
 | 93 |  .F PSOX1=0:0 S PSOX1=$O(PSORX("PSOL",PSOX1)) Q:'PSOX1  I PSORX("PSOL",PSOX1)[RX_"," S QFLG=1 Q
 | 
|---|
 | 94 |  Q
 | 
|---|
 | 95 | ULR ;
 | 
|---|
 | 96 |  I $G(PSORPSRX) D PSOUL^PSSLOCK(PSORPSRX)
 | 
|---|
 | 97 |  Q
 | 
|---|