IBTRKR ;ALB/AAS - CLAIMS TRACKER - AUTO-ENROLLER ; 4-AUG-93
;;2.0;INTEGRATED BILLING;**23,43,45,56,214,547,565**;21-MAR-94;Build 41
;;Per VA Directive 6402, this routine should not be modified.
;
INP ; -- Inpatient Tracker
; called by ibamtd from DGPM MOVEMENT EVENTS
; add edit delete
; dgpma = after movement 0th node file 405 : data data null
; dgpmp = prior movement 0th node file 405 : null data data
; dfn = ien of patient
;
N %,%H,%I,IBMVAD,IBMVTP,IBTRKR
;
; inpatient claims tracking turned off
S IBTRKR=$G(^IBE(350.9,1,6)) I '$P(IBTRKR,"^",2) Q
;
; movement type 1=admission, 2=transfer, 3=discharge, 6=specialty chg
S IBMVTP=$S($P(DGPMA,"^",2):$P(DGPMA,"^",2),1:$P(DGPMP,"^",2)) I 'IBMVTP Q
;
; $p(14)=admission movement ptr entry in file 405
S IBMVAD=$S(DGPMA'="":$P(DGPMA,"^",14),1:$P(DGPMP,"^",14)) I 'IBMVAD Q
;
D WRITE("Updating claims tracking ... ",2)
;
I '$D(VAIN(1)) D INP^VADPT
;
; add/edit admission
I IBMVTP=1 D ADMIT Q
;
; transfer to asih (patch 23)
I $P($G(^DGPM(+$P(DGPMA,"^",15),0)),"^",2)=1 S IBMVAD=$P(DGPMA,"^",15) D ADMIT Q
;
; specialty change
I IBMVTP=6 D SPECIAL Q
;
D WRITE("completed.")
Q
;
;
WRITE(MSG,FF) ; write message on screen if not silent
; write 'F'orm 'F'eeds count followed by msg (optional)
N %
I '$D(IB20),'$G(DGQUIET) D
. F %=1:1:$G(FF) W !
. W MSG
Q
;
;
ADMIT ; -- process admission movements
; ibmvad is admission movement pointer to file 405
; dgpma is movement entry from file 405
N %,%H,%I,IBCTFLAG,IBNEW,IBRANDOM,IBTRN,LASTADM,LASTDA,LASTDATA
;
; this is a deleted admission from file 405, dgpma=null
I DGPMA="" D DELADMIT Q
;
; try and relink to existing entry if already there
; find the last admission, check to make sure its inactive and there
; is not a pointer to the movement file ($p(5)). if the current
; admission date is within 5 days, update the entry.
S LASTADM=$O(^IBT(356,"APTY",DFN,+$O(^IBE(356.6,"AC",1,0)),9999999),-1)
I LASTADM S LASTDA=+$O(^IBT(356,"APTY",DFN,1,LASTADM,0)),LASTDATA=$G(^IBT(356,LASTDA,0)) I $P(LASTDATA,"^",20)=0,$P(LASTDATA,"^",5)="" D Q:$G(IBCTFLAG)
. S %=$$FMDIFF^XLFDT($P(DGPMA,"."),$P(LASTADM,"."))
. I %>-5,%<5 D RELINK^IBTRKRU(LASTDA,IBMVAD,$P(DGPMA,"^")),RELBULL^IBTRKRBR(DFN,LASTDA,DGPMA,+$G(VAIN(3))),WRITE("entry re-linked.") S IBCTFLAG=1
;
; random sampler, admission date must equal today (dt)
I +$G(VAIN(3)),($E(+DGPMA,1,7)=DT) S IBRANDOM=$$RANDOM^IBTRKR1(+VAIN(3))
;
N D,D0,DI,DIG,DIH,DIU,DIV,DQ,IBADMDT,IBETYP ; variables left by ibtutl
; inpatient claims tracking = all patients
; no visit date/time for inpatient events - IB*2.0*565
I $P(IBTRKR,"^",2)=2 D Q
. D ADM^IBTUTL(IBMVAD,+$E(+DGPMA,1,12),$G(IBRANDOM))
. D WRITE("entry "_$S($G(IBNEW):"added.",1:"edited."))
. I $G(IBRANDOM),$G(IBTRN) D ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$G(VAIN(3)))
;
; inpatient claims tracking = insured and ur only
I $P(IBTRKR,"^",2)=1,$S($G(IBRANDOM):1,'$$INSURED^IBCNS1(DFN,+DGPMA):0,1:$$PTCOV^IBCNSU3(DFN,+DGPMA,"INPATIENT")) D Q
. D ADM^IBTUTL(IBMVAD,+$E(+DGPMA,1,12),$G(IBRANDOM))
. D WRITE("entry "_$S($G(IBNEW):"added.",1:"edited."))
. I $G(IBRANDOM),$G(IBTRN) D ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$G(VAIN(3)))
;
; inpatient claims tracking = insured and ur only, but not insurred
; need to send off RDV in background
N IBT
I $P(IBTRKR,"^",2)=1,'$$INSURED^IBCNS1(DFN,+DGPMA),$$TFL^IBARXMU(DFN,.IBT),'$D(^IBT(356,"ARDV",DFN)) D ADM^IBCNRDV(DFN,IBMVAD,+$E(+DGPMA,1,12),$G(IBRANDOM)) D WRITE("Remote Query for insurance sent.") Q
;
;
D WRITE("no action taken.")
Q
;
;
DELADMIT ; deleted admission
N DA,FILE,IBDATE,IBTRN,SPECALTY
S IBTRN=$O(^IBT(356,"AD",+IBMVAD,0)) I IBTRN D Q
. S SPECALTY=+$P($G(^UTILITY($J,"ATS",+$P(DGPMP,"^"),+$O(^UTILITY($J,"ATS",+$P(DGPMP,"^"),0)))),"^",9)
. ; send information bulletin
. D DELBULL^IBTRKRBD(DFN,IBTRN,DGPMP,SPECALTY)
. ; clean up files pointing to 405
. F FILE=356.9,356.91,356.94 S DA=0 F S DA=$O(^IBT(FILE,"C",+IBMVAD,DA)) Q:'DA D DELETE^IBTRKRU(FILE,DA)
. S IBDATE=0 F S IBDATE=$O(^IBT(356.93,"AMVD",+IBMVAD,IBDATE)) Q:'IBDATE S DA=0 F S DA=$O(^IBT(356.93,"AMVD",+IBMVAD,IBDATE,DA)) Q:'DA D DELETE^IBTRKRU(356.93,DA)
. ; inactivate entry in ct 356
. D INACTIVE^IBTRKRU(IBTRN)
. D WRITE("entry inactivated.")
D WRITE("no action taken.")
Q
;
;
SPECIAL ; specialty change
; deleted movement
I DGPMA="" D WRITE("no action taken.") Q
;
; if specialty change is past 7 days, quit
I +DGPMA<$$FMADD^XLFDT(+DT,-7) D WRITE("no action taken.") Q
;
N IBDT,IBTSA,IBTSP,IBTRC,IBTRN,IBTRV
; treating specialty after
S IBTSA=$P($G(^DIC(42.4,+$P($G(^DIC(45.7,+$P(DGPMA,"^",9),0)),"^",2),0)),"^",3)
;
; treating specialty before
I DGPMP'="" S IBTSP=$P($G(^DIC(42.4,+$P($G(^DIC(45.7,+$P(DGPMP,"^",9),0)),"^",2),0)),"^",3)
;
I DGPMP="" D
. S IBDT=9999999.9999999-$P(DGPMA,"^")
. S IBTSP=$P($G(^DIC(45.7,+$O(^(+$O(^DGPM("ATS",+DFN,+IBMVAD,+IBDT)),0)),0)),"^",2)
. S IBTSP=$P($G(^DIC(42.4,+IBTSP,0)),"^",3)
;
; no change in major bed section
I IBTSA=IBTSP D WRITE("no action taken.") Q
;
S IBTRN=$O(^IBT(356,"AD",+IBMVAD,0))
;
; tracked as hospital review
I $O(^IBT(356.1,"C",+IBTRN,0)) D
. I $$ALREADY(356.1,+DGPMA) Q
. D PRE^IBTUTL2($E(+DGPMA,1,7),IBTRN,30)
. I $G(IBTRV) D COMMENT^IBTRKRU(356.1,+IBTRV)
;
; tracked as insurance review
I $O(^IBT(356.2,"C",+IBTRN,0)) D
. I $$ALREADY(356.2,+DGPMA) Q
. I $P($G(^IBT(356,+IBTRN,0)),"^",24) D COM^IBTUTL3($E(+DGPMA,1,12),IBTRN,30)
. I $G(IBTRC) D COMMENT^IBTRKRU(356.2,+IBTRC)
;
D WRITE("completed.")
Q
;
;
ALREADY(FILE,DATE) ; -- see if already is review for date
N X,Y,IBX
S IBX=0
S X=$P(DATE,".")+.25
S Y=$O(^IBT(FILE,"ATIDT",+IBTRN,-X)) S Y=-Y I Y,$P(Y,".")=$P(DATE,".") S IBX=1
Q IBX
;
;
NIGHTLY ; -- nightly job for claims tracking, called by IBAMTC
;
D PURG^IBRFIHL1 ; purge RFAI file (#368) - IB*2.0*547
D PURGWL^IBRFIWLA ; purge Out of Date WLs of RFAI file (#368) - IB*2.0*547
D UPDATE^IBTRKR1 ; pdate claims tracking site parameters (random sampler)
D ^IBTRKR2 ; add scheduled admissions to tracking
D ^IBTRKR3 ; add rx refill to outpatient encounters
D ^IBTRKR4 ; add outpatient encounters to tracking
D ^IBTRKR5 ; add outpatient prosthetics item to tracking
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HIBTRKR 6569 printed Dec 13, 2024@02:28:35 Page 2
IBTRKR ;ALB/AAS - CLAIMS TRACKER - AUTO-ENROLLER ; 4-AUG-93
+1 ;;2.0;INTEGRATED BILLING;**23,43,45,56,214,547,565**;21-MAR-94;Build 41
+2 ;;Per VA Directive 6402, this routine should not be modified.
+3 ;
INP ; -- Inpatient Tracker
+1 ; called by ibamtd from DGPM MOVEMENT EVENTS
+2 ; add edit delete
+3 ; dgpma = after movement 0th node file 405 : data data null
+4 ; dgpmp = prior movement 0th node file 405 : null data data
+5 ; dfn = ien of patient
+6 ;
+7 NEW %,%H,%I,IBMVAD,IBMVTP,IBTRKR
+8 ;
+9 ; inpatient claims tracking turned off
+10 SET IBTRKR=$GET(^IBE(350.9,1,6))
IF '$PIECE(IBTRKR,"^",2)
QUIT
+11 ;
+12 ; movement type 1=admission, 2=transfer, 3=discharge, 6=specialty chg
+13 SET IBMVTP=$SELECT($PIECE(DGPMA,"^",2):$PIECE(DGPMA,"^",2),1:$PIECE(DGPMP,"^",2))
IF 'IBMVTP
QUIT
+14 ;
+15 ; $p(14)=admission movement ptr entry in file 405
+16 SET IBMVAD=$SELECT(DGPMA'="":$PIECE(DGPMA,"^",14),1:$PIECE(DGPMP,"^",14))
IF 'IBMVAD
QUIT
+17 ;
+18 DO WRITE("Updating claims tracking ... ",2)
+19 ;
+20 IF '$DATA(VAIN(1))
DO INP^VADPT
+21 ;
+22 ; add/edit admission
+23 IF IBMVTP=1
DO ADMIT
QUIT
+24 ;
+25 ; transfer to asih (patch 23)
+26 IF $PIECE($GET(^DGPM(+$PIECE(DGPMA,"^",15),0)),"^",2)=1
SET IBMVAD=$PIECE(DGPMA,"^",15)
DO ADMIT
QUIT
+27 ;
+28 ; specialty change
+29 IF IBMVTP=6
DO SPECIAL
QUIT
+30 ;
+31 DO WRITE("completed.")
+32 QUIT
+33 ;
+34 ;
WRITE(MSG,FF) ; write message on screen if not silent
+1 ; write 'F'orm 'F'eeds count followed by msg (optional)
+2 NEW %
+3 IF '$DATA(IB20)
IF '$GET(DGQUIET)
Begin DoDot:1
+4 FOR %=1:1:$GET(FF)
WRITE !
+5 WRITE MSG
End DoDot:1
+6 QUIT
+7 ;
+8 ;
ADMIT ; -- process admission movements
+1 ; ibmvad is admission movement pointer to file 405
+2 ; dgpma is movement entry from file 405
+3 NEW %,%H,%I,IBCTFLAG,IBNEW,IBRANDOM,IBTRN,LASTADM,LASTDA,LASTDATA
+4 ;
+5 ; this is a deleted admission from file 405, dgpma=null
+6 IF DGPMA=""
DO DELADMIT
QUIT
+7 ;
+8 ; try and relink to existing entry if already there
+9 ; find the last admission, check to make sure its inactive and there
+10 ; is not a pointer to the movement file ($p(5)). if the current
+11 ; admission date is within 5 days, update the entry.
+12 SET LASTADM=$ORDER(^IBT(356,"APTY",DFN,+$ORDER(^IBE(356.6,"AC",1,0)),9999999),-1)
+13 IF LASTADM
SET LASTDA=+$ORDER(^IBT(356,"APTY",DFN,1,LASTADM,0))
SET LASTDATA=$GET(^IBT(356,LASTDA,0))
IF $PIECE(LASTDATA,"^",20)=0
IF $PIECE(LASTDATA,"^",5)=""
Begin DoDot:1
+14 SET %=$$FMDIFF^XLFDT($PIECE(DGPMA,"."),$PIECE(LASTADM,"."))
+15 IF %>-5
IF %<5
DO RELINK^IBTRKRU(LASTDA,IBMVAD,$PIECE(DGPMA,"^"))
DO RELBULL^IBTRKRBR(DFN,LASTDA,DGPMA,+$GET(VAIN(3)))
DO WRITE("entry re-linked.")
SET IBCTFLAG=1
End DoDot:1
if $GET(IBCTFLAG)
QUIT
+16 ;
+17 ; random sampler, admission date must equal today (dt)
+18 IF +$GET(VAIN(3))
IF ($EXTRACT(+DGPMA,1,7)=DT)
SET IBRANDOM=$$RANDOM^IBTRKR1(+VAIN(3))
+19 ;
+20 ; variables left by ibtutl
NEW D,D0,DI,DIG,DIH,DIU,DIV,DQ,IBADMDT,IBETYP
+21 ; inpatient claims tracking = all patients
+22 ; no visit date/time for inpatient events - IB*2.0*565
+23 IF $PIECE(IBTRKR,"^",2)=2
Begin DoDot:1
+24 DO ADM^IBTUTL(IBMVAD,+$EXTRACT(+DGPMA,1,12),$GET(IBRANDOM))
+25 DO WRITE("entry "_$SELECT($GET(IBNEW):"added.",1:"edited."))
+26 IF $GET(IBRANDOM)
IF $GET(IBTRN)
DO ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$GET(VAIN(3)))
End DoDot:1
QUIT
+27 ;
+28 ; inpatient claims tracking = insured and ur only
+29 IF $PIECE(IBTRKR,"^",2)=1
IF $SELECT($GET(IBRANDOM):1,'$$INSURED^IBCNS1(DFN,+DGPMA):0,1:$$PTCOV^IBCNSU3(DFN,+DGPMA,"INPATIENT"))
Begin DoDot:1
+30 DO ADM^IBTUTL(IBMVAD,+$EXTRACT(+DGPMA,1,12),$GET(IBRANDOM))
+31 DO WRITE("entry "_$SELECT($GET(IBNEW):"added.",1:"edited."))
+32 IF $GET(IBRANDOM)
IF $GET(IBTRN)
DO ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$GET(VAIN(3)))
End DoDot:1
QUIT
+33 ;
+34 ; inpatient claims tracking = insured and ur only, but not insurred
+35 ; need to send off RDV in background
+36 NEW IBT
+37 IF $PIECE(IBTRKR,"^",2)=1
IF '$$INSURED^IBCNS1(DFN,+DGPMA)
IF $$TFL^IBARXMU(DFN,.IBT)
IF '$DATA(^IBT(356,"ARDV",DFN))
DO ADM^IBCNRDV(DFN,IBMVAD,+$EXTRACT(+DGPMA,1,12),$GET(IBRANDOM))
DO WRITE("Remote Query for insurance sent.")
QUIT
+38 ;
+39 ;
+40 DO WRITE("no action taken.")
+41 QUIT
+42 ;
+43 ;
DELADMIT ; deleted admission
+1 NEW DA,FILE,IBDATE,IBTRN,SPECALTY
+2 SET IBTRN=$ORDER(^IBT(356,"AD",+IBMVAD,0))
IF IBTRN
Begin DoDot:1
+3 SET SPECALTY=+$PIECE($GET(^UTILITY($JOB,"ATS",+$PIECE(DGPMP,"^"),+$ORDER(^UTILITY($JOB,"ATS",+$PIECE(DGPMP,"^"),0)))),"^",9)
+4 ; send information bulletin
+5 DO DELBULL^IBTRKRBD(DFN,IBTRN,DGPMP,SPECALTY)
+6 ; clean up files pointing to 405
+7 FOR FILE=356.9,356.91,356.94
SET DA=0
FOR
SET DA=$ORDER(^IBT(FILE,"C",+IBMVAD,DA))
if 'DA
QUIT
DO DELETE^IBTRKRU(FILE,DA)
+8 SET IBDATE=0
FOR
SET IBDATE=$ORDER(^IBT(356.93,"AMVD",+IBMVAD,IBDATE))
if 'IBDATE
QUIT
SET DA=0
FOR
SET DA=$ORDER(^IBT(356.93,"AMVD",+IBMVAD,IBDATE,DA))
if 'DA
QUIT
DO DELETE^IBTRKRU(356.93,DA)
+9 ; inactivate entry in ct 356
+10 DO INACTIVE^IBTRKRU(IBTRN)
+11 DO WRITE("entry inactivated.")
End DoDot:1
QUIT
+12 DO WRITE("no action taken.")
+13 QUIT
+14 ;
+15 ;
SPECIAL ; specialty change
+1 ; deleted movement
+2 IF DGPMA=""
DO WRITE("no action taken.")
QUIT
+3 ;
+4 ; if specialty change is past 7 days, quit
+5 IF +DGPMA<$$FMADD^XLFDT(+DT,-7)
DO WRITE("no action taken.")
QUIT
+6 ;
+7 NEW IBDT,IBTSA,IBTSP,IBTRC,IBTRN,IBTRV
+8 ; treating specialty after
+9 SET IBTSA=$PIECE($GET(^DIC(42.4,+$PIECE($GET(^DIC(45.7,+$PIECE(DGPMA,"^",9),0)),"^",2),0)),"^",3)
+10 ;
+11 ; treating specialty before
+12 IF DGPMP'=""
SET IBTSP=$PIECE($GET(^DIC(42.4,+$PIECE($GET(^DIC(45.7,+$PIECE(DGPMP,"^",9),0)),"^",2),0)),"^",3)
+13 ;
+14 IF DGPMP=""
Begin DoDot:1
+15 SET IBDT=9999999.9999999-$PIECE(DGPMA,"^")
+16 SET IBTSP=$PIECE($GET(^DIC(45.7,+$ORDER(^(+$ORDER(^DGPM("ATS",+DFN,+IBMVAD,+IBDT)),0)),0)),"^",2)
+17 SET IBTSP=$PIECE($GET(^DIC(42.4,+IBTSP,0)),"^",3)
End DoDot:1
+18 ;
+19 ; no change in major bed section
+20 IF IBTSA=IBTSP
DO WRITE("no action taken.")
QUIT
+21 ;
+22 SET IBTRN=$ORDER(^IBT(356,"AD",+IBMVAD,0))
+23 ;
+24 ; tracked as hospital review
+25 IF $ORDER(^IBT(356.1,"C",+IBTRN,0))
Begin DoDot:1
+26 IF $$ALREADY(356.1,+DGPMA)
QUIT
+27 DO PRE^IBTUTL2($EXTRACT(+DGPMA,1,7),IBTRN,30)
+28 IF $GET(IBTRV)
DO COMMENT^IBTRKRU(356.1,+IBTRV)
End DoDot:1
+29 ;
+30 ; tracked as insurance review
+31 IF $ORDER(^IBT(356.2,"C",+IBTRN,0))
Begin DoDot:1
+32 IF $$ALREADY(356.2,+DGPMA)
QUIT
+33 IF $PIECE($GET(^IBT(356,+IBTRN,0)),"^",24)
DO COM^IBTUTL3($EXTRACT(+DGPMA,1,12),IBTRN,30)
+34 IF $GET(IBTRC)
DO COMMENT^IBTRKRU(356.2,+IBTRC)
End DoDot:1
+35 ;
+36 DO WRITE("completed.")
+37 QUIT
+38 ;
+39 ;
ALREADY(FILE,DATE) ; -- see if already is review for date
+1 NEW X,Y,IBX
+2 SET IBX=0
+3 SET X=$PIECE(DATE,".")+.25
+4 SET Y=$ORDER(^IBT(FILE,"ATIDT",+IBTRN,-X))
SET Y=-Y
IF Y
IF $PIECE(Y,".")=$PIECE(DATE,".")
SET IBX=1
+5 QUIT IBX
+6 ;
+7 ;
NIGHTLY ; -- nightly job for claims tracking, called by IBAMTC
+1 ;
+2 ; purge RFAI file (#368) - IB*2.0*547
DO PURG^IBRFIHL1
+3 ; purge Out of Date WLs of RFAI file (#368) - IB*2.0*547
DO PURGWL^IBRFIWLA
+4 ; pdate claims tracking site parameters (random sampler)
DO UPDATE^IBTRKR1
+5 ; add scheduled admissions to tracking
DO ^IBTRKR2
+6 ; add rx refill to outpatient encounters
DO ^IBTRKR3
+7 ; add outpatient encounters to tracking
DO ^IBTRKR4
+8 ; add outpatient prosthetics item to tracking
DO ^IBTRKR5
+9 QUIT