| 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
 | 
|---|