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

VAFHLPI2.m

Go to the documentation of this file.
  1. VAFHLPI2 ;ALB/BWF - EXTENSION OF PID SEGMENT BUILDER ;23-APR-2003
  1. ;;5.3;Registration;**508,1015**;Aug 13, 1993;Build 21
  1. ;
  1. Q
  1. ;
  1. SEQ11(TYPE,HLQ) ;Patient Address (seq #11)
  1. ;
  1. ;Input : TYPE - Qualifiers denoting which type of address to return
  1. ; P = Include permanent address
  1. ; C = Include confidential address
  1. ; "" = Only return permanent address (default)
  1. ; HLQ - HL7 null designation
  1. ;Assumed: VAPA() - Output of call to ADD^VADPT
  1. ;Output : None - sets nodes in array VAFY
  1. ; VAFY(11,1,1..X) = Primary address
  1. ; VAFY(11,2..X,1..X) = Confidential Address
  1. ;Notes : Validity and existance of input is assumed
  1. ; : Assumes no individual component is greater than 245
  1. ; characters long
  1. ; : If TYPE = "", line 3 of the permanent address will be added
  1. ; to the end of line 2 (instead of being returned separately)
  1. ;
  1. ;Declare variables
  1. N NODE
  1. K VAFY(11)
  1. I '$D(HLQ) S HLQ=$C(34,34)
  1. S TYPE=$G(TYPE)
  1. I (TYPE'["P"),(TYPE'["C") S TYPE=""
  1. S NODE=1
  1. I TYPE="" D PERMADD
  1. I (TYPE["P") D PERMADD
  1. I (TYPE["C") D CONFADD
  1. Q
  1. ;
  1. PERMADD ; Put permanent address into output array
  1. N X
  1. S VAFY(11,NODE,1)=$S(VAPA(1)'="":VAPA(1),1:HLQ)
  1. S VAFY(11,NODE,2)=$S(VAPA(2)'="":VAPA(2),1:HLQ)
  1. I TYPE'["P" S X=VAPA(2)_" "_VAPA(3),VAFY(11,NODE,2)=$S(X'=" ":X,1:HLQ)
  1. S VAFY(11,NODE,3)=$S(VAPA(4)'="":VAPA(4),1:HLQ)
  1. S X=$P($G(^DIC(5,+VAPA(5),0)),"^",2)
  1. S VAFY(11,NODE,4)=$S(X'="":X,1:HLQ)
  1. S VAFY(11,NODE,5)=$S($P(VAPA(6),U,1)'="":$P(VAPA(6),U,1),1:HLQ)
  1. I TYPE["P" D
  1. .S VAFY(11,NODE,6)=""
  1. .S VAFY(11,NODE,7)="P"
  1. .S VAFY(11,NODE,8)=$S(VAPA(3)'="":VAPA(3),1:HLQ)
  1. .S X=$P($G(^DIC(5,+VAPA(5),1,+VAPA(7),0)),"^",3)
  1. .S VAFY(11,NODE,9)=$S(X'="":X,1:HLQ)
  1. S NODE=NODE+1
  1. Q
  1. CONFADD ;Put confidential address into output array
  1. N LOOP,ADDTYPE,CSTATE,CCOUNTY,CSTDATE,CENDATE
  1. S CSTATE=$P($G(^DIC(5,+VAPA(17),0)),"^",2)
  1. S CCOUNTY=$P($G(^DIC(5,+VAPA(17),1,+VAPA(19),0)),"^",3)
  1. S CSTDATE=$$HLDATE^HLFNC($P(VAPA(20),"^",1))
  1. S CENDATE=$$HLDATE^HLFNC($P(VAPA(21),"^",1))
  1. F ADDTYPE=1:1:5 D
  1. .I +VAPA(12) I $P($G(VAPA(22,ADDTYPE)),"^",3)="Y" D CONFACT Q
  1. .D CONFIN
  1. Q
  1. CONFACT ;Active confidential address type
  1. S VAFY(11,NODE,1)=$S(VAPA(13)'="":VAPA(13),1:HLQ)
  1. S VAFY(11,NODE,2)=$S(VAPA(14)'="":VAPA(14),1:HLQ)
  1. S VAFY(11,NODE,3)=$S(VAPA(16)'="":VAPA(16),1:HLQ)
  1. S VAFY(11,NODE,4)=$S(CSTATE'="":CSTATE,1:HLQ)
  1. S X=$P(VAPA(18),"^",1),VAFY(11,NODE,5)=$S(X'="":X,1:HLQ)
  1. S VAFY(11,NODE,6)=""
  1. S VAFY(11,NODE,7)=$S(ADDTYPE=1:"VACAE",ADDTYPE=2:"VACAA",ADDTYPE=3:"VACAC",ADDTYPE=4:"VACAM",ADDTYPE=5:"VACAO",1:HLQ)
  1. S VAFY(11,NODE,8)=$S(VAPA(15)'="":VAPA(15),1:HLQ)
  1. S VAFY(11,NODE,9)=$S(CCOUNTY'="":CCOUNTY,1:HLQ)
  1. S VAFY(11,NODE,10)=""
  1. S VAFY(11,NODE,11)=""
  1. S VAFY(11,NODE,12,1)=$S(CSTDATE'="":CSTDATE,1:HLQ)
  1. S VAFY(11,NODE,12,2)=$S(CENDATE'="":CENDATE,1:HLQ)
  1. S NODE=NODE+1
  1. Q
  1. CONFIN ;Inactive confidential address type
  1. N X
  1. F X=1,2,3,4,5,8,9 S VAFY(11,NODE,X)=HLQ
  1. F X=6,10,11 S VAFY(11,NODE,X)=""
  1. S VAFY(11,NODE,7)=$S(ADDTYPE=1:"VACAE",ADDTYPE=2:"VACAA",ADDTYPE=3:"VACAC",ADDTYPE=4:"VACAM",ADDTYPE=5:"VACAO",1:HLQ)
  1. S VAFY(11,NODE,12,1)=HLQ
  1. S VAFY(11,NODE,12,2)=HLQ
  1. S NODE=NODE+1
  1. Q