IBRFN3 ;ALB/ARH - PASS BILL/CLAIM TO AR ;3/18/96
;;2.0;INTEGRATED BILLING;**61,133,210,309,389,516**;21-MAR-94;Build 123
;;Per VA Directive 6402, this routine should not be modified.
;
; Returns information on the bill passed in, all data returned in external format, for AR's RC project
;
; If the bill can not be found then returns ARRAY=0 (should be called with ARRAY passed by reference)
; Otherwise ARRAY=1 and the following array elements may be defined
; these array elements will only be defined is there is data to return
; those elements that have multiple entries will be in the form ARRAY("SUB",X) where X=1:1:...
;
; ARRAY("BN") = BILL NUMBER
; ARRAY("SR") = SENSITIVE RECORD? (Y or N)
; ARRAY("STF") = STATEMENT COVERS FROM DATE - first date covered by bill
; ARRAY("STT") = STATEMENT COVERS TO DATE - last date covered by bill
; ARRAY("TCG") = TOTAL CHARGES^OFFSET AMT (PRIOR PAYMENTS)^OFFSET DESC
; ARRAY("TOC") = BILL TYPE (INPATIENT OR OUTPATIENT)
; ARRAY("TCF") = BILL FORM TYPE
; ARRAY("DFP") = DATE FIRST PRINTED
; ARRAY("TAX") = FEDERAL TAX NUMBER - for facility, a site parameter
;
; ARRAY("PIN") = DEBTOR INSURANCE NAME ^ HOSPITAL PROVIDER NUMBER ^ GROUP NAME ^ GROUP NUMBER ^
; NAME OF INSURED ^ SUBSCRIBER ID ^ RELATIONSHIP TO INSURED
;
; ARRAY("PIN","MMA") = DEBTOR MAILING STREET ADDRESS [LINE 1] ^
; MAILING STREET ADDRESS [LINE 2] ^ MAILING STREET ADDRESS [LINE 3] ^ CITY ^
; STATE (ABBREVIATED) ^ ZIP ^ PHONE NUMBER
;
; ARRAY("RVC") = NUMBER OF REVENUE CODES ON BILL
; ARRAY("RVC",X) = REVENUE CODE ^ REVENUE CODE DESCRIPTION ^ CHARGE (PER UNIT) ^ UNITS ^
; TOTAL CHARGE FOR REV CODE
;
; ARRAY("OPV") = NUMBER OF OUTPATIENT VISIT DATES ON BILL
; ARRAY("OPV",X) = OUTPATIENT VISIT DATE
;
; ARRAY("PRC") = NUMBER OF PROCEDURES ON BILL
; ARRAY("PRC",X) = PROCEDURE CODE ^ PROCEDURE DESCRIPTION ^ PROCEDURE DATE ^
; PLACE OF SERVICE CODE ^ PLACE OF SERVICE ^ TYPE OF SERVICE CODE ^ TYPE OF SERVICE
;
; ARRAY("DXS") = NUMBER OF DIAGNOSIS ON BILL
; ARRAY("DXS,X) = DIAGNOSIS CODE ^ DIAGNOSIS
;
; ARRAY("RXF") = NUMBER OF PRESCRIPTION REFILLS ON BILL
; ARRAY("RXF",X) = PRESCRIPTION # ^ REFILL DATE ^ DRUG NAME ^ DAYS SUPPLY ^ QUANTITY ^ NDC #
;
; ARRAY("PRD") = NUMBER OF PROSTHETIC ITEMS ON BILL
; ARRAY("PRD",X) = PROSTHETIC DEVICE ^ DELIVERY DATE
;
; IF CONDITION RELATED TO EMPLOYMENT: ARRAY("CRE") = "EMPLOYMENT"
; IF CONDITION RELATED TO AN AUTO ACCIDENT: ARRAY("CRA") = "AUTO ACCIDENT" ^ STATE (ABBREVIATION)
; IF CONDITION RELATED TO AN OTHER ACCIDENT: ARRAY("CRO") = "OTHER ACCIDENT"
;
BILL(IBIFN,ARRAY) ; returns array of information on a specific bill, based on RC requirements
;
N IBI,IBJ,IBK,IBX,IBY,IBTMP,IBD0,IBDU,IBDU1,IBDI1,IBDS,IBDATE
K ARRAY S ARRAY=1 I '$G(IBIFN)!($G(^DGCR(399,+$G(IBIFN),0))="") S ARRAY=0 Q
F IBI=0,"U","U1","S" S @("IBD"_IBI)=$G(^DGCR(399,IBIFN,IBI))
;IB*2.0*516/TAZ - Call $$POLICY^IBCEF to insert HIPAA compliant fields into variable IBDI1. Data will
;continue to be extracted from IBDI1 original location.
;S IBX=$P(IBD0,U,21),IBX=$S(IBX="P":"I1",IBX="S":"I2",IBX="T":"I3",1:" ")
;S IBDI1=$G(^DGCR(399,IBIFN,IBX)) ; 516 - baa
S IBX=$P(IBD0,U,21) ; Pass P, S, or T to $$POLICY^IBCEF
S IBDI1=$$POLICY^IBCEF(IBIFN,,IBX) ; 516 - baa
;
S ARRAY("TCG")=$P(IBDU1,U,1,3)
S ARRAY("BN")=$P(IBD0,U,1)
S ARRAY("SR")=$S($P(IBDU,U,5)=1:"Y",1:"N")
S ARRAY("STF")=$P(IBDU,U,1)
S ARRAY("STT")=$P(IBDU,U,2)
S ARRAY("TOC")=$S($P(IBD0,U,5)<3:"INPATIENT",1:"OUTPATIENT")
S ARRAY("TCF")=$$FTN^IBCU3($$FT^IBCU3(IBIFN))
S ARRAY("DFP")=$P(IBDS,U,12)
S ARRAY("TAX")=$P($G(^IBE(350.9,1,1)),U,5)
;
INS ; insurance information
S IBX=$G(^DGCR(399,+IBIFN,"M"))
S ARRAY("PIN")=$P(IBX,U,4)_U_$P($G(^DIC(36,+IBDI1,0)),U,11)_U_$P(IBDI1,U,15)_U_$P(IBDI1,U,3)_U_$P(IBDI1,U,17)_U_$P(IBDI1,U,2)_U_$$RTI($P(IBDI1,U,16))
S ARRAY("PIN","MMA")=$P(IBX,U,5)_U_$P(IBX,U,6)_U_$P($G(^DGCR(399,+IBIFN,"M1")),U,1)_U_$P(IBX,U,7)_U_$$STATE($P(IBX,U,8))
S ARRAY("PIN","MMA")=ARRAY("PIN","MMA")_U_$$ZIP($P(IBX,U,9))_U_$P($G(^DIC(36,+IBDI1,.13)),U,1)
;
RC ; revenue codes
S (IBI,IBJ)=0,ARRAY("RVC")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"RC",IBI)) Q:'IBI D
. S IBX=$G(^DGCR(399,IBIFN,"RC",IBI,0)) Q:IBX="" S IBY=$G(^DGCR(399.2,+IBX,0))
. S IBJ=IBJ+1,ARRAY("RVC")=IBJ
. S ARRAY("RVC",IBJ)=$P(IBY,U,1)_U_$P(IBY,U,2)_U_$P(IBX,U,2)_U_$P(IBX,U,3)_U_$P(IBX,U,4)
;
OPV ; outpatient visit dates
S (IBI,IBJ)=0,ARRAY("OPV")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"OP",IBI)) Q:'IBI D
. S IBX=$G(^DGCR(399,IBIFN,"OP",IBI,0)) Q:'IBX
. S IBJ=IBJ+1,ARRAY("OPV")=IBJ
. S ARRAY("OPV",IBJ)=+IBX
;
PRC ; procedure codes
S (IBI,IBJ)=0,ARRAY("PRC")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"CP",IBI)) Q:'IBI D
. S IBX=$G(^DGCR(399,IBIFN,"CP",IBI,0)),IBY=""
. S IBDATE=$P(IBX,U,2) I 'IBDATE S IBDATE=$$BDATE^IBACSV(IBIFN)
. S IBY=$P($$PRCD^IBCEF1($P(IBX,U),1,IBDATE),U,2,3)
. Q:$P(IBY,U)=""
. S IBJ=IBJ+1,ARRAY("PRC")=IBJ
. S ARRAY("PRC",IBJ)=IBY_U_$P(IBX,U,2)
. S IBY=$G(^IBE(353.1,+$P(IBX,U,9),0)),ARRAY("PRC",IBJ)=ARRAY("PRC",IBJ)_U_$P(IBY,U)_U_$P(IBY,U,3)
. S IBY=$G(^IBE(353.2,+$P(IBX,U,10),0)),ARRAY("PRC",IBJ)=ARRAY("PRC",IBJ)_U_$P(IBY,U)_U_$P(IBY,U,3)
;
DX ; diagnosis codes
K IBTMP D SET^IBCSC4D(IBIFN,"",.IBTMP)
S IBDATE=$$BDATE^IBACSV(IBIFN)
S (IBI,IBJ)=0,ARRAY("DXS")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
. S IBX=IBTMP(IBI),IBY=$$ICD9^IBACSV(+IBX,IBDATE) Q:IBY=""
. S IBJ=IBJ+1,ARRAY("DXS")=IBJ
. S ARRAY("DXS",IBJ)=$P(IBY,U)_U_$P(IBY,U,3)
;
RX ; prescription refills
K IBTMP D SET^IBCSC5A(IBIFN,.IBTMP)
S (IBI,IBJ)=0,ARRAY("RXF")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
. S IBK=0 F S IBK=$O(IBTMP(IBI,IBK)) Q:'IBK D
.. S IBX=IBTMP(IBI,IBK) D ZERO^IBRXUTL(+$P(IBX,U,2)) S IBY=$G(^TMP($J,"IBDRUG",+$P(IBX,U,2),.01))
.. S IBJ=IBJ+1,ARRAY("RXF")=IBJ
.. S ARRAY("RXF",IBJ)=IBI_U_IBK_U_IBY_U_$P(IBX,U,3)_U_$P(IBX,U,4)_U_$P(IBX,U,5)
.. K ^TMP($J,"IBDRUG")
.. Q
;
PD ; prosthetic items
K IBTMP D SET^IBCSC5B(IBIFN,.IBTMP)
S (IBI,IBJ)=0,ARRAY("PRD")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
. S IBK=0 F S IBK=$O(IBTMP(IBI,IBK)) Q:'IBK D
.. S IBX=IBTMP(IBI,IBK)
.. S IBJ=IBJ+1,ARRAY("PRD")=IBJ
.. S ARRAY("PRD",IBJ)=$$PINB^IBCSC5B(+IBX)_U_IBI
;
CC ; condition related to employment, auto accident (place), other accident
S IBI=0 F S IBI=$O(^DGCR(399,IBIFN,"CC",IBI)) Q:'IBI I $G(^(IBI,0))="02" S ARRAY("CRE")="EMPLOYMENT"
S IBI=0 F S IBI=$O(^DGCR(399,IBIFN,"OC",IBI)) Q:'IBI S IBX=$G(^(IBI,0)) I +IBX D
. S IBY=$G(^DGCR(399.1,+IBX,0)) Q:IBY=""
. I $P(IBY,U,9)=1 S ARRAY("CRE")="EMPLOYMENT"
. I $P(IBY,U,9)=2 S ARRAY("CRA")="AUTO ACCIDENT"_U_$$STATE($P(IBX,U,3))
. I $P(IBY,U,9)=3 S ARRAY("CRO")="OTHER ACCIDENT"
Q
;
STATE(X) ; returns 2 letter abbreviation for state
Q $P($G(^DIC(5,+X,0)),U,2)
ZIP(X) ; returns zip in external form
S X=$E(X,1,5)_$S($E(X,6,9)]"":"-"_$E(X,6,9),1:"")
Q X
RTI(X) ; returns external form of relationship to insured
I X'="" S X=$S(X="01":"PATIENT",X="02":"SPOUSE",X="03":"NATURAL CHILD",X="08":"EMPLOYEE",X="09":"UNKNOWN",X="11":"ORGAN DONOR",X="15":"INJURED PLANTIFF",X="18":"PARENT",1:"")
Q X
;IBRFN3
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HIBRFN3 7325 printed Oct 16, 2024@18:27:33 Page 2
IBRFN3 ;ALB/ARH - PASS BILL/CLAIM TO AR ;3/18/96
+1 ;;2.0;INTEGRATED BILLING;**61,133,210,309,389,516**;21-MAR-94;Build 123
+2 ;;Per VA Directive 6402, this routine should not be modified.
+3 ;
+4 ; Returns information on the bill passed in, all data returned in external format, for AR's RC project
+5 ;
+6 ; If the bill can not be found then returns ARRAY=0 (should be called with ARRAY passed by reference)
+7 ; Otherwise ARRAY=1 and the following array elements may be defined
+8 ; these array elements will only be defined is there is data to return
+9 ; those elements that have multiple entries will be in the form ARRAY("SUB",X) where X=1:1:...
+10 ;
+11 ; ARRAY("BN") = BILL NUMBER
+12 ; ARRAY("SR") = SENSITIVE RECORD? (Y or N)
+13 ; ARRAY("STF") = STATEMENT COVERS FROM DATE - first date covered by bill
+14 ; ARRAY("STT") = STATEMENT COVERS TO DATE - last date covered by bill
+15 ; ARRAY("TCG") = TOTAL CHARGES^OFFSET AMT (PRIOR PAYMENTS)^OFFSET DESC
+16 ; ARRAY("TOC") = BILL TYPE (INPATIENT OR OUTPATIENT)
+17 ; ARRAY("TCF") = BILL FORM TYPE
+18 ; ARRAY("DFP") = DATE FIRST PRINTED
+19 ; ARRAY("TAX") = FEDERAL TAX NUMBER - for facility, a site parameter
+20 ;
+21 ; ARRAY("PIN") = DEBTOR INSURANCE NAME ^ HOSPITAL PROVIDER NUMBER ^ GROUP NAME ^ GROUP NUMBER ^
+22 ; NAME OF INSURED ^ SUBSCRIBER ID ^ RELATIONSHIP TO INSURED
+23 ;
+24 ; ARRAY("PIN","MMA") = DEBTOR MAILING STREET ADDRESS [LINE 1] ^
+25 ; MAILING STREET ADDRESS [LINE 2] ^ MAILING STREET ADDRESS [LINE 3] ^ CITY ^
+26 ; STATE (ABBREVIATED) ^ ZIP ^ PHONE NUMBER
+27 ;
+28 ; ARRAY("RVC") = NUMBER OF REVENUE CODES ON BILL
+29 ; ARRAY("RVC",X) = REVENUE CODE ^ REVENUE CODE DESCRIPTION ^ CHARGE (PER UNIT) ^ UNITS ^
+30 ; TOTAL CHARGE FOR REV CODE
+31 ;
+32 ; ARRAY("OPV") = NUMBER OF OUTPATIENT VISIT DATES ON BILL
+33 ; ARRAY("OPV",X) = OUTPATIENT VISIT DATE
+34 ;
+35 ; ARRAY("PRC") = NUMBER OF PROCEDURES ON BILL
+36 ; ARRAY("PRC",X) = PROCEDURE CODE ^ PROCEDURE DESCRIPTION ^ PROCEDURE DATE ^
+37 ; PLACE OF SERVICE CODE ^ PLACE OF SERVICE ^ TYPE OF SERVICE CODE ^ TYPE OF SERVICE
+38 ;
+39 ; ARRAY("DXS") = NUMBER OF DIAGNOSIS ON BILL
+40 ; ARRAY("DXS,X) = DIAGNOSIS CODE ^ DIAGNOSIS
+41 ;
+42 ; ARRAY("RXF") = NUMBER OF PRESCRIPTION REFILLS ON BILL
+43 ; ARRAY("RXF",X) = PRESCRIPTION # ^ REFILL DATE ^ DRUG NAME ^ DAYS SUPPLY ^ QUANTITY ^ NDC #
+44 ;
+45 ; ARRAY("PRD") = NUMBER OF PROSTHETIC ITEMS ON BILL
+46 ; ARRAY("PRD",X) = PROSTHETIC DEVICE ^ DELIVERY DATE
+47 ;
+48 ; IF CONDITION RELATED TO EMPLOYMENT: ARRAY("CRE") = "EMPLOYMENT"
+49 ; IF CONDITION RELATED TO AN AUTO ACCIDENT: ARRAY("CRA") = "AUTO ACCIDENT" ^ STATE (ABBREVIATION)
+50 ; IF CONDITION RELATED TO AN OTHER ACCIDENT: ARRAY("CRO") = "OTHER ACCIDENT"
+51 ;
BILL(IBIFN,ARRAY) ; returns array of information on a specific bill, based on RC requirements
+1 ;
+2 NEW IBI,IBJ,IBK,IBX,IBY,IBTMP,IBD0,IBDU,IBDU1,IBDI1,IBDS,IBDATE
+3 KILL ARRAY
SET ARRAY=1
IF '$GET(IBIFN)!($GET(^DGCR(399,+$GET(IBIFN),0))="")
SET ARRAY=0
QUIT
+4 FOR IBI=0,"U","U1","S"
SET @("IBD"_IBI)=$GET(^DGCR(399,IBIFN,IBI))
+5 ;IB*2.0*516/TAZ - Call $$POLICY^IBCEF to insert HIPAA compliant fields into variable IBDI1. Data will
+6 ;continue to be extracted from IBDI1 original location.
+7 ;S IBX=$P(IBD0,U,21),IBX=$S(IBX="P":"I1",IBX="S":"I2",IBX="T":"I3",1:" ")
+8 ;S IBDI1=$G(^DGCR(399,IBIFN,IBX)) ; 516 - baa
+9 ; Pass P, S, or T to $$POLICY^IBCEF
SET IBX=$PIECE(IBD0,U,21)
+10 ; 516 - baa
SET IBDI1=$$POLICY^IBCEF(IBIFN,,IBX)
+11 ;
+12 SET ARRAY("TCG")=$PIECE(IBDU1,U,1,3)
+13 SET ARRAY("BN")=$PIECE(IBD0,U,1)
+14 SET ARRAY("SR")=$SELECT($PIECE(IBDU,U,5)=1:"Y",1:"N")
+15 SET ARRAY("STF")=$PIECE(IBDU,U,1)
+16 SET ARRAY("STT")=$PIECE(IBDU,U,2)
+17 SET ARRAY("TOC")=$SELECT($PIECE(IBD0,U,5)<3:"INPATIENT",1:"OUTPATIENT")
+18 SET ARRAY("TCF")=$$FTN^IBCU3($$FT^IBCU3(IBIFN))
+19 SET ARRAY("DFP")=$PIECE(IBDS,U,12)
+20 SET ARRAY("TAX")=$PIECE($GET(^IBE(350.9,1,1)),U,5)
+21 ;
INS ; insurance information
+1 SET IBX=$GET(^DGCR(399,+IBIFN,"M"))
+2 SET ARRAY("PIN")=$PIECE(IBX,U,4)_U_$PIECE($GET(^DIC(36,+IBDI1,0)),U,11)_U_$PIECE(IBDI1,U,15)_U_$PIECE(IBDI1,U,3)_U_$PIECE(IBDI1,U,17)_U_$PIECE(IBDI1,U,2)_U_$$RTI($PIECE(IBDI1,U,16))
+3 SET ARRAY("PIN","MMA")=$PIECE(IBX,U,5)_U_$PIECE(IBX,U,6)_U_$PIECE($GET(^DGCR(399,+IBIFN,"M1")),U,1)_U_$PIECE(IBX,U,7)_U_$$STATE($PIECE(IBX,U,8))
+4 SET ARRAY("PIN","MMA")=ARRAY("PIN","MMA")_U_$$ZIP($PIECE(IBX,U,9))_U_$PIECE($GET(^DIC(36,+IBDI1,.13)),U,1)
+5 ;
RC ; revenue codes
+1 SET (IBI,IBJ)=0
SET ARRAY("RVC")=IBJ
FOR
SET IBI=$ORDER(^DGCR(399,IBIFN,"RC",IBI))
if 'IBI
QUIT
Begin DoDot:1
+2 SET IBX=$GET(^DGCR(399,IBIFN,"RC",IBI,0))
if IBX=""
QUIT
SET IBY=$GET(^DGCR(399.2,+IBX,0))
+3 SET IBJ=IBJ+1
SET ARRAY("RVC")=IBJ
+4 SET ARRAY("RVC",IBJ)=$PIECE(IBY,U,1)_U_$PIECE(IBY,U,2)_U_$PIECE(IBX,U,2)_U_$PIECE(IBX,U,3)_U_$PIECE(IBX,U,4)
End DoDot:1
+5 ;
OPV ; outpatient visit dates
+1 SET (IBI,IBJ)=0
SET ARRAY("OPV")=IBJ
FOR
SET IBI=$ORDER(^DGCR(399,IBIFN,"OP",IBI))
if 'IBI
QUIT
Begin DoDot:1
+2 SET IBX=$GET(^DGCR(399,IBIFN,"OP",IBI,0))
if 'IBX
QUIT
+3 SET IBJ=IBJ+1
SET ARRAY("OPV")=IBJ
+4 SET ARRAY("OPV",IBJ)=+IBX
End DoDot:1
+5 ;
PRC ; procedure codes
+1 SET (IBI,IBJ)=0
SET ARRAY("PRC")=IBJ
FOR
SET IBI=$ORDER(^DGCR(399,IBIFN,"CP",IBI))
if 'IBI
QUIT
Begin DoDot:1
+2 SET IBX=$GET(^DGCR(399,IBIFN,"CP",IBI,0))
SET IBY=""
+3 SET IBDATE=$PIECE(IBX,U,2)
IF 'IBDATE
SET IBDATE=$$BDATE^IBACSV(IBIFN)
+4 SET IBY=$PIECE($$PRCD^IBCEF1($PIECE(IBX,U),1,IBDATE),U,2,3)
+5 if $PIECE(IBY,U)=""
QUIT
+6 SET IBJ=IBJ+1
SET ARRAY("PRC")=IBJ
+7 SET ARRAY("PRC",IBJ)=IBY_U_$PIECE(IBX,U,2)
+8 SET IBY=$GET(^IBE(353.1,+$PIECE(IBX,U,9),0))
SET ARRAY("PRC",IBJ)=ARRAY("PRC",IBJ)_U_$PIECE(IBY,U)_U_$PIECE(IBY,U,3)
+9 SET IBY=$GET(^IBE(353.2,+$PIECE(IBX,U,10),0))
SET ARRAY("PRC",IBJ)=ARRAY("PRC",IBJ)_U_$PIECE(IBY,U)_U_$PIECE(IBY,U,3)
End DoDot:1
+10 ;
DX ; diagnosis codes
+1 KILL IBTMP
DO SET^IBCSC4D(IBIFN,"",.IBTMP)
+2 SET IBDATE=$$BDATE^IBACSV(IBIFN)
+3 SET (IBI,IBJ)=0
SET ARRAY("DXS")=IBJ
FOR
SET IBI=$ORDER(IBTMP(IBI))
if 'IBI
QUIT
Begin DoDot:1
+4 SET IBX=IBTMP(IBI)
SET IBY=$$ICD9^IBACSV(+IBX,IBDATE)
if IBY=""
QUIT
+5 SET IBJ=IBJ+1
SET ARRAY("DXS")=IBJ
+6 SET ARRAY("DXS",IBJ)=$PIECE(IBY,U)_U_$PIECE(IBY,U,3)
End DoDot:1
+7 ;
RX ; prescription refills
+1 KILL IBTMP
DO SET^IBCSC5A(IBIFN,.IBTMP)
+2 SET (IBI,IBJ)=0
SET ARRAY("RXF")=IBJ
FOR
SET IBI=$ORDER(IBTMP(IBI))
if 'IBI
QUIT
Begin DoDot:1
+3 SET IBK=0
FOR
SET IBK=$ORDER(IBTMP(IBI,IBK))
if 'IBK
QUIT
Begin DoDot:2
+4 SET IBX=IBTMP(IBI,IBK)
DO ZERO^IBRXUTL(+$PIECE(IBX,U,2))
SET IBY=$GET(^TMP($JOB,"IBDRUG",+$PIECE(IBX,U,2),.01))
+5 SET IBJ=IBJ+1
SET ARRAY("RXF")=IBJ
+6 SET ARRAY("RXF",IBJ)=IBI_U_IBK_U_IBY_U_$PIECE(IBX,U,3)_U_$PIECE(IBX,U,4)_U_$PIECE(IBX,U,5)
+7 KILL ^TMP($JOB,"IBDRUG")
+8 QUIT
End DoDot:2
End DoDot:1
+9 ;
PD ; prosthetic items
+1 KILL IBTMP
DO SET^IBCSC5B(IBIFN,.IBTMP)
+2 SET (IBI,IBJ)=0
SET ARRAY("PRD")=IBJ
FOR
SET IBI=$ORDER(IBTMP(IBI))
if 'IBI
QUIT
Begin DoDot:1
+3 SET IBK=0
FOR
SET IBK=$ORDER(IBTMP(IBI,IBK))
if 'IBK
QUIT
Begin DoDot:2
+4 SET IBX=IBTMP(IBI,IBK)
+5 SET IBJ=IBJ+1
SET ARRAY("PRD")=IBJ
+6 SET ARRAY("PRD",IBJ)=$$PINB^IBCSC5B(+IBX)_U_IBI
End DoDot:2
End DoDot:1
+7 ;
CC ; condition related to employment, auto accident (place), other accident
+1 SET IBI=0
FOR
SET IBI=$ORDER(^DGCR(399,IBIFN,"CC",IBI))
if 'IBI
QUIT
IF $GET(^(IBI,0))="02"
SET ARRAY("CRE")="EMPLOYMENT"
+2 SET IBI=0
FOR
SET IBI=$ORDER(^DGCR(399,IBIFN,"OC",IBI))
if 'IBI
QUIT
SET IBX=$GET(^(IBI,0))
IF +IBX
Begin DoDot:1
+3 SET IBY=$GET(^DGCR(399.1,+IBX,0))
if IBY=""
QUIT
+4 IF $PIECE(IBY,U,9)=1
SET ARRAY("CRE")="EMPLOYMENT"
+5 IF $PIECE(IBY,U,9)=2
SET ARRAY("CRA")="AUTO ACCIDENT"_U_$$STATE($PIECE(IBX,U,3))
+6 IF $PIECE(IBY,U,9)=3
SET ARRAY("CRO")="OTHER ACCIDENT"
End DoDot:1
+7 QUIT
+8 ;
STATE(X) ; returns 2 letter abbreviation for state
+1 QUIT $PIECE($GET(^DIC(5,+X,0)),U,2)
ZIP(X) ; returns zip in external form
+1 SET X=$EXTRACT(X,1,5)_$SELECT($EXTRACT(X,6,9)]"":"-"_$EXTRACT(X,6,9),1:"")
+2 QUIT X
RTI(X) ; returns external form of relationship to insured
+1 IF X'=""
SET X=$SELECT(X="01":"PATIENT",X="02":"SPOUSE",X="03":"NATURAL CHILD",X="08":"EMPLOYEE",X="09":"UNKNOWN",X="11":"ORGAN DONOR",X="15":"INJURED PLANTIFF",X="18":"PARENT",1:"")
+2 QUIT X
+3 ;IBRFN3