1 | PSBOWA ;BIRMINGHAM/EFC-WARD ADMINISTRATION TIMES ;Mar 2004
|
---|
2 | ;;3.0;BAR CODE MED ADMIN;**9,32**;Mar 2004;Build 32
|
---|
3 | ;Per VHA Directive 2004-038 (or future revisions regarding same), this routine should not be modified.
|
---|
4 | ;
|
---|
5 | ; Reference/IA
|
---|
6 | ; ^DPT/10035
|
---|
7 | ; EN^PSJBCMA/2828
|
---|
8 | EN ;
|
---|
9 | N PSBHDR,PSBGTOT,PSBTOT,PSBINDX,DFN,PSBX,PSBY,PSBSM,PSBADST,PSBZ
|
---|
10 | S (Y,PSBEVDT)=$P(PSBRPT(.1),U,6) D D^DIQ
|
---|
11 | S PSBHDR(2)="ADMINISTRATION DATE: "_Y
|
---|
12 | S (Y,PSBEVDT2)=$S($P(PSBRPT(.1),U,8)']"":PSBEVDT,1:$P(PSBRPT(.1),U,8)) D D^DIQ
|
---|
13 | S PSBHDR(2)=PSBHDR(2)_" to "_Y
|
---|
14 | F PSBIX=0:1 S PSBRPDT=$$FMADD^XLFDT(PSBEVDT,PSBIX) Q:PSBRPDT>PSBEVDT2 D
|
---|
15 | .D:$P(PSBRPT(.1),U)="W"
|
---|
16 | ..F X=0,.01:.01:.24 S PSBGTOT(X)=""
|
---|
17 | ..W $$WRDHDR()
|
---|
18 | ..S PSBINDX=""
|
---|
19 | ..F S PSBINDX=$O(^TMP("PSBO",$J,"B",PSBINDX)) Q:PSBINDX="" D
|
---|
20 | ...F DFN=0:0 S DFN=$O(^TMP("PSBO",$J,"B",PSBINDX,DFN)) Q:'DFN D
|
---|
21 | ....W:$Y>(IOSL-10) $$WRDHDR()
|
---|
22 | ....W !,$P(^DPT(DFN,0),U,1),!,"SSN: ",$P(^(0),U,9)
|
---|
23 | ....W !,"Ward: ",$E($G(^DPT(DFN,.1)),1,25),!,"Room-Bed: ",$E($G(^(.101)),1,21)
|
---|
24 | ....W ?32
|
---|
25 | ....F X=0,.01:.01:.24 S PSBTOT(X)=""
|
---|
26 | ....K ^TMP("PSJ",$J)
|
---|
27 | ....D EN^PSJBCMA(DFN,$P(PSBRPT(.1),U,6))
|
---|
28 | ....F PSBX=0:0 S PSBX=$O(^TMP("PSJ",$J,PSBX)) Q:'PSBX D
|
---|
29 | .....Q:^TMP("PSJ",$J,PSBX,0)=-1 ; No Orders
|
---|
30 | .....D CLEAN^PSBVT
|
---|
31 | .....D PSJ^PSBVT(PSBX)
|
---|
32 | .....Q:PSBSCHT'="C" ; Not a Continuous
|
---|
33 | .....Q:PSBOSTS'="A"&(PSBOSTS'="R") ; Active?
|
---|
34 | .....Q:PSBSM=1 ;Self med?
|
---|
35 | .....S (PSBCADM,PSBYES,PSBODD)=0
|
---|
36 | .....S PSBFREQ=$$GETFREQ^PSBVDLU1(DFN,PSBONX)
|
---|
37 | .....S:$$PSBDCHK1^PSBVT1(PSBSCH) PSBYES=1
|
---|
38 | .....F I=1:1 Q:$P(PSBSCH,"-",I)="" I ($P(PSBSCH,"-",I)?2N)!($P(PSBSCH,"-",I)?4N) S PSBYES=1
|
---|
39 | .....I PSBYES,PSBADST="",PSBSCHT'="O",PSBSCHT'="OC",PSBSCHT'="P" D Q
|
---|
40 | ......D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Admin times required",PSBSCH)
|
---|
41 | .....I "PCS"'[PSBIVT,PSBONX'["U" Q
|
---|
42 | .....I PSBIVT["S",PSBISYR'=1 Q ; allow intermittent syringe only
|
---|
43 | .....I PSBIVT["C",PSBCHEMT'="P",PSBISYR'=1 Q
|
---|
44 | .....I PSBIVT["C",PSBCHEMT="A" Q ; allow Chemo with intermittent syringe or Piggyback type only
|
---|
45 | .....I PSBFREQ="D" S PSBFREQ=""
|
---|
46 | .....I 'PSBYES,PSBFREQ<1 D Q
|
---|
47 | ......D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Invalid frequency received from order",PSBSCH)
|
---|
48 | .....I +PSBFREQ>0 D
|
---|
49 | ......I (PSBFREQ#1440'=0),(1440#PSBFREQ'=0) S PSBODD=1
|
---|
50 | .....I PSBODD,PSBADST'="" D Q
|
---|
51 | ......D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Administration Times on ODD SCHEDULE",PSBSCH)
|
---|
52 | .....K ^TMP("PSB",$J,"GETADMIN")
|
---|
53 | .....I PSBADST="" S PSBADST=$$GETADMIN^PSBVDLU1(DFN,PSBONX,PSBOST,PSBFREQ,PSBRPDT) S:PSBADST'="" PSBCADM=1
|
---|
54 | .....E S ^TMP("PSB",$J,"GETADMIN",0)=PSBADST
|
---|
55 | .....Q:PSBADST=""
|
---|
56 | .....I PSBONX'["V" D Q:'$$OKAY^PSBVDLU1(PSBOST,$P(PSBRPT(.1),U,6),PSBSCH,PSBONX,PSBOIT,PSBFREQ)
|
---|
57 | .....I PSBONX["V",PSBSCH'="" Q:'$$OKAY^PSBVDLU1(PSBOST,$P(PSBRPT(.1),U,6),PSBSCH,PSBONX,PSBOIT,PSBFREQ)
|
---|
58 | .....F PSBXX=0:1 Q:'$D(^TMP("PSB",$J,"GETADMIN",PSBXX)) S PSBADST=$G(^TMP("PSB",$J,"GETADMIN",PSBXX)) D
|
---|
59 | ......F Y=1:1:$L(PSBADST,"-") S Z=+("."_$E($P(PSBADST,"-",Y),1,2)) D
|
---|
60 | .......Q:(($P(PSBRPT(.1),U,6)+Z)<$E(PSBOST,1,12))&($G(Z)'=0) ;Start Date
|
---|
61 | .......Q:($P(PSBRPT(.1),U,6)+Z)'<$E(PSBOSP,1,12) ;Stop Date
|
---|
62 | .......;For invalid admin times
|
---|
63 | .......D:($P(PSBADST,"-",Y)'?2N)&($P(PSBADST,"-",Y)'?4N)
|
---|
64 | ........D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Invalid Admin times",PSBSCH)
|
---|
65 | .......S PSBTOT(Z)=PSBTOT(Z)+1
|
---|
66 | .......S PSBGTOT(Z)=PSBGTOT(Z)+1
|
---|
67 | ....S PSBX="" F S PSBX=$O(PSBTOT(PSBX)) Q:$G(PSBX)="" W $J(PSBTOT(PSBX),4)
|
---|
68 | ....W !,$TR($J("",IOM)," ","-")
|
---|
69 | ..W !!,$TR($J("",IOM)," ","=")
|
---|
70 | ..W !?32 F X=0,.01:.01:.24 W $J($E(X_"00",2,3),4)
|
---|
71 | ..W !,"Hourly Totals:",?32
|
---|
72 | ..S PSBGTOT=0
|
---|
73 | ..S PSBX="" F S PSBX=$O(PSBGTOT(PSBX)) Q:$G(PSBX)="" D
|
---|
74 | ...W $J(PSBGTOT(PSBX),4)
|
---|
75 | ...S PSBGTOT=PSBGTOT+PSBGTOT(PSBX)
|
---|
76 | ..W !!,"Ward Total:",?32,$J(PSBGTOT,4)
|
---|
77 | ..W !!,$TR($J("",IOM)," ","-")
|
---|
78 | ..K ^TMP("PSJ",$J)
|
---|
79 | .D:$P(PSBRPT(.1),U)="P"
|
---|
80 | ..S DFN=PSBDFN
|
---|
81 | ..S PSBHDR(1)="WARD ADMINISTRATION TIMES"
|
---|
82 | ..S Y=$P(PSBRPT(.1),U,6) D D^DIQ S PSBHDR(2)="ADMINISTRATION DATE: "_Y
|
---|
83 | ..S Y=PSBEVDT2 D D^DIQ S PSBHDR(2)=PSBHDR(2)_" to "_Y
|
---|
84 | ..W $$PTHDR()
|
---|
85 | ..K ^TMP("PSJ",$J),PSBTOT
|
---|
86 | ..D EN^PSJBCMA(PSBDFN,PSBRPDT,"")
|
---|
87 | ..F PSBX=0:0 S PSBX=$O(^TMP("PSJ",$J,PSBX)) Q:'PSBX D
|
---|
88 | ...Q:^TMP("PSJ",$J,PSBX,0)=-1 ; No Orders
|
---|
89 | ...D CLEAN^PSBVT
|
---|
90 | ...D PSJ^PSBVT(PSBX)
|
---|
91 | ...Q:PSBSCHT'="C" ; Not a Continuous
|
---|
92 | ...Q:PSBOSTS'="A"&(PSBOSTS'="R") ; Active?
|
---|
93 | ...S (PSBCADM,PSBYES,PSBODD)=0
|
---|
94 | ...S PSBFREQ=$$GETFREQ^PSBVDLU1(DFN,PSBONX)
|
---|
95 | ...S:$$PSBDCHK1^PSBVT1(PSBSCH) PSBYES=1
|
---|
96 | ...F I=1:1 Q:$P(PSBSCH,"-",I)="" I ($P(PSBSCH,"-",I)?2N)!($P(PSBSCH,"-",I)?4N) S PSBYES=1
|
---|
97 | ...I PSBYES,PSBADST="",PSBSCHT'="O",PSBSCHT'="OC",PSBSCHT'="P" D Q
|
---|
98 | ....D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Admin times required",PSBSCH)
|
---|
99 | ...I "PCS"'[PSBIVT,PSBONX'["U" Q
|
---|
100 | ...I PSBIVT["S",PSBISYR'=1 Q ; allow intermittent syringe only
|
---|
101 | ...I PSBIVT["C",PSBCHEMT'="P",PSBISYR'=1 Q
|
---|
102 | ...I PSBIVT["C",PSBCHEMT="A" Q ; allow Chemo with intermittent syringe or Piggyback type only
|
---|
103 | ...I PSBFREQ="D" S PSBFREQ=""
|
---|
104 | ...I 'PSBYES,PSBFREQ<1 D Q
|
---|
105 | ....D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Invalid frequency received from order",PSBSCH)
|
---|
106 | ...I +PSBFREQ>0 D
|
---|
107 | ....I (PSBFREQ#1440'=0),(1440#PSBFREQ'=0) S PSBODD=1
|
---|
108 | ...I PSBODD,PSBADST'="" D Q
|
---|
109 | ....D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Administration Times on ODD SCHEDULE",PSBSCH)
|
---|
110 | ...K ^TMP("PSB",$J,"GETADMIN")
|
---|
111 | ...I PSBADST="",+$G(PSBFREQ)>0,$G(PSBFREQ)<30 S PSBADST="MESSAGE",$P(PSBTOT(PSBADST,PSBOITX,PSBONX),2)="Due every "_PSBFREQ_" Mins" Q
|
---|
112 | ...I PSBADST="",+$G(PSBFREQ)'<30 S PSBADST=$$GETADMIN^PSBVDLU1(DFN,PSBONX,PSBOST,PSBFREQ,PSBRPDT) S:PSBADST'="" PSBCADM=1
|
---|
113 | ...E S ^TMP("PSB",$J,"GETADMIN",0)=PSBADST
|
---|
114 | ...Q:PSBADST=""
|
---|
115 | ...I PSBONX'["V" D Q:'$$OKAY^PSBVDLU1(PSBOST,PSBRPDT,PSBSCH,PSBONX,PSBOIT,PSBFREQ)
|
---|
116 | ...I PSBONX["V",PSBSCH'="" Q:'$$OKAY^PSBVDLU1(PSBOST,PSBRPDT,PSBSCH,PSBONX,PSBOIT,PSBFREQ)
|
---|
117 | ...F PSBXX=0:1 Q:'$D(^TMP("PSB",$J,"GETADMIN",PSBXX)) S PSBADST=$G(^TMP("PSB",$J,"GETADMIN",PSBXX)) D
|
---|
118 | ....F Y=1:1:$L(PSBADST,"-") S Z=+("."_$P(PSBADST,"-",Y)) D
|
---|
119 | .....Q:(PSBRPDT+Z)<$E(PSBOST,1,12) ; Start Date
|
---|
120 | .....Q:(PSBRPDT+Z)'<$E(PSBOSP,1,12) ; Stop Date
|
---|
121 | .....;For Invalid admin times
|
---|
122 | .....D:($P(PSBADST,"-",Y)'?2N)&($P(PSBADST,"-",Y)'?4N)
|
---|
123 | ......D ERROR^PSBMLU(PSBONX,PSBOITX,DFN,"Invalid Admin times",PSBSCH)
|
---|
124 | .....S PSBSM=$S(PSBHSM=1:"HSM",PSBSM=1:"SM",1:"")
|
---|
125 | .....;*** Local array to include order no
|
---|
126 | .....S PSBTOT(Z,PSBOITX,PSBONX)=PSBSM_U_"Dosage: "_PSBDOSE_" Route: "_PSBMR_" "_PSBIFR
|
---|
127 | ..S PSBX="" F S PSBX=$O(PSBTOT(PSBX)) Q:PSBX="" D
|
---|
128 | ...W !
|
---|
129 | ...S PSBY="" F S PSBY=$O(PSBTOT(PSBX,PSBY)) Q:PSBY="" D
|
---|
130 | ....S PSBZ="" F S PSBZ=$O(PSBTOT(PSBX,PSBY,PSBZ)) Q:PSBZ="" D
|
---|
131 | .....W:$Y>(IOSL-6) $$PTFTR^PSBOHDR(),$$PTHDR()
|
---|
132 | .....I PSBX="MESSAGE" W !,$P(PSBTOT(PSBX,PSBY,PSBZ),U,1),?20,PSBY Q
|
---|
133 | .....W !,$$TIMEOUT^PSBUTL(PSBX),?10
|
---|
134 | .....W $P(PSBTOT(PSBX,PSBY,PSBZ),U,1),?20,PSBY,?55,$P(PSBTOT(PSBX,PSBY,PSBZ),U,2)
|
---|
135 | ..W $$PTFTR^PSBOHDR()
|
---|
136 | .K ^TMP("PSJ",$J),^TMP("PSB",$J)
|
---|
137 | .Q
|
---|
138 | ;
|
---|
139 | WRDHDR() ;
|
---|
140 | S PSBHDR(1)="WARD ADMINISTRATION TIMES"
|
---|
141 | D WARD^PSBOHDR(PSBWRD,.PSBHDR)
|
---|
142 | S Y=PSBRPDT D D^DIQ
|
---|
143 | W !,"Patient Name",?64,Y_" Administration Times"
|
---|
144 | W !,"Room-Bed",?32
|
---|
145 | F X=0,.01:.01:.24 W $J($E(X_"00",2,3),4)
|
---|
146 | W !,$TR($J("",IOM)," ","-")
|
---|
147 | Q ""
|
---|
148 | ;
|
---|
149 | PTHDR() ;
|
---|
150 | S PSBHDR(1)="PATIENT ADMINISTRATION TIMES"
|
---|
151 | D PT^PSBOHDR(PSBDFN,.PSBHDR)
|
---|
152 | W !,"Date/Time",?10,"Self Med",?20,"Medication",?55,"Dose/Route"
|
---|
153 | W !,$TR($J("",IOM)," ","-")
|
---|
154 | S Y=PSBRPDT D D^DIQ
|
---|
155 | W !!,Y,!
|
---|
156 | Q ""
|
---|
157 | ;
|
---|