| 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
 | 
|---|