VADPT ;ALB/MRL,MJK,ERC,TDM,ARF,JAM,JMM - RETURN PATIENT VARIABLE ARRAYS [DRIVER];7/17/14
;;5.3;Registration;**193,343,389,415,489,498,688,754,887,996,1061,1103,1121**;Aug 13, 1993;Build 14
;DFN = Patient IFN [if not passed entire array returned as null]
;
DEM ;Demographic Variables
S VAN=1,VAN(1)=13,VAV="VADM" D ^VADPT0 Q ;/**/
;
DEMUPD ; Updated Demographic Variables ;dg*5.3*996 add preferred name to Demographic Variables in new VADEMO array;VADEMO added to KVAR
S VAN="01",VAN(1)=13,VAV="VADEMO" D ^VADPT0 Q
;
OPD ;Other Patient Data
S VAN=2,VAN(1)=8,VAV="VAPD" D ^VADPT0 Q
;
ADD ;Current Address
S VAN=3,VAN(1)=29,VAV="VAPA" D ^VADPT0 Q
;
OAD ;Other Patient Variables
S VAN=4,VAN(1)=11,VAV="VAOA" D ^VADPT0 Q
;
INP ;Inpatient Data [pre-version 5]
N VAINDTT S VAN=5,VAN(1)=11,VAV="VAIN",VAINDTT=$G(VAINDT) N VAINDT S:VAINDTT VAINDT=$$DATIM(VAINDTT) D ^VADPT0 Q
;
IN5 ;Inpatient Data [v5.0 and above]
N VAINDTT S VAN=6,VAN(1)=19,VAV=$S('$D(VAIP("V")):"VAIP",VAIP("V")'?1A.E:"VAIP",1:VAIP("V")),VAINDTT=$G(VAIP("D")) S:$L(VAINDTT) VAIP("D")=VAINDTT S:VAINDTT VAIP("D")=$$DATIM(VAINDTT) D ^VADPT0 S:$L(VAINDTT) VAIP("D")=VAINDTT Q
;
ELIG ;Eligibility Information
S VAN=7,VAN(1)=9,VAV="VAEL" D ^VADPT0 Q
;
MB ;Monetary Benefits
S VAN=8,VAN(1)=9,VAV="VAMB" D ^VADPT0 Q
;
SVC ;Service Information
; DG*5.3*1103 - Increase VAN(1) to 15 for adding the TERA indicator
; DG*5.3*1121 - Increase VAN(1) to 17 for adding the Persian Gulf Deployment Indicator and Persian Gulf Indicator Last Change Date
; S VAN=9,VAN(1)=15,VAV="VASV" D ^VADPT0 Q
S VAN=9,VAN(1)=17,VAV="VASV" D ^VADPT0 Q
;
REG ;Registration data
S VAN=10,VAV="VARP" D ^VADPT0 Q
;
SDE ;Enrollment Information
S VAN=11,VAV="VAEN" D ^VADPT0 Q
;
SDA ;Appointment Information
S VAN=12,VAV="VASD" D ^VADPT0 Q
;
PID ;Patient Id
S VAN=13,VAV="VA" D ^VADPT0 Q
;
CAI ; COMPACT Act Indicator; DG*5.3*1061
; Store CAI value in array VACOM. (Array VACOM added to KVAR)
S VACOM("CAI")=$$CAI^DGENELA(DFN) Q
;
TESTPAT(DFN) ;Test patient ? Returns 0 (No) or 1 (Yes)
S DFN=+$G(DFN) I 'DFN Q 0
I $D(^DPT("ATEST",DFN)) Q 1
N NODE S NODE=$G(^DPT(DFN,0))
I $P(NODE,"^",21)=1 Q 1
I $E($P(NODE,"^",9),1,5)="00000" Q 1
Q 0
;
V5 S X=$S($D(^DG(43,1,"VERSION")):+^("VERSION"),1:""),VADPT("V")=$S(X<5:0,1:1) K X Q
OERR ;
1 S VATAG=1 D MULT Q
2 S VATAG=2 D MULT Q
3 S VATAG=3 D MULT Q
4 S VATAG=4 D MULT Q
5 S VATAG=5 D MULT Q
6 S VATAG=6 D MULT Q
7 S VATAG=7 D MULT Q
8 S VATAG=8 D MULT Q
9 S VATAG=9 D MULT Q
10 S VATAG=10 D MULT Q
51 S VATAG=11 D MULT Q
52 S VATAG=12 D MULT Q
53 S VATAG=13 D MULT Q
ALL S VATAG=14 D MULT Q
A5 S VATAG=15 D MULT Q
SEL Q:$O(VARRAY(0))']"" S VATAG=0,VATAG(2)=$P($T(TAG),";;",2)
F VATAG(1)=0:0 S VATAG=$O(VARRAY(VATAG)) Q:VATAG="" I VATAG(2)[("^"_VATAG_"^") S VARRAY(VATAG)=1,VAROOT=$S($D(VAROOT(VATAG)):VAROOT(VATAG),1:"") D @VATAG
G Q
;
MULT S VATAG=$P($T(TG+VATAG),";;",2)
F VATAG(1)=1:1 S VATAG(2)=$P(VATAG,"^",VATAG(1)) Q:VATAG(2)="" S VAROOT=$S($D(VAROOT(VATAG(2))):VAROOT(VATAG(2)),1:"") D @(VATAG(2))
Q S VAROOT="" K:$D(VAROOT)'=11 VAROOT K VATAG Q
;
KVA K VA
KVAR D KVAR^VADPT0 K:$D(VAIP("V")) @(VAIP("V")) K I,X,Y,VARRAY,VADM,VADEMO,VAPD,VADPT,VAOA,VASV,VAEL,VAMB,VARP,VAEN,VASD,VAIN,VAIP,VAPA,VAHOW,VAINDT,VAERR,^UTILITY("VADPT",$J),VA200,VATEST,VACOM Q
DATIM(DATIM) ;If time not specified see if movement on that date
Q:DATIM'?7N DATIM
N A,B S A=$O(^DGPM("ADFN"_DFN,DATIM)),B=+$O(^(+A,0))
I 'A Q DATIM
I $P($G(^DGPM(+B,0)),"^",2)=3 Q DATIM ;Next movement is discharge
F Q:"^4^5^7^"'[(U_$P($G(^DGPM(+B,0)),"^",2)) S A=$O(^DGPM("ADFN"_DFN,A)),B=+$O(^(+A,0)) I $E(A,1,7)'=DATIM Q
I 'A Q DATIM
I $E(A,1,7)'=DATIM Q DATIM
Q A
;
TG ;
;;DEM^INP
;;DEM^ELIG
;;ELIG^INP
;;DEM^ADD
;;ADD^INP
;;DEM^ELIG^ADD
;;ELIG^SVC
;;ELIG^SVC^MB
;;DEM^REG^SDE^SDA
;;SDE^SDA
;;DEM^IN5
;;ELIG^IN5
;;ADD^IN5
;;DEM^OPD^INP^ADD^ELIG^SVC^OAD^MB^REG^SDE^SDA
;;DEM^OPD^IN5^ADD^ELIG^SVC^OAD^MB^REG^SDE^SDA
;
TAG ;;^DEM^OPD^INP^IN5^ADD^OAD^ELIG^SVC^MB^REG^SDE^SDA^
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HVADPT 4104 printed Nov 22, 2024@18:11:10 Page 2
VADPT ;ALB/MRL,MJK,ERC,TDM,ARF,JAM,JMM - RETURN PATIENT VARIABLE ARRAYS [DRIVER];7/17/14
+1 ;;5.3;Registration;**193,343,389,415,489,498,688,754,887,996,1061,1103,1121**;Aug 13, 1993;Build 14
+2 ;DFN = Patient IFN [if not passed entire array returned as null]
+3 ;
DEM ;Demographic Variables
+1 ;/**/
SET VAN=1
SET VAN(1)=13
SET VAV="VADM"
DO ^VADPT0
QUIT
+2 ;
DEMUPD ; Updated Demographic Variables ;dg*5.3*996 add preferred name to Demographic Variables in new VADEMO array;VADEMO added to KVAR
+1 SET VAN="01"
SET VAN(1)=13
SET VAV="VADEMO"
DO ^VADPT0
QUIT
+2 ;
OPD ;Other Patient Data
+1 SET VAN=2
SET VAN(1)=8
SET VAV="VAPD"
DO ^VADPT0
QUIT
+2 ;
ADD ;Current Address
+1 SET VAN=3
SET VAN(1)=29
SET VAV="VAPA"
DO ^VADPT0
QUIT
+2 ;
OAD ;Other Patient Variables
+1 SET VAN=4
SET VAN(1)=11
SET VAV="VAOA"
DO ^VADPT0
QUIT
+2 ;
INP ;Inpatient Data [pre-version 5]
+1 NEW VAINDTT
SET VAN=5
SET VAN(1)=11
SET VAV="VAIN"
SET VAINDTT=$GET(VAINDT)
NEW VAINDT
if VAINDTT
SET VAINDT=$$DATIM(VAINDTT)
DO ^VADPT0
QUIT
+2 ;
IN5 ;Inpatient Data [v5.0 and above]
+1 NEW VAINDTT
SET VAN=6
SET VAN(1)=19
SET VAV=$SELECT('$DATA(VAIP("V")):"VAIP",VAIP("V")'?1A.E:"VAIP",1:VAIP("V"))
SET VAINDTT=$GET(VAIP("D"))
if $LENGTH(VAINDTT)
SET VAIP("D")=VAINDTT
if VAINDTT
SET VAIP("D")=$$DATIM(VAINDTT)
DO ^VADPT0
if $LENGTH(VAINDTT)
SET VAIP("D")=VAINDTT
QUIT
+2 ;
ELIG ;Eligibility Information
+1 SET VAN=7
SET VAN(1)=9
SET VAV="VAEL"
DO ^VADPT0
QUIT
+2 ;
MB ;Monetary Benefits
+1 SET VAN=8
SET VAN(1)=9
SET VAV="VAMB"
DO ^VADPT0
QUIT
+2 ;
SVC ;Service Information
+1 ; DG*5.3*1103 - Increase VAN(1) to 15 for adding the TERA indicator
+2 ; DG*5.3*1121 - Increase VAN(1) to 17 for adding the Persian Gulf Deployment Indicator and Persian Gulf Indicator Last Change Date
+3 ; S VAN=9,VAN(1)=15,VAV="VASV" D ^VADPT0 Q
+4 SET VAN=9
SET VAN(1)=17
SET VAV="VASV"
DO ^VADPT0
QUIT
+5 ;
REG ;Registration data
+1 SET VAN=10
SET VAV="VARP"
DO ^VADPT0
QUIT
+2 ;
SDE ;Enrollment Information
+1 SET VAN=11
SET VAV="VAEN"
DO ^VADPT0
QUIT
+2 ;
SDA ;Appointment Information
+1 SET VAN=12
SET VAV="VASD"
DO ^VADPT0
QUIT
+2 ;
PID ;Patient Id
+1 SET VAN=13
SET VAV="VA"
DO ^VADPT0
QUIT
+2 ;
CAI ; COMPACT Act Indicator; DG*5.3*1061
+1 ; Store CAI value in array VACOM. (Array VACOM added to KVAR)
+2 SET VACOM("CAI")=$$CAI^DGENELA(DFN)
QUIT
+3 ;
TESTPAT(DFN) ;Test patient ? Returns 0 (No) or 1 (Yes)
+1 SET DFN=+$GET(DFN)
IF 'DFN
QUIT 0
+2 IF $DATA(^DPT("ATEST",DFN))
QUIT 1
+3 NEW NODE
SET NODE=$GET(^DPT(DFN,0))
+4 IF $PIECE(NODE,"^",21)=1
QUIT 1
+5 IF $EXTRACT($PIECE(NODE,"^",9),1,5)="00000"
QUIT 1
+6 QUIT 0
+7 ;
V5 SET X=$SELECT($DATA(^DG(43,1,"VERSION")):+^("VERSION"),1:"")
SET VADPT("V")=$SELECT(X<5:0,1:1)
KILL X
QUIT
OERR ;
1 SET VATAG=1
DO MULT
QUIT
2 SET VATAG=2
DO MULT
QUIT
3 SET VATAG=3
DO MULT
QUIT
4 SET VATAG=4
DO MULT
QUIT
5 SET VATAG=5
DO MULT
QUIT
6 SET VATAG=6
DO MULT
QUIT
7 SET VATAG=7
DO MULT
QUIT
8 SET VATAG=8
DO MULT
QUIT
9 SET VATAG=9
DO MULT
QUIT
10 SET VATAG=10
DO MULT
QUIT
51 SET VATAG=11
DO MULT
QUIT
52 SET VATAG=12
DO MULT
QUIT
53 SET VATAG=13
DO MULT
QUIT
ALL SET VATAG=14
DO MULT
QUIT
A5 SET VATAG=15
DO MULT
QUIT
SEL if $ORDER(VARRAY(0))']""
QUIT
SET VATAG=0
SET VATAG(2)=$PIECE($TEXT(TAG),";;",2)
+1 FOR VATAG(1)=0:0
SET VATAG=$ORDER(VARRAY(VATAG))
if VATAG=""
QUIT
IF VATAG(2)[("^"_VATAG_"^")
SET VARRAY(VATAG)=1
SET VAROOT=$SELECT($DATA(VAROOT(VATAG)):VAROOT(VATAG),1:"")
DO @VATAG
+2 GOTO Q
+3 ;
MULT SET VATAG=$PIECE($TEXT(TG+VATAG),";;",2)
+1 FOR VATAG(1)=1:1
SET VATAG(2)=$PIECE(VATAG,"^",VATAG(1))
if VATAG(2)=""
QUIT
SET VAROOT=$SELECT($DATA(VAROOT(VATAG(2))):VAROOT(VATAG(2)),1:"")
DO @(VATAG(2))
Q SET VAROOT=""
if $DATA(VAROOT)'=11
KILL VAROOT
KILL VATAG
QUIT
+1 ;
KVA KILL VA
KVAR DO KVAR^VADPT0
if $DATA(VAIP("V"))
KILL @(VAIP("V"))
KILL I,X,Y,VARRAY,VADM,VADEMO,VAPD,VADPT,VAOA,VASV,VAEL,VAMB,VARP,VAEN,VASD,VAIN,VAIP,VAPA,VAHOW,VAINDT,VAERR,^UTILITY("VADPT",$JOB),VA200,VATEST,VACOM
QUIT
DATIM(DATIM) ;If time not specified see if movement on that date
+1 if DATIM'?7N
QUIT DATIM
+2 NEW A,B
SET A=$ORDER(^DGPM("ADFN"_DFN,DATIM))
SET B=+$ORDER(^(+A,0))
+3 IF 'A
QUIT DATIM
+4 ;Next movement is discharge
IF $PIECE($GET(^DGPM(+B,0)),"^",2)=3
QUIT DATIM
+5 FOR
if "^4^5^7^"'[(U_$PIECE($GET(^DGPM(+B,0)),"^",2))
QUIT
SET A=$ORDER(^DGPM("ADFN"_DFN,A))
SET B=+$ORDER(^(+A,0))
IF $EXTRACT(A,1,7)'=DATIM
QUIT
+6 IF 'A
QUIT DATIM
+7 IF $EXTRACT(A,1,7)'=DATIM
QUIT DATIM
+8 QUIT A
+9 ;
TG ;
+1 ;;DEM^INP
+2 ;;DEM^ELIG
+3 ;;ELIG^INP
+4 ;;DEM^ADD
+5 ;;ADD^INP
+6 ;;DEM^ELIG^ADD
+7 ;;ELIG^SVC
+8 ;;ELIG^SVC^MB
+9 ;;DEM^REG^SDE^SDA
+10 ;;SDE^SDA
+11 ;;DEM^IN5
+12 ;;ELIG^IN5
+13 ;;ADD^IN5
+14 ;;DEM^OPD^INP^ADD^ELIG^SVC^OAD^MB^REG^SDE^SDA
+15 ;;DEM^OPD^IN5^ADD^ELIG^SVC^OAD^MB^REG^SDE^SDA
+16 ;
TAG ;;^DEM^OPD^INP^IN5^ADD^OAD^ELIG^SVC^MB^REG^SDE^SDA^