PSBOMM2 ;BIRMINGHAM/EFC-MISSED MEDS ;Mar 2004 ;;3.0;BAR CODE MED ADMIN;**26,32**;Mar 2004;Build 32 ;Per VHA Directive 2004-038 (or future revisions regarding same), this routine should not be modified. ; MISSED(PSBADMN,PSBEDIT,PSBXDT) ; N PSBMISD,PSBAUDT,PSBSTRT2 S PSBSTRT2=(PSBXDT\1) F D Q:PSBODD S PSBSTRT2=$$FMADD^XLFDT(PSBSTRT2,1) Q:PSBSTRT2>PSBSTOP .F Y=1:1:$L(PSBADMN,"-") S PSBDT=+("."_$P(PSBADMN,"-",Y))+(PSBSTRT2) D ..S PSBMISD=$$CHECK(PSBDT) ..;CHECK AUDITED ADMIN TIMES FOR MISSED MED ..I PSBMISD F I=1:1:$P(PSBOACTL(0),U,4) I $P($G(PSBOACTL(I,1)),U,3)["ADMIN TIMES" D Q:'PSBMISD ...Q:$P(PSBOACTL(I,1),U)PSBSTOP ...S PSBAUDT=+("."_$P(PSBOACTL(I,2),"-",Y))+(PSBSTRT2\1) ...S PSBMISD=$$CHECK(PSBAUDT),PSBEDIT=1 ..I PSBMISD D ...Q:'$$OKAY^PSBVDLU1(PSBOST,PSBSTRT2,PSBSCH,PSBONX,$P(^TMP("PSJ",$J,PSBX,3),U,2),PSBFREQ,PSBOSTS) ...S:'$D(^TMP("PSB",$J,DFN,PSBDT,"* "_PSBOITX,PSBONX)) ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="" ...D UDCONT Q CHECK(PSBDT) ; I PSBDTPSBSTOP Q 0 ; Report Window I $D(^PSB(53.79,"AORD",DFN,PSBONX,PSBDT)) D Q:PSBSTUS'="N" $G(PART,0) .K PART S PSBIX=$O(^PSB(53.79,"AORD",DFN,PSBONX,PSBDT,"")),PSBSTUS=$P(^PSB(53.79,PSBIX,0),U,9) .I PSBOCRIT[PSBOSTS D:(PSBACRIT[PSBSTUS) Q ..I (PSBSTUS="G")&$D(^PSB(53.79,PSBIX,.5)) D ...S X=0 F S X=$O(^PSB(53.79,PSBIX,.5,X)) Q:+X=0 D ....I $P(^PSB(53.79,PSBIX,.5,X,0),U,2)>$P(^PSB(53.79,PSBIX,.5,X,0),U,3) D S PSBOITX=$E(PSBOITX,3,999) .....S PSBOITX="* "_PSBOITX S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX,"X")="Units Ordered: "_$P(^PSB(53.79,PSBIX,.5,X,0),U,2)_" Units Given: "_$P(^PSB(53.79,PSBIX,.5,X,0),U,3)_" Admin. Status: * Partial (Given)" .....S PART=1 .....D:PSBINCC GCMNTS(PSBIX) ..I PSBSTUS'="G" I PSBACRIT[PSBSTUS S PART=1 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX,"X")="Admin. Status: ("_$S(PSBSTUS="":" *UNKNOWN* ",PSBSTUS="M":"Missing Dose",PSBSTUS="H":"Held",PSBSTUS="R":"Refused")_")" D:PSBINCC GCMNTS(PSBIX) Q 1 UDCONT ; S PSBFLAG=0,J=1 K ^TMP("PSB1",$J) F I=1:1:$P(PSBOACTL(0),U,4) D . I $P($G(PSBOACTL(I,1)),U,4)["ON HOLD"!($P($G(PSBOACTL(I,1)),U,4)="HOLD") S ^TMP("PSB1",$J,DFN,J)="HOLD"_U_$E($P($G(PSBOACTL(I,1)),U,1),1,12) . I $P($G(PSBOACTL(I,1)),U,4)["TAKEN OFF HOLD"!($P($G(PSBOACTL(I,1)),U,4)["UNHOLD") S $P(^TMP("PSB1",$J,DFN,J),U,3)="OFF HOLD"_U_$E($P($G(PSBOACTL(I,1)),U,1),1,12),J=J+1 D:$D(^TMP("PSB1",$J,DFN))&($P(PSBOACTL(0),U,4)'=1) .S J=0 F S J=$O(^TMP("PSB1",$J,DFN,J)) Q:'J Q:PSBFLAG D ..S PSBHDDT=$P(^TMP("PSB1",$J,DFN,J),U,2) ..S PSBHDST=$P(^TMP("PSB1",$J,DFN,J),U) ..S PSBOFDT=$P(^TMP("PSB1",$J,DFN,J),U,4) ..S PSBOFST=$P(^TMP("PSB1",$J,DFN,J),U,3) ..I PSBDT>PSBHDDT,PSBHDST="HOLD",PSBOFST'="" I PSBDTPSBHDDT,PSBHDST="HOLD",PSBOFST="" S PSBFLAG=1 K PSBCNT,TMP("PSB1",$J) S PSBOITX2=PSBOITX I $D(^TMP("PSB",$J,DFN,PSBDT,"* "_PSBOITX,PSBONX)) S PSBOITX="* "_PSBOITX I PSBFLAG=1 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT) I PSBFLAG=2 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT)_" "_"(Off Hold) "_$$DTFMT(PSBUNHD) S PSBOITX=PSBOITX2 Q ; UDONE ; S PSBFLAG=0,J=1 F I=1:1:$P(PSBOACTL(0),U,4) D .I $P($G(PSBOACTL(I,1)),U,4)["ON HOLD"!($P($G(PSBOACTL(I,1)),U,4)="HOLD") S ^TMP("PSB1",$J,DFN,J)="HOLD"_U_$E($P($G(PSBOACTL(I,1)),U,1),1,12) .I $P($G(PSBOACTL(I,1)),U,4)["TAKEN OFF HOLD"!($P($G(PSBOACTL(I,1)),U,4)["UNHOLD") S $P(^TMP("PSB1",$J,DFN,J),U,3)="OFF HOLD"_U_$E($P($G(PSBOACTL(I,1)),U,1),1,12),J=J+1 D:$D(^TMP("PSB1",$J,DFN))&($P(PSBOACTL(0),U,4)'=1) .S J="" F S J=$O(^TMP("PSB1",$J,DFN,J)) Q:'J Q:PSBFLAG D ..S PSBHDDT=$P(^TMP("PSB1",$J,DFN,J),U,2) ..S PSBHDST=$P(^TMP("PSB1",$J,DFN,J),U) ..S PSBOFDT=$P(^TMP("PSB1",$J,DFN,J),U,4) ..S PSBOFST=$P(^TMP("PSB1",$J,DFN,J),U,3) ..I PSBOSTS="A",PSBHDST="HOLD",PSBOFST'="",'$D(^TMP("PSB1",$J,DFN,J+1)) I PSBSTOP>PSBOFDT,PSBOFST="OFF HOLD" S PSBFLAG=2,PSBUNHD=PSBOFDT ..I PSBOSTS="A",PSBHDST="HOLD",PSBOFST'="",PSBOFDT'$P(^PSB(53.79,XIEN,.5,X,0),U,3) D S PSBOITX=$E(PSBOITX,3,999),PSBGVN=0 .....S PSBOITX="* "_PSBOITX S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX,"X")="Units Ordered: "_$P(^PSB(53.79,XIEN,.5,X,0),U,2)_" Units Given: "_$P(^PSB(53.79,XIEN,.5,X,0),U,3)_" Admin. Status: * Partial (Given)" .....I PSBINCC D GCMNTS(XIEN) ..I PSBSTUS'="G" D S PSBGVN=0 ...I PSBACRIT[PSBSTUS S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX,"X")="Admin. Status: ("_$S(PSBSTUS="":" *UNKNOWN* ",PSBSTUS="M":"Missing Dose",PSBSTUS="H":"Held",PSBSTUS="R":"Refused")_")" ...I PSBINCC D GCMNTS(XIEN) Q LN1 ; W !,$TR($J("",IOM)," ","-") Q DEFLT ; S PSBFUTR=$TR(PSBRPT(1),"~","^") Q:PSBRPT(1)]"" S PSBFUTR="^^^^1^^1^1^^^^^^^^1" ;default MM Report settings Per GUI MM report... S X01="" D RPC^PSBPAR(.X01,"GETPAR","ALL","PSB RPT INCL COMMENTS") S $P(PSBRPT(.2),U,8)=+X01(0) K PSBSTOP S PSBSTOP=$P(PSBRPT(.1),U,6)+$P(PSBRPT(.1),U,9) Q DTFMT(DT) ; N Y,X I +DT'>0 S DTFMT=DT Q DTFMT S Y=DT,X=$E($P(Y,".",2)_"0000",1,4) S DTFMT=$TR($J(+$E(Y,4,5),2)_"/"_$J(+$E(Y,6,7),2)_"/"_($E(Y,1,3)+1700)," ","0")_"@"_X Q DTFMT