VistA-WorldVistAEHR/r/OUTPATIENT_PHARMACY-PSO-APS.../PSOP288R.m

51 lines
2.4 KiB
Mathematica

PSOP288R ;REPORT FOR PATCH PSO*7.0*288
;;7.0;OUTPATIENT PHARMACY;**288**;DEC 2007;Build 17
;External reference to File ^PS(55 supported by DBIA 2228
;External reference to File ^DPT supported by DBIA 10035
;External reference to File ^SC supported by DBIA 10040
;
;FIND ERRONEOUS RECORDS IN THE PHARMACY PATIENT FILE (#55) AND ALLOW THE USER TO CLEAN THEM UP
;
EN W !!,"CREATING REPORT...",!
S ZTRTN="QUEUE^PSOP288R",ZTDESC="Erroneous Non-VA Meds Records Report",ZTIO="" D ^%ZTLOAD K IO("Q")
Q
QUEUE N PSOPAT,PSONVA,PSONVA0,PSODRG,PSOI,PSOSPC,PSOPATDB,PSOTXT,PSOTEXT,XMY,XMTEXT,XMSUB,XMDUZ,PSOPATI,X,X1,X2,PSOLOC,PSODIV,PSODIVN
S PSOSPC="",PSODIVN=""
F PSOI=1:1:20 S $E(PSOSPC,PSOI)=" "
K ^XTMP("PSOP288") S X1=DT,X2=+90 D C^%DTC S ^XTMP("PSOP288",0)=$G(X)_U_DT_"^Erroneous Pharmacy Pateint File (#55) Non-VA Meds records"
S PSOPAT=0 F S PSOPAT=$O(^PS(55,PSOPAT)) Q:'PSOPAT D
.S PSONVA=0 F S PSONVA=$O(^PS(55,PSOPAT,"NVA",PSONVA)) Q:'PSONVA D
..S PSONVA0=$G(^PS(55,PSOPAT,"NVA",PSONVA,0))
..I $P(PSONVA0,"^",10)]"",$P(PSONVA0,"^",11)]"" Q
..S PSOLOC=$P(PSONVA0,"^",12) I PSOLOC S PSODIV=$P(^SC(PSOLOC,0),"^",15) I PSODIV]"" S PSODIVN=$P($G(^DG(40.8,PSODIV,0)),"^")
..S:PSODIVN="" PSODIVN="UNKNOWN"
..S PSODRG=+PSONVA0
..S ^XTMP("PSOP288",PSODIVN,PSOPAT,PSONVA)=PSODRG_U_$P($G(^PS(50.7,PSODRG,0)),"^")
REP ;CREATE REPORT - SEND TO USER
S XMY(DUZ)=""
S XMDUZ=.5,XMSUB="ERRONEOUS NON-VA MEDS RECORDS IN PHARMACY PATIENT FILE"
;
S PSOTXT=1
S PSOTEXT(PSOTXT)="REPORT OF ERRONEOUS PHARMACY PATIENT FILE (#55) NON-VA MEDS RECORDS"
S PSODIVN=0 F S PSODIVN=$O(^XTMP("PSOP288",PSODIVN)) Q:PSODIVN="" D
.S PSOTXT=PSOTXT+1
.S PSOTEXT(PSOTXT)=""
.S PSOTEXT(PSOTXT+1)="DIVISION: "_PSODIVN
.S PSOTEXT(PSOTXT+2)=""
.S PSOTXT=PSOTXT+2
.S PSOTEXT(PSOTXT)="IEN - PATIENT NAME",PSOTXT=PSOTXT+1
.S PSOTEXT(PSOTXT)=$E(PSOSPC,1,3)_"DRUG IEN - DRUG NAME",PSOTXT=PSOTXT+1
.S PSOTEXT(PSOTXT)="",PSOTXT=PSOTXT+1
.S PSOPAT=0 F S PSOPAT=$O(^XTMP("PSOP288",PSODIVN,PSOPAT)) Q:'PSOPAT D
..S PSOPATI=$G(^DPT(PSOPAT,0))
..S PSOTEXT(PSOTXT)=PSOPAT_" - "_$P(PSOPATI,U)
..S PSOTXT=PSOTXT+1
..S PSONVA=0 F S PSONVA=$O(^XTMP("PSOP288",PSODIVN,PSOPAT,PSONVA)) Q:'PSONVA D
...S PSONVA0=$G(^PS(55,PSOPAT,"NVA",PSONVA,0))
...S PSODRG=+PSONVA0
...S PSOTEXT(PSOTXT)=$E(PSOSPC,1,3)_$P(PSONVA0,U)_" - "_$P($G(^PS(50.7,PSODRG,0)),U)
...S PSOTXT=PSOTXT+1
I PSOTXT=1 S PSOTEXT(PSOTXT+1)="",PSOTEXT(PSOTXT+2)="NO ERRONEOUS ENTRIES FOUND"
S XMTEXT="PSOTEXT(" N DIFROM D ^XMD K XMDUZ,XMTEXT,XMSUB
Q