1 | IBBAADTI ;OAK/ELZ - PFSS INBOUND FILER ;15-MAR-2005
|
---|
2 | ;;2.0;INTEGRATED BILLING;**286**;21-MAR-94
|
---|
3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | A04 ;receiver for returned A04 messages to create account
|
---|
6 | N IBBHDR,IBBMSG,IBBDFN,IBBARFN,IBBEXVN,HLERR
|
---|
7 | Q:'$$STARTMSG^HLPRS(.IBBMSG,HLMTIENS,.IBBHDR)
|
---|
8 | I $G(IBBHDR("EVENT"))'="A04" Q
|
---|
9 | S IBBDFN=+$$PID()
|
---|
10 | I 'IBBDFN S HLERR="Patient data could not be matched to database." D NAK Q
|
---|
11 | S IBBEXVN=+$$EXVN()
|
---|
12 | I 'IBBEXVN S HLERR="External billing system account # is not defined." D NAK Q
|
---|
13 | S IBBARFN=$$SET(IBBDFN,HLMTIENS)
|
---|
14 | I 'IBBARFN S HLERR="External billing system account # could not be filed." D NAK Q
|
---|
15 | I IBBARFN D ACK
|
---|
16 | Q
|
---|
17 | ;
|
---|
18 | A05 ;receiver for returned A05 messages to create account
|
---|
19 | N IBBHDR,IBBMSG,IBBDFN,IBBARFN,IBBEXVN,HLERR
|
---|
20 | Q:'$$STARTMSG^HLPRS(.IBBMSG,HLMTIENS,.IBBHDR)
|
---|
21 | I $G(IBBHDR("EVENT"))'="A05" Q
|
---|
22 | S IBBDFN=$$PID()
|
---|
23 | I 'IBBDFN S HLERR="Patient data could not be matched to database." D NAK Q
|
---|
24 | S IBBEXVN=+$$EXVN()
|
---|
25 | I 'IBBEXVN S HLERR="External billing system account # is not defined." D NAK Q
|
---|
26 | S IBBARFN=$$SET(IBBDFN,HLMTIENS)
|
---|
27 | I 'IBBARFN S HLERR="External billing system account # could not be filed." D NAK Q
|
---|
28 | I IBBARFN D ACK
|
---|
29 | Q
|
---|
30 | ;
|
---|
31 | SET(IBBDFN,HLMTIENS) ;set returned external account number in file #375
|
---|
32 | N DIC,IEN1,IEN2,IENS,REC,PHYS,PHYSX,ALTNUM,ALTNUMX,PROC,PROCX,OUT,OK,X,XX
|
---|
33 | N IBBEVENT,IBBEXVN,IBBWHEN,IBBWHERE,IBBARFN,IBBIEN,IBBMSG,IBBHDR,IBBSEG,IBBARRAY
|
---|
34 | S IBBARFN=""
|
---|
35 | Q:'$G(HLMTIENS) IBBARFN
|
---|
36 | Q:'$G(IBBDFN) IBBARFN
|
---|
37 | Q:'$$STARTMSG^HLPRS(.IBBMSG,HLMTIENS,.IBBHDR) IBBARFN
|
---|
38 | ;parse critical data elements from HL7 msg
|
---|
39 | S OUT=0
|
---|
40 | F Q:OUT Q:'$$NEXTSEG^HLPRS(.IBBMSG,.IBBSEG) D
|
---|
41 | .I IBBSEG("SEGMENT TYPE")="EVN" D Q
|
---|
42 | ..S (XX,IBBEVENT)=$$GET^HLOPRS(.IBBSEG,1,1,)
|
---|
43 | ..I ";A01;A04;A05;"'[(";"_XX_";") S OUT=1
|
---|
44 | .I IBBSEG("SEGMENT TYPE")="PV1" D Q
|
---|
45 | ..S IBBWHERE=$$GET^HLOPRS(.IBBSEG,3,1)
|
---|
46 | ..S PHYS=$E($$GET^HLOPRS(.IBBSEG,7,1),4,99)
|
---|
47 | ..S IBBARFN=$$GET^HLOPRS(.IBBSEG,5,1)
|
---|
48 | ..S IBBEXVN=$$GET^HLOPRS(.IBBSEG,19,1)
|
---|
49 | ..S ALTNUM=$$GET^HLOPRS(.IBBSEG,50,1)
|
---|
50 | ..S XX=$$GET^HLOPRS(.IBBSEG,44,1),IBBWHEN=$$FMDATE^HLFNC(XX)
|
---|
51 | .I IBBSEG("SEGMENT TYPE")="PR1" D Q
|
---|
52 | ..S PROC=$$GET^HLOPRS(.IBBSEG,3,1)
|
---|
53 | ;exit if not event type of interest
|
---|
54 | Q:OUT IBBARFN
|
---|
55 | ;exit if external visit already known for A01 event
|
---|
56 | I IBBEVENT="A01",IBBWHERE'="FEE BASIS" S X=$$INTNUM(IBBEXVN) I X S IBBARFN=X Q IBBARFN
|
---|
57 | ;resolve location
|
---|
58 | I IBBWHERE'="FEE BASIS" D
|
---|
59 | .K Y S DIC=44,DIC(0)="MXZ",X=IBBWHERE
|
---|
60 | .D ^DIC
|
---|
61 | .I $P($G(Y),U,2)=IBBWHERE S IBBWHERE=+Y
|
---|
62 | I IBBWHERE="FEE BASIS" S IBBWHEN=$P(IBBWHEN,".",1)
|
---|
63 | ;verify account record if IBBARFN is not null
|
---|
64 | I IBBARFN D I 'OK S IBBARFN=""
|
---|
65 | .S OK=1,IBBIEN=0
|
---|
66 | .S IENS=IBBARFN_"," D GETS^DIQ(375,IENS,".01;.03;1.03;1.44;16.01","I","IBBARRAY")
|
---|
67 | .I IBBARFN'=$G(IBBARRAY(375,IENS,.01,"I")) S OK=0 Q
|
---|
68 | .I IBBDFN'=$G(IBBARRAY(375,IENS,.03,"I")) S OK=0 Q
|
---|
69 | .I IBBWHEN'=$G(IBBARRAY(375,IENS,1.44,"I")) S OK=0 Q
|
---|
70 | .I IBBEVENT="A01",IBBWHERE'=$G(IBBARRAY(375,IENS,16.01,"I")) S OK=0 Q
|
---|
71 | .I ((IBBEVENT="A04")!(IBBEVENT="A05"))&(IBBWHERE'=$G(IBBARRAY(375,IENS,1.03,"I"))) S OK=0 Q
|
---|
72 | .S IBBIEN=IBBARFN
|
---|
73 | ;find account record if IBBARFN is null; should be used (normally) only for inpatient A01
|
---|
74 | I 'IBBARFN D
|
---|
75 | .S IBBIEN=0
|
---|
76 | .I IBBWHERE=+IBBWHERE D
|
---|
77 | ..S IEN1=+$O(^IBBAA(375,"AC",IBBDFN,IBBWHEN,IBBWHERE,0))
|
---|
78 | ..S IEN2=+$O(^IBBAA(375,"AC",IBBDFN,IBBWHEN,IBBWHERE,IEN1))
|
---|
79 | .I IBBWHERE'=+IBBWHERE D
|
---|
80 | ..S IEN1=+$O(^IBBAA(375,"AF",IBBDFN,IBBWHEN,IBBWHERE,0))
|
---|
81 | ..S IEN2=+$O(^IBBAA(375,"AF",IBBDFN,IBBWHEN,IBBWHERE,IEN1))
|
---|
82 | .;inpatient admission
|
---|
83 | .I 'IEN1,IBBEVENT="A01",IBBWHERE'="FEE BASIS" S IBBIEN=$$INPT() Q
|
---|
84 | .;unique index entry
|
---|
85 | .I IEN1,'IEN2 S IBBIEN=IEN1
|
---|
86 | .;multiple index entries
|
---|
87 | .I 'IBBIEN,IEN2,IBBWHERE=+IBBWHERE D
|
---|
88 | ..S IEN1=0 F S IEN1=+$O(^IBBAA(375,"AC",IBBDFN,IBBWHEN,IBBWHERE,IEN1)) Q:'IEN1 D Q:IBBIEN
|
---|
89 | ...S REC=$G(^IBBAA(375,IEN1,"PV1")),ALTNUMX=+$P(REC,U,50)
|
---|
90 | ...I $G(ALTNUM),ALTNUMX=ALTNUM S IBBIEN=IEN1 Q
|
---|
91 | ...I $G(ALTNUM),ALTNUMX'=ALTNUM Q
|
---|
92 | ...S PHYSX=$P(REC,U,7)
|
---|
93 | ...I $G(PHYS),PHYSX=PHYS S IBBIEN=IEN1 Q
|
---|
94 | ...I $G(PHYS),PHYSX'=PHYS Q
|
---|
95 | ...I $G(PROC)'="" S PROC=$$CODEN^ICPTCOD(PROC),PROCX=$P($G(^IBBAA(375,IEN1,"PR1")),U,3)
|
---|
96 | ...I +PROC,PROCX=PROC S IBBIEN=IEN1 Q
|
---|
97 | ;store external visit #
|
---|
98 | I $G(IBBIEN) D
|
---|
99 | .S:('IBBARFN) IBBARFN=IBBIEN
|
---|
100 | .I $P(^IBBAA(375,IBBIEN,0),U,2)="" D
|
---|
101 | ..S $P(^IBBAA(375,IBBIEN,0),U,2)=IBBEXVN
|
---|
102 | ..S $P(^IBBAA(375,IBBIEN,0),U,5)=$$NOW^XLFDT()
|
---|
103 | ..D EVENT^IBBAACCT(IBBIEN,IBBEVENT,"I")
|
---|
104 | Q IBBARFN
|
---|
105 | ;
|
---|
106 | INPT() ;set new account record for inpatient admission
|
---|
107 | N IBB,IBBARFN,IBBIEN,IBBIENS,IBBERR,FDA,X
|
---|
108 | S IBBARFN=0
|
---|
109 | L +^IBBAA(375,0):5
|
---|
110 | Q:'$T 0
|
---|
111 | S IBBIEN=$P(^IBBAA(375,0),U,3)+1
|
---|
112 | S IBBIEN(1)=IBBIEN
|
---|
113 | S IBBIENS="+1,"
|
---|
114 | S IBBERR="IBB(""DIERR"")"
|
---|
115 | S FDA(375,IBBIENS,.01)=IBBIEN
|
---|
116 | S FDA(375,IBBIENS,.02)=IBBEXVN
|
---|
117 | S FDA(375,IBBIENS,.03)=IBBDFN
|
---|
118 | S FDA(375,IBBIENS,.04)="COTS_SYSTEM"
|
---|
119 | S FDA(375,IBBIENS,.05)=$$NOW^XLFDT
|
---|
120 | D UPDATE^DIE("","FDA","IBBIEN",IBBERR)
|
---|
121 | L -^IBBAA(375,0)
|
---|
122 | I '$D(IBB("DIERR")) D
|
---|
123 | .S IBBARFN=IBBIEN
|
---|
124 | .S X="",$P(X,U,2)="I",$P(X,U,3)=IBBWHERE,$P(X,U,44)=IBBWHEN
|
---|
125 | .S ^IBBAA(375,IBBIEN,"PV1")=X
|
---|
126 | .D EVENT^IBBAACCT(IBBIEN,IBBEVENT,"I")
|
---|
127 | .S ^IBBAA(375,"AC",IBBDFN,IBBWHEN,IBBWHERE,IBBIEN)=""
|
---|
128 | Q IBBARFN
|
---|
129 | ;
|
---|
130 | INTNUM(IBBEXVN) ;return PFSS Account Reference using external visit number
|
---|
131 | N IBBARFN,XX
|
---|
132 | S IBBARFN=""
|
---|
133 | Q:'$G(IBBEXVN) IBBARFN
|
---|
134 | S XX=$O(^IBBAA(375,"C",IBBEXVN,0))
|
---|
135 | I XX S IBBARFN=XX
|
---|
136 | Q IBBARFN
|
---|
137 | ;
|
---|
138 | PID() ;get DFN from HL7 message; compare to file #2 data
|
---|
139 | N IBBARRY,OUT,REP,FILE,FIELD,IENS,XID,XTYP,XSITE,XSSN,XNAME,XX
|
---|
140 | S OUT=0,XID=0,XSSN=0
|
---|
141 | F Q:OUT Q:'$$NEXTSEG^HLPRS(.IBBMSG,.IBBSEG) I IBBSEG("SEGMENT TYPE")="PID" D
|
---|
142 | .S XNAME=$$GET^HLOPRS(.IBBSEG,5,1,1)
|
---|
143 | .F REP=1:1 Q:OUT D
|
---|
144 | ..S XTYP=$$GET^HLOPRS(.IBBSEG,3,5,1,REP)
|
---|
145 | ..I XTYP="PI" D
|
---|
146 | ...S XX=$$GET^HLOPRS(.IBBSEG,3,1,1,REP)
|
---|
147 | ...S XSITE=+$E(XX,1,3),XID=+$E(XX,4,99)
|
---|
148 | ..I XTYP="SS" S XSSN=$$GET^HLOPRS(.IBBSEG,3,1,1,REP)
|
---|
149 | ..I XID&XSSN S OUT=1
|
---|
150 | I XSITE=$P($$SITE^VASITE(),U,3) D
|
---|
151 | .S FILE=2,IENS=XID_",",FIELD=".01;.09"
|
---|
152 | .D GETS^DIQ(FILE,IENS,FIELD,"","IBBARRY")
|
---|
153 | .I XSSN'=$G(IBBARRY(2,IENS,.09)) S XID=0
|
---|
154 | .I XNAME'=$P($G(IBBARRY(2,IENS,.01)),",",1) S XID=0
|
---|
155 | Q XID
|
---|
156 | ;
|
---|
157 | EXVN() ;external account/visit number must be non-null
|
---|
158 | N OUT,IBBEXVN
|
---|
159 | S IBBEXVN="",OUT=0
|
---|
160 | F Q:OUT Q:'$$NEXTSEG^HLPRS(.IBBMSG,.IBBSEG) D
|
---|
161 | .I IBBSEG("SEGMENT TYPE")="PV1" D Q
|
---|
162 | ..S IBBEXVN=$$GET^HLOPRS(.IBBSEG,19,1),OUT=1
|
---|
163 | Q IBBEXVN
|
---|
164 | ;
|
---|
165 | ACK ; prepare positive acknowledgement (AA) message
|
---|
166 | N HLA,HLRESULT
|
---|
167 | S XX=$$SETPURG^HLUTIL(0)
|
---|
168 | S HLA("HLA",$J,1)="MSA"_HL("FS")_"AA"_HL("FS")_HL("MID")
|
---|
169 | D GENACK^HLMA1(HL("EID"),HLMTIENS,HL("EIDS"),"LM",1,.HLRESULT)
|
---|
170 | Q
|
---|
171 | ;
|
---|
172 | NAK ;prepare negative acknowledgement (AE) message
|
---|
173 | N HLA,HLRESULT
|
---|
174 | S XX=$$SETPURG^HLUTIL(1)
|
---|
175 | S HLA("HLA",$J,1)="MSA"_HL("FS")_"AE"_HL("FS")_HL("MID")_HL("FS")_HLERR
|
---|
176 | D GENACK^HLMA1(HL("EID"),HLMTIENS,HL("EIDS"),"LM",1,.HLRESULT)
|
---|
177 | Q
|
---|
178 | ;
|
---|
179 | IBBACONV(IBBDFN,IBBTYPE,IBBWHEN,IBBWHERE,IBBEXVN) ;new account record for converted inpatient or outpatient
|
---|
180 | ;called only from DG or SD routine during back-load of converted data
|
---|
181 | ;input IBBDFN = pointer to file #2
|
---|
182 | ; IBBTYPE = I(npatient) or O(utpatient)
|
---|
183 | ; IBBWHEN = date/time of visit; internal FM format
|
---|
184 | ; IBBWHERE = location of visit; pointer to file #44
|
---|
185 | ; IBBEXVN = external system visit #
|
---|
186 | ;output IBBARFN = ien in file #375; PFSS Account Reference
|
---|
187 | ;
|
---|
188 | N IBB,IBBARFN,IBBIEN,IBBIENS,IBBERR,FDA,X
|
---|
189 | S IBBARFN=0
|
---|
190 | L +^IBBAA(375,0):5
|
---|
191 | Q:'$T 0
|
---|
192 | S IBBIEN=$P(^IBBAA(375,0),U,3)+1
|
---|
193 | S IBBIEN(1)=IBBIEN
|
---|
194 | S IBBIENS="+1,"
|
---|
195 | S IBBERR="IBB(""DIERR"")"
|
---|
196 | S FDA(375,IBBIENS,.01)=IBBIEN
|
---|
197 | S FDA(375,IBBIENS,.02)=$G(IBBEXVN)
|
---|
198 | S FDA(375,IBBIENS,.03)=$G(IBBDFN)
|
---|
199 | S FDA(375,IBBIENS,.04)="CONVERSION"
|
---|
200 | S FDA(375,IBBIENS,.05)=$$NOW^XLFDT
|
---|
201 | D UPDATE^DIE("","FDA","IBBIEN",IBBERR)
|
---|
202 | L -^IBBAA(375,0)
|
---|
203 | I '$D(IBB("DIERR")) D
|
---|
204 | .S IBBARFN=IBBIEN
|
---|
205 | .S X="",$P(X,U,2)=$G(IBBTYPE),$P(X,U,3)=$G(IBBWHERE),$P(X,U,44)=$G(IBBWHEN)
|
---|
206 | .S ^IBBAA(375,IBBIEN,"PV1")=X
|
---|
207 | .I IBBTYPE="O" S $P(^IBBAA(375,IBBIEN,"PV2"),U,8)=$G(IBBWHEN)
|
---|
208 | .I $G(IBBDFN),$G(IBBWHEN),$G(IBBWHERE) S ^IBBAA(375,"AC",IBBDFN,IBBWHEN,IBBWHERE,IBBIEN)=""
|
---|
209 | Q IBBARFN
|
---|