| 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 | ; | 
|---|