Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSBOMH2

PSBOMH2.m

Go to the documentation of this file.
  1. PSBOMH2 ;BIRMINGHAM/EFC-MAH ;9/13/12 5:15pm
  1. ;;3.0;BAR CODE MED ADMIN;**6,20,27,26,67,68,70,133**;Mar 2004;Build 1
  1. ;
  1. ; Reference/IA
  1. ; EN^PSJBCMA/2828
  1. ; GETSIOPI^PSJBCMA5/5763
  1. ;
  1. ;*68 - Add ability to get special instructions at end of each orders
  1. ; grid and print in free space before next orders grid, check
  1. ; for page overflow each line of word processing text.
  1. ;*70 - Print Clinic from ^TMP(""PSB",$J,"ORDERS",PSBORD,"INST") on
  1. ; the intruction/med cell of grid. Add psbclinord=2 mode for
  1. ; dual heading text.
  1. ;
  1. EN ; Add dual sections for MAH report - IM and then CO *70
  1. ; only one Legend section after CO section
  1. ; sort 1 = IM sort 2 = CO
  1. ;
  1. ;*70 MAH was missing report Title
  1. S Y=$S($P(PSBRPT(.1),U,8)]"":$P(PSBRPT(.1),U,8),1:$P(PSBRPT(.1),U,6))
  1. S PSBHDR(0)="MEDICATION ADMINISTRATION HISTORY for "_$$FMTE^XLFDT($P(PSBRPT(.1),U,6)+$P(PSBRPT(.1),U,7))_" to "_$$FMTE^XLFDT(Y+$P(PSBRPT(.1),U,9))
  1. ;
  1. ;**** INPATIENT ORDERS 1st **** *70
  1. N PSBSUBHD
  1. S PSBSUBHD="** INPATIENT ORDERS **"
  1. S PSBWEEK=0
  1. F S PSBWEEK=$O(^TMP("PSB",$J,PSBWEEK)) Q:'PSBWEEK D
  1. .D:$D(^TMP("PSB",$J,PSBWEEK,"SORT",1,"C"))
  1. ..D CONT(1)
  1. ;
  1. ; Now the PRN/One Time/On-Call Sheets
  1. S PSBWEEK=0
  1. F S PSBWEEK=$O(^TMP("PSB",$J,PSBWEEK)) Q:'PSBWEEK D
  1. .D:$D(^TMP("PSB",$J,PSBWEEK,"SORT",1,"P"))
  1. ..D PRN(1)
  1. ;
  1. ;**** CLINIC ORDERS 2nd **** *70
  1. S PSBSUBHD="** CLINIC ORDERS **"
  1. S PSBWEEK=0
  1. F S PSBWEEK=$O(^TMP("PSB",$J,PSBWEEK)) Q:'PSBWEEK D
  1. .D:$D(^TMP("PSB",$J,PSBWEEK,"SORT",2,"C"))
  1. ..D CONT(2)
  1. ;
  1. ; Now the PRN/One Time/On-Call Sheets
  1. S PSBWEEK=0
  1. F S PSBWEEK=$O(^TMP("PSB",$J,PSBWEEK)) Q:'PSBWEEK D
  1. .D:$D(^TMP("PSB",$J,PSBWEEK,"SORT",2,"P"))
  1. ..D PRN(2)
  1. ;
  1. S PSBSUBHD="** LEGEND **"
  1. D LEGEND
  1. K ^TMP("PSB",$J)
  1. Q
  1. ;
  1. CONT(XO) ;
  1. N SILN,SITXT
  1. S PSBHDR(1)="Continuing/PRN/Stat/One Time Medication/Treatment Record (VAF 10-2970 B, C, D)"
  1. W $$HDR()
  1. S PSBDRUG=""
  1. F S PSBDRUG=$O(^TMP("PSB",$J,PSBWEEK,"SORT",XO,"C",PSBDRUG)) Q:PSBDRUG="" D
  1. .S PSBORD=""
  1. .F S PSBORD=$O(^TMP("PSB",$J,PSBWEEK,"SORT",XO,"C",PSBDRUG,PSBORD)) Q:'PSBORD D
  1. ..S PSBCNT=8
  1. ..S:$O(^TMP("PSB",$J,"ORDERS",PSBORD,"INST",""),-1)>PSBCNT PSBCNT=$O(^(""),-1)
  1. ..S:$O(^TMP("PSB",$J,"ORDERS",PSBORD,"AT",""),-1)>PSBCNT PSBCNT=$O(^(""),-1)
  1. ..W:$Y>(IOSL-PSBCNT-4) $$HDR()
  1. ..F PSBLINE=0:1:PSBCNT D ;*70 start at 0 for inserted Clinic name
  1. ...D CHKPAGE ;*68 convert overflow logic to a tag call
  1. ...W !,$G(^TMP("PSB",$J,"ORDERS",PSBORD,"INST",PSBLINE))
  1. ...W ?32,"| " W:PSBLINE>0 $G(^TMP("PSB",$J,"ORDERS",PSBORD,"AT",PSBLINE))
  1. ...S PSBDAY=0,PSBCOL=0
  1. ...F S PSBDAY=$O(^TMP("PSB",$J,PSBWEEK,"HDR",PSBDAY)) Q:'PSBDAY D
  1. ....W ?(40+(PSBCOL*13)),"|" ;Remove space, PSB*3*67
  1. ....S Y=$G(^TMP("PSB",$J,PSBWEEK,PSBORD,PSBDAY,PSBLINE))
  1. ....;Write space when status does not contain >, PSB*3*67
  1. ....I ($L($P(Y,U,2))'=5)!($P(Y,U,3)'="RM"),($P(Y,U,3)'[">") W " "
  1. ....W $P(Y,U,3)
  1. ....W $E($P($P(Y,U,1)_"0000",".",2),1,4)," "
  1. ....W $P(Y,U,2)
  1. ....I $D(^TMP("PSB",$J,"ORDERS",PSBORD,"HOLD",PSBDAY)),(PSBLINE=PSBCNT) W "HOLD" ;output hold status
  1. ....I '$D(^TMP("PSB",$J,"ORDERS",PSBORD,"DISC",PSBDAY))&'$D(^TMP("PSB",$J,"ORDERS",PSBORD,"HOLD",PSBDAY)) D
  1. .....I $D(^TMP("PSB",$J,"ORDERS",PSBORD,"NTDUE",PSBDAY)),(PSBLINE=PSBCNT) W "***" ;write *** when day no due
  1. ....I $D(^TMP("PSB",$J,"ORDERS",PSBORD,"DISC",PSBDAY)),(PSBLINE=PSBCNT) W "***" ;output discontinued status
  1. ....S PSBCOL=PSBCOL+1
  1. ..D SIOPI ;*68 get and print SI lines, if exist
  1. ..W !,$TR($J("",IOM)," ","-")
  1. Q
  1. ;
  1. PRN(XO) ;
  1. S PSBHDR(1)="Continuing/PRN/Stat/One Time Medication/Treatment Record (VAF 10-2970 B, C, D)"
  1. W $$HDR(1)
  1. S PSBDRUG=""
  1. F S PSBDRUG=$O(^TMP("PSB",$J,PSBWEEK,"SORT",XO,"P",PSBDRUG)) Q:PSBDRUG="" D
  1. .S PSBORD=""
  1. .F S PSBORD=$O(^TMP("PSB",$J,PSBWEEK,"SORT",XO,"P",PSBDRUG,PSBORD)) Q:'PSBORD D
  1. ..S PSBCNT=$O(^TMP("PSB",$J,PSBWEEK,PSBORD,"AT",""),-1)
  1. ..D:PSBCNT<$O(^TMP("PSB",$J,"ORDERS",PSBORD,"INST",""),-1)
  1. ...S PSBCNT=$O(^TMP("PSB",$J,"ORDERS",PSBORD,"INST",""),-1)
  1. ..S:PSBCNT<8 PSBCNT=8 ; Minimum space for order
  1. ..W:$Y>(IOSL-PSBCNT-4) $$HDR(1)
  1. ..F PSBLINE=0:1:PSBCNT D
  1. ...D CHKPAGE ;*68 move overflow page logic to a tag
  1. ...W !,$G(^TMP("PSB",$J,"ORDERS",PSBORD,"INST",PSBLINE))
  1. ...W ?32,"| ",$G(^TMP("PSB",$J,PSBWEEK,PSBORD,"AT",PSBLINE))
  1. ..D SIOPI ;*68 get and print SI lines, if exist
  1. ..W !,$TR($J("",IOM)," ","-")
  1. Q
  1. ;
  1. LEGEND ;
  1. ;print the initials - name legend as an extra page ;
  1. N PSBCLINORD S PSBCLINORD=2 ;*70
  1. D PT^PSBOHDR(DFN,.PSBHDR,,,,$G(PSBSUBHD)) ;*70
  1. W !!,"Initial - Name Legend",! ;
  1. I $D(^TMP("PSB",$J,"LEGEND")) D
  1. .S X=$Q(^TMP("PSB",$J,"LEGEND",""))
  1. .F W $S($QS(X,4)[99:"",1:$QS(X,4)),?10,$QS(X,5),! S X=$Q(@X) Q:$QS(X,3)'="LEGEND" ;
  1. W !!,"Status Codes",!,"C - Completed",!,"G - Given",!,"H - Held",!,"I - Infusing",!,"M - Missing Dose Requested",!,"N - Not Given (Undo-Given)",!,"R - Refused",!,"RM - Removed",!,"S - Stopped",! ;P133
  1. W "> - Scheduled administration times for the order have been changed",!,"*** - Medication Not Due",! ;add changed Admin time message, PSB*3*67
  1. K ^TMP("PSJ",$J)
  1. Q
  1. ;
  1. HDR(PRN) ;
  1. ; PRN = TRUE IF DISPLAYING PRN MED (OPTIONAL)
  1. N PSBCLINORD S PSBCLINORD=2 ;*70
  1. D PT^PSBOHDR(DFN,.PSBHDR,,,,$G(PSBSUBHD)) ;*70
  1. W !,"Location",?32,"| " ;*70
  1. I '$G(PRN) F X=0:1:6 W ?(40+(X*13)),"|" ;*70
  1. W !,"Start Date",?20,"Stop Date",?32,"| ",$S('$G(PRN):"Admin",1:"Action Status")
  1. I '$G(PRN) F X=0:1:6 W ?(40+(X*13)),"|"
  1. W !,"and Time",?20,"and Time",?32,"| ",$S('$G(PRN):"Times",1:"Action Date/Times")
  1. D:'$G(PRN)
  1. .S PSBCOL=0,X=0 F S X=$O(^TMP("PSB",$J,PSBWEEK,"HDR",X)) Q:'X D
  1. ..W ?(40+(PSBCOL*13)),"| ",$E(X,4,5),"/",$E(X,6,7),"/",(1700+$E(X,1,3))
  1. ..S PSBCOL=PSBCOL+1
  1. D:$G(PRN)
  1. .W ?76,"PRN Reason"
  1. W !,$TR($J("",IOM)," ","-")
  1. Q ""
  1. ;
  1. PSBCK1(PSBCHK) ;
  1. I PSBCHK="A" D
  1. .S TEST=$P(^PSB(53.79,PSBIEN,0),U,6)
  1. .D PSBOUT^PSBOMH1(TEST,PSBINIT)
  1. .S X=$P(^PSB(53.79,PSBIEN,0),U,6)_U_PSBINIT_U_"G"_U_PSBIEN
  1. I PSBCHK="B" D
  1. .S TESTB=$P(^PSB(53.79,PSBIEN,0),U,6)
  1. .D PSBOUT^PSBOMH1(TESTB,PSBINIT)
  1. .S X=$P(^PSB(53.79,PSBIEN,0),U,6)_U_PSBINIT_U_$P(^(0),U,9)_U_PSBIEN
  1. S PSBCHK=""
  1. Q
  1. ;
  1. PSBENT(PSBTIS) ;
  1. S PSBNAME="",PSBNAME=$$GET1^DIQ(53.79,PSBIEN_",","ACTION BY:NAME")
  1. S ^TMP("PSB",$J,"LEGEND",$S($G(PSBTIS)="":99,1:PSBTIS),PSBNAME)=""
  1. Q
  1. ;
  1. PSBSTIV ;
  1. S YB="" F S YB=$O(PSBAUD(YB)) Q:YB="" D
  1. .S Z="" F S Z=$O(^PSB(53.79,PSBIEN,.9,Z)) Q:Z="" I Z'=0 D
  1. ..I $P(PSBAUD(YB),U,1)=$P(^PSB(53.79,PSBIEN,.9,Z,0),"^",1) D
  1. ...I $P(^PSB(53.79,PSBIEN,.9,Z,0),"^",3)["Instruct" D
  1. ....I $P(PSBAUD(YB),U,2)'["*" S $P(PSBAUD(YB),U,2)=$P(PSBAUD(YB),U,2)_"*"
  1. ....D PSBOUT^PSBOMH1($P(PSBAUD(YB),U,1),$P(PSBAUD(YB),U,2))
  1. Q
  1. ;
  1. PSBCTAR ;
  1. S YC="" F S YC=$O(PSBTAR(YC)) Q:YC="" D
  1. .S Z="" F S Z=$O(^PSB(53.79,PSBIEN,.9,Z)) Q:Z="" I Z'=0 D
  1. ..I $P(PSBTAR(YC),U,1)=$P(^PSB(53.79,PSBIEN,.9,Z,0),"^",1) D
  1. ...I $P(^PSB(53.79,PSBIEN,.9,Z,0),"^",3)["Instruct" D
  1. ....S $P(PSBTAR(YC),U,2)=$P(PSBTAR(YC),U,2)_"*"
  1. ....D PSBOUT^PSBOMH1($P(^PSB(53.79,PSBIEN,.9,Z,0),"^",1),$P(PSBTAR(YC),U,2))
  1. Q
  1. ;
  1. SIOPI ;Get and print SI/OPI Wp text *68
  1. K ^TMP("PSJBCMA5",$J,DFN)
  1. S SILN=$$GETSIOPI^PSJBCMA5(DFN,PSBORD,1)
  1. I SILN F QQ=0:0 S QQ=$O(^TMP("PSJBCMA5",$J,DFN,PSBORD,QQ)) Q:'QQ D
  1. .S SITXT=^TMP("PSJBCMA5",$J,DFN,PSBORD,QQ)
  1. .I SILN=1,SITXT="" Q
  1. .D CHKPAGE I QQ=1 W !," Special Instructions:"
  1. .D CHKPAGE W !," ",SITXT
  1. K ^TMP("PSJBCMA5",$J,DFN)
  1. Q
  1. ;
  1. CHKPAGE ;check for page full and print overflow msgs and new page headers *68
  1. I IOSL>24,$Y>$S(PSBCNT<13:(IOSL-PSBCNT-4),(PSBCNT-PSBLINE=12):(IOSL-12),1:(IOSL-12)) D
  1. .W !!?(IOM-35\2),"*** CONTINUED ON NEXT PAGE ***"
  1. .W $$HDR()
  1. .W !?(IOM-35\2),"*** CONTINUED FROM PREVIOUS PAGE ***",!
  1. Q