Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: IBRFN3

IBRFN3.m

Go to the documentation of this file.
  1. 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
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. ; Returns information on the bill passed in, all data returned in external format, for AR's RC project
  1. ;
  1. ; If the bill can not be found then returns ARRAY=0 (should be called with ARRAY passed by reference)
  1. ; Otherwise ARRAY=1 and the following array elements may be defined
  1. ; these array elements will only be defined is there is data to return
  1. ; those elements that have multiple entries will be in the form ARRAY("SUB",X) where X=1:1:...
  1. ;
  1. ; ARRAY("BN") = BILL NUMBER
  1. ; ARRAY("SR") = SENSITIVE RECORD? (Y or N)
  1. ; ARRAY("STF") = STATEMENT COVERS FROM DATE - first date covered by bill
  1. ; ARRAY("STT") = STATEMENT COVERS TO DATE - last date covered by bill
  1. ; ARRAY("TCG") = TOTAL CHARGES^OFFSET AMT (PRIOR PAYMENTS)^OFFSET DESC
  1. ; ARRAY("TOC") = BILL TYPE (INPATIENT OR OUTPATIENT)
  1. ; ARRAY("TCF") = BILL FORM TYPE
  1. ; ARRAY("DFP") = DATE FIRST PRINTED
  1. ; ARRAY("TAX") = FEDERAL TAX NUMBER - for facility, a site parameter
  1. ;
  1. ; ARRAY("PIN") = DEBTOR INSURANCE NAME ^ HOSPITAL PROVIDER NUMBER ^ GROUP NAME ^ GROUP NUMBER ^
  1. ; NAME OF INSURED ^ SUBSCRIBER ID ^ RELATIONSHIP TO INSURED
  1. ;
  1. ; ARRAY("PIN","MMA") = DEBTOR MAILING STREET ADDRESS [LINE 1] ^
  1. ; MAILING STREET ADDRESS [LINE 2] ^ MAILING STREET ADDRESS [LINE 3] ^ CITY ^
  1. ; STATE (ABBREVIATED) ^ ZIP ^ PHONE NUMBER
  1. ;
  1. ; ARRAY("RVC") = NUMBER OF REVENUE CODES ON BILL
  1. ; ARRAY("RVC",X) = REVENUE CODE ^ REVENUE CODE DESCRIPTION ^ CHARGE (PER UNIT) ^ UNITS ^
  1. ; TOTAL CHARGE FOR REV CODE
  1. ;
  1. ; ARRAY("OPV") = NUMBER OF OUTPATIENT VISIT DATES ON BILL
  1. ; ARRAY("OPV",X) = OUTPATIENT VISIT DATE
  1. ;
  1. ; ARRAY("PRC") = NUMBER OF PROCEDURES ON BILL
  1. ; ARRAY("PRC",X) = PROCEDURE CODE ^ PROCEDURE DESCRIPTION ^ PROCEDURE DATE ^
  1. ; PLACE OF SERVICE CODE ^ PLACE OF SERVICE ^ TYPE OF SERVICE CODE ^ TYPE OF SERVICE
  1. ;
  1. ; ARRAY("DXS") = NUMBER OF DIAGNOSIS ON BILL
  1. ; ARRAY("DXS,X) = DIAGNOSIS CODE ^ DIAGNOSIS
  1. ;
  1. ; ARRAY("RXF") = NUMBER OF PRESCRIPTION REFILLS ON BILL
  1. ; ARRAY("RXF",X) = PRESCRIPTION # ^ REFILL DATE ^ DRUG NAME ^ DAYS SUPPLY ^ QUANTITY ^ NDC #
  1. ;
  1. ; ARRAY("PRD") = NUMBER OF PROSTHETIC ITEMS ON BILL
  1. ; ARRAY("PRD",X) = PROSTHETIC DEVICE ^ DELIVERY DATE
  1. ;
  1. ; IF CONDITION RELATED TO EMPLOYMENT: ARRAY("CRE") = "EMPLOYMENT"
  1. ; IF CONDITION RELATED TO AN AUTO ACCIDENT: ARRAY("CRA") = "AUTO ACCIDENT" ^ STATE (ABBREVIATION)
  1. ; IF CONDITION RELATED TO AN OTHER ACCIDENT: ARRAY("CRO") = "OTHER ACCIDENT"
  1. ;
  1. BILL(IBIFN,ARRAY) ; returns array of information on a specific bill, based on RC requirements
  1. ;
  1. N IBI,IBJ,IBK,IBX,IBY,IBTMP,IBD0,IBDU,IBDU1,IBDI1,IBDS,IBDATE
  1. K ARRAY S ARRAY=1 I '$G(IBIFN)!($G(^DGCR(399,+$G(IBIFN),0))="") S ARRAY=0 Q
  1. F IBI=0,"U","U1","S" S @("IBD"_IBI)=$G(^DGCR(399,IBIFN,IBI))
  1. ;IB*2.0*516/TAZ - Call $$POLICY^IBCEF to insert HIPAA compliant fields into variable IBDI1. Data will
  1. ;continue to be extracted from IBDI1 original location.
  1. ;S IBX=$P(IBD0,U,21),IBX=$S(IBX="P":"I1",IBX="S":"I2",IBX="T":"I3",1:" ")
  1. ;S IBDI1=$G(^DGCR(399,IBIFN,IBX)) ; 516 - baa
  1. S IBX=$P(IBD0,U,21) ; Pass P, S, or T to $$POLICY^IBCEF
  1. S IBDI1=$$POLICY^IBCEF(IBIFN,,IBX) ; 516 - baa
  1. ;
  1. S ARRAY("TCG")=$P(IBDU1,U,1,3)
  1. S ARRAY("BN")=$P(IBD0,U,1)
  1. S ARRAY("SR")=$S($P(IBDU,U,5)=1:"Y",1:"N")
  1. S ARRAY("STF")=$P(IBDU,U,1)
  1. S ARRAY("STT")=$P(IBDU,U,2)
  1. S ARRAY("TOC")=$S($P(IBD0,U,5)<3:"INPATIENT",1:"OUTPATIENT")
  1. S ARRAY("TCF")=$$FTN^IBCU3($$FT^IBCU3(IBIFN))
  1. S ARRAY("DFP")=$P(IBDS,U,12)
  1. S ARRAY("TAX")=$P($G(^IBE(350.9,1,1)),U,5)
  1. ;
  1. INS ; insurance information
  1. S IBX=$G(^DGCR(399,+IBIFN,"M"))
  1. 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))
  1. 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))
  1. S ARRAY("PIN","MMA")=ARRAY("PIN","MMA")_U_$$ZIP($P(IBX,U,9))_U_$P($G(^DIC(36,+IBDI1,.13)),U,1)
  1. ;
  1. RC ; revenue codes
  1. S (IBI,IBJ)=0,ARRAY("RVC")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"RC",IBI)) Q:'IBI D
  1. . S IBX=$G(^DGCR(399,IBIFN,"RC",IBI,0)) Q:IBX="" S IBY=$G(^DGCR(399.2,+IBX,0))
  1. . S IBJ=IBJ+1,ARRAY("RVC")=IBJ
  1. . 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)
  1. ;
  1. OPV ; outpatient visit dates
  1. S (IBI,IBJ)=0,ARRAY("OPV")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"OP",IBI)) Q:'IBI D
  1. . S IBX=$G(^DGCR(399,IBIFN,"OP",IBI,0)) Q:'IBX
  1. . S IBJ=IBJ+1,ARRAY("OPV")=IBJ
  1. . S ARRAY("OPV",IBJ)=+IBX
  1. ;
  1. PRC ; procedure codes
  1. S (IBI,IBJ)=0,ARRAY("PRC")=IBJ F S IBI=$O(^DGCR(399,IBIFN,"CP",IBI)) Q:'IBI D
  1. . S IBX=$G(^DGCR(399,IBIFN,"CP",IBI,0)),IBY=""
  1. . S IBDATE=$P(IBX,U,2) I 'IBDATE S IBDATE=$$BDATE^IBACSV(IBIFN)
  1. . S IBY=$P($$PRCD^IBCEF1($P(IBX,U),1,IBDATE),U,2,3)
  1. . Q:$P(IBY,U)=""
  1. . S IBJ=IBJ+1,ARRAY("PRC")=IBJ
  1. . S ARRAY("PRC",IBJ)=IBY_U_$P(IBX,U,2)
  1. . 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)
  1. . 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)
  1. ;
  1. DX ; diagnosis codes
  1. K IBTMP D SET^IBCSC4D(IBIFN,"",.IBTMP)
  1. S IBDATE=$$BDATE^IBACSV(IBIFN)
  1. S (IBI,IBJ)=0,ARRAY("DXS")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
  1. . S IBX=IBTMP(IBI),IBY=$$ICD9^IBACSV(+IBX,IBDATE) Q:IBY=""
  1. . S IBJ=IBJ+1,ARRAY("DXS")=IBJ
  1. . S ARRAY("DXS",IBJ)=$P(IBY,U)_U_$P(IBY,U,3)
  1. ;
  1. RX ; prescription refills
  1. K IBTMP D SET^IBCSC5A(IBIFN,.IBTMP)
  1. S (IBI,IBJ)=0,ARRAY("RXF")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
  1. . S IBK=0 F S IBK=$O(IBTMP(IBI,IBK)) Q:'IBK D
  1. .. S IBX=IBTMP(IBI,IBK) D ZERO^IBRXUTL(+$P(IBX,U,2)) S IBY=$G(^TMP($J,"IBDRUG",+$P(IBX,U,2),.01))
  1. .. S IBJ=IBJ+1,ARRAY("RXF")=IBJ
  1. .. S ARRAY("RXF",IBJ)=IBI_U_IBK_U_IBY_U_$P(IBX,U,3)_U_$P(IBX,U,4)_U_$P(IBX,U,5)
  1. .. K ^TMP($J,"IBDRUG")
  1. .. Q
  1. ;
  1. PD ; prosthetic items
  1. K IBTMP D SET^IBCSC5B(IBIFN,.IBTMP)
  1. S (IBI,IBJ)=0,ARRAY("PRD")=IBJ F S IBI=$O(IBTMP(IBI)) Q:'IBI D
  1. . S IBK=0 F S IBK=$O(IBTMP(IBI,IBK)) Q:'IBK D
  1. .. S IBX=IBTMP(IBI,IBK)
  1. .. S IBJ=IBJ+1,ARRAY("PRD")=IBJ
  1. .. S ARRAY("PRD",IBJ)=$$PINB^IBCSC5B(+IBX)_U_IBI
  1. ;
  1. CC ; condition related to employment, auto accident (place), other accident
  1. S IBI=0 F S IBI=$O(^DGCR(399,IBIFN,"CC",IBI)) Q:'IBI I $G(^(IBI,0))="02" S ARRAY("CRE")="EMPLOYMENT"
  1. S IBI=0 F S IBI=$O(^DGCR(399,IBIFN,"OC",IBI)) Q:'IBI S IBX=$G(^(IBI,0)) I +IBX D
  1. . S IBY=$G(^DGCR(399.1,+IBX,0)) Q:IBY=""
  1. . I $P(IBY,U,9)=1 S ARRAY("CRE")="EMPLOYMENT"
  1. . I $P(IBY,U,9)=2 S ARRAY("CRA")="AUTO ACCIDENT"_U_$$STATE($P(IBX,U,3))
  1. . I $P(IBY,U,9)=3 S ARRAY("CRO")="OTHER ACCIDENT"
  1. Q
  1. ;
  1. STATE(X) ; returns 2 letter abbreviation for state
  1. Q $P($G(^DIC(5,+X,0)),U,2)
  1. ZIP(X) ; returns zip in external form
  1. S X=$E(X,1,5)_$S($E(X,6,9)]"":"-"_$E(X,6,9),1:"")
  1. Q X
  1. RTI(X) ; returns external form of relationship to insured
  1. 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:"")
  1. Q X
  1. ;IBRFN3