[613] | 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
|
---|