1 | VAFMON ;ALB/CAW/GN - Returns income/dependents ; 2/19/03 3:35pm
|
---|
2 | ;;5.3;Registration;**45,67,499**;Aug 13, 1993
|
---|
3 | ;
|
---|
4 | INCOME(DFN,VADT,VASOURCE) ;
|
---|
5 | ; Returns Income (veterans+spouse+dependents)
|
---|
6 | ; First from the means test
|
---|
7 | ; (Income+Net Worth-Deductible Expenses)
|
---|
8 | ; If no means test then co-pay test
|
---|
9 | ; (Income-Deductible Expenses)
|
---|
10 | ; If no co-pay test then income screening
|
---|
11 | ; (Income)
|
---|
12 | ; If none of the above then total VA check amount
|
---|
13 | ;
|
---|
14 | ; INPUT: DFN = Patient IEN
|
---|
15 | ; VADT = Date income calculated for
|
---|
16 | ; VASOURCE = [optional] income type requested
|
---|
17 | ; 1 = returns income (veteran,spouse,children)
|
---|
18 | ; minus deductibe expenses - this excludes net worth
|
---|
19 | ; OUTPUT: VAINCM = Income^source flag
|
---|
20 | ; (2nd piece is only used when VASOURCE is used and is equal to 1)
|
---|
21 | ;
|
---|
22 | N I,VAINCM,VAMT,DGREL,DGINR,DGINC,DGDEP,VAX,X
|
---|
23 | I '$D(VADT) S VAINCM="" G INCQ
|
---|
24 | S VAINCM="",VADT=$P(VADT,".")
|
---|
25 | S VAMT=$$LST^DGMTCOU1(DFN,VADT,3)
|
---|
26 | I VAMT,$P(VAMT,U,4)'="N",$P(VAMT,U,4)'="L" S X=$G(^DGMT(408.31,+VAMT,0)) S:$L($P(X,U,4))!$L($P(X,U,15)) VAINCM=$P(X,U,4)-$P(X,U,15) D
|
---|
27 | .I $G(VASOURCE)'=1,$L($P(X,U,5)) S VAINCM=VAINCM+$P(X,U,5) Q ; includes net worth
|
---|
28 | .I VAINCM]"" S VAINCM=VAINCM_$S($P(VAMT,U,5)=1:"^M",1:"^C") ;bt source flag
|
---|
29 | I VAINCM']"" D
|
---|
30 | .N VADX S VADX=$S($G(VASOURCE)=1:"C",1:"D")
|
---|
31 | .; DG*5.3*499 pass ien of Means/Co-pay test via 5th parameter
|
---|
32 | .D ALL^DGMTU21(DFN,"VS"_VADX,VADT,"I",+VAMT)
|
---|
33 | .S VAX=$G(^DGMT(408.21,+$G(DGINC("V")),0)) I VAX]"" F I=8:1:17 S:$L($P(VAX,"^",I)) VAINCM=VAINCM+$P(VAX,"^",I)
|
---|
34 | .S VAX=$G(^DGMT(408.21,+$G(DGINC("S")),0)) I VAX]"" F I=8:1:17 S:$L($P(VAX,"^",I)) VAINCM=VAINCM+$P(VAX,"^",I)
|
---|
35 | .S VACNT=0 F S VACNT=$O(DGINC(VADX,VACNT)) Q:'VACNT S VAX=$G(^DGMT(408.21,+$G(DGINC(VADX,VACNT)),0)) I VAX]"" F I=8:1:17 S:$L($P(VAX,"^",I)) VAINCM=VAINCM+$P(VAX,"^",I)
|
---|
36 | .I $G(VASOURCE)=1,VAINCM]"" S VAINCM=VAINCM_"^I"
|
---|
37 | I VAINCM']"" S VAINCM=$P($G(^DPT(DFN,.362)),U,20) I $G(VASOURCE)=1,VAINCM]"" S VAINCM=VAINCM_"^V"
|
---|
38 | ;
|
---|
39 | INCQ Q VAINCM
|
---|
40 | ;
|
---|
41 | DEP(DFN,VADT) ;Total dependents for a patient
|
---|
42 | ;Input: DFN = Internal Entry Number of Patient file
|
---|
43 | ; VADT = Date (Optional - default today)
|
---|
44 | ;Output Number of dependents
|
---|
45 | N VAMT,VAMTDEP,VAVIR0,VAVIRI,DGDEP,DGINR,DGREL,VADEP
|
---|
46 | I 'VADT S VADT=DT
|
---|
47 | S VADEP=""
|
---|
48 | S VAMT=$$LST^DGMTCOU1(DFN,VADT,3)
|
---|
49 | I VAMT,$P(VAMT,U,4)'="N",$P(VAMT,U,4)'="L",$D(^DGMT(408.31,+VAMT,0)) S VADEP=$P(^(0),U,18)
|
---|
50 | I VADEP']"" D I VADEP]"" G DEPQ
|
---|
51 | .D ALL^DGMTU21(DFN,"DSV",VADT) I '$D(DGREL) Q
|
---|
52 | .S VAVIRI=+$G(DGINR("V")),VAVIR0=$G(^DGMT(408.22,VAVIRI,0)),VADEP=$P(VAVIR0,U,13)
|
---|
53 | .I 'VADEP&($P(VAVIR0,U,8)) S:VADEP=0 VAMTDEP="" Q
|
---|
54 | .; Questions: piece 5=married last calender year
|
---|
55 | .; piece 6=lived with patient
|
---|
56 | .; piece 7=amount contributed to spouse
|
---|
57 | .;
|
---|
58 | .; If no spouse, and questions not answered, set dep=null
|
---|
59 | .;
|
---|
60 | .I '$D(DGREL("S"))&($P(VAVIR0,U,5,7)']"") S VADEP="" Q
|
---|
61 | .;
|
---|
62 | .; If no spouse, but questions answered, set dep=$S
|
---|
63 | .;
|
---|
64 | .I '$D(DGREL("S")),$P(VAVIR0,U,5,7)]"" S VADEP=VADEP+$S('$P(VAVIR0,U,5):0,$P(VAVIR0,U,6)'=0:1,$P(VAVIR0,U,7)>49:1,1:0) Q
|
---|
65 | .;
|
---|
66 | .; If spouse and no questions answered, set dep+1
|
---|
67 | .;
|
---|
68 | .I $D(DGREL("S")),$P(VAVIR0,U,5,7)']"" S VADEP=VADEP+1 Q
|
---|
69 | .;
|
---|
70 | .; If spouse and questions answered, set dep=$S
|
---|
71 | .;
|
---|
72 | .I $D(DGREL("S")) S VADEP=VADEP+$S($P(VAVIR0,U,6):1,$P(VAVIR0,U,7)>49:1,$P(VAVIR0,U,5)&($P(VAVIR0,U,6)=""):1,1:0)
|
---|
73 | ;
|
---|
74 | DEPQ Q VADEP
|
---|