| 1 | PSIVHYPL ;BIR/PR-PRINT OUT LABELS ;26 FEB 97 / 3:20 PM
 | 
|---|
| 2 |  ;;5.0; INPATIENT MEDICATIONS ;**58,96,128,178**;16 DEC 97;Build 9
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; Reference to ^%ZIS(2 is supported by DBIA 3435.
 | 
|---|
| 5 |  ; Reference to ^PS(52.6 is supported by DBIA 1231.
 | 
|---|
| 6 |  ; Reference to ^PS(52.7 is supported by DBIA 2173.
 | 
|---|
| 7 |  ; Reference to ^PS(55 is supported by DBIA 2191.
 | 
|---|
| 8 |  ; Reference to ^PS(50.4 is supported by DBIA 2175.
 | 
|---|
| 9 |  ; Reference to ^PS(51.2 is supported by DBIA 2178.
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 |  ;NEEDS DFN, ON AND PSIVNOL (Total number of labels to print) and
 | 
|---|
| 12 |  ;PSIVCT - $D(PSIVCT) NO COUNT LABEL
 | 
|---|
| 13 | SSWARD ;Get patient SS# and ward location
 | 
|---|
| 14 |  N X0,PSJIO,I
 | 
|---|
| 15 |  S I=0 F  S I=$O(^%ZIS(2,IOST(0),55,I)) Q:'I  S X0=^(I,0),PSJIO($P(X0,"^"))=^(1)
 | 
|---|
| 16 |  S PSJIO=$S('$D(PSJIO):0,1:1)
 | 
|---|
| 17 |  D ENIV^PSJAC S VADM(2)=$E(VADM(2),6,9),PSIVWD=$S(+VAIN(4):$P(VAIN(4),U,2),1:"Opt. IV")
 | 
|---|
| 18 |  G:PSIVNOL<1 Q D SETP,^PSIVHYP S PSIVRM=$P(PSIVSITE,U,13),P16=$P($G(^PS(55,DFN,"IV",+ON,9)),U,3) S:PSIVRM<1 PSIVRM=30 I $D(PSIVCT),PSIVCT'=1 K PSIVCT
 | 
|---|
| 19 |  I PSJIO,$G(PSJIO("FI"))]"" X PSJIO("FI")
 | 
|---|
| 20 |  I $P(PSIVSITE,U,7) D
 | 
|---|
| 21 |  . S PSIVFLAG=1,(LINE,PSIV1)=0,PSIV2=PSIVNOL,PSIVNOL=0 D RE
 | 
|---|
| 22 |  . S PSIVRP="",PSIVRT=""
 | 
|---|
| 23 |  . I $D(^PS(55,DFN,"IV",+ON,.2)) S PSIVRP=$P(^PS(55,DFN,"IV",+ON,.2),U,3) D
 | 
|---|
| 24 |  .. I PSIV1'>0!'$P(PSIVSITE,U,3)!($P(PSIVSITE,U,3)=1&(P(4)'="P"))!($P(PSIVSITE,U,3)=2&("AH"'[P(4))) Q   ;QUIT IF "DOSE DUE AT" LINE IS SET TO NOT PRINT
 | 
|---|
| 25 |  .. S PSIVRT=$P(^PS(51.2,PSIVRP,0),U,1)
 | 
|---|
| 26 |  .. S X="ROUTE: "_PSIVRT D:X]"" PMR
 | 
|---|
| 27 |  . S X="Solution: _______________" D PRNTL S X="Additive: _______________" D PRNTL
 | 
|---|
| 28 |  . S PSIVNOL=PSIV2
 | 
|---|
| 29 |  . I 'PSJIO F LINE=LINE+1:1:(PSIVSITE+$P(PSIVSITE,U,16)) W !
 | 
|---|
| 30 |  . I PSJIO,$G(PSJIO("EL"))]"" X PSJIO("EL")
 | 
|---|
| 31 |  I '$D(PSIVCT) D NOW^%DTC S Y=%,$P(^PS(55,DFN,"IV",+ON,9),U,1,2)=Y_"^"_PSIVNOL,$P(^(9),U,3)=$P(^(9),U,3)+PSIVNOL
 | 
|---|
| 32 |  K PSIVFLAG,PSIVSH
 | 
|---|
| 33 | START F PSIV1=1:1:PSIVNOL D
 | 
|---|
| 34 |  . S LINE=0 D RE
 | 
|---|
| 35 |  . Q:$D(PSIVFLAG) 
 | 
|---|
| 36 |  . I 'PSJIO F LINE=LINE+1:1:(PSIVSITE+$P(PSIVSITE,U,16)) W !
 | 
|---|
| 37 |  . I PSJIO,$G(PSJIO("EL"))]"" X PSJIO("EL")
 | 
|---|
| 38 |  I PSJIO,$G(PSJIO("FE"))]"" X PSJIO("FE")
 | 
|---|
| 39 |  D:'$D(PSIVCT) ^PSIVSTAT
 | 
|---|
| 40 | Q K HYPL,LINE,MESS,P16,PDATE,PDOSE,PSIV,PSIVA,PSIV1,PSIV2,PSIVCT,PSIVDOSE,PSIVFLAG,PSIVRM,PSIVWD,TVOL,HYPLPRT Q
 | 
|---|
| 41 | RE I PSIV1 S:P(15)>2880!('P(15)) P(15)=2880 S P(16)=P16+PSIV1#(1440/P(15)+.5\1) S:'P(16) P(16)=1440/P(15)+.5\1
 | 
|---|
| 42 |  K DO
 | 
|---|
| 43 |  I PSJIO,$G(PSJIO("SL"))]"" X PSJIO("SL")
 | 
|---|
| 44 |  I PSIV1 S PSJBCID=$$BCMA^PSIVBCID(DFN,ON,$D(PSIVCT),$G(PSIV1),$G(PSIV2),$G(PSIVNOL)) D BARCODE
 | 
|---|
| 45 |  S X="["_$P(^PS(55,DFN,"IV",+ON,0),U)_"]"_" "_VADM(2)_"  "_PSIVWD_"  "_$E(DT,4,5)_"/"_$E(DT,6,7)_"/"_$E(DT,2,3) D PRNTL
 | 
|---|
| 46 |  S X=VADM(1) S:$P(PSIVSITE,U,9) X=X_"  "_$S(VAIN(5)]"":VAIN(5),1:"NF") D PRNTL S X=" " D PRNTL
 | 
|---|
| 47 |  D:$P(PSIVSITE,U,12) TVOL
 | 
|---|
| 48 |  S X="",$P(X,"=",PSIVRM-1)="" D PRNTL
 | 
|---|
| 49 |  I $D(PSIVFLAG) F PSIV=0:0 S PSIV=$O(^PS(55,DFN,"IV",+ON,"AD",PSIV)) Q:'PSIV  S Y=^(PSIV,0),X=$S($D(^PS(52.6,+Y,0)):$P(^(0),U),1:"*********")_"  "_$P(Y,U,2)_" " S:$P(Y,U,3)]"" X=X_" ("_$P(Y,U,3)_")" D
 | 
|---|
| 50 |  . D PRNTL
 | 
|---|
| 51 |  . D MESS
 | 
|---|
| 52 |  I $D(PSIVFLAG) F PSIV=0:0 S PSIV=$O(^PS(55,DFN,"IV",+ON,"SOL",PSIV)) Q:'PSIV  S PSIV=PSIV_"^"_+^(PSIV,0),YY=^(0) D
 | 
|---|
| 53 |  . D SOL1,PRNTL
 | 
|---|
| 54 |  . S X=$P(^PS(52.7,$P(PSIV,U,2),0),U,4) I X]"" S X="   "_X D PRNTL
 | 
|---|
| 55 |  G:$D(PSIVFLAG) SOL
 | 
|---|
| 56 |  F PSIV=0:0 S PSIV=$O(^PS(55,DFN,"IV",+ON,"SOL",PSIV)) Q:'PSIV  S PSIV=PSIV_"^"_+^(PSIV,0),YY=^(0) D
 | 
|---|
| 57 |  . D SOL1,PRNTL I PSIV1 D UP3^PSIVBCID(DFN,PSJBLN,PSIV,YY)
 | 
|---|
| 58 |  . S X=$P(^PS(52.7,$P(PSIV,U,2),0),U,4) I X]"" S X="   "_X D PRNTL
 | 
