| 1 | PSOLBL ;BIR/SAB/RTR-BOTTLE LABEL ;5/9/07 8:57am
 | 
|---|
| 2 |  ;;7.0;OUTPATIENT PHARMACY;**8,19,30,36,47,71,92,120,157,244,206**;DEC 1997;Build 39
 | 
|---|
| 3 |  ;DBIAs PSDRUG-221, PS(55-2228, IBARX-125, PSXSRP-2201, %ZIS-3435, DPT-3097
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ;*244 rem test for part fill when testing status > 11
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 | DQ I $D(PSOIOS),PSOIOS]"" D DEVBAR^PSOBMST
 | 
|---|
| 8 |  I $G(PSOBAR0)]"",$G(PSOBAR1)]"",$D(^PS(59,PSOSITE,1)) S PSOBARS=1
 | 
|---|
| 9 | DQ1 D ^PSOLBL4
 | 
|---|
| 10 |  I $G(IOST(0)),$D(^%ZIS(2,IOST(0),55,"B","LL")) G ^PSOLLLI
 | 
|---|
| 11 |  G:'$D(PPL) HLEX G:($P($G(PSOPAR),"^",30)=2)&('$G(PSOEXREP)) HLEX K RXFLX S PSOCKHN=","_$G(PPL) S PSRESOLV=+PPL D CHECK F PI=1:1  D  S RX=$P(PPL,",",PI) D C Q:$G(PSOLAPPL)  D:$G(PSDFNFLG) TRAIL^PSOLBL2 K RXP,REPRINT
 | 
|---|
| 12 |  .S (PSDFNFLG,PSOLAPPL)=0 S NEXTRX=$P(PPL,",",(PI+1)) I NEXTRX=""!(NEXTRX=",") S PSOLAPPL=1 Q
 | 
|---|
| 13 |  .I PSOPDFN'=$P(^PSRX(NEXTRX,0),"^",2) S PSDFNFLG=1,PSOPDFN=$P(^PSRX(NEXTRX,0),"^",2) Q
 | 
|---|
| 14 |  I $P(^PS(59,PSOSITE,1),"^",28) D ^PSOLBLN2
 | 
|---|
| 15 |  D:'$P(^PS(59,PSOSITE,1),"^",28) ^PSOLBLS
 | 
|---|
| 16 | DQ5 I $D(^TMP($J,"PSOCP",DFN)),'$P(^PS(59,PSOSITE,1),"^",28) D INV^PSOCPE
 | 
|---|
| 17 | HLEX K RXPI,PSORX,RXP,PSOIOS,PSOLAPPL,XXX,COPAYVAR,TECH,PHYS,MFG,NURSE,STATE,SIDE,COPIES,EXDT,ISD,PSOINST,RXN,RXY,VADT,DEA,WARN,FDT,QTY,PATST,PDA,PS,PS1,PS2,PSL,PSNP,INRX,RR,XTYPE,SSNP,SSNPN,PNM,ADDR,PSODBQ,PSOLASTF,PSRESOLV,PSOEXREP,PSOSXQ
 | 
|---|
| 18 |  K ^TMP($J,"PSOCP",+$G(PSOCPN)),PSOCPN,PSOLBLDR,PSOLBLPS,PSOLBLCP,RXPR,RXRP,RXRS,PSOCKHN,RXFLX,PSOLAPPL,PSOPDFN,PSDFNFLG,PSOZERO,NEXTRX,PSOBLALL,STA S:'$G(PSOSUREP)&('$G(PSOSUSPR)) ZTREQ="@" Q
 | 
|---|
| 19 | C I $G(IOST(0)),$D(^%ZIS(2,IOST(0),55,"B","LL")) G C^PSOLLLI
 | 
