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

RCDPRTEX.m

Go to the documentation of this file.
  1. RCDPRTEX ;ALB/LMH - Claims Matching Report for Excel ;30-SEP 2016
  1. ;;4.5;Accounts Receivable;**315,339**;Mar 20, 1995;Build 2
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. Q
  1. ;
  1. PRINT ; Entry point for printing the Excel version of the report (either in foreground or background)
  1. ; Input:
  1. ; RCEXCEL=1 here
  1. ; Output:
  1. ; Report is printed in text format for Excel (turn on logging)
  1. ;
  1. U IO
  1. K ^TMP("RCDPRTPB",$J),^TMP("IBRBT",$J),^TMP("IBRBF",$J)
  1. N DAT,RCBIL,RCBIL0,RCNAM,RCPAY,RCPAY1,RCREC,RCREC1,RCRECTDA,RCSSN,RCTYP,CRT,DIR,DIROUT,DIRUT,DTOUT,DUOUT
  1. N RCSTOP,PAGE,SEPLINE,X,XX,Y,RCNO
  1. S CRT=$S(IOST["C-":1,1:0) ; 1 - Print to Screen, 0 - Otherwise
  1. I '$D(ZTQUEUED) U 0 W !!?5,"Compiling Claims Matching Report for Excel output. Please wait ... " U IO
  1. ;
  1. ; build the initial ^TMP("RCDPRTPB",$J) scratch global
  1. D @($S(RCSORT=1:"PAT",RCSORT=2:"BILL",RCSORT=3:"DATE",RCSORT=4:"REC",RCSORT=5:"TYPE")_"^RCDPRTP0")
  1. ;
  1. S IOSL=999999 ; Long screen length for Excel output
  1. S PAGE=0,RCSTOP=0,$P(SEPLINE,"-",81)=""
  1. ;
  1. I '$D(^TMP("RCDPRTPB",$J)) D Q
  1. . W:CRT @IOF W:'CRT $C(13) ; initial form feed or page reset for no data found
  1. . W !!?5,"No data found for this report."
  1. . I CRT,'$D(ZTQUEUED) S DIR(0)="E" D ^DIR K DIR
  1. . D ^%ZISC
  1. . Q
  1. ;
  1. START ;
  1. N RCPAT0,NAME,BILLNUM,BILLFROM,BILLTO,RXCOV,RCIBFN,DOB,AMT,CHGTYP,STATUS
  1. N RCH,AMT1,PAYOR,PST,FILLFROM,FILLTO,ONHOLD,RCAMT,RCAMT1,RCIBDAT,STRING,RCBILL0
  1. N RCQ,RCSSN,RCTP,RCEXNAM,ELIG,FPCBILL,POSTDATE,RCDOB,RCFLAG,BAL,DATE,DEBTOR,RCDATE,RCDEBTOR,RCNAME
  1. D EXCELHD
  1. ;
  1. S RCNAM="" F S RCNAM=$O(^TMP("RCDPRTPB",$J,RCNAM)) Q:RCNAM="" D
  1. .S RCBILL=0 F S RCBILL=$O(^TMP("RCDPRTPB",$J,RCNAM,RCBILL)) Q:'RCBILL D
  1. ..D DEMOG
  1. ..D PROC^RCDPRTP1 ; Process each third party bill for a patient.
  1. ..K ^TMP("IBRBT",$J),^TMP("IBRBF",$J)
  1. ;
  1. D ^%ZISC
  1. K ^TMP("RCDPRTPB",$J)
  1. Q
  1. ;
  1. DEMOG ; Demographic data for third party bills &
  1. ; first party charges detail line header
  1. ;
  1. S RCPAT0=$G(^TMP("RCDPRTPB",$J,RCNAM))
  1. S DATE=$G(^TMP("RCDPRTPB",$J,RCNAM,RCBILL))
  1. S RCNAME=$P(RCNAM,"^")
  1. S RCBILL0=$G(^PRCA(430,RCBILL,0))
  1. S RCDFN=$P($G(^PRCA(430,RCBILL,0)),U,7)
  1. S RCDOB=$P($G(^DPT(RCDFN,0)),U,3)
  1. S DOB=$$FMTE^XLFDT(RCDOB,"5Z")
  1. S DEBTOR=$P($G(RCBILL0),U,9)
  1. S RCDEBTOR=$O(^RCD(340,"B",RCDFN_";DPT(",0)) Q:'RCDEBTOR
  1. S RCSSN=$$SSN^RCFN01($G(RCDEBTOR))
  1. S ELIG=$P($G(RCPAT0),U,2)
  1. Q
  1. ;
  1. PRNTPAT ; setup & print third party bills (called by PROC^RCDPRTP1 for Excel output only)
  1. S RCTP=RCBILL,RCIBDAT=$G(^TMP("IBRBT",$J,RCBILL,RCBILL))
  1. S STATUS=$$STAT^RCDPRTP2(RCTP) Q:STATUS="CN"!(STATUS="CB") ;Added a last minute check for cancelled third party bills
  1. S RXCOV=$S('$G(^TMP("IBRBT",$J,RCBILL)):"NO",1:"YES")
  1. S BILLNUM=$P(RCIBDAT,U,4) ; BILL #
  1. S PST=$P(RCIBDAT,U,5) ; P/S/T
  1. S BILLFROM=$$DATE^RCDPRTP2($P(RCIBDAT,U)) ; bill date from
  1. S BILLTO=$$DATE^RCDPRTP2($P(RCIBDAT,U,2)) ; bill date to
  1. S RCDATE=$S($G(RCTP(RCTP)):RCTP(RCTP),$G(^TMP("RCDPRTPB",$J,RCNAM,RCBILL)):^(RCBILL),1:"") I RCTP=RCBILL!($D(RCTP(RCTP))) S POSTDATE=$$DATE^RCDPRTP2(RCDATE)
  1. S RCIBFN=RCTP
  1. S RCDATE=$P($G(^PRCA(430,+RCTP,0)),U,14)
  1. S POSTDATE=$S(RCDATE=DATE:$$DATE^RCDPRTP2(RCDATE),RCDATE'=DATE:"^")
  1. S PAYOR=$P(RCIBDAT,U,7) ; payor
  1. S RCAMT=$P($G(^PRCA(430,+RCTP,0)),"^",3) ; amt billed
  1. S RCAMT1=$P($G(^PRCA(430,+RCTP,7)),"^",7) ; amt paid
  1. S RCTYPE=$$TYP^IBRFN(RCTP) ;Third party bill type of care
  1. S RCTYPE=$S(RCTYPE="":-1,RCTYPE="PR":"P",RCTYPE="PH":"R",1:RCTYPE)
  1. S RCFLAG=RCTYPE
  1. S RCTP=RCBILL
  1. D EXCELPAT
  1. ;
  1. EXCELTPB ; print other assoc. third party bills
  1. S RCTP=0 F S RCTP=$O(^TMP("IBRBT",$J,RCBILL,RCTP)) Q:'RCTP D
  1. .S STATUS=$$STAT^RCDPRTP2(RCTP) Q:STATUS="CN"!(STATUS="CB") ;Added a last minute check for cancelled third party bills
  1. .I RCBILL=RCTP Q ; don't reprint the bill that was paid.
  1. .S RCIBDAT=$G(^TMP("IBRBT",$J,RCBILL,RCTP))
  1. .I 'RCAN,($P(RCIBDAT,"^",3)) Q ; exclude cancelled bills
  1. .D DEMOG
  1. .S RXCOV=$S('$G(^TMP("IBRBT",$J,RCBILL)):"NO",1:"YES")
  1. .S BILLNUM=$P(RCIBDAT,U,4) ; BILL #
  1. .S PST=$P(RCIBDAT,U,5) ; P/S/T
  1. .S BILLFROM=$$DATE^RCDPRTP2($P(RCIBDAT,U)) ; bill date from
  1. .S BILLTO=$$DATE^RCDPRTP2($P(RCIBDAT,U,2)) ; bill date to
  1. .S RCDATE=$P($G(^PRCA(430,+RCTP,0)),U,14)
  1. .S POSTDATE=$S(RCDATE=DATE:$$DATE^RCDPRTP2(RCDATE),RCDATE'=DATE:"^")
  1. .S RCIBFN=RCTP
  1. .S PAYOR=$P(RCIBDAT,U,7) ; payor
  1. .S RCAMT=$P($G(^PRCA(430,+RCTP,0)),"^",3) ; amt billed
  1. .S RCAMT1=$P($G(^PRCA(430,+RCTP,7)),"^",7) ; amt paid
  1. .S RCTYPE=$$TYP^IBRFN(RCTP) ;Third party bill type of care
  1. .S RCTYPE=$S(RCTYPE="":-1,RCTYPE="PR":"P",RCTYPE="PH":"R",1:RCTYPE)
  1. .D EXCELPAT
  1. ;
  1. PRNTFPC ; print associated first party charges
  1. ; This code screens entries from file 350.1 returned by API - RELBILL^IBRFN
  1. N RCACTYP,I,J ;Do the next section of code only if Care Types were selected - Stored in RCTYPE([care type])
  1. ; We must loop through all Bills and First party charges for this screening
  1. I $D(RCTYPE)>1 S I=0 F S I=$O(^TMP("IBRBF",$J,I)) Q:'I S J=0 F S J=$O(^TMP("IBRBF",$J,I,J)) Q:'J D
  1. . S RCACTYP=$P(^TMP("IBRBF",$J,I,J),U,6) Q:RCACTYP="" ;6th piece is Action Type
  1. . I RCACTYP["TRICARE"!(RCACTYP["CHAMPA") Q ;Not needed for screening 1st party charges
  1. . I RCACTYP["RX" S RCTYP="R" D KILFPTY^RCDPRTP1 Q
  1. . I RCACTYP["OPT"!(RCACTYP["OBSERV") S RCTYP="O" D KILFPTY^RCDPRTP1 Q
  1. . I RCACTYP["INPT"!(RCACTYP["NHCU")!(RCACTYP["ADMIS")!(RCACTYP["MEDICARE DECUCTIBLE") S RCTYP="I" D KILFPTY^RCDPRTP1 Q
  1. . Q
  1. ;
  1. S RCTP(0)=0 F S RCTP(0)=$O(^TMP("IBRBF",$J,RCTP(0))) Q:'RCTP(0)!$G(RCQ) D
  1. .S RCTP=0 F S RCTP=$O(^TMP("IBRBF",$J,RCTP(0),RCTP)) Q:'RCTP!$G(RCQ) D
  1. ..S RCNO=1
  1. ..S RCIBDAT=$G(^TMP("IBRBF",$J,RCTP(0),RCTP))
  1. ..S RCIBFN=$P(RCIBDAT,U,4) I RCIBFN S RCIBFN=$O(^PRCA(430,"B",RCIBFN,0))
  1. ..D DEMOG
  1. ..S RXCOV=$S('$G(^TMP("IBRBT",$J,RCBILL)):"NO",1:"YES")
  1. ..S FILLFROM=$$DATE^RCDPRTP2(+RCIBDAT) ; Bill from
  1. ..S FILLTO=$$DATE^RCDPRTP2($P(RCIBDAT,U,2)) ; Bill to
  1. ..S CHGTYP=$P(RCIBDAT,U,6)
  1. ..S RCIBFN=$P(RCIBDAT,"^",4) I RCIBFN S RCIBFN=$O(^PRCA(430,"B",RCIBFN,0))
  1. ..S FPCBILL=$P(RCIBDAT,U,4)
  1. ..S STATUS=$$STAT^RCDPRTP2(RCIBFN) ; Status
  1. ..S ONHOLD=$P(RCIBDAT,U,7) ; # Days On Hold
  1. ..S AMT=$P(RCIBDAT,U,5) ; Amount billed
  1. ..S BAL=$S($G(^PRCA(430,+RCIBFN,7)):+($P(^(7),"^")+$P(^(7),"^",2)+$P(^(7),"^",3)+$P(^(7),"^",4)+$P(^(7),"^",4)),1:0)
  1. ..D EXCELFPC
  1. .Q
  1. Q
  1. ;
  1. EXCELHD ; Print an Excel CSV header record
  1. ;
  1. ; Input: None
  1. ; Output: Header line printed for CSV format (excel)
  1. ;
  1. W:CRT @IOF W:'CRT $C(13) ; initial form feed or page reset for Excel header line
  1. N RCH
  1. S STRING=""
  1. S RCH=$$CSV("","Patient")
  1. S RCH=$$CSV(RCH,"SSN")
  1. S RCH=$$CSV(RCH,"DOB")
  1. S RCH=$$CSV(RCH,"Prim. Elig")
  1. S RCH=$$CSV(RCH,"RX Cvg")
  1. S RCH=$$CSV(RCH,"Bill Type")
  1. S RCH=$$CSV(RCH,"Bill#")
  1. S RCH=$$CSV(RCH,"P/S/T")
  1. S RCH=$$CSV(RCH,"Chg Type")
  1. S RCH=$$CSV(RCH,"Status")
  1. S RCH=$$CSV(RCH,"Bill From")
  1. S RCH=$$CSV(RCH,"Bill To")
  1. S RCH=$$CSV(RCH,"Posted")
  1. S RCH=$$CSV(RCH,"Amt Billed")
  1. S RCH=$$CSV(RCH,"Amt Pd")
  1. S RCH=$$CSV(RCH,"Bal")
  1. S RCH=$$CSV(RCH,"Care Type")
  1. S RCH=$$CSV(RCH,"On Hold")
  1. S RCH=$$CSV(RCH,"Payor")
  1. W RCH
  1. Q
  1. ;
  1. EXCELPAT ; Print patient third party bills
  1. ;
  1. ; Input: None
  1. ; Output: Detail line printed for CSV format (excel)
  1. ;
  1. N RCD
  1. S STRING=""
  1. S RCD=$$CSV("",RCNAME)_"^"_$E(RCNAME,1)_$E(RCSSN,6,9)
  1. S RCD=$$CSV(RCD,DOB)
  1. S RCD=$$CSV(RCD,ELIG)
  1. S RCD=$$CSV(RCD,RXCOV)
  1. S RCD=$$CSV(RCD,"Third Party Bill")
  1. S RCD=$$CSV(RCD,BILLNUM)
  1. S RCD=$$CSV(RCD,PST)
  1. S RCD=$$CSV(RCD,"^")
  1. S RCD=$$CSV(RCD,STATUS)
  1. S RCD=$$CSV(RCD,BILLFROM)
  1. S RCD=$$CSV(RCD,BILLTO)
  1. S RCD=$$CSV(RCD,POSTDATE)
  1. S RCD=$$CSV(RCD,RCAMT)
  1. S RCD=$$CSV(RCD,RCAMT1)
  1. S RCD=$$CSV(RCD,"^")
  1. S RCD=$$CSV(RCD,RCTYPE)
  1. S RCD=$$CSV(RCD,"^")
  1. S RCD=$$CSV(RCD,PAYOR)
  1. W !,RCD
  1. K RCTP(RCTP)
  1. Q
  1. ;
  1. EXCELFPC ; Print patient first party charges
  1. ;
  1. ; Input: None
  1. ; Output: Detail line printed for CSV format (excel)
  1. ;
  1. N RCB
  1. S STRING=""
  1. S RCB=$$CSV("",RCNAME)_"^"_$E(RCNAME,1)_$E(RCSSN,6,9)
  1. S RCB=$$CSV(RCB,DOB)
  1. S RCB=$$CSV(RCB,ELIG)
  1. S RCB=$$CSV(RCB,"^")
  1. S RCB=$$CSV(RCB,"First Party Charge")
  1. S RCB=$$CSV(RCB,FPCBILL)
  1. S RCB=$$CSV(RCB,"^")
  1. S RCB=$$CSV(RCB,CHGTYP)
  1. S RCB=$$CSV(RCB,STATUS)
  1. S RCB=$$CSV(RCB,FILLFROM)
  1. S RCB=$$CSV(RCB,FILLTO)
  1. S RCB=$$CSV(RCB,"^")
  1. S RCB=$$CSV(RCB,AMT)
  1. S RCB=$$CSV(RCB,"^")
  1. S RCB=$$CSV(RCB,BAL)
  1. S RCB=$$CSV(RCB,"^")
  1. S RCB=$$CSV(RCB,ONHOLD)
  1. W !,RCB
  1. Q
  1. ;
  1. CSV(STRING,DATA) ; Build the Excel data string for CSV format
  1. ; Input: STRING - Current string being built or ""
  1. ; DATA - New data to be added to the string
  1. ; Returns: STRING - Updated string with DATA added
  1. ;
  1. S DATA=""_$TR(DATA,$C(94))
  1. S STRING=$S(STRING="":DATA,1:STRING_"^"_DATA)
  1. Q STRING
  1. ;