1 | IBCSC4F ;ALB/ARH - GET PTF DIAGNOSIS ; 10-OCT-1998
|
---|
2 | ;;2.0;INTEGRATED BILLING;**106**;21-MAR-94
|
---|
3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | PTFDXDT(IBPTF,IBDT1,IBDT2,TF) ; collect PTF Transfer (501) and Discharge (701) movements and diagnosis within a date range
|
---|
6 | ; if end date is before Discharge date delete Discharge Diagnosis
|
---|
7 | ; if bill is an interim first or interim continuous then the last date on the bill is included in the bill
|
---|
8 | N IBSTAY,IBADM,IBDSCH,IBDT,IBLAST,IBMDT K ^TMP($J,"IBDX","D"),^TMP($J,"IBDX","M") Q:'$G(IBPTF)
|
---|
9 | S IBDT1=+$G(IBDT1)\1 Q:IBDT1'?7N S IBDT2=+$G(IBDT2)\1 Q:IBDT2'?7N
|
---|
10 | ;
|
---|
11 | D PTFDX(IBPTF)
|
---|
12 | ;
|
---|
13 | S IBSTAY=$G(^TMP($J,"IBDX","M")),IBADM=+$P($P(IBSTAY,U,2),".",1),IBDSCH=+$P($P(IBSTAY,U,3),".",1)
|
---|
14 | ;
|
---|
15 | I IBADM=IBDSCH Q ; 1 day stay, accept all
|
---|
16 | I IBDT1=IBADM,IBDT2=IBDSCH Q ; bill for entire length of stay, accept all
|
---|
17 | ;
|
---|
18 | I IBDT2<IBDSCH K ^TMP($J,"IBDX","D") ; discharge date not on bill, exclude 701 Dxs
|
---|
19 | I 'IBDSCH,IBDT2<DT K ^TMP($J,"IBDX","D") ; not discharged, current end date (today) not on bill, exclude 701 Dxs
|
---|
20 | ;
|
---|
21 | ; determine which of the movements should be included based on dates and timeframe
|
---|
22 | S TF=$G(TF) I (TF=2)!(TF=3) S IBDT2=$$FMADD^XLFDT(IBDT2,1) ; if first or continuous bill include end date
|
---|
23 | ;
|
---|
24 | S (IBLAST,IBDT)="" F S IBDT=$O(^TMP($J,"IBDX","M",IBDT)) Q:'IBDT D S IBLAST=IBDT
|
---|
25 | . S IBMDT=$P(IBDT,".",1)
|
---|
26 | . I IBMDT'>IBDT1 K ^TMP($J,"IBDX","M",IBDT)
|
---|
27 | . I IBLAST>IBDT2 K ^TMP($J,"IBDX","M",IBDT)
|
---|
28 | Q
|
---|
29 | ;
|
---|
30 | PTFDX(IBPTF) ; collect all PTF Transfer (501) and Discharge (701) movements and diagnosis and try to assign SC
|
---|
31 | ; PTF movements are assigned SC or NSC but diagnosis are not
|
---|
32 | ; this routine 'interprets' this PTF data and 'assigns' SC/NSC to individual Diagnosis
|
---|
33 | ; Movement (501) Diagnosis: all Dx on SC movements are assigned SC
|
---|
34 | ; a Dx on an NSC movement that is also the first Dx on an SC move is assigned SC
|
---|
35 | ; Discharge (701) Diagnosis: if admit is for SC care all discharge Dx are assigned SC
|
---|
36 | ; if the Dx is also the first Dx on an SC movement then is assigned SC
|
---|
37 | ; a Dx on an SC movement only is assigned SC
|
---|
38 | ;
|
---|
39 | ; Output: TMP($J,"IBDX","D")=PTF # ^ ADMIT DATE ^ DISCHARGE DATE
|
---|
40 | ; TMP($J,"IBDX","D", DISCHARGE DATE) = DISCHARGE DATE ^ SPECIALTY ^ SC (1/0) ^ DRG ^ PROVIDER
|
---|
41 | ; TMP($J,"IBDX","D", DISCHARGE DATE, x) = DIAGNOSIS ^ SC? (1/0)
|
---|
42 | ;
|
---|
43 | ; TMP($J,"IBDX","M")=PTF # ^ ADMIT DATE ^ DISCHARGE DATE
|
---|
44 | ; TMP($J,"IBDX","M", MOVEMENT DATE) = MOVEMENT DATE ^ SPECIALTY ^ SC (1/0) ^ DRG ^ PROVIDER
|
---|
45 | ; TMP($J,"IBDX","M", MOVEMENT DATE, x) = DIAGNOSIS ^ SC? (1/0)
|
---|
46 | ; if patient not discharged then NOW is used as date subscript and first piece will be null, SC?=interpreted SC
|
---|
47 | ;
|
---|
48 | N IBSTAY,IBMI,IBM0,IBDT,IBMDT,IBMBS,IBMP,IBMDRG,IBMPRV,IBMSC,IBMDX,IBD0,IBDDT,IBDBS,IBDDRG,IBDPRV,IBDSC,IBDDX
|
---|
49 | N IBCNT,IBI,IBTMP,DFN,DGVAR,DRG,DRGCAL,ICDCAL,PTF K ^TMP($J,"IBDX","M"),^TMP($J,"IBDX","D") Q:'$G(IBPTF)
|
---|
50 | ;
|
---|
51 | S IBSTAY=IBPTF_U_$P($G(^DGPT(IBPTF,0)),U,2)_U_$P($G(^DGPT(IBPTF,70)),U,1) Q:'$P(IBSTAY,U,2)
|
---|
52 | ;
|
---|
53 | ; collect PTF Movement Diagnosis (501)
|
---|
54 | S ^TMP($J,"IBDX","M")=IBSTAY
|
---|
55 | S IBMI=0 F S IBMI=$O(^DGPT(IBPTF,"M",IBMI)) Q:'IBMI D
|
---|
56 | . S IBM0=$G(^DGPT(IBPTF,"M",IBMI,0)) Q:'IBM0
|
---|
57 | . S (IBDT,IBMDT)=$P(IBM0,U,10) I 'IBDT S IBDT=$$NOW^XLFDT
|
---|
58 | . S IBMBS=$P(IBM0,U,2),IBMSC=$P(IBM0,U,18),IBMSC=$S(IBMSC=1:1,1:"")
|
---|
59 | . S IBMP=$G(^DGPT(IBPTF,"M",IBMI,"P")),IBMPRV=$P(IBMP,U,5),IBMDRG=$$MVDRG^IBCRBG(IBPTF,IBMI)
|
---|
60 | . ;
|
---|
61 | . S ^TMP($J,"IBDX","M",IBDT)=IBMDT_U_IBMBS_U_IBMSC_U_IBMDRG_U_IBMPRV
|
---|
62 | . ;
|
---|
63 | . S IBCNT=0 F IBI=5:1:9 S IBMDX=+$P(IBM0,U,IBI) I +IBMDX S IBCNT=IBCNT+1 D
|
---|
64 | .. S ^TMP($J,"IBDX","M",IBDT,IBCNT)=IBMDX,IBTMP("DXSC",IBMDX,+IBMSC,IBCNT)=""
|
---|
65 | ;
|
---|
66 | ; collect PTF Discharge Diagnosis (701)
|
---|
67 | S ^TMP($J,"IBDX","D")=IBSTAY
|
---|
68 | S IBD0=$G(^DGPT(IBPTF,70)),IBDDRG=$$GET1^DIQ(45,IBPTF,9,""),IBDPRV=$P(IBD0,U,15)
|
---|
69 | S (IBDT,IBDDT)=$P(IBD0,U,1) I 'IBDT S IBDT=$$NOW^XLFDT
|
---|
70 | S IBDBS=$P(IBD0,U,2),IBDSC=$P(IBD0,U,25),IBDSC=$S(IBDSC=1:1,1:"")
|
---|
71 | ;
|
---|
72 | S ^TMP($J,"IBDX","D",IBDT)=IBDDT_U_IBDBS_U_IBDSC_U_IBDDRG_U_IBDPRV
|
---|
73 | ;
|
---|
74 | S IBCNT=0 F IBI=10,16:1:24 S IBDDX=+$P(IBD0,U,IBI) I +IBDDX S IBCNT=IBCNT+1 D
|
---|
75 | . S ^TMP($J,"IBDX","D",IBDT,IBCNT)=IBDDX
|
---|
76 | ;
|
---|
77 | ; Try to assign SC to PTF Diagnosis
|
---|
78 | ;
|
---|
79 | ; assign SC to Movement Diagnosis (501): if movement is SC or first Dx on an SC movement
|
---|
80 | S IBMDT=0 F S IBMDT=$O(^TMP($J,"IBDX","M",IBMDT)) Q:'IBMDT D
|
---|
81 | . S IBI="" F S IBI=$O(^TMP($J,"IBDX","M",IBMDT,IBI)) Q:'IBI D
|
---|
82 | .. S IBMDX=+$G(^TMP($J,"IBDX","M",IBMDT,IBI)) Q:'IBMDX
|
---|
83 | .. ;
|
---|
84 | .. S IBMSC=+$P($G(^TMP($J,"IBDX","M",IBMDT)),U,3) ; sc move
|
---|
85 | .. I 'IBMSC,$D(IBTMP("DXSC",IBMDX,1,1)) S IBMSC=1 ; first dx on sc move
|
---|
86 | .. ;
|
---|
87 | .. I +IBMSC S $P(^TMP($J,"IBDX","M",IBMDT,IBI),U,2)=1
|
---|
88 | ;
|
---|
89 | ; assign SC to Discharge Diagnosis (701): if stay is SC or first Dx on an SC movement or only on SC movement
|
---|
90 | S IBDDT=0 F S IBDDT=$O(^TMP($J,"IBDX","D",IBDDT)) Q:'IBDDT D
|
---|
91 | . S IBI="" F S IBI=$O(^TMP($J,"IBDX","D",IBDDT,IBI)) Q:'IBI D
|
---|
92 | .. S IBDDX=+$G(^TMP($J,"IBDX","D",IBDDT,IBI)) Q:'IBDDX
|
---|
93 | .. ;
|
---|
94 | .. S IBDSC=+$P($G(^TMP($J,"IBDX","D",IBDDT)),U,3) ; sc stay
|
---|
95 | .. I 'IBDSC,$D(IBTMP("DXSC",IBDDX,1,1)) S IBDSC=1 ; first dx on sc move
|
---|
96 | .. I 'IBDSC,+$O(IBTMP("DXSC",IBDDX,"")) S IBDSC=1 ; on sc move only
|
---|
97 | .. ;
|
---|
98 | .. I +IBDSC S $P(^TMP($J,"IBDX","D",IBDDT,IBI),U,2)=1
|
---|
99 | ;
|
---|
100 | Q
|
---|