|---|
| 20 |  U IO S X=$S('$P(^PS(59,PSOSITE,1),"^",28):132,1:158) X ^%ZOSF("RM") Q:'$D(^PSRX(RX,0))
 | 
|---|
| 21 |  S:$G(PSOBLALL) PSOBLRX=RX
 | 
|---|
| 22 |  S:$D(RXRP(RX)) REPRINT=1 S:$D(RXPR(RX)) RXP=RXPR(RX)
 | 
|---|
| 23 |  I $G(PSOSUREP)!($G(PSOEXREP)) S REPRINT=1 S:'$G(RXRP(RX)) RXRP(RX)=1
 | 
|---|
| 24 |  S RXY=^PSRX(RX,0),RXSTA=$P(^PSRX(RX,"STA"),"^") I RXSTA>11 D AL("QT") K RXY,RXP,REPRINT Q         ;*244
 | 
|---|
| 25 |  I RXSTA=3 D AL("QT") K RXY,RXP,REPRINT Q
 | 
|---|
| 26 |  I $G(RXPR(RX)),'$D(^PSRX(RX,"P",RXP,0)) K RXY,RXP,REPRINT Q
 | 
|---|
| 27 |  I $P($G(RXFL(RX)),"^"),'$D(^PSRX(RX,1,$P($G(RXFL(RX)),"^"),0)) K RXY,RXP,REPRINT Q
 | 
|---|
| 28 |  I $G(PSODBQ)!($G(RXRS(RX))) S RR=$O(^PS(52.5,"B",RX,0)) Q:'RR  I $G(^PS(52.5,RR,"P"))=1 K RXY,RXP,REPRINT Q
 | 
|---|
| 29 |  I $G(RXRS(RX))!($G(PSOPULL)) S PSOSXQ=0 N DR,DA,DIE D  I $G(PSOSXQ) K RXY,RXP,REPRINT Q
 | 
|---|
| 30 |  .S DA=$O(^PS(52.5,"B",RX,0)) Q:'DA  S A=$P($G(^PS(52.5,DA,0)),"^",7) Q:A=""
 | 
|---|
| 31 |  .I A="Q" S DIE="^PS(52.5,",DR="3////P" D ^DIE Q
 | 
|---|
| 32 |  .K RXRS(RX) S PSOSXQ=1
 | 
|---|
| 33 |  I $G(PSRESOLV)=RX D ENLBL^PSOBSET K PSRESOLV
 | 
|---|
| 34 |  I RXSTA'=4 D:$G(PSOSUSPR) AREC^PSOSUTL D:$G(PSOPULL)!($G(RXRS(RX))) AREC1^PSOSUTL D:$G(PSOSUREP) AREC^PSOSUSRP D:$G(PSXREP) AREC^PSXSRP
 | 
|---|
| 35 |  K ^UTILITY("DIQ1",$J) S DA=$P($$SITE^VASITE(),"^") I $G(DA) S DIC=4,DIQ(0)="I",DR="99" D EN^DIQ1 S PSOINST=$G(^UTILITY("DIQ1",$J,4,DA,99,"I")) K ^UTILITY("DIQ1",$J),DA,DR,DIC
 | 
|---|
| 36 |  S RXN=$P(RXY,"^"),ISD=$P(RXY,"^",13),RXF=0,DFN=+$P(RXY,"^",2),SIG=$P($G(^PSRX(RX,"SIG")),"^"),ISD=$E(ISD,4,5)_"/"_$E(ISD,6,7)_"/"_($E(ISD,1,3)+1700),ZY=0,$P(LINE,"_",28)="_"
 | 
|---|
| 37 |  S PSOLBLPS=+$P(RXY,"^",3),PSOLBLDR=+$P(RXY,"^",6)
 | 
|---|
| 38 |  S NURSE=$S($P($G(^DPT(DFN,"NHC")),"^")="Y":1,$P($G(^PS(55,DFN,40)),"^"):1,1:0) S FDT=$P(^PSRX(RX,2),"^",2),PS=$S($D(^PS(59,PSOSITE,0)):^(0),1:""),PS1=$S($D(^(1)):^(1),1:""),PSOSITE7=$P(^("IB"),"^")
 | 
|---|
| 39 |  S PS2=$P(PS,"^")_"^"_$P(PS,"^",6)
 | 
|---|
| 40 |  S (EXPDT,EXDT)=$P(^PSRX(RX,2),"^",6),EXDT=$S('EXDT:"",1:$E(EXDT,4,5)_"/"_$E(EXDT,6,7)_"/"_($E(EXDT,1,3)+1700))
 | 
|---|
| 41 |  S COPIES=$S($P($G(RXRP(RX)),"^",2):$P($G(RXRP(RX)),"^",2),$P(RXY,"^",18)]"":$P(RXY,"^",18),1:1)
 | 
|---|
| 42 |  K PSOCKHNX S PSOCKHL=$L(RX),PSOCKHN=$E($G(PSOCKHN),(PSOCKHL+2),999) D  K PSOCKHNX,PSOCKHL,PSOCKHA
 | 
|---|
| 43 |  .S PSOCKHA=","_RX_","
 | 
|---|
| 44 |  .I PSOCKHN'[PSOCKHA Q
 | 
|---|
| 45 |  .S PSOCKHA=$E(PSOCKHA,1,($L(PSOCKHA)-1))
 | 
|---|
| 46 |  .S PSOCKHNX=$L(PSOCKHN,PSOCKHA)-1
 | 
|---|
| 47 |  .I +$G(PSOCKHNX)>0 D DOUB
 | 
|---|
| 48 |  I $O(^PSRX(RX,1,0)),$G(RXFL(RX))'=0 S $P(^PSRX(RX,3),"^",6)="" K ^PSRX(RX,"DAI"),^PSRX(RX,"DRI")
 | 
|---|
| 49 |  I '$G(RXP),'$O(^PSRX(RX,1,0)) S RXFL(RX)=0
 | 
|---|
| 50 |  I '$G(RXP) D OSET I '$O(^PSRX(RX,1,0))!($G(RXFL(RX))=0) G ORIG
 | 
|---|
| 51 |  I $O(^PSRX(RX,1,0)),'$G(RXP),'$G(RXFL(RX)) S XTYPE=1 D REF G STA
 | 
|---|
| 52 |  I $O(^PSRX(RX,1,0)),'$G(RXP),$G(RXFL(RX)) G STA
 | 
|---|
| 53 |  I $G(RXP) S XTYPE="P" D REF G STA
 | 
|---|
| 54 | ORIG S TECH=$P($G(^VA(200,+$P(^PSRX(RX,0),"^",16),0)),"^"),QTY=$P(^PSRX(RX,0),"^",7),PHYS=$S($D(^VA(200,+$P(^PSRX(RX,0),"^",4),0)):$P(^(0),"^"),1:"UKN") D 6^VADPT,PID^VADPT S SSNPN=$E($G(VA("PID")),5,12)
 | 
|---|
| 55 |  S DAYS=$P(^PSRX(RX,0),"^",8),MFG="________",LOT="________"
 | 
|---|
| 56 | STA S STATE=$S($D(^DIC(5,+$P(PS,"^",8),0)):$P(^(0),"^",2),1:"UKN")
 | 
|---|
| 57 |  S DRUG=$$ZZ^PSOSUTL(RX),DEA=$P($G(^PSDRUG(+$P(RXY,"^",6),0)),"^",3),WARN=$P($G(^(0)),"^",8)
 | 
|---|
| 58 |  S SIDE=$S($P($G(RXRP(RX)),"^",3):1,1:0)
 | 
|---|
| 59 |  I $G(^PSRX(RX,"P",+$G(RXP),0))]"" S RXPI=RXP D
 | 
|---|
| 60 |  .S RXP=^PSRX(RX,"P",RXP,0)
 | 
|---|
| 61 |  .S RXY=$P(RXP,"^")_"^"_$P(RXY,"^",2,6)_"^"_$P(RXP,"^",4)_"^"_$P(RXP,"^",10)_"^"_$P(RXY,"^",9)_"^"_$P($G(^PSRX(RX,"SIG")),"^",2)_"^"_$P(RXP,"^",2)_"^"_$P(RXY,"^",12,14)_"^"_$P(^PSRX(RX,"STA"),"^")_"^"_$P(RXP,"^",7)_"^"_$P(RXY,"^",17,99)
 | 
|---|
| 62 |  .S FDT=$P(RXP,"^")
 | 
|---|
| 63 |  S MW=$P(RXY,"^",11) I $G(RXFL(RX))'=0 D:$G(RXFL(RX))  I '$G(RXFL(RX)) F I=0:0 S I=$O(^PSRX(RX,1,I)) Q:'I  S RXF=RXF+1 S:'$G(RXP) MW=$P(^PSRX(RX,1,I,0),"^",2) I +^PSRX(RX,1,I,0)'<FDT S FDT=+^(0)
 | 
|---|
| 64 |  .I $G(RXFL(RX)),'$D(^PSRX(RX,1,RXFL(RX),0)) K RXFL(RX) Q
 | 
|---|
| 65 |  .S RXF=RXFL(RX) S:'$G(RXP) MW=$P($G(^PSRX(RX,1,RXF,0)),"^",2) I +^PSRX(RX,1,RXF,0)'<FDT S FDT=+^(0)
 | 
|---|
| 66 |  I MW="W" S PSMP=$G(^PSRX(RX,"MP")) I PSMP]"" D
 | 
|---|
| 67 |  .S PSJ=0 F PSI=1:1:$L(PSMP) S PSMP(PSI)="",PSJ=PSJ+1 F PSJ=PSJ:1 S PSMP(PSI)=PSMP(PSI)_$P(PSMP," ",PSJ)_" " Q:($L(PSMP(PSI))+$L($P(PSMP," ",PSJ+1))>30)
 | 
|---|
| 68 |  .K PSMP(PSI)
 | 
|---|
| 69 |  S X=$S($D(^PS(55,DFN,0)):^(0),1:""),PSCAP=$P(X,"^",2),PS55=$P($G(X),"^",3),PS55X=$P($G(X),"^",5)
 | 
|---|
| 70 |  I (($G(PS55X)]"")&(PS55>1)&(PS55X<DT)) S PS55=0
 | 
|---|
| 71 |  S:MW="M" MW=$S((PS55=1!(PS55=4)):"R",1:MW)
 | 
|---|
| 72 |  S MW=$S(MW="M":"REGULAR",MW="R":"CERTIFIED",1:"WINDOW")
 | 
|---|
| 73 |  I ($G(PSMP(1))']""&($G(PS55)=2)) S PSMP(1)=$G(SSNPN)
 | 
|---|
| 74 |  ;S X=$S($D(^PS(55,DFN,0)):^(0),1:""),PSCAP=$P(X,"^",2) S:MW="M" MW=$S(+$P(X,"^",3):"R",1:MW) S MW=$S(MW="M":"REGULAR",MW="R":"CERTIFIED",1:"WINDOW")
 | 
|---|
| 75 |  S DATE=$E(FDT,1,7),REF=$P(RXY,"^",9)-RXF S:'$G(RXP) $P(^PSRX(RX,3),"^")=FDT S:REF<1 REF=0 D ^PSOLBL2 S II=RX D ^PSORFL,RFLDT^PSORFL
 | 
|---|
| 76 |  S PATST=$G(^PS(53,+$P(RXY,"^",3),0)) S PRTFL=1 I REF=0 S:('$P(PATST,"^",5))!(DEA["W")!(DEA[1)!(DEA[2) PRTFL=0
 | 
|---|
| 77 |  S VRPH=$P(^PSRX(RX,2),"^",10),PSCLN=+$P(RXY,"^",5),PSCLN=$S($D(^SC(PSCLN,0)):$P(^(0),"^",2),1:"UNKNOWN")
 | 
|---|
| 78 |  S PATST=$P(PATST,"^",2),X1=DT,X2=$P(RXY,"^",8)-10 D C^%DTC:REF I $D(^PSRX(RX,2)),$P(^(2),"^",6),REF,X'<$P(^(2),"^",6) S REF=0,VRPH=$P(^(2),"^",10)
 | 
|---|
| 79 |  I $G(PSOCHAMP),$G(PSOTRAMT) S COPAYVAR="CHAMPUS" G LBL
 | 
|---|
| 80 |  I $G(RXP) S COPAYVAR="" G LBL
 | 
|---|
| 81 |  I $P($G(^PS(53,+$G(PSOLBLPS),0)),"^",7) D SNO G LBL
 | 
|---|
| 82 |  I $P($G(^PSDRUG(+$G(PSOLBLDR),0)),"^",3)["I"!($P($G(^(0)),"^",3)["S") D SNO G LBL
 | 
|---|
| 83 |  I $P(^PSRX(RX,"STA"),"^")>0,$P(^("STA"),"^")'=2,'$G(PSODBQ) D SNO G LBL
 | 
|---|
| 84 |  I $G(PSOLBLCP)="" D IBCP
 | 
|---|
| 85 |  N PSOQI S PSOQI=$G(^PSRX(RX,"IBQ")) I $G(PSOLBLCP)=0 D SNO G LBL
 | 
|---|
| 86 |  I $G(PSOLBLCP)=1 I $P(PSOQI,"^",2)!($P(PSOQI,"^",3))!($P(PSOQI,"^",4))!($P(PSOQI,"^",5))!($P(PSOQI,"^",6))!($P(PSOQI,"^",7)) D SNO G LBL
 | 
|---|
| 87 |  I $G(PSOLBLCP)=2 I $P(PSOQI,"^")!($P(PSOQI,"^",2))!($P(PSOQI,"^",3))!($P(PSOQI,"^",4))!($P(PSOQI,"^",5))!($P(PSOQI,"^",6))!($P(PSOQI,"^",7)) D SNO G LBL
 | 
|---|
| 88 |  I $G(PSOLBLCP)=2,'$P($G(^PSRX(RX,"IB")),"^") D SNO G LBL
 | 
|---|
| 89 |  S PSOCPN=$P(^PSRX(RX,0),"^",2),INRX=$P(^(0),"^") I $G(^TMP($J,"PSOCP",PSOCPN))="" S ^(PSOCPN)=PSOCPN
 | 
|---|
| 90 |  S ^TMP($J,"PSOCP",PSOCPN,INRX)=INRX_"^"_$$ZZ^PSOSUTL(RX)_"^"_+$G(DAYS) S COPAYVAR="COPAY" K ZDRUG
 | 
|---|
| 91 | LBL G ^PSOLBLD:$P(^PSRX(RX,"STA"),"^")=4 D ^PSOLBLD:$D(^PSRX(RX,"DRI"))&('$G(RXF))&('$G(RXP)) D:$P($G(^PSRX(RX,3)),"^",6)&('$G(RXF))&('$G(RXP)) ^PSOLBLD1 G ^PSOLBL1:'$P(^PS(59,PSOSITE,1),"^",28)
 | 
|---|
| 92 |  G ^PSOLBLN
 | 
|---|
| 93 | REF F XXX=0:0 S XXX=$O(^PSRX(RX,XTYPE,XXX)) Q:+XXX'>0  D
 | 
|---|
| 94 |  .S TECH=$S($D(^VA(200,+$P(^PSRX(RX,XTYPE,XXX,0),"^",7),0)):$P(^(0),"^"),1:"UNKNOWN")
 | 
|---|
| 95 |  .S QTY=$P(^PSRX(RX,XTYPE,XXX,0),"^",4),PHYS=$S($D(^VA(200,+$P(^PSRX(RX,XTYPE,XXX,0),"^",17),0)):$P(^(0),"^"),$D(^VA(200,+$P(^PSRX(RX,0),"^",4),0)):$P(^(0),"^"),1:"UNKNOWN") D 6^VADPT,PID^VADPT S SSNPN=$E($G(VA("PID")),5,12)
 | 
|---|
| 96 |  .S DAYS=$P(^PSRX(RX,XTYPE,XXX,0),"^",10),LOT="________",MFG="________"
 | 
|---|
| 97 |  Q
 | 
|---|
| 98 | CHECK S PSDFNFLG=0,PSOZERO=$P(PPL,","),PSOPDFN=$P(^PSRX(PSOZERO,0),"^",2)
 | 
|---|
| 99 |  Q
 | 
|---|
| 100 | OSET I $G(RXFL(RX))']""!($G(RXFL(RX))=0) D  Q
 | 
|---|
| 101 |  .S TECH=$P($G(^VA(200,+$P(^PSRX(RX,0),"^",16),0)),"^"),QTY=$P(^PSRX(RX,0),"^",7),PHYS=$S($D(^VA(200,+$P(^PSRX(RX,0),"^",4),0)):$P(^(0),"^"),1:"UKN") D 6^VADPT,PID^VADPT S SSNPN=$E($G(VA("PID")),5,12)
 | 
|---|
| 102 |  .S DAYS=$P(^PSRX(RX,0),"^",8),MFG="________",LOT="________"
 | 
|---|
| 103 |  I '$D(^PSRX(RX,1,RXFL(RX),0)) K RXFL(RX) Q
 | 
|---|
| 104 |  S TECH=$S($D(^VA(200,+$P(^PSRX(RX,1,RXFL(RX),0),"^",7),0)):$P(^(0),"^"),1:"UNKNOWN")
 | 
|---|
| 105 |  S QTY=$P(^PSRX(RX,1,RXFL(RX),0),"^",4),PHYS=$S($D(^VA(200,+$P(^PSRX(RX,1,RXFL(RX),0),"^",17),0)):$P(^(0),"^"),$D(^VA(200,+$P(^PSRX(RX,0),"^",4),0)):$P(^(0),"^"),1:"UNKNOWN") D 6^VADPT,PID^VADPT S SSNPN=$E($G(VA("PID")),5,12)
 | 
|---|
| 106 |  S DAYS=$P(^PSRX(RX,1,RXFL(RX),0),"^",10),LOT="________",MFG="________"
 | 
|---|
| 107 |  Q
 | 
|---|
| 108 | DOUB Q:'$D(RXFL(RX))  I +$G(RXFL(RX))-PSOCKHNX<0 Q
 | 
|---|
| 109 |  S RXFLX(RX)=$G(RXFL(RX)),RXFL(RX)=$G(RXFL(RX))-PSOCKHNX
 | 
|---|
| 110 |  Q
 | 
|---|
| 111 | AL(T) N I,IR,RF,USR,TY,DES S USR=""
 | 
|---|
| 112 |  I T="UT" D
 | 
|---|
| 113 |  .N J,RX S USR=$G(DUZ),TY="B",DES="Label never queued to print by User"
 | 
|---|
| 114 |  .F J=1:1  S RX=+$P(PPL,",",J) Q:'RX  D AL1
 | 
|---|
| 115 |  I T="QT" D
 | 
|---|
| 116 |  .S I=+$P(^PSRX(RX,"STA"),"^"),TY=$S((I=3)!(I=16):"H",I=13:"D",1:"C")
 | 
|---|
| 117 |  .S DES=I_" "_$S((I=3)!(I=16):"HOLD"_$S(I=16:"(PROVIDER)",1:""),(I=12)!(I=14)!(I=15):"DISCONTINUED"_$S(I=14:"(PROVIDER)",I=15:"(EDIT)",1:""),I=13:"DELETED",1:"")
 | 
|---|
| 118 |  .S DES="Queued label terminated - "_DES D AL1
 | 
|---|
| 119 |  K %,%H,%I Q
 | 
|---|
| 120 | AL1 S (IR,I,RF)=0 F  S I=$O(^PSRX(RX,1,I)) Q:'I  S RF=I S:I>5 RF=I+1
 | 
|---|
| 121 |  S I=0 F  S I=$O(^PSRX(RX,"A",I)) Q:'I  S IR=I
 | 
|---|
| 122 |  S IR=IR+1,^PSRX(RX,"A",0)="^52.3DA^"_IR_"^"_IR
 | 
|---|
| 123 |  D NOW^%DTC S ^PSRX(RX,"A",IR,0)=%_"^"_TY_"^"_USR_"^"_$S($G(RXPR(RX)):6,1:RF)_"^"_DES
 | 
|---|
| 124 |  Q
 | 
|---|
| 125 | IBCP N X,Y,PSOJJ,PSOLL
 | 
|---|
| 126 |  S PSOLBLCP="",X=$P($G(^PS(59,+$G(PSOSITE),"IB")),"^")_"^"_$G(DFN) D XTYPE^IBARX
 | 
|---|
| 127 |  S PSOJJ="" F  S PSOJJ=$O(Y(PSOJJ)) Q:'PSOJJ  S PSOLL="" F  S PSOLL=$O(Y(PSOJJ,PSOLL)) Q:PSOLL=""  S:PSOLL>0 PSOLBLCP=PSOLL
 | 
|---|
| 128 |  I '$G(PSOLBLCP) S PSOLBLCP=0
 | 
|---|
| 129 |  Q
 | 
|---|
| 130 | SNO S COPAYVAR="NO COPAY" Q
 | 
|---|