| 1 | PPPGET8 ;ALB/DMB - GET LOCAL PHARMACY DATA ; 3/11/92 | 
|---|
| 2 | ;;V1.0;PHARMACY PRESCRIPTION PRACTICE;;APR 7,1995 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | GLPHRM(PATDFN,ARRYNM) ; Get the local data | 
|---|
| 6 | ; | 
|---|
| 7 | N PPPTMP,DA,DIC,DIQ,DR,FOUND,PARMERR,RVRSDT,RXCUTOFF | 
|---|
| 8 | N RXDATA,RXIFN,SRCHDT,STANAME,STANO,X,X1,X2 | 
|---|
| 9 | ; | 
|---|
| 10 | S PARMERR=-9001 | 
|---|
| 11 | S RXCUTOFF=90 | 
|---|
| 12 | S FOUND=0 | 
|---|
| 13 | ; | 
|---|
| 14 | I '$D(PATDFN) Q PARMERR | 
|---|
| 15 | I '$D(ARRYNM) Q PARMERR | 
|---|
| 16 | I ARRYNM="" Q PARMERR | 
|---|
| 17 | ; | 
|---|
| 18 | ; Get the cutoff date | 
|---|
| 19 | ; | 
|---|
| 20 | S X1=DT,X2=-RXCUTOFF | 
|---|
| 21 | D C^%DTC | 
|---|
| 22 | S SRCHDT=X | 
|---|
| 23 | ; | 
|---|
| 24 | ; Get the local station name | 
|---|
| 25 | ; | 
|---|
| 26 | S STANO=+$P($G(^PPP(1020.1,1,0)),"^",9) | 
|---|
| 27 | I STANO>0 S STANAME=$P($$GETSNIFN^PPPGET1(STANO),"^",2) | 
|---|
| 28 | E  S STANO="UNKNOWN" | 
|---|
| 29 | I STANAME="" S STANAME="UNKNOWN" | 
|---|
| 30 | ; | 
|---|
| 31 | ; Get the narrative | 
|---|
| 32 | ; | 
|---|
| 33 | S DIC=55,DA=PATDFN,DR="1",DIQ="PPPTMP" D EN^DIQ1 | 
|---|
| 34 | I $G(PPPTMP(55,PATDFN,1))'="" S @ARRYNM@(0,STANAME)=PPPTMP(55,PATDFN,1) | 
|---|
| 35 | K PPPTMP | 
|---|
| 36 | ; | 
|---|
| 37 | ; Order through the "A" xref to find the RX's | 
|---|
| 38 | ; | 
|---|
| 39 | F SRCHDT=SRCHDT:0 D  Q:'SRCHDT | 
|---|
| 40 | .S SRCHDT=$O(^PS(55,PATDFN,"P","A",SRCHDT)) Q:'SRCHDT | 
|---|
| 41 | .F RXIFN=0:0 D  Q:'RXIFN | 
|---|
| 42 | ..S RXIFN=$O(^PS(55,PATDFN,"P","A",SRCHDT,RXIFN)) Q:'RXIFN | 
|---|
| 43 | ..S RXDATA=$$GETPHDAT(RXIFN,SRCHDT,STANO,STANAME) | 
|---|
| 44 | ..I RXDATA<0 Q | 
|---|
| 45 | ..S RVRSDT=9999999-(+$P(RXDATA,"^",6)) | 
|---|
| 46 | ..S @ARRYNM@(RVRSDT,STANO,RXIFN)=RXDATA | 
|---|
| 47 | ..S FOUND=FOUND+1 | 
|---|
| 48 | Q FOUND | 
|---|
| 49 | ; | 
|---|
| 50 | GETPHDAT(RXIFN,SRCHDT,STANO,STANAME) ; Get the data via fileman | 
|---|
| 51 | ; | 
|---|
| 52 | N PPPTMP,RXNODE0,STATUS,DIC,DA,DR,DIQ,LFDT,RXNUM,ISSUEDT,DRUG,QTY,SIG | 
|---|
| 53 | N RESULT,PARMERR,FMERR,U,PROVIDER | 
|---|
| 54 | ; | 
|---|
| 55 | S PARMERR=-9001 | 
|---|
| 56 | S FMERR=-9002 | 
|---|
| 57 | S U="^" | 
|---|
| 58 | ; | 
|---|
| 59 | S RXNODE0=$G(^PSRX(RXIFN,0)) | 
|---|
| 60 | I RXNODE0="" Q PARMERR | 
|---|
| 61 | ; | 
|---|
| 62 | S STATUS=$S(SRCHDT'<DT:"A",$P(RXNODE0,"^",15)=12:"C",1:"E") | 
|---|
| 63 | ; | 
|---|
| 64 | S DIC=52 | 
|---|
| 65 | S DA=RXIFN | 
|---|
| 66 | S DR=".01;1;4;6;7;10;101" | 
|---|
| 67 | S DIQ="PPPTMP" | 
|---|
| 68 | S DIQ(0)="IE" | 
|---|
| 69 | D EN^DIQ1 | 
|---|
| 70 | I '$D(PPPTMP) Q FMERR | 
|---|
| 71 | ; | 
|---|
| 72 | S LFDT=PPPTMP(52,RXIFN,101,"I") | 
|---|
| 73 | S RXNUM=PPPTMP(52,RXIFN,.01,"E") | 
|---|
| 74 | S ISSUEDT=PPPTMP(52,RXIFN,1,"I") | 
|---|
| 75 | S PROVIDER=PPPTMP(52,RXIFN,4,"E") | 
|---|
| 76 | S DRUG=PPPTMP(52,RXIFN,6,"E") | 
|---|
| 77 | S QTY=PPPTMP(52,RXIFN,7,"E") | 
|---|
| 78 | S SIG=PPPTMP(52,RXIFN,10,"E") | 
|---|
| 79 | S RESULT=RXNUM_U_DRUG_U_STATUS_U_QTY_U_ISSUEDT_U_LFDT_U_SIG_U_STANAME_U_STANO_U_PROVIDER | 
|---|
| 80 | Q RESULT | 
|---|