Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSOORNE2

PSOORNE2.m

Go to the documentation of this file.
  1. PSOORNE2 ;BIR/SAB - Display finished orders from backdoor ;Jul 20, 2021@15:35:49
  1. ;;7.0;OUTPATIENT PHARMACY;**11,21,23,27,32,37,46,84,103,117,131,146,156,210,148,222,238,264,281,289,251,379,391,313,282,427,454,446,467,612,524,441,698,753**;DEC 1997;Build 53
  1. ;
  1. ;^PSDRUG( - 221
  1. ;^YSCL(603.01 - 2697
  1. ;^PS(50.606 - 2174
  1. ;^PS(50.7 - 2223
  1. ;PSO*210 add call to WORDWRAP api
  1. ;$$DAWEXT^PSSDAWUT - 4708
  1. ;Reference to ^SC( is supported by DBIA #10040
  1. ;
  1. ;*524 create and init psohz; user has seen Haz drug warning during this order's session
  1. ;
  1. SEL N ORN,ORD,OR0,PSORRBLD I '$G(PSOCNT),'$G(PSORCNT) S VALMSG="This patient has no Prescriptions!" S VALMBCK="" Q
  1. D K1^PSOORNE6 S DIR("A")="Select Orders by number",DIR(0)="LO^1:"_$S($G(PSORCNT):PSORCNT,1:PSOCNT) D ^DIR I $D(DIRUT) D KV^PSOVER1 S VALMBCK="" Q
  1. NEWSEL N ORN,ORD,OR0 D K2^PSOORNE6
  1. N PSOHZ,PSOLSTDR S (PSOHZ,PSOLSTDR)=0 ;reset haz alerts displayed to user *524
  1. ;*282 Correct Patient Instructions Copy
  1. I +Y S PSOOELSE=1,PSLST=Y K PSOREEDT F ORD=1:1:$L(PSLST,",") Q:$P(PSLST,",",ORD)']"" D D UL1 K ^TMP("PSORXPO",$J),PSORXED,PSONEW,PSOPINS,PSOPIND,PSOPINDF I $G(PSOQUIT) K PSOQUIT Q ;*441-IND
  1. .; bwf 1/21/2014 - replaced line below with the one that follows for remote rx data handling.
  1. .;S ORN=+$P(PSLST,",",ORD) D @$S(+PSOLST(ORN)=52:"ACT",1:"PEN^PSOORNE5")
  1. .S ORN=+$P(PSLST,",",ORD) D @$S(+PSOLST(ORN)=52:"ACT",$P(PSOLST(ORN),"^")="R52":"RACT",1:"PEN^PSOORNE5")
  1. .K PSOREEDT,PSOSIGFL,PSONACT,SIGOK,PSOFDR,DRET,SIG,INS1
  1. K PRC,PHI,RTE I '$G(PSOOELSE) S VALMBCK=""
  1. K PSONACT,PSOOELSE,CLOZPAT
  1. ;
  1. ; Only rebuild remote if something changed
  1. I $G(PSORRBLD) W !!,"Updating prescription order list...",!! D REMOTERX^PSORRX1(PSODFN,PSOSITE) K PSORRBLD
  1. ;
  1. D ^PSOBUILD,BLD^PSOORUT1,K3^PSOORNE6
  1. Q
  1. ;
  1. ACT N REF,RPHKEY,PKIND K ^TMP("PSOAO",$J),PCOMX,PDA,PHI,PRC,ACOM,ANS,PSOFDR,CLOZPAT,ANQREM,DUR,DRET
  1. S RXN=$P(PSOLST(ORN),"^",2),RX0=^PSRX(RXN,0),RX2=$G(^(2)),RX3=$G(^(3)),ST=+$G(^("STA")),RXOR=$G(^("OR1")),POE=$G(^("POE")),EXDT=$S($P($G(^(2)),"^",6)>DT:1,1:0)
  1. I 'RX3 S $P(RX3,"^",1)=$P(RX2,"^",2),$P(^PSRX(RXN,3),"^")=$P(RX2,"^",2)
  1. S PSODRG=+$P(RX0,"^",6),PSODRUG0=^PSDRUG(PSODRG,0),INDT=$G(^("I"))
  1. ;PSO*7*238;SET PSODRUG ARRAY ; PSOY KILLED AT END OF SET^PSODRG
  1. K PSODRUG
  1. S PSOY=PSODRG,PSOY(0)=PSODRUG0 D SET^PSODRG
  1. I 'RXOR,$P(^PSDRUG(PSODRG,2),"^") S $P(^PSRX(RXN,"OR1"),"^")=$P(^PSDRUG(PSODRG,2),"^"),RXOR=$P(^PSDRUG(PSODRG,2),"^")
  1. I $P($G(^PSDRUG(PSODRG,"CLOZ1")),"^")="PSOCLO1" D
  1. .; BEGIN - JCH: PSO*7*612
  1. .S CLOZPAT=$$GETREGYS^PSOCLUTL(PSODFN) Q:'($G(CLOZPAT)>0)
  1. .; END - JCH: PSO*7*612
  1. .S CLOZPAT=$P(^YSCL(603.01,CLOZPAT,0),"^",3)
  1. .S CLOZPAT=$S(CLOZPAT="M":2,CLOZPAT="B":1,1:0)
  1. S PKIND=$D(^PSRX(RXN,"PKI")),RPHKEY=$S('PKIND&($D(^XUSEC("PSORPH",DUZ))):1,PKIND&($D(^XUSEC("PSDRPH",DUZ))):1,1:0)
  1. I RPHKEY S RPH=1 D
  1. .S PSOACT=$S('ST&($G(INDT)]"")&(DT>$G(INDT)):"DHPLATC",ST=1!(ST=4):"DVE",ST=3:"DU",ST=5:"ELTD",ST=11:"ETDPCL",ST=12&EXDT:"EDCL",ST=12&'EXDT:"ECL",(ST=14!(ST=15))&'EXDT:"ECL",ST=13:"L",ST=16:"DL",1:"DHPEATCL")
  1. .D GET^PSOORNE5 S PSOACT=PSOACT_$S(ACTREN:"N",1:""),PSOACT=PSOACT_$S(ACTREF:"R",1:"")
  1. .I ST=5 S SURX=$O(^PS(52.5,"B",RXN,0)) I SURX,$P($G(^PS(52.5,SURX,0)),"^",7)="L" S PSOACT="TL" K SURX Q
  1. .S:ST'=12&('$D(^PS(50.7,+$P(RXOR,"^"),0))) PSOACT="DL",VALMSG="No Pharmacy Orderable Item !",PSONACT=1
  1. .S:ST=12&('$D(^PS(50.7,+$P(RXOR,"^"),0))) PSOACT="L",VALMSG="No Pharmacy Orderable Item !",PSONACT=1
  1. .S:ST=16 VALMSG="Rx Placed on HOLD by Provider."
  1. E D
  1. .I ST=5 S SURX=$O(^PS(52.5,"B",RXN,0)) I SURX,$P($G(^PS(52.5,SURX,0)),"^",7)="L" S PSOACT="TL" Q
  1. .S PSOACT=$S(ST'<1&(ST'>4)!(ST>12):"",ST=12&EXDT&($P($G(PSOPAR),"^",2)):"CDPLT",1:"CPLT")
  1. .D GET^PSOORNE5 S PSOACT=PSOACT_$S(ACTREN:"N",1:""),PSOACT=PSOACT_$S(ACTREF:"R",1:"")
  1. .S:'$D(^PS(50.7,+$P(RXOR,"^"),0)) PSOACT="L",PSONACT=1,VALMSG="No Pharmacy Orderable Item !"
  1. ;K PSOLKFL D PSOL^PSSLOCK(RXN) I '$G(PSOMSG) K PSOMSG S PSOLKFL=1 S PSOACT="",VALMSG="This Order is being edited by another user."
  1. K PSOMSG S IEN=0,$P(RN," ",12)=" "
  1. D DIN^PSONFI(+RXOR,$P(RX0,"^",6))
  1. ; pso*7*467 - add display of erx information if the rx came from eRx
  1. N ERXIEN
  1. I $P(RXOR,U,2)]"" D
  1. .S ERXIEN=$$CHKERX^PSOERXU1($P(RXOR,U,2)) I ERXIEN D DERX1^PSOERXU1($NA(^TMP("PSOAO",$J)),ERXIEN,"",.IEN)
  1. ; pso*7*467 - end eRx enhancement
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=$S($P($G(^PSRX(RXN,"TPB")),"^"):" TPB Rx #: ",1:" Rx #: ")
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_$P(RX0,"^")_$S($G(^PSRX(RXN,"IB")):"$",1:"")_$$ECME^PSOBPSUT(RXN)_$$TITRX^PSOUTL(RXN)_$E(RN,$L($P(RX0,"^")_$S($G(^PSRX(RXN,"IB")):"$",1:"")_$$ECME^PSOBPSUT(RXN)_$$TITRX^PSOUTL(RXN))+1,12)
  1. I $$ECME^PSOBPSUT(RXN)'="" D ;*524
  1. . S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_"(ECME#: "_$$ECMENUM^PSOBPSU2(RXN)_")"
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" ("_$S($P(PSOPAR,"^",3):1,1:"#")_")"_" *Orderable Item: "_$S($D(^PS(50.7,$P(+RXOR,"^"),0)):$P(^PS(50.7,$P(+RXOR,"^"),0),"^")_" "_$P(^PS(50.606,$P(^(0),"^",2),0),"^"),1:"")_NFIO
  1. S:NFIO["<DIN>" NFIO=IEN_","_($L(^TMP("PSOAO",$J,IEN,0))-4)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" ("_$S($P(PSOPAR,"^",3):2,1:"#")_")"_$S($D(^PSDRUG("AQ",$P(RX0,"^",6))):" CMOP ",1:" ")_"Drug: "_$P(^PSDRUG($P(RX0,"^",6),0),"^")_NFID
  1. S:NFID["<DIN>" NFID=IEN_","_($L(^TMP("PSOAO",$J,IEN,0))-4)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" "_$S('$P(PSOPAR,"^",3):"(2)",1:" ")_" NDC: "_$$GETNDC^PSONDCUT(RXN,0)
  1. S:$G(^PSRX(RXN,"TN"))]"" IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Trade Name: "_$G(^PSRX(RXN,"TN"))
  1. D DOSE^PSOORNE5
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" (4)Pat Instructions:" D INS^PSOORNE5
  1. D PC^PSOORNE5
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Indications: "_$S($P($G(^PSRX(RXN,"IND")),"^")]"":$P(^PSRX(RXN,"IND"),"^"),1:"") ;*441-IND
  1. I $P($G(^PS(55,PSODFN,"LAN")),"^") S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Other Indications: "_$S($P($G(^PSRX(RXN,"IND")),"^",3)]"":$P(^("IND"),"^",3),1:"")
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" SIG:"
  1. I '$P($G(^PSRX(RXN,"SIG")),"^",2) S SIGOK=0 D G PTST
  1. .S X=$P($G(^PSRX(RXN,"SIG")),"^") D SIGONE^PSOHELP S SIG=$E($G(INS1),2,250)
  1. .F SG=1:1:$L(SIG) S:$L(^TMP("PSOAO",$J,IEN,0)_" "_$P(SIG," ",SG))>80 IEN=IEN+1,$P(^TMP("PSOAO",$J,IEN,0)," ",21)=" " S:$P(SIG," ",SG)'="" ^TMP("PSOAO",$J,IEN,0)=$G(^TMP("PSOAO",$J,IEN,0))_" "_$P(SIG," ",SG)
  1. S SIGOK=1
  1. F I=0:0 S I=$O(^PSRX(RXN,"SIG1",I)) Q:'I D ;PSO*210
  1. . S MIG=$P(^PSRX(RXN,"SIG1",I,0),"^")
  1. . D WORDWRAP^PSOUTLA2(MIG,.IEN,$NA(^TMP("PSOAO",$J)),21)
  1. S SIGOK=1 K MIG,SG
  1. PTST S $P(RN," ",25)=" ",PTST=$S($G(^PS(53,+$P(RX0,"^",3),0))]"":$P($G(^PS(53,+$P(RX0,"^",3),0)),"^"),1:""),IEN=IEN+1
  1. S ^TMP("PSOAO",$J,IEN,0)=" (5) Patient Status: "_PTST_$E(RN,$L(PTST)+1,25)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" (6) Issue Date: "_$E($P(RX0,"^",13),4,5)_"/"_$E($P(RX0,"^",13),6,7)_"/"_$E($P(RX0,"^",13),2,3)
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_" (7) Fill Date: "_$E($P(RX2,"^",2),4,5)_"/"_$E($P(RX2,"^",2),6,7)_"/"_$E($P(RX2,"^",2),2,3)
  1. S ROU=$S($P(RX0,"^",11)="W":"Window",$P(RX0,"^",11)="P":"Park",1:"Mail") ;PAPI 441
  1. S REFL=$P(RX0,"^",9),I=0 F S I=$O(^PSRX(RXN,1,I)) Q:'I S REFL=REFL-1,ROU=$S($P(^PSRX(RXN,1,I,0),"^",2)="W":"Window",$P(^PSRX(RXN,1,I,0),"^",2)="P":"Park",1:"Mail")
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Last Fill Date: "_$E($P(RX3,"^"),4,5)_"/"_$E($P(RX3,"^"),6,7)_"/"_$E($P(RX3,"^"),2,3)
  1. D CMOP^PSOORNE3
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_" ("_ROU_$S($G(PSOCMOP)]"":", "_PSOCMOP,1:"")_")" K ROU,PSOCMOP
  1. ;*282 Correct return to stock/release display
  1. S IEN=IEN+1 D
  1. .S RLD=$S($P(RX2,"^",13):$E($P(RX2,"^",13),4,5)_"/"_$E($P(RX2,"^",13),6,7)_"/"_$E($P(RX2,"^",13),2,3),1:"")
  1. .I $O(^PSRX(RXN,1,0)) F I=0:0 S I=$O(^PSRX(RXN,1,I)) Q:'I D
  1. ..I $P(^PSRX(RXN,1,I,0),"^",18) S RLD=$E($P(^(0),"^",18),4,5)_"/"_$E($P(^(0),"^",18),6,7)_"/"_$E($P(^(0),"^",18),2,3)
  1. .I $P(RX2,"^",15)&'$G(RLD) S ^TMP("PSOAO",$J,IEN,0)=" Returned to Stock: "_$E($P(RX2,"^",15),4,5)_"/"_$E($P(RX2,"^",15),6,7)_"/"_$E($P(RX2,"^",15),2,3)_$S($P(RX2,"^",14):" (Reprinted)",1:"")
  1. .E S ^TMP("PSOAO",$J,IEN,0)=" Last Release Date: "_$S($G(RLD)]"":RLD,1:" ")
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_" (8) Lot #: "_$P($G(RX2),"^",4)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Expires: "_$E($P(RX2,"^",6),4,5)_"/"_$E($P(RX2,"^",6),6,7)_"/"_$E($P(RX2,"^",6),2,3)
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_" MFG: "_$P($G(RX2),"^",8)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(9) Days Supply: "_$P(RX0,"^",8)_$S($L($P(RX0,"^",8))=1:" ",1:"")
  1. S ^TMP("PSOAO",$J,IEN,0)=^TMP("PSOAO",$J,IEN,0)_" (10) QTY"_$S($P($G(^PSDRUG($P(RX0,"^",6),660)),"^",8)]"":" ("_$P($G(^PSDRUG($P(RX0,"^",6),660)),"^",8)_")",1:" ( )")_": "_$P(RX0,"^",7)
  1. I $P($G(^PSDRUG($P(RX0,"^",6),5)),"^")]"" D
  1. .S $P(RN," ",79)=" ",IEN=IEN+1
  1. .S ^TMP("PSOAO",$J,IEN,0)=$E(RN,$L("QTY DSP MSG: "_$P(^PSDRUG($P(RX0,"^",6),5),"^"))+1,79)_"QTY DSP MSG: "_$P(^PSDRUG($P(RX0,"^",6),5),"^") K RN
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(11) # of Refills: "_$P(RX0,"^",9)_$S($L($P(RX0,"^",9))=1:" ",1:"")_" Remaining: "_REFL
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(12) Provider: "_$S($D(^VA(200,$P(RX0,"^",4),0)):$P(^VA(200,$P(RX0,"^",4),0),"^"),1:"UNKNOWN")
  1. I +$P($G(^PSDRUG($P(RX0,"^",6),0)),"^",3)>1,+$P($G(^PSDRUG($P(RX0,"^",6),0)),"^",3)<6 D PRV^PSOORNE5
  1. I $P(RX3,"^",3) S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Cos-Provider: "_$P(^VA(200,$S($G(PSORX("COSIGNING PROVIDER")):PSORX("COSIGNING PROVIDER"),1:$P(RX3,"^",3)),0),"^")
  1. ;PAPI 441
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(13) Routing: "_$S($P(RX0,"^",11)="M":"MAIL",$P(RX0,"^",11)="P":"PARK",1:"WINDOW")_" (14) Copies: "_$S($P(RX0,"^",18):$P(RX0,"^",18),1:1)
  1. S:$P(RX0,"^",11)="W"&($P(PSOPAR,"^",12)) IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)=" Method of Pickup: "_$G(^PSRX(RXN,"MP"))
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(15) Clinic: "_$S($D(^SC(+$P(RX0,"^",5),0)):$P(^SC($P(RX0,"^",5),0),"^"),1:"Not on File")
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(16) Division: "_$S($G(^PS(59,+$P(RX2,"^",9),0))]"":$P(^PS(59,$P(RX2,"^",9),0),"^")_" ("_$P(^(0),"^",6)_")",1:"UNKNOWN")
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(17) Pharmacist: "_$S($P(RX2,"^",3):$P(^VA(200,$P(RX2,"^",3),0),"^"),1:"")
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(18) Remarks:" D RMK^PSOORNE3
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(19) Counseling: "_$S($P($G(^PSRX(RXN,"PC")),"^"):"YES",1:"NO")_" "_$S($P($G(^PSRX(RXN,"PC")),"^"):"Was Counseling Understood: "_$S($P($G(^PSRX(RXN,"PC")),"^",2):"YES",1:"NO"),1:"")
  1. S:$O(^PSRX(RXN,1,0)) REF=1,IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(20) Refill Data"
  1. I $$STATUS^PSOBPSUT(RXN,0)'="" D
  1. . N DAW S IEN=IEN+1,DAW=$$GETDAW^PSODAWUT(RXN,0)
  1. . S ^TMP("PSOAO",$J,IEN,0)="(21) DAW Code: "_DAW_" - "_$$DAWEXT^PSSDAWUT(DAW)
  1. S IEN=IEN+1,^TMP("PSOAO",$J,IEN,0)="(22) Mail Exemption: "_$$GET1^DIQ(52,RXN,100.2) ;p753
  1. D DISP^PSOORNE6
  1. I $G(PSOBEDT),PSOACT["E" S PSOACT="E"
  1. I $G(PSOBEDT),PSOACT'["E" S PSOACT=""
  1. Q:$G(PSORXED)!($G(COPY))!($G(UPMI))
  1. S:$G(PSOBEDT) (PSOEDIT,PSORXED)=1
  1. RENERR S PSORERR=0 D ^PSOLMLST
  1. I PSORERR=1 S:$G(PSOBEDT) (PSOEDIT,PSORXED)=1 G RENERR
  1. K DRET,SIG
  1. Q
  1. UL1 ;
  1. Q
  1. ; bwf 1/21/2014 - adding display of remote active orders.
  1. RACT ; display remote active order
  1. N REMSITE,CNT,REMDATA,RSITENM,RRXNUM,RDETSTR,RSIGSTR,RDET,RSIG,REMSIEN,RXSTAT,SIGLOOP,DETLOOP,DONE,SRXSTAT,SDNAME,DNAME
  1. K ^TMP("PSOAO",$J)
  1. S (RSIG,RDET)=""
  1. S REMSITE=$P(PSOLST(ORN),U,4) Q:'REMSITE
  1. S REMSIEN=$O(^DIC(4,"D",REMSITE,""))
  1. S REMSIEN=$$FIND1^DIC(4,,"X",REMSITE,"D","I $P(^(0),U,11)=""N"",'$P($G(^(99)),U,4)") Q:'REMSIEN
  1. S RSITENM=$$GET1^DIQ(4,REMSIEN,.01,"E")
  1. ; do not continue if we are missing the remote order number for some reason
  1. S RRXNUM=$P(PSOLST(ORN),U,2) Q:'RRXNUM
  1. S DONE=0
  1. S RXSTAT="" F S RXSTAT=$O(^XTMP("PSORRX1",$J,PSODFN,REMSITE,RXSTAT)) Q:RXSTAT=""!DONE D
  1. .S SRXSTAT=RXSTAT
  1. .S DNAME="" F S DNAME=$O(^XTMP("PSORRX1",$J,PSODFN,REMSITE,RXSTAT,DNAME)) Q:DNAME=""!DONE D
  1. ..S SDNAME=DNAME
  1. ..I $P(^XTMP("PSORRX1",$J,PSODFN,REMSITE,RXSTAT,DNAME,0),U,1)=RRXNUM S DONE=1 Q
  1. Q:$G(SRXSTAT)=""
  1. S REMDATA=$G(^XTMP("PSORRX1",$J,PSODFN,REMSITE,SRXSTAT,SDNAME,0))
  1. S RDETSTR=$G(^XTMP("PSORRX1",$J,PSODFN,REMSITE,SRXSTAT,SDNAME,"DETAIL"))
  1. S RSIGSTR=$G(^XTMP("PSORRX1",$J,PSODFN,REMSITE,SRXSTAT,SDNAME,"SIG"))
  1. S CNT=1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Site #: "_REMSITE_"("_RSITENM_")",CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Rx #: "_RRXNUM,CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Drug Name: "_$P(REMDATA,U,11),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Days Supply: "_$S($E($P(REMDATA,U,4),1)?1A:$E($P(REMDATA,U,4),2,99),1:$P(REMDATA,U,4)),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Quantity: "_$P(REMDATA,U,2),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Refills: "_$P(REMDATA,U,3),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)="Expiration Date: "_$$RDT($P($P(REMDATA,U,5),".")),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Issue Date: "_$$RDT($P($P(REMDATA,U,6),".")),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Stop Date: "_$$RDT($P($P(REMDATA,U,7),".")),CNT=CNT+1
  1. S ^TMP("PSOAO",$J,CNT,0)=" Last Fill Date: "_$$RDT($P($P(REMDATA,U,8),".")),CNT=CNT+1
  1. ;D RCHUNK(.RDET,RDETSTR),RCHUNK(.RSIG,RSIGSTR)
  1. ;S ^TMP("PSOAO",$J,CNT,0)=" Detail: "_$G(RDET(1)),CNT=CNT+1
  1. ;S DETLOOP=1 F S DETLOOP=$O(RDET(DETLOOP)) Q:'DETLOOP D
  1. ;.S ^TMP("PSOAO",$J,CNT,0)=" "_RDET(DETLOOP),CNT=CNT+1
  1. D RCHUNK(.RSIG,RSIGSTR)
  1. S ^TMP("PSOAO",$J,CNT,0)=" Sig: "_$G(RSIG(1))
  1. S SIGLOOP=1 F S SIGLOOP=$O(RSIG(SIGLOOP)) Q:'SIGLOOP D
  1. .S CNT=CNT+1,^TMP("PSOAO",$J,CNT,0)=" "_RSIG(SIGLOOP)
  1. ; ^PSOLMLST is the local order template
  1. D EN^PSOROS
  1. Q
  1. RCHUNK(ARR,STR) ;
  1. N START,END,I,C,ROOM
  1. S ROOM=60
  1. ; if there is enough room for 1 line, no wrapping needed
  1. I $L(STR)'>ROOM S ARR(1)=STR Q
  1. ; add a space to the end of the string to avoid dropping last character
  1. S START=1,END=ROOM,STR=STR_" "
  1. F C=1:1 D Q:$L(STR)<START ; stop if we have made it to the end of the data string
  1. .; start at the end and work backwards until you find a blank space, cut the line there and move on to the next line
  1. .F I=END:-1:START I $E(STR,I)=" " S ARR(C)=$E(STR,START,I),START=I+1,END=ROOM+START Q
  1. .; make sure there wasn't a really long string without spaces
  1. .I I=START S ARR(C)=$E(STR,START,END),START=END+1,END=ROOM+START
  1. Q
  1. RDT(DATE) ;
  1. N Y,M,D
  1. S Y=$E(DATE,3,4),M=$E(DATE,5,6),D=$E(DATE,7,8)
  1. Q M_"/"_D_"/"_Y