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