| [613] | 1 | IBTRKR ;ALB/AAS - CLAIMS TRACKER - AUTO-ENROLLER ; 4-AUG-93 | 
|---|
|  | 2 | ;;2.0;INTEGRATED BILLING;**23,43,45,56,214**;21-MAR-94 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | INP ; -- Inpatient Tracker | 
|---|
|  | 6 | ;    called by ibamtd  from DGPM MOVEMENT EVENTS | 
|---|
|  | 7 | ;                                               add   edit   delete | 
|---|
|  | 8 | ;  dgpma = after movement 0th node file 405  : data   data   null | 
|---|
|  | 9 | ;  dgpmp = prior movement 0th node file 405  : null   data   data | 
|---|
|  | 10 | ;  dfn   = ien of patient | 
|---|
|  | 11 | ; | 
|---|
|  | 12 | N %,%H,%I,IBMVAD,IBMVTP,IBTRKR | 
|---|
|  | 13 | ; | 
|---|
|  | 14 | ;  inpatient claims tracking turned off | 
|---|
|  | 15 | S IBTRKR=$G(^IBE(350.9,1,6)) I '$P(IBTRKR,"^",2) Q | 
|---|
|  | 16 | ; | 
|---|
|  | 17 | ;  movement type 1=admission, 2=transfer, 3=discharge, 6=specialty chg | 
|---|
|  | 18 | S IBMVTP=$S($P(DGPMA,"^",2):$P(DGPMA,"^",2),1:$P(DGPMP,"^",2)) I 'IBMVTP Q | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | ;  $p(14)=admission movement ptr entry in file 405 | 
|---|
|  | 21 | S IBMVAD=$S(DGPMA'="":$P(DGPMA,"^",14),1:$P(DGPMP,"^",14)) I 'IBMVAD Q | 
|---|
|  | 22 | ; | 
|---|
|  | 23 | D WRITE("Updating claims tracking ... ",2) | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | I '$D(VAIN(1)) D INP^VADPT | 
|---|
|  | 26 | ; | 
|---|
|  | 27 | ;  add/edit admission | 
|---|
|  | 28 | I IBMVTP=1 D ADMIT Q | 
|---|
|  | 29 | ; | 
|---|
|  | 30 | ;  transfer to asih (patch 23) | 
|---|
|  | 31 | I $P($G(^DGPM(+$P(DGPMA,"^",15),0)),"^",2)=1 S IBMVAD=$P(DGPMA,"^",15) D ADMIT Q | 
|---|
|  | 32 | ; | 
|---|
|  | 33 | ;  specialty change | 
|---|
|  | 34 | I IBMVTP=6 D SPECIAL Q | 
|---|
|  | 35 | ; | 
|---|
|  | 36 | D WRITE("completed.") | 
|---|
|  | 37 | Q | 
|---|
|  | 38 | ; | 
|---|
|  | 39 | ; | 
|---|
|  | 40 | WRITE(MSG,FF)         ;  write message on screen if not silent | 
|---|
|  | 41 | ;  write 'F'orm 'F'eeds count followed by msg (optional) | 
|---|
|  | 42 | N % | 
|---|
|  | 43 | I '$D(IB20),'$G(DGQUIET) D | 
|---|
|  | 44 | .   F %=1:1:$G(FF) W ! | 
|---|
|  | 45 | .   W MSG | 
|---|
|  | 46 | Q | 
|---|
|  | 47 | ; | 
|---|
|  | 48 | ; | 
|---|
|  | 49 | ADMIT ; -- process admission movements | 
|---|
|  | 50 | ;  ibmvad is admission movement pointer to file 405 | 
|---|
|  | 51 | ;  dgpma  is movement entry from file 405 | 
|---|
|  | 52 | N %,%H,%I,IBCTFLAG,IBNEW,IBRANDOM,IBTRN,LASTADM,LASTDA,LASTDATA | 
|---|
|  | 53 | ; | 
|---|
|  | 54 | ;  this is a deleted admission from file 405, dgpma=null | 
|---|
|  | 55 | I DGPMA="" D DELADMIT Q | 
|---|
|  | 56 | ; | 
|---|
|  | 57 | ;  try and relink to existing entry if already there | 
|---|
|  | 58 | ;  find the last admission, check to make sure its inactive and there | 
|---|
|  | 59 | ;  is not a pointer to the movement file ($p(5)).  if the current | 
|---|
|  | 60 | ;  admission date is within 5 days, update the entry. | 
|---|
|  | 61 | S LASTADM=$O(^IBT(356,"APTY",DFN,+$O(^IBE(356.6,"AC",1,0)),9999999),-1) | 
|---|
|  | 62 | 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) | 
|---|
|  | 63 | .   S %=$$FMDIFF^XLFDT($P(DGPMA,"."),$P(LASTADM,".")) | 
|---|
|  | 64 | .   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 | 
|---|
|  | 65 | ; | 
|---|
|  | 66 | ;  random sampler, admission date must equal today (dt) | 
|---|
|  | 67 | I +$G(VAIN(3)),($E(+DGPMA,1,7)=DT) S IBRANDOM=$$RANDOM^IBTRKR1(+VAIN(3)) | 
|---|
|  | 68 | ; | 
|---|
|  | 69 | N D,D0,DI,DIG,DIH,DIU,DIV,DQ,IBADMDT,IBETYP  ; variables left by ibtutl | 
|---|
|  | 70 | ;  inpatient claims tracking = all patients | 
|---|
|  | 71 | I $P(IBTRKR,"^",2)=2 D  Q | 
|---|
|  | 72 | .   D ADM^IBTUTL(IBMVAD,+$E(+DGPMA,1,12),$G(IBRANDOM),$P(DGPMA,"^",27)) | 
|---|
|  | 73 | .   D WRITE("entry "_$S($G(IBNEW):"added.",1:"edited.")) | 
|---|
|  | 74 | .   I $G(IBRANDOM),$G(IBTRN) D ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$G(VAIN(3))) | 
|---|
|  | 75 | ; | 
|---|
|  | 76 | ;  inpatient claims tracking = insured and ur only | 
|---|
|  | 77 | I $P(IBTRKR,"^",2)=1,$S($G(IBRANDOM):1,'$$INSURED^IBCNS1(DFN,+DGPMA):0,1:$$PTCOV^IBCNSU3(DFN,+DGPMA,"INPATIENT")) D  Q | 
|---|
|  | 78 | .   D ADM^IBTUTL(IBMVAD,+$E(+DGPMA,1,12),$G(IBRANDOM),$P(DGPMA,"^",27)) | 
|---|
|  | 79 | .   D WRITE("entry "_$S($G(IBNEW):"added.",1:"edited.")) | 
|---|
|  | 80 | .   I $G(IBRANDOM),$G(IBTRN) D ADMTBULL^IBTRKRBA(DFN,IBTRN,DGPMA,+$G(VAIN(3))) | 
|---|
|  | 81 | ; | 
|---|
|  | 82 | ;  inpatient claims tracking = insured and ur only, but not insurred | 
|---|
|  | 83 | ;  need to send off RDV in background | 
|---|
|  | 84 | N IBT | 
|---|
|  | 85 | 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),$P(DGPMA,"^",27)) D WRITE("Remote Query for insurance sent.") Q | 
|---|
|  | 86 | ; | 
|---|
|  | 87 | ; | 
|---|
|  | 88 | D WRITE("no action taken.") | 
|---|
|  | 89 | Q | 
|---|
|  | 90 | ; | 
|---|
|  | 91 | ; | 
|---|
|  | 92 | DELADMIT ;  deleted admission | 
|---|
|  | 93 | N DA,FILE,IBDATE,IBTRN,SPECALTY | 
|---|
|  | 94 | S IBTRN=$O(^IBT(356,"AD",+IBMVAD,0)) I IBTRN D  Q | 
|---|
|  | 95 | .   S SPECALTY=+$P($G(^UTILITY($J,"ATS",+$P(DGPMP,"^"),+$O(^UTILITY($J,"ATS",+$P(DGPMP,"^"),0)))),"^",9) | 
|---|
|  | 96 | .   ;  send information bulletin | 
|---|
|  | 97 | .   D DELBULL^IBTRKRBD(DFN,IBTRN,DGPMP,SPECALTY) | 
|---|
|  | 98 | .   ;  clean up files pointing to 405 | 
|---|
|  | 99 | .   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) | 
|---|
|  | 100 | .   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) | 
|---|
|  | 101 | .   ;  inactivate entry in ct 356 | 
|---|
|  | 102 | .   D INACTIVE^IBTRKRU(IBTRN) | 
|---|
|  | 103 | .   D WRITE("entry inactivated.") | 
|---|
|  | 104 | D WRITE("no action taken.") | 
|---|
|  | 105 | Q | 
|---|
|  | 106 | ; | 
|---|
|  | 107 | ; | 
|---|
|  | 108 | SPECIAL ;  specialty change | 
|---|
|  | 109 | ;  deleted movement | 
|---|
|  | 110 | I DGPMA="" D WRITE("no action taken.") Q | 
|---|
|  | 111 | ; | 
|---|
|  | 112 | ;  if specialty change is past 7 days, quit | 
|---|
|  | 113 | I +DGPMA<$$FMADD^XLFDT(+DT,-7) D WRITE("no action taken.") Q | 
|---|
|  | 114 | ; | 
|---|
|  | 115 | N IBDT,IBTSA,IBTSP,IBTRC,IBTRN,IBTRV | 
|---|
|  | 116 | ;  treating specialty after | 
|---|
|  | 117 | S IBTSA=$P($G(^DIC(42.4,+$P($G(^DIC(45.7,+$P(DGPMA,"^",9),0)),"^",2),0)),"^",3) | 
|---|
|  | 118 | ; | 
|---|
|  | 119 | ;  treating specialty before | 
|---|
|  | 120 | I DGPMP'="" S IBTSP=$P($G(^DIC(42.4,+$P($G(^DIC(45.7,+$P(DGPMP,"^",9),0)),"^",2),0)),"^",3) | 
|---|
|  | 121 | ; | 
|---|
|  | 122 | I DGPMP="" D | 
|---|
|  | 123 | .   S IBDT=9999999.9999999-$P(DGPMA,"^") | 
|---|
|  | 124 | .   S IBTSP=$P($G(^DIC(45.7,+$O(^(+$O(^DGPM("ATS",+DFN,+IBMVAD,+IBDT)),0)),0)),"^",2) | 
|---|
|  | 125 | .   S IBTSP=$P($G(^DIC(42.4,+IBTSP,0)),"^",3) | 
|---|
|  | 126 | ; | 
|---|
|  | 127 | ;  no change in major bed section | 
|---|
|  | 128 | I IBTSA=IBTSP D WRITE("no action taken.") Q | 
|---|
|  | 129 | ; | 
|---|
|  | 130 | S IBTRN=$O(^IBT(356,"AD",+IBMVAD,0)) | 
|---|
|  | 131 | ; | 
|---|
|  | 132 | ;  tracked as hospital review | 
|---|
|  | 133 | I $O(^IBT(356.1,"C",+IBTRN,0)) D | 
|---|
|  | 134 | .   I $$ALREADY(356.1,+DGPMA) Q | 
|---|
|  | 135 | .   D PRE^IBTUTL2($E(+DGPMA,1,7),IBTRN,30) | 
|---|
|  | 136 | .   I $G(IBTRV) D COMMENT^IBTRKRU(356.1,+IBTRV) | 
|---|
|  | 137 | ; | 
|---|
|  | 138 | ;  tracked as insurance review | 
|---|
|  | 139 | I $O(^IBT(356.2,"C",+IBTRN,0)) D | 
|---|
|  | 140 | .   I $$ALREADY(356.2,+DGPMA) Q | 
|---|
|  | 141 | .   I $P($G(^IBT(356,+IBTRN,0)),"^",24) D COM^IBTUTL3($E(+DGPMA,1,12),IBTRN,30) | 
|---|
|  | 142 | .   I $G(IBTRC) D COMMENT^IBTRKRU(356.2,+IBTRC) | 
|---|
|  | 143 | ; | 
|---|
|  | 144 | D WRITE("completed.") | 
|---|
|  | 145 | Q | 
|---|
|  | 146 | ; | 
|---|
|  | 147 | ; | 
|---|
|  | 148 | ALREADY(FILE,DATE) ; -- see if already is review for date | 
|---|
|  | 149 | N X,Y,IBX | 
|---|
|  | 150 | S IBX=0 | 
|---|
|  | 151 | S X=$P(DATE,".")+.25 | 
|---|
|  | 152 | S Y=$O(^IBT(FILE,"ATIDT",+IBTRN,-X)) S Y=-Y I Y,$P(Y,".")=$P(DATE,".") S IBX=1 | 
|---|
|  | 153 | Q IBX | 
|---|
|  | 154 | ; | 
|---|
|  | 155 | ; | 
|---|
|  | 156 | NIGHTLY ; -- nightly job for claims tracking, called by IBAMTC | 
|---|
|  | 157 | ; | 
|---|
|  | 158 | D UPDATE^IBTRKR1 ; update claims tracking site parameters (random sampler) | 
|---|
|  | 159 | D ^IBTRKR2 ;       add scheduled admissions to tracking | 
|---|
|  | 160 | D ^IBTRKR3 ;       add rx refill to outpatient encounters | 
|---|
|  | 161 | D ^IBTRKR4 ;       add outpatient encounters to tracking | 
|---|
|  | 162 | D ^IBTRKR5 ;       add outpatient prosthetics item to tracking | 
|---|
|  | 163 | Q | 
|---|