VADPT ;ALB/MRL/MJK - RETURN PATIENT VARIABLE ARRAYS [DRIVER];07 DEC 1988 ;;5.3;Registration;**193,343,389,415,489,498**;Aug 13, 1993 ;DFN = Patient IFN [if not passed entire array returned as null] ; DEM ;Demographic Variables S VAN=1,VAN(1)=12,VAV="VADM" D ^VADPT0 Q ; OPD ;Other Patient Data S VAN=2,VAN(1)=7,VAV="VAPD" D ^VADPT0 Q ; ADD ;Current Address S VAN=3,VAN(1)=22,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 S VAN=9,VAN(1)=9,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 ; 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,VAPD,VADPT,VAOA,VASV,VAEL,VAMB,VARP,VAEN,VASD,VAIN,VAIP,VAPA,VAHOW,VAINDT,VAERR,^UTILITY("VADPT",$J),VA200,VATEST 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^