HBHCUTL1 ; LR VAMC(IRMS)/MJT-HBHC Utility Module; May 05, 2021@16:27
;;1.0;HOSPITAL BASED HOME CARE;**1,2,6,9,19,24,32**;NOV 01, 1993;Build 58
;
;Reference to:
; ^DG(40.8 supported by ICR #7024
; ^DIC(4 supported by ICR #10090
;
ENDRPT ; Print end of report message
W !!?28,"==== End of Report ===="
Q
END132 ; Print end of report message for 132 column report
W !!?54,"==== End of Report ===="
Q
FORMMSG ; Process Form 3/4/5/7 Transmit Status fields
W $C(7),!!,"Transmit Status Flag must be reset before editing this record is allowed."
I $P(^HBHC(631.9,1,0),U,5)="" W !!,"*** NOTICE: Hospital Number is missing from System Parameter file (#631.9).",!,"Due to automatic Form 6 Correction Record generation, Transmit Status Flag"
I $P(^HBHC(631.9,1,0),U,5)="" W !,"CANNOT be reset without this information. Contact IRM to enter this",!,"information using FileMan.",! S HBHCNHSP=1 H 10 Q
;HBH*1.0*32: At least one parent site must be defined.
I $O(^HBHC(631.9,1,1,"B",""))="" D Q
. ;Variable HBHCNHSP is killed at exit of calling routine
. S HBHCNHSP=1
. W !!,"No parent sites are defined at this facility."
. W !,"Contact your HBPC Program Manager to define at least one"
. W !,"parent site in option ""System Parameters Edit"".",!
. N DIR
. S DIR("A")="Press any key to continue",DIR(0)="FO"
. D ^DIR
W !!,"Do you wish to reset the Flag" S %=2 D YN^DICN W ! I %=0 W !,"A 'Yes' response will reset the Transmit Status Flag field data. A 'No'",!,"response will return you to the menu without resetting the Transmit",!,"Status Flag.",!! G FORMMSG
S HBHCPRCT=%
I %'=1 S:(HBHCFORM=4)!(HBHCFORM=7) Y=0 Q
S HBHCFILE=$S(HBHCFORM=7:633.2,HBHCFORM=4:632,1:631),HBHCNODE=$S(HBHCFORM=7:12,HBHCFORM=4:0,1:1),HBHCPC1=$S(HBHCFORM=3:17,HBHCFORM=7:1,HBHCFORM=4:8,1:18),HBHCPC2=$S(HBHCFORM=3:25,HBHCFORM=7:5,HBHCFORM=4:12,1:27)
L +^HBHC(HBHCFILE,HBHCDFN,HBHCNODE):$S($D(DILOCKTM):DILOCKTM,1:3) I '$T W !,"*** Record locked by another user. Please try again later. ***",! H 3 Q
S HBHCPC3=$S(HBHCFORM=3:26,HBHCFORM=7:6,HBHCFORM=4:13,1:28),HBHCXREF=$S(HBHCFORM=3:"AE",HBHCFORM=7:"AC",HBHCFORM=4:"AC",1:"AF")
S HBHCSTAT=$S(HBHCFORM=3:$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17),HBHCFORM=5:$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18),HBHCFORM=7:$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U),1:$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,8))
D NOW^%DTC S HBHCNOW=$E(%,1,12)
K:HBHCSTAT]"" ^HBHC(HBHCFILE,HBHCXREF,HBHCSTAT,HBHCDFN)
S $P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC1)="N",^HBHC(HBHCFILE,HBHCXREF,"N",HBHCDFN)="",$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC2)=HBHCNOW,$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC3)=DUZ
I (HBHCFORM=3)&($P(^HBHC(HBHCFILE,HBHCDFN,0),U,40)]"") S HBHC5XMT=$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18) K:HBHC5XMT]"" ^HBHC(HBHCFILE,"AF",HBHC5XMT,HBHCDFN) S $P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18)="N",^HBHC(HBHCFILE,"AF","N",HBHCDFN)=""
I HBHCFORM=5 S HBHC3XMT=$P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17) K:HBHC3XMT]"" ^HBHC(HBHCFILE,"AE",HBHC3XMT,HBHCDFN) S $P(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17)="N",^HBHC(HBHCFILE,"AE","N",HBHCDFN)=""
L -^HBHC(HBHCFILE,HBHCDFN,HBHCNODE)
D:(HBHCFORM'=4)&(HBHCFORM'=7) SETNODE
EXIT ; Exit FORMMSG module
K HBHCADDT,HBHCDPT0,HBHCDSDT,HBHCFILE,HBHCHOSP,HBHCINFO,HBHCLNTH,HBHCNAME,HBHCNDX1,HBHCNODE,HBHCNOW,HBHCPC1,HBHCPC2,HBHCPC3,HBHCREC,HBHCS136,HBHCSP4,HBHCSP8,HBHCSTAT,HBHCXREF,HBHC3XMT,HBHC5XMT
Q
SETNODE ; Set node in ^HBHC(634.4) (Form 6 Corrections file)
S $P(HBHCSP4," ",5)="",$P(HBHCSP8," ",9)="",$P(HBHCS136," ",137)="",HBHCLNTH=30
L +^HBHC(634.4,0):$S($D(DILOCKTM):DILOCKTM,1:3) Q:'$T S HBHCNDX1=$P(^HBHC(634.4,0),U,3)+1,$P(^HBHC(634.4,0),U,3)=HBHCNDX1,$P(^HBHC(634.4,0),U,4)=$P(^HBHC(634.4,0),U,4)+1 L -^HBHC(634.4,0)
S HBHCINFO=^HBHC(HBHCFILE,HBHCDFN,0),HBHCDPT0=^DPT(HBHCDPT,0)
S HBHCADDT=$S($P(HBHCINFO,U,18)]"":$E($P(HBHCINFO,U,18),4,5)_$E($P(HBHCINFO,U,18),6,7)_(1700+$E($P(HBHCINFO,U,18),1,3)),1:HBHCSP8)
S HBHCDSDT=$S($P(HBHCINFO,U,40)]"":$E($P(HBHCINFO,U,40),4,5)_$E($P(HBHCINFO,U,40),6,7)_(1700+$E($P(HBHCINFO,U,40),1,3)),1:HBHCSP8)
S HBHCNAME=$P(HBHCDPT0,U) S:$L(HBHCNAME)<HBHCLNTH HBHCNAME=HBHCNAME_$J("",HBHCLNTH-$L(HBHCNAME))
;HBH*1.0*32: Retrieve parent site
N HBHCHOSPX
D PARENT
;If HBHCHOSPX="", admission occurred before install of
;HBH*1.0*32. In that case, use the system default.
I $G(HBHCHOSPX)="" D
. D HOSP
. S HBHCHOSPX=HBHCHOSP
S HBHCREC=6_HBHCHOSPX_$P(HBHCDPT0,U,9)_HBHCADDT_HBHCNAME_HBHCDSDT_2_HBHCS136
S ^HBHC(634.4,HBHCNDX1,0)=HBHCREC,^HBHC(634.4,"B",$E(HBHCREC,1,30),HBHCNDX1)=""
Q
BIRTHYR ; Birth year field display during Evaluation/Admission Data Entry
S HBHCDPT0=^DPT(HBHCDPT,0)
W !!,"BIRTH YEAR: ",$S($P(HBHCDPT0,U,3):1700+$E($P(HBHCDPT0,U,3),1,3),1:"0000"),$C(7) D MASMSG
Q
SEXRACE ; Sex & Race fields display during Evaluation/Admission Data Entry
S HBHCDPT0=^DPT(HBHCDPT,0),HBHCSEX=$P(HBHCDPT0,U,2)
W !!,"SEX: ",$S(HBHCSEX="M":"Male (1)",1:"Female (2)"),$C(7) D MASMSG
; Obsolete with Race/Ethnicity Info Jan 2003 mandate; commented out historical reference mjt
; ,HBHCRACE=$S($P(HBHCDPT0,U,6)]"":$P(^DIC(10,$P(HBHCDPT0,U,6),0),U,2),1:"")
;W !,"RACE: ",$S(HBHCRACE=4:"Black (2)",HBHCRACE=3:"American Indian/Alaskan Native (4)",HBHCRACE=6:"White (1)",(HBHCRACE=1)!(HBHCRACE=2):"Hispanic Origin (3)",HBHCRACE=5:"Asian/Pacific Islander (5)",1:"Not Determined (9)")
; Field retained until VA Form 10-0014 modified to remove field mjt
W !,"RACE: Obsolete Field Jan 2003",!
K HBHCDPT0,HBHCSEX
Q
MASMSG ; MAS message for BIRTHYR & SEX modules
W !?18,"*** Contact MAS if value is incorrect. ***",!
Q
HOSP ; Obtain Hospital Number from ^DIC(4 (Institution file); set HBHCHOSP variable
; Newing Y to prevent undef in calling routines since DIQ1 call is apparently killing Y
N Y
S:'$D(HBHCSP4) $P(HBHCSP4," ",5)=""
K DA,DIC,DR,^UTILITY("DIQ1",$J)
S DIC=4,DR=99,DA=$P(^HBHC(631.9,1,0),U,5) D EN^DIQ1
S HBHCHOSP=^UTILITY("DIQ1",$J,4,DA,DR)
S:$L(HBHCHOSP)'=7 HBHCHOSP=HBHCHOSP_$E(HBHCSP4,1,(7-($L(HBHCHOSP))))
K DA,DIC,DR,^UTILITY("DIQ1",$J)
Q
;
PARENT ;retrieve patient's parent site
;calling routine should pass in HBHCDFN
Q:$G(HBHCDFN)=""
N HBHCPRNT
;HBHCHOSPX should be new'd by calling routine
S (HBHCHOSPX,HBHCPRNT)=""
S:'$D(HBHCSP4) $P(HBHCSP4," ",5)=""
;Is patient in a Medical Foster Home?
N HBHCMFHPAT,HBHCMFHX
S HBHCMFHPAT=$P($G(^HBHC(631,HBHCDFN,3)),"^")
I HBHCMFHPAT="Y" D
. S HBHCMFHX=$P($G(^HBHC(631,HBHCDFN,3)),"^",2)
. ;HBHCMFHX could be null if MFH location not yet known.
. I HBHCMFHX]"" D
. . S HBHCPRNT=$P($G(^HBHC(633.2,HBHCMFHX,13)),"^")
;HBHCMFHPAT could be null if not known yet whether patient is in a MFH.
;If a transaction is queued up before MFH status is known, a correction
;will be transmitted later.
I HBHCMFHPAT'="Y" D
. S HBHCPRNT=$P($G(^HBHC(631,HBHCDFN,5)),"^")
;If patient does not have a parent site, admission occurred before install
;of HBH*1.0*32. In that case, calling routine will use the HBHCHOSP default.
Q:HBHCPRNT=""
;retrieve institution file pointer
S HBHCPRNT=$P(^DG(40.8,HBHCPRNT,0),"^",7)
;retrieve station number
S HBHCHOSPX=$P($G(^DIC(4,+HBHCPRNT,99)),"^")
I HBHCHOSPX]"",$L(HBHCHOSPX)'=7 S HBHCHOSPX=HBHCHOSPX_$E(HBHCSP4,1,(7-($L(HBHCHOSPX))))
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HHBHCUTL1 7326 printed Dec 13, 2024@01:58:49 Page 2
HBHCUTL1 ; LR VAMC(IRMS)/MJT-HBHC Utility Module; May 05, 2021@16:27
+1 ;;1.0;HOSPITAL BASED HOME CARE;**1,2,6,9,19,24,32**;NOV 01, 1993;Build 58
+2 ;
+3 ;Reference to:
+4 ; ^DG(40.8 supported by ICR #7024
+5 ; ^DIC(4 supported by ICR #10090
+6 ;
ENDRPT ; Print end of report message
+1 WRITE !!?28,"==== End of Report ===="
+2 QUIT
END132 ; Print end of report message for 132 column report
+1 WRITE !!?54,"==== End of Report ===="
+2 QUIT
FORMMSG ; Process Form 3/4/5/7 Transmit Status fields
+1 WRITE $CHAR(7),!!,"Transmit Status Flag must be reset before editing this record is allowed."
+2 IF $PIECE(^HBHC(631.9,1,0),U,5)=""
WRITE !!,"*** NOTICE: Hospital Number is missing from System Parameter file (#631.9).",!,"Due to automatic Form 6 Correction Record generation, Transmit Status Flag"
+3 IF $PIECE(^HBHC(631.9,1,0),U,5)=""
WRITE !,"CANNOT be reset without this information. Contact IRM to enter this",!,"information using FileMan.",!
SET HBHCNHSP=1
HANG 10
QUIT
+4 ;HBH*1.0*32: At least one parent site must be defined.
+5 IF $ORDER(^HBHC(631.9,1,1,"B",""))=""
Begin DoDot:1
+6 ;Variable HBHCNHSP is killed at exit of calling routine
+7 SET HBHCNHSP=1
+8 WRITE !!,"No parent sites are defined at this facility."
+9 WRITE !,"Contact your HBPC Program Manager to define at least one"
+10 WRITE !,"parent site in option ""System Parameters Edit"".",!
+11 NEW DIR
+12 SET DIR("A")="Press any key to continue"
SET DIR(0)="FO"
+13 DO ^DIR
End DoDot:1
QUIT
+14 WRITE !!,"Do you wish to reset the Flag"
SET %=2
DO YN^DICN
WRITE !
IF %=0
WRITE !,"A 'Yes' response will reset the Transmit Status Flag field data. A 'No'",!,"response will return you to the menu without resetting the Transmit",!,"Status Flag.",!!
GOTO FORMMSG
+15 SET HBHCPRCT=%
+16 IF %'=1
if (HBHCFORM=4)!(HBHCFORM=7)
SET Y=0
QUIT
+17 SET HBHCFILE=$SELECT(HBHCFORM=7:633.2,HBHCFORM=4:632,1:631)
SET HBHCNODE=$SELECT(HBHCFORM=7:12,HBHCFORM=4:0,1:1)
SET HBHCPC1=$SELECT(HBHCFORM=3:17,HBHCFORM=7:1,HBHCFORM=4:8,1:18)
SET HBHCPC2=$SELECT(HBHCFORM=3:25,HBHCFORM=7:5,HBHCFORM=4:12,1:27)
+18 LOCK +^HBHC(HBHCFILE,HBHCDFN,HBHCNODE):$SELECT($DATA(DILOCKTM):DILOCKTM,1:3)
IF '$TEST
WRITE !,"*** Record locked by another user. Please try again later. ***",!
HANG 3
QUIT
+19 SET HBHCPC3=$SELECT(HBHCFORM=3:26,HBHCFORM=7:6,HBHCFORM=4:13,1:28)
SET HBHCXREF=$SELECT(HBHCFORM=3:"AE",HBHCFORM=7:"AC",HBHCFORM=4:"AC",1:"AF")
+20 SET HBHCSTAT=$SELECT(HBHCFORM=3:$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17),HBHCFORM=5:$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18),HBHCFORM=7:$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U),1:$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,8))
+21 DO NOW^%DTC
SET HBHCNOW=$EXTRACT(%,1,12)
+22 if HBHCSTAT]""
KILL ^HBHC(HBHCFILE,HBHCXREF,HBHCSTAT,HBHCDFN)
+23 SET $PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC1)="N"
SET ^HBHC(HBHCFILE,HBHCXREF,"N",HBHCDFN)=""
SET $PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC2)=HBHCNOW
SET $PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,HBHCPC3)=DUZ
+24 IF (HBHCFORM=3)&($PIECE(^HBHC(HBHCFILE,HBHCDFN,0),U,40)]"")
SET HBHC5XMT=$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18)
if HBHC5XMT]""
KILL ^HBHC(HBHCFILE,"AF",HBHC5XMT,HBHCDFN)
SET $PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,18)="N"
SET ^HBHC(HBHCFILE,"AF","N",HBHCDFN)=""
+25 IF HBHCFORM=5
SET HBHC3XMT=$PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17)
if HBHC3XMT]""
KILL ^HBHC(HBHCFILE,"AE",HBHC3XMT,HBHCDFN)
SET $PIECE(^HBHC(HBHCFILE,HBHCDFN,HBHCNODE),U,17)="N"
SET ^HBHC(HBHCFILE,"AE","N",HBHCDFN)=""
+26 LOCK -^HBHC(HBHCFILE,HBHCDFN,HBHCNODE)
+27 if (HBHCFORM'=4)&(HBHCFORM'=7)
DO SETNODE
EXIT ; Exit FORMMSG module
+1 KILL HBHCADDT,HBHCDPT0,HBHCDSDT,HBHCFILE,HBHCHOSP,HBHCINFO,HBHCLNTH,HBHCNAME,HBHCNDX1,HBHCNODE,HBHCNOW,HBHCPC1,HBHCPC2,HBHCPC3,HBHCREC,HBHCS136,HBHCSP4,HBHCSP8,HBHCSTAT,HBHCXREF,HBHC3XMT,HBHC5XMT
+2 QUIT
SETNODE ; Set node in ^HBHC(634.4) (Form 6 Corrections file)
+1 SET $PIECE(HBHCSP4," ",5)=""
SET $PIECE(HBHCSP8," ",9)=""
SET $PIECE(HBHCS136," ",137)=""
SET HBHCLNTH=30
+2 LOCK +^HBHC(634.4,0):$SELECT($DATA(DILOCKTM):DILOCKTM,1:3)
if '$TEST
QUIT
SET HBHCNDX1=$PIECE(^HBHC(634.4,0),U,3)+1
SET $PIECE(^HBHC(634.4,0),U,3)=HBHCNDX1
SET $PIECE(^HBHC(634.4,0),U,4)=$PIECE(^HBHC(634.4,0),U,4)+1
LOCK -^HBHC(634.4,0)
+3 SET HBHCINFO=^HBHC(HBHCFILE,HBHCDFN,0)
SET HBHCDPT0=^DPT(HBHCDPT,0)
+4 SET HBHCADDT=$SELECT($PIECE(HBHCINFO,U,18)]"":$EXTRACT($PIECE(HBHCINFO,U,18),4,5)_$EXTRACT($PIECE(HBHCINFO,U,18),6,7)_(1700+$EXTRACT($PIECE(HBHCINFO,U,18),1,3)),1:HBHCSP8)
+5 SET HBHCDSDT=$SELECT($PIECE(HBHCINFO,U,40)]"":$EXTRACT($PIECE(HBHCINFO,U,40),4,5)_$EXTRACT($PIECE(HBHCINFO,U,40),6,7)_(1700+$EXTRACT($PIECE(HBHCINFO,U,40),1,3)),1:HBHCSP8)
+6 SET HBHCNAME=$PIECE(HBHCDPT0,U)
if $LENGTH(HBHCNAME)<HBHCLNTH
SET HBHCNAME=HBHCNAME_$JUSTIFY("",HBHCLNTH-$LENGTH(HBHCNAME))
+7 ;HBH*1.0*32: Retrieve parent site
+8 NEW HBHCHOSPX
+9 DO PARENT
+10 ;If HBHCHOSPX="", admission occurred before install of
+11 ;HBH*1.0*32. In that case, use the system default.
+12 IF $GET(HBHCHOSPX)=""
Begin DoDot:1
+13 DO HOSP
+14 SET HBHCHOSPX=HBHCHOSP
End DoDot:1
+15 SET HBHCREC=6_HBHCHOSPX_$PIECE(HBHCDPT0,U,9)_HBHCADDT_HBHCNAME_HBHCDSDT_2_HBHCS136
+16 SET ^HBHC(634.4,HBHCNDX1,0)=HBHCREC
SET ^HBHC(634.4,"B",$EXTRACT(HBHCREC,1,30),HBHCNDX1)=""
+17 QUIT
BIRTHYR ; Birth year field display during Evaluation/Admission Data Entry
+1 SET HBHCDPT0=^DPT(HBHCDPT,0)
+2 WRITE !!,"BIRTH YEAR: ",$SELECT($PIECE(HBHCDPT0,U,3):1700+$EXTRACT($PIECE(HBHCDPT0,U,3),1,3),1:"0000"),$CHAR(7)
DO MASMSG
+3 QUIT
SEXRACE ; Sex & Race fields display during Evaluation/Admission Data Entry
+1 SET HBHCDPT0=^DPT(HBHCDPT,0)
SET HBHCSEX=$PIECE(HBHCDPT0,U,2)
+2 WRITE !!,"SEX: ",$SELECT(HBHCSEX="M":"Male (1)",1:"Female (2)"),$CHAR(7)
DO MASMSG
+3 ; Obsolete with Race/Ethnicity Info Jan 2003 mandate; commented out historical reference mjt
+4 ; ,HBHCRACE=$S($P(HBHCDPT0,U,6)]"":$P(^DIC(10,$P(HBHCDPT0,U,6),0),U,2),1:"")
+5 ;W !,"RACE: ",$S(HBHCRACE=4:"Black (2)",HBHCRACE=3:"American Indian/Alaskan Native (4)",HBHCRACE=6:"White (1)",(HBHCRACE=1)!(HBHCRACE=2):"Hispanic Origin (3)",HBHCRACE=5:"Asian/Pacific Islander (5)",1:"Not Determined (9)")
+6 ; Field retained until VA Form 10-0014 modified to remove field mjt
+7 WRITE !,"RACE: Obsolete Field Jan 2003",!
+8 KILL HBHCDPT0,HBHCSEX
+9 QUIT
MASMSG ; MAS message for BIRTHYR & SEX modules
+1 WRITE !?18,"*** Contact MAS if value is incorrect. ***",!
+2 QUIT
HOSP ; Obtain Hospital Number from ^DIC(4 (Institution file); set HBHCHOSP variable
+1 ; Newing Y to prevent undef in calling routines since DIQ1 call is apparently killing Y
+2 NEW Y
+3 if '$DATA(HBHCSP4)
SET $PIECE(HBHCSP4," ",5)=""
+4 KILL DA,DIC,DR,^UTILITY("DIQ1",$JOB)
+5 SET DIC=4
SET DR=99
SET DA=$PIECE(^HBHC(631.9,1,0),U,5)
DO EN^DIQ1
+6 SET HBHCHOSP=^UTILITY("DIQ1",$JOB,4,DA,DR)
+7 if $LENGTH(HBHCHOSP)'=7
SET HBHCHOSP=HBHCHOSP_$EXTRACT(HBHCSP4,1,(7-($LENGTH(HBHCHOSP))))
+8 KILL DA,DIC,DR,^UTILITY("DIQ1",$JOB)
+9 QUIT
+10 ;
PARENT ;retrieve patient's parent site
+1 ;calling routine should pass in HBHCDFN
+2 if $GET(HBHCDFN)=""
QUIT
+3 NEW HBHCPRNT
+4 ;HBHCHOSPX should be new'd by calling routine
+5 SET (HBHCHOSPX,HBHCPRNT)=""
+6 if '$DATA(HBHCSP4)
SET $PIECE(HBHCSP4," ",5)=""
+7 ;Is patient in a Medical Foster Home?
+8 NEW HBHCMFHPAT,HBHCMFHX
+9 SET HBHCMFHPAT=$PIECE($GET(^HBHC(631,HBHCDFN,3)),"^")
+10 IF HBHCMFHPAT="Y"
Begin DoDot:1
+11 SET HBHCMFHX=$PIECE($GET(^HBHC(631,HBHCDFN,3)),"^",2)
+12 ;HBHCMFHX could be null if MFH location not yet known.
+13 IF HBHCMFHX]""
Begin DoDot:2
+14 SET HBHCPRNT=$PIECE($GET(^HBHC(633.2,HBHCMFHX,13)),"^")
End DoDot:2
End DoDot:1
+15 ;HBHCMFHPAT could be null if not known yet whether patient is in a MFH.
+16 ;If a transaction is queued up before MFH status is known, a correction
+17 ;will be transmitted later.
+18 IF HBHCMFHPAT'="Y"
Begin DoDot:1
+19 SET HBHCPRNT=$PIECE($GET(^HBHC(631,HBHCDFN,5)),"^")
End DoDot:1
+20 ;If patient does not have a parent site, admission occurred before install
+21 ;of HBH*1.0*32. In that case, calling routine will use the HBHCHOSP default.
+22 if HBHCPRNT=""
QUIT
+23 ;retrieve institution file pointer
+24 SET HBHCPRNT=$PIECE(^DG(40.8,HBHCPRNT,0),"^",7)
+25 ;retrieve station number
+26 SET HBHCHOSPX=$PIECE($GET(^DIC(4,+HBHCPRNT,99)),"^")
+27 IF HBHCHOSPX]""
IF $LENGTH(HBHCHOSPX)'=7
SET HBHCHOSPX=HBHCHOSPX_$EXTRACT(HBHCSP4,1,(7-($LENGTH(HBHCHOSPX))))
+28 QUIT