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

IBCERPN.m

Go to the documentation of this file.
  1. IBCERPN ;ALB/VD - RPN Resubmission/Printing Claims No Changes CSA Report ;1/16/2019
  1. ;;2.0;INTEGRATED BILLING;**641**;21-MAR-94;Build 61
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ; This report is generated to provide a list of claims that have errors that
  1. ; prevent a claim from being RESUBMITTED BY PRINT, or RETRANSMITTED, or PRINTED.
  1. ; The user can use this report in tandem with the CLAIMS STATUS AWAITING RESOLUTION
  1. ; worklist.
  1. ; The user is prompted for the following dates:
  1. ; - Earliest Retransmitted/Printed Date
  1. ; - Latest Retransmitted/Printed Date
  1. ; This report has a format of 132 columns.
  1. ; This report will display the following data elements:
  1. ; - Bill #
  1. ; - Payer Name (Secondary sort)
  1. ; - Error Message (Tertiary sort based on the Error Code). If there is no Error
  1. ; message then Narrative, and if no Narrative then Category message.
  1. ; - Current Balance
  1. ; - User Name (Primary sort)
  1. ; - Date (Retransmitted/Resubmitted/Printed)
  1. ;
  1. ; Refer to US3380
  1. ; Called by EDI Return Message Management Menu (Path: Billing Clerk Menu>EDI>MM)
  1. ; Option: RPN
  1. ;
  1. ENT ; Menu Option Entry Point
  1. N BILLDT,BEGDT,BEGIN,BILLNO,CNT,CURBAL,DASH,DT,END,ENDDT,EORMSG,HDR1,HDR2,IBABEG
  1. N IBAEND,IBQUIT,LEGEND,LNCNT,MAX,NARATV,PAGES,PAYNAM,PGC,RNAME,USERNM,Y,LNTOT,POP
  1. S IBQUIT=0,RNAME="IBCERPN"
  1. D DATES Q:IBQUIT Q:'Y
  1. S LEGEND="Retransmitted/Printed Timeframe: "_BEGIN_" thru "_END
  1. D DEVICE Q:POP Q:IBQUIT
  1. QUE ; Queued Entry Point
  1. K ^TMP(RNAME,$J)
  1. D GATHER
  1. S BEGDT=$$FMTE^XLFDT(IBABEG,2),ENDDT=$$FMTE^XLFDT(IBAEND,2)
  1. S LEGEND="Retransmitted/Printed Timeframe: "_BEGDT_" thru "_ENDDT
  1. D HDRINIT
  1. D HEADER Q:IBQUIT
  1. D PRINT
  1. D EXIT
  1. Q
  1. ;
  1. DATES ; Enter the date range for this report
  1. N DIR
  1. W !
  1. S DIR(0)="DA^:DT:EX",DIR("A")="Enter Earliest Retransmitted/Printed Date: "
  1. S DIR("B")=$$HTE^XLFDT($H-30),DIR("?")="Enter the earliest retransmitted or printed date for this report."
  1. D ^DIR K DIR Q:'Y S IBABEG=+Y,BEGIN=Y(0)
  1. ;
  1. W !
  1. S DIR(0)="DA^"_+Y_":DT:EX",DIR("A")="Enter Latest Retransmitted/Printed Date: "
  1. S DIR("B")=$$FMTE^XLFDT(DT,1),DIR("?")="Enter the latest retransmitted or printed date for this report."
  1. D ^DIR K DIR Q:'Y S IBAEND=+Y,END=Y(0)
  1. Q
  1. ;
  1. DEVICE ; - Ask device
  1. N %ZIS,ZTDESC,ZTIO,ZTQUEUED,ZTRTN,ZTSAVE
  1. W !!!,"You will need a 132 column printer for this report",!
  1. S %ZIS="QM" D ^%ZIS S:POP IBQUIT=1 Q:POP
  1. I $D(IO("Q")) D S IBQUIT=1 Q
  1. . S ZTRTN="QUE^IBCERPN",ZTDESC="Resubmission/Printing claims No Changes CSA Report"
  1. . S (ZTSAVE("BEGIN"),ZTSAVE("END"),ZTSAVE("IBABEG"),ZTSAVE("IBAEND"))=""
  1. . S (ZTSAVE("BEGDT"),ZTSAVE("ENDDT"),ZTSAVE("RNAME"),ZTSAVE("IBQUIT"))=""
  1. . D ^%ZTLOAD
  1. . W !!,$S($D(ZTSK):"Your task number "_ZTSK_" has been queued.",1:"Unable to queue this job.")
  1. . K ZTSK D HOME^%ZIS
  1. . W !!! I $E(IOST,1,2)["C-" K DIR S DIR(0)="E" D ^DIR K DIR ;pause to see task no.
  1. U IO
  1. Q
  1. ;
  1. GATHER ;GATHER THE INFO BASED ON THE DATE RANGE ENTERED
  1. ; Uses the ^IBM(361,"ARPN",CURDAT,IBNO,USER,ACTION) cross-reference file to get
  1. ; data within date range. If data is within date range this sets up the ^TMP($J
  1. ; file with all data needed for the report.
  1. ;
  1. N ACTION,ARPNRC,CURDAT,IBCBAL,IBCLMNO,IBIFN,IBNO,IBOAM,IBPAY
  1. N LNCNT,SEQ,USER,USRNAM
  1. S $P(DASH,"_",132)=""
  1. S LNTOT=0,PGC=1,MAX=IOSL
  1. S CURDAT=IBABEG
  1. F S CURDAT=$O(^IBM(361,"ARPN",CURDAT)) Q:CURDAT="" Q:CURDAT>(IBAEND+1) D
  1. . S IBNO="" F S IBNO=$O(^IBM(361,"ARPN",CURDAT,IBNO)) Q:IBNO="" D
  1. .. S IBIFN=+$G(^IBM(361,IBNO,0))
  1. .. S IBCLMNO=$P($G(^DGCR(399,IBIFN,0)),U) ; External Claim No.
  1. .. S IBPAY=$P($G(^DIC(36,+$P($G(^DGCR(399,IBIFN,"MP")),U),0)),U)
  1. .. I IBPAY="" S IBPAY=$P($G(^DIC(36,+$$CURR^IBCEF2(IBIFN),0)),U)
  1. .. I IBPAY="" S IBPAY="UNKNOWN PAYER"
  1. .. S IBOAM=$G(^DGCR(399,IBIFN,"U1"))
  1. .. S IBCBAL=$P(IBOAM,U,1)-$P(IBOAM,U,2) ; current balance (total charges - offset)
  1. .. S IBEMSG=$$TXT^IBCECSA1(IBNO,60) ; error message (60 chars max).
  1. .. S:IBEMSG="" IBEMSG=" "
  1. .. S SEQ="" F S SEQ=$O(^IBM(361,"ARPN",CURDAT,IBNO,SEQ)) Q:SEQ="" D
  1. ... ;S ARPNRC=$G(^IBM(361,"ARPN",CURDAT,IBNO,SEQ))
  1. ... S ARPNRC=$G(^IBM(361,IBNO,3,SEQ,0))
  1. ... S USER=$P(ARPNRC,U,2),ACTION=$P(ARPNRC,U,3)
  1. ... S USRNAM=$P(^VA(200,USER,0),U) ; External User Name
  1. ... S ^TMP(RNAME,$J,USRNAM,IBPAY,$E(IBEMSG,1,50),CURDAT,IBCLMNO)=IBCBAL_U_ACTION_U_USER_U_IBIFN
  1. ... S LNTOT=LNTOT+1
  1. Q
  1. ;
  1. PRINT ; Print data
  1. ;
  1. ; PGC=page ct,LNTOT=no of lines to be printed,LNCNT=when to page break
  1. ; MAX=IOSL (device length)
  1. ;
  1. N CURDAT,EORMSG,IBCBAL,IBCLMNO,IBEMSG,IBPAY,LCTR,NONEMSG,USRNAM
  1. S EORMSG="*** END OF REPORT ***"
  1. S NONEMSG="* * * N O D A T A T O P R I N T * * *"
  1. S LCTR=0
  1. ;
  1. I '$D(^TMP(RNAME,$J)) W !!!,NONEMSG D END Q
  1. S USRNAM="" F S USRNAM=$O(^TMP(RNAME,$J,USRNAM)) Q:USRNAM="" D
  1. . S IBPAY="" F S IBPAY=$O(^TMP(RNAME,$J,USRNAM,IBPAY)) Q:IBPAY="" D
  1. .. S IBEMSG="" F S IBEMSG=$O(^TMP(RNAME,$J,USRNAM,IBPAY,IBEMSG)) Q:IBEMSG="" D
  1. ... S CURDAT="" F S CURDAT=$O(^TMP(RNAME,$J,USRNAM,IBPAY,IBEMSG,CURDAT)) Q:CURDAT="" Q:IBQUIT D
  1. .... S IBCLMNO="" F S IBCLMNO=$O(^TMP(RNAME,$J,USRNAM,IBPAY,IBEMSG,CURDAT,IBCLMNO)) Q:IBCLMNO="" Q:IBQUIT D
  1. ..... S IBCBAL=+$G(^TMP(RNAME,$J,USRNAM,IBPAY,IBEMSG,CURDAT,IBCLMNO))
  1. ..... I LNCNT>MAX D HEADER Q:IBQUIT
  1. ..... S LCTR=LCTR+1
  1. ..... ;W !,$J(LCTR,4),?10,$E(IBPAY,1,20),?38,$E(USRNAM,1,15),?55,$E(IBEMSG,1,50),?111,$P($$FMTE^XLFDT(CURDAT,2),"@"),?120, $J("$"_$FN(IBCBAL,"",2),12)
  1. ..... W !,$J(LCTR,3),?7,IBCLMNO,?16,$E(IBPAY,1,20),?38,$E(USRNAM,1,15),?59
  1. ..... W $E(IBEMSG,1,50),?111,$P($$FMTE^XLFDT(CURDAT,2),"@"),?120,$J("$"_$FN(IBCBAL,"",2),12)
  1. ..... S LNCNT=LNCNT+1
  1. I LNCNT>MAX D HEADER
  1. Q:IBQUIT
  1. ;
  1. END W !!!,?49,EORMSG,!!!
  1. I $E(IOST,1,2)["C-" K DIR S DIR(0)="E" D ^DIR K DIR ;pause at end of report
  1. Q
  1. ;
  1. HDRINIT ; Initial setting
  1. S LNCNT=0
  1. I PGC=1,$E(IOST,1,2)["C-" W @IOF ; refresh terminal screen on 1st hdr
  1. I 'LNTOT S PAGES=1
  1. I LNTOT,PGC=1 D
  1. . S LNCNT=0
  1. . S PAGES=LNTOT/(MAX-10)
  1. . I PAGES<1 S PAGES=1
  1. . I PAGES["." S PAGES=$P(PAGES+1,".") ; if more than one page set whole number
  1. S HDR1="Resubmission/Printing claims No Changes CSA Report"
  1. S HDR2=$$FMTE^XLFDT($$NOW^XLFDT,1)
  1. Q
  1. ;
  1. N DIR,DUOUT
  1. S LNCNT=0
  1. I PGC'=1 D Q:IBQUIT
  1. . W !
  1. . I $E(IOST,1,2)["C-" K DIR S DIR(0)="E" D ^DIR K DIR I $D(DUOUT) S IBQUIT=1 Q:IBQUIT
  1. . W @IOF ; refresh terminal screen on hdr
  1. W !,HDR1,?59,HDR2,?114," Page: "_PGC_" of "_PAGES
  1. W !,LEGEND
  1. W !!,?7,"Bill #",?17,"Payer Name",?38,"User Name",?59,"Error Message/Narrative/Category",?111,"Date",?124,"Curr Bal"
  1. W !,DASH
  1. S LNCNT=LNCNT+10,PGC=PGC+1
  1. Q
  1. EXIT() ;clean up and quit
  1. N ZTREQ
  1. ; Force a form feed at end of a printer report
  1. I $E(IOST,1,2)'["C-" W @IOF
  1. ; handle device closing before exiting
  1. I $D(ZTQUEUED) S ZTREQ="@"
  1. I '$D(ZTQUEUED) D ^%ZISC
  1. K ^TMP(RNAME,$J)
  1. K BEGIN,BEGDT,ENDDT,IBABEG,IBAEND,IBQUIT,IEN,LNCNT,Y
  1. Q