1 | PSBOMM2 ;BIRMINGHAM/EFC-MISSED MEDS ;Mar 2004
|
---|
2 | ;;3.0;BAR CODE MED ADMIN;**26,32**;Mar 2004;Build 32
|
---|
3 | ;Per VHA Directive 2004-038 (or future revisions regarding same), this routine should not be modified.
|
---|
4 | ;
|
---|
5 | MISSED(PSBADMN,PSBEDIT,PSBXDT) ;
|
---|
6 | N PSBMISD,PSBAUDT,PSBSTRT2
|
---|
7 | S PSBSTRT2=(PSBXDT\1) F D Q:PSBODD S PSBSTRT2=$$FMADD^XLFDT(PSBSTRT2,1) Q:PSBSTRT2>PSBSTOP
|
---|
8 | .F Y=1:1:$L(PSBADMN,"-") S PSBDT=+("."_$P(PSBADMN,"-",Y))+(PSBSTRT2) D
|
---|
9 | ..S PSBMISD=$$CHECK(PSBDT)
|
---|
10 | ..;CHECK AUDITED ADMIN TIMES FOR MISSED MED
|
---|
11 | ..I PSBMISD F I=1:1:$P(PSBOACTL(0),U,4) I $P($G(PSBOACTL(I,1)),U,3)["ADMIN TIMES" D Q:'PSBMISD
|
---|
12 | ...Q:$P(PSBOACTL(I,1),U)<PSBSTRT2
|
---|
13 | ...Q:$P(PSBOACTL(I,1),U)>PSBSTOP
|
---|
14 | ...S PSBAUDT=+("."_$P(PSBOACTL(I,2),"-",Y))+(PSBSTRT2\1)
|
---|
15 | ...S PSBMISD=$$CHECK(PSBAUDT),PSBEDIT=1
|
---|
16 | ..I PSBMISD D
|
---|
17 | ...Q:'$$OKAY^PSBVDLU1(PSBOST,PSBSTRT2,PSBSCH,PSBONX,$P(^TMP("PSJ",$J,PSBX,3),U,2),PSBFREQ,PSBOSTS)
|
---|
18 | ...S:'$D(^TMP("PSB",$J,DFN,PSBDT,"* "_PSBOITX,PSBONX)) ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)=""
|
---|
19 | ...D UDCONT
|
---|
20 | Q
|
---|
21 | CHECK(PSBDT) ;
|
---|
22 | I PSBDT<PSBOST Q 0 ; Order Start Date
|
---|
23 | I PSBDT'<PSBOSP Q 0 ; Order Stop Date
|
---|
24 | I PSBDT<PSBSTRT Q 0 ; Report Window
|
---|
25 | I PSBDT>PSBSTOP Q 0 ; Report Window
|
---|
26 | I $D(^PSB(53.79,"AORD",DFN,PSBONX,PSBDT)) D Q:PSBSTUS'="N" $G(PART,0)
|
---|
27 | .K PART S PSBIX=$O(^PSB(53.79,"AORD",DFN,PSBONX,PSBDT,"")),PSBSTUS=$P(^PSB(53.79,PSBIX,0),U,9)
|
---|
28 | .I PSBOCRIT[PSBOSTS D:(PSBACRIT[PSBSTUS) Q
|
---|
29 | ..I (PSBSTUS="G")&$D(^PSB(53.79,PSBIX,.5)) D
|
---|
30 | ...S X=0 F S X=$O(^PSB(53.79,PSBIX,.5,X)) Q:+X=0 D
|
---|
31 | ....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)
|
---|
32 | .....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)"
|
---|
33 | .....S PART=1
|
---|
34 | .....D:PSBINCC GCMNTS(PSBIX)
|
---|
35 | ..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)
|
---|
36 | Q 1
|
---|
37 | UDCONT ;
|
---|
38 | S PSBFLAG=0,J=1
|
---|
39 | K ^TMP("PSB1",$J)
|
---|
40 | F I=1:1:$P(PSBOACTL(0),U,4) D
|
---|
41 | . 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)
|
---|
42 | . 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
|
---|
43 | D:$D(^TMP("PSB1",$J,DFN))&($P(PSBOACTL(0),U,4)'=1)
|
---|
44 | .S J=0 F S J=$O(^TMP("PSB1",$J,DFN,J)) Q:'J Q:PSBFLAG D
|
---|
45 | ..S PSBHDDT=$P(^TMP("PSB1",$J,DFN,J),U,2)
|
---|
46 | ..S PSBHDST=$P(^TMP("PSB1",$J,DFN,J),U)
|
---|
47 | ..S PSBOFDT=$P(^TMP("PSB1",$J,DFN,J),U,4)
|
---|
48 | ..S PSBOFST=$P(^TMP("PSB1",$J,DFN,J),U,3)
|
---|
49 | ..I PSBDT>PSBHDDT,PSBHDST="HOLD",PSBOFST'="" I PSBDT<PSBOFDT,PSBOFST="OFF HOLD" S PSBFLAG=2,PSBUNHD=PSBOFDT
|
---|
50 | ..I PSBDT>PSBHDDT,PSBHDST="HOLD",PSBOFST="" S PSBFLAG=1
|
---|
51 | K PSBCNT,TMP("PSB1",$J)
|
---|
52 | S PSBOITX2=PSBOITX
|
---|
53 | I $D(^TMP("PSB",$J,DFN,PSBDT,"* "_PSBOITX,PSBONX)) S PSBOITX="* "_PSBOITX
|
---|
54 | I PSBFLAG=1 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT)
|
---|
55 | I PSBFLAG=2 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT)_" "_"(Off Hold) "_$$DTFMT(PSBUNHD)
|
---|
56 | S PSBOITX=PSBOITX2
|
---|
57 | Q
|
---|
58 | ;
|
---|
59 | UDONE ;
|
---|
60 | S PSBFLAG=0,J=1
|
---|
61 | F I=1:1:$P(PSBOACTL(0),U,4) D
|
---|
62 | .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)
|
---|
63 | .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
|
---|
64 | D:$D(^TMP("PSB1",$J,DFN))&($P(PSBOACTL(0),U,4)'=1)
|
---|
65 | .S J="" F S J=$O(^TMP("PSB1",$J,DFN,J)) Q:'J Q:PSBFLAG D
|
---|
66 | ..S PSBHDDT=$P(^TMP("PSB1",$J,DFN,J),U,2)
|
---|
67 | ..S PSBHDST=$P(^TMP("PSB1",$J,DFN,J),U)
|
---|
68 | ..S PSBOFDT=$P(^TMP("PSB1",$J,DFN,J),U,4)
|
---|
69 | ..S PSBOFST=$P(^TMP("PSB1",$J,DFN,J),U,3)
|
---|
70 | ..I PSBOSTS="A",PSBHDST="HOLD",PSBOFST'="",'$D(^TMP("PSB1",$J,DFN,J+1)) I PSBSTOP>PSBOFDT,PSBOFST="OFF HOLD" S PSBFLAG=2,PSBUNHD=PSBOFDT
|
---|
71 | ..I PSBOSTS="A",PSBHDST="HOLD",PSBOFST'="",PSBOFDT'<PSBSTOP S PSBFLAG=1
|
---|
72 | ..I PSBOSTS="H",PSBHDST="HOLD",'$D(^TMP("PSB1",$J,DFN,J+1)) S PSBFLAG=1
|
---|
73 | K PSBCNT,^TMP("PSB1",$J)
|
---|
74 | S PSBOITX2=PSBOITX
|
---|
75 | I $D(^TMP("PSB",$J,DFN,PSBDT,"* "_PSBOITX,PSBONX)) S PSBOITX="* "_PSBOITX
|
---|
76 | I PSBFLAG=1 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT)
|
---|
77 | I PSBFLAG=2 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX)="(On Hold) "_$$DTFMT(PSBHDDT)_" "_"(Off Hold) "_$$DTFMT(PSBUNHD)
|
---|
78 | S PSBOITX=PSBOITX2
|
---|
79 | Q
|
---|
80 | GCMNTS(XIEN) ;
|
---|
81 | Q:'$D(^PSB(53.79,XIEN,.3,1))
|
---|
82 | N X
|
---|
83 | S X=$O(^PSB(53.79,XIEN,.3,""),-1) Q:+X=0 S ^TMP("PSB",$J,DFN,PSBDT,PSBOITX,PSBONX,.3)="Comment: "_$P(^PSB(53.79,XIEN,.3,X,0),U)
|
---|
84 | Q
|
---|
85 | PARTG1(XIEN) ;
|
---|
86 | I $D(^PSB(53.79,XIEN)) D
|
---|
87 | .S PSBSTUS=$P(^PSB(53.79,XIEN,0),U,9)
|
---|
88 | .I PSBOCRIT[PSBOSTS I PSBACRIT[PSBSTUS D S PSBEXST=1 Q
|
---|
89 | ..I (PSBSTUS="G")&$D(^PSB(53.79,XIEN,.5)) D
|
---|
90 | ...S X=0 F S X=$O(^PSB(53.79,XIEN,.5,X)) Q:+X=0 D
|
---|
91 | ....I $P(^PSB(53.79,XIEN,.5,X,0),U,2)>$P(^PSB(53.79,XIEN,.5,X,0),U,3) D S PSBOITX=$E(PSBOITX,3,999),PSBGVN=0
|
---|
92 | .....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)"
|
---|
93 | .....I PSBINCC D GCMNTS(XIEN)
|
---|
94 | ..I PSBSTUS'="G" D S PSBGVN=0
|
---|
95 | ...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")_")"
|
---|
96 | ...I PSBINCC D GCMNTS(XIEN)
|
---|
97 | Q
|
---|
98 | LN1 ;
|
---|
99 | W !,$TR($J("",IOM)," ","-")
|
---|
100 | Q
|
---|
101 | DEFLT ;
|
---|
102 | S PSBFUTR=$TR(PSBRPT(1),"~","^")
|
---|
103 | Q:PSBRPT(1)]""
|
---|
104 | S PSBFUTR="^^^^1^^1^1^^^^^^^^1" ;default MM Report settings Per GUI MM report...
|
---|
105 | S X01=""
|
---|
106 | D RPC^PSBPAR(.X01,"GETPAR","ALL","PSB RPT INCL COMMENTS")
|
---|
107 | S $P(PSBRPT(.2),U,8)=+X01(0)
|
---|
108 | K PSBSTOP S PSBSTOP=$P(PSBRPT(.1),U,6)+$P(PSBRPT(.1),U,9)
|
---|
109 | Q
|
---|
110 | DTFMT(DT) ;
|
---|
111 | N Y,X
|
---|
112 | I +DT'>0 S DTFMT=DT Q DTFMT
|
---|
113 | S Y=DT,X=$E($P(Y,".",2)_"0000",1,4)
|
---|
114 | S DTFMT=$TR($J(+$E(Y,4,5),2)_"/"_$J(+$E(Y,6,7),2)_"/"_($E(Y,1,3)+1700)," ","0")_"@"_X
|
---|
115 | Q DTFMT
|
---|