|---|
| 59 |  F I=0:0 S I=$O(HYPL(I)) Q:'I  S PSIV="" D
 | 
|---|
| 60 |  . F I=I:0 S PSIV=$O(HYPL(I,PSIV)) Q:PSIV=""  S Y="",X=0 D
 | 
|---|
| 61 |  .. X "F ZZ=0:0 S Y=$O(HYPL(I,PSIV,Y)) Q:Y=""""  I Y=""ALL""!(Y=""***"")!(Y[P(16)) S X=X+$P(HYPL(I,PSIV,Y),U),PSIVP=HYPL(I,PSIV,Y) D UPD"
 | 
|---|
| 62 |  .. I X D HYP
 | 
|---|
| 63 |  K HYPAD
 | 
|---|
| 64 | SOL S X="",$P(X,"=",PSIVRM-1)="" D PRNTL
 | 
|---|
| 65 |  S X=" " D PRNTL I PSIV1'>0!'$P(PSIVSITE,U,3)!($P(PSIVSITE,U,3)=1&(P(4)'="P"))!($P(PSIVSITE,U,3)=2&("AH"'[P(4))) G MEDRT
 | 
|---|
| 66 |  S:'$D(PSIVDOSE) PSIVDOSE="" S X=$P(PSIVDOSE," ",PSIV1) D:$E(X)="." CONVER^PSIVLABL S X="Dose due at: "_$S(X="":"________",1:$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)_" "_$E(X#1_"000",2,5)) D PRNTL
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 | MEDRT ;Find Medication Route   
 | 
|---|
| 69 |  S PSIVRP="",PSIVRT=""
 | 
|---|
| 70 |  I $D(^PS(55,DFN,"IV",+ON,.2)) S PSIVRP=$P(^PS(55,DFN,"IV",+ON,.2),U,3) D
 | 
|---|
| 71 |  .S PSIVRT=$P(^PS(51.2,PSIVRP,0),U,1)
 | 
|---|
| 72 |  .S X="ROUTE: "_PSIVRT D:X]"" PMR
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 | INF S X=$P(P(8),"@") D:X]"" PRNTL
 | 
|---|
| 75 |  I $D(^PS(55,DFN,"IV",+ON,3)) S X=$P(^(3),U) D:X]"" PRNTL
 | 
|---|
| 76 |  S X=P(9) D:X]"" PRNTL
 | 
|---|
| 77 |  S X=P(11) D:X]"" PRNTL
 | 
|---|
| 78 |  I $D(MESS) S X=MESS D PRNTL
 | 
|---|
| 79 |  I $D(^PS(59.5,PSIVSN,4)) S Y=^(4) F PSIV=1:1 S X=$P(Y,U,PSIV) Q:X=""  D PRNTL
 | 
|---|
| 80 |  S X=PSIV1_"["_PSIVNOL_"]" D PRNTL
 | 
|---|
| 81 |  Q
 | 
|---|
| 82 | PRNTL N I F LINE=LINE+1:1 D  Q:$L(X)<1
 | 
|---|
| 83 |  . I LINE>PSIVSITE D
 | 
|---|
| 84 |  .. S LINE=1
 | 
|---|
| 85 |  .. I 'PSJIO D  Q
 | 
|---|
| 86 |  ... F ZZ=1:1 Q:ZZ>$P(PSIVSITE,"^",16)  W !
 | 
|---|
| 87 |  .. F I="EL","SL" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 88 |  . K ZZ
 | 
|---|
| 89 |  . F I="ST","STF" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 90 |  . W $E(X,1,PSIVRM)
 | 
|---|
| 91 |  . F I="ETF","ET" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 92 |  . I 'PSJIO W !
 | 
|---|
| 93 |  . S X=$E(X,PSIVRM+1,999)
 | 
|---|
| 94 |  Q
 | 
|---|
| 95 | PMR ; Print Med Route on label
 | 
|---|
| 96 |  ;  
 | 
|---|
| 97 |  F LINE=LINE+1:1 D  Q:$L(X)<1
 | 
|---|
| 98 |  . I LINE>PSIVSITE D
 | 
|---|
| 99 |  .. S LINE=1
 | 
|---|
| 100 |  .. I 'PSJIO D  Q
 | 
|---|
| 101 |  ... F ZZ=1:1 Q:ZZ>$P(PSIVSITE,"^",16)  W !
 | 
|---|
| 102 |  .. F I="EL","SL" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 103 |  . K ZZ
 | 
|---|
| 104 |  . ;
 | 
|---|
| 105 |  . F I="ST","STF","SM","SMF" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 106 |  . W $E(X,1,PSIVRM)
 | 
|---|
| 107 |  . F I="ETF","ET","EMF","EM" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 108 |  . I 'PSJIO W !
 | 
|---|
| 109 |  . S X=$E(X,PSIVRM+1,999)
 | 
|---|
| 110 |  Q
 | 
|---|
| 111 | TVOL ;
 | 
|---|
| 112 |  S PSIV=TVOL F X=0:0 S X=$O(^PS(55,DFN,"IV",+ON,"AD",X)) Q:'X  S X=X_"^"_^(X,0) S:$P(X,U,4)[P(16)!($P(X,U,4)="")!'PSIV1 PSIV=PSIV+$S($P(^PS(52.6,$P(X,U,2),0),U,10):$P(X,U,3)/$P(^(0),U,10),1:0)
 | 
|---|
| 113 |  S X="Total Volume: "_(PSIV+.5\1) D PRNTL
 | 
|---|
| 114 |  Q
 | 
|---|
| 115 | SOL1 S X=$S($D(^PS(52.7,$P(PSIV,U,2),0)):$P(^(0),U)_" "_$P(^PS(55,DFN,"IV",+ON,"SOL",+PSIV,0),U,2),1:"**********") Q
 | 
|---|
| 116 | HYP ;
 | 
|---|
| 117 |  I PSIV="*" S X="*** Error in "_$S(I=50.4:"electrolyte",I=52.7:"solution",1:"additive") D PRNTL Q
 | 
|---|
| 118 |  S PSIVA=$S(I=50.4:PSIV,I=52.7:+$G(^PS(55,DFN,"IV",+ON,"SOL",PSIV,0)),1:+$G(^PS(55,DFN,"IV",+ON,"AD",PSIV,0)))
 | 
|---|
| 119 |  S X=$S($D(^PS(I,PSIVA,0)):$P(^(0),U),1:"Undefined "_$S(I=50.4:"electrolyte",I=52.7:"solution",1:"additive"))_" "_$S(X<1:"0"_(X+.005\.01/100),1:(X+.005\.01/100))_" "_$P($P(HYPL(I,PSIV,$O(HYPL(I,PSIV,""))),U)," ",2)
 | 
|---|
| 120 |  D PRNTL
 | 
|---|
| 121 |  Q
 | 
|---|
| 122 | SETP S Y=^PS(55,DFN,"IV",+ON,0) F X=1:1:23 S P(X)=$P(Y,U,X)
 | 
|---|
| 123 |  Q
 | 
|---|
| 124 | MESS I '$D(MESS) I $P(^PS(52.6,+Y,0),U,9)]"" S MESS=$P(^(0),U,9)
 | 
|---|
| 125 |  Q
 | 
|---|
| 126 | UPD N X,Y,PSIVEL,PSIVAD
 | 
|---|
| 127 |  S PSIVEL=$P(PSIVP,"^",2)
 | 
|---|
| 128 |  I I=50.4 F PSIVAD=0:0 S PSIVAD=$O(HYPLRPT(PSIVEL,"AD",PSIVAD)) Q:'PSIVAD  D
 | 
|---|
| 129 |  .I $D(HYPAD(+PSIVAD)) Q
 | 
|---|
| 130 |  .S YY=$G(^PS(55,DFN,"IV",+ON,"AD",+PSIVAD,0))
 | 
|---|
| 131 |  .S HYPAD(+PSIVAD)=""
 | 
|---|
| 132 |  .I +$P(YY,U,3),(+$P(YY,U,3)'=P(16)) Q
 | 
|---|
| 133 |  .D UP2^PSIVBCID(DFN,PSJBLN,PSIV,YY)
 | 
|---|
| 134 |  I I'=50.4 S YY=$G(^PS(55,DFN,"IV",+ON,"AD",+PSIV,0)) D UP2^PSIVBCID(DFN,PSJBLN,PSIV,YY)
 | 
|---|
| 135 |  Q
 | 
|---|
| 136 | BARCODE D PSET^%ZISP
 | 
|---|
| 137 |  I 'PSJIO D
 | 
|---|
| 138 |  . I IOBARON]"" W @IOBARON
 | 
|---|
| 139 |  . W PSJBCID
 | 
|---|
| 140 |  . I IOBAROFF]"" W @IOBAROFF
 | 
|---|
| 141 |  . W !
 | 
|---|
| 142 |  I PSJIO D
 | 
|---|
| 143 |  . F I="SB","SBF" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 144 |  . W PSJBCID
 | 
|---|
| 145 |  . F I="EBF","EB" I $G(PSJIO(I))]"" X PSJIO(I)
 | 
|---|
| 146 |  Q
 | 
|---|