- 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 Feb 18, 2025@23:55:04 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