| 1 | IBAECM1 ;WOIFO/SS-LTC PHASE 2 MONTHLY JOB ; 20-FEB-02
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**176**;21-MAR-94
 | 
|---|
| 3 |  ;;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ;Input: IBMDS1 - array with month info
 | 
|---|
| 6 |  ;IBMDS1 (0)-first day of the month
 | 
|---|
| 7 |  ;IBMDS1 (1)-last day of the month
 | 
|---|
| 8 |  ;IBMDS1 (2)-yyymm in Fileman format (like 30201 - for Jan 2002)
 | 
|---|
| 9 | MJT ;entry for Monthly Calculation Process
 | 
|---|
| 10 |  ;(array IBMDS1 must be specified outside!)
 | 
|---|
| 11 |  Q:'$D(IBMDS1)
 | 
|---|
| 12 |  ;------ variables
 | 
|---|
| 13 |  N IBCLKAD1 ; variable to return back from PROCPAT info for clock adjustment
 | 
|---|
| 14 |  N IBDFN
 | 
|---|
| 15 |  N IBCLKIE1
 | 
|---|
| 16 |  N IBONCE ;to detect "more than 1 active clock" case for the patient
 | 
|---|
| 17 |  N IBCLKDAT ;clock data
 | 
|---|
| 18 |  N IBSTRTD ;EFFECTIVE DATE
 | 
|---|
| 19 |  S IBSTRTD=$$BILDATE^IBAECN1()
 | 
|---|
| 20 |  K ^TMP($J,"IBMJERR")
 | 
|---|
| 21 |  K ^TMP($J,"IBMJINP")
 | 
|---|
| 22 |  K ^TMP($J,"IBMJOUT")
 | 
|---|
| 23 |  ;go thru all patients in #351.81
 | 
|---|
| 24 |  S IBDFN1=0
 | 
|---|
| 25 |  ;for each patient in file 351.81
 | 
|---|
| 26 |  F  S IBDFN1=$O(^IBA(351.81,"C",IBDFN1)) Q:+IBDFN1=0  D
 | 
|---|
| 27 |  . S IBCLKIE1=0,IBERR="",IBONCE=0
 | 
|---|
| 28 |  . F  S IBCLKIE1=+$O(^IBA(351.81,"C",IBDFN1,IBCLKIE1)) Q:+IBCLKIE1=0  D
 | 
|---|
| 29 |  . . S IBCLKDAT=^IBA(351.81,IBCLKIE1,0)
 | 
|---|
| 30 |  . . ; quit if STATUS'=OPEN
 | 
|---|
| 31 |  . . Q:$P(IBCLKDAT,"^",5)'=1
 | 
|---|
| 32 |  . . ; quit if CURRENT EVENTS DATE="" i.e. no LTC events happend 
 | 
|---|
| 33 |  . . ; this month for the patient
 | 
|---|
| 34 |  . . Q:$P(IBCLKDAT,"^",7)=""
 | 
|---|
| 35 |  . . ; quit if CURRENT EVENTS DATE>last day of previous month
 | 
|---|
| 36 |  . . ; i.e. this patient has been already processed. Probably when MJ already has been run and then crushed.
 | 
|---|
| 37 |  . . ;in such cases NJ runs MJ again next day. SO we don't need to charge the patient again.
 | 
|---|
| 38 |  . . Q:$P(IBCLKDAT,"^",7)>IBMDS1(1)
 | 
|---|
| 39 |  . . ; if error save it in ^TMP for further e-mail
 | 
|---|
| 40 |  . . I IBONCE>0 D ERRLOG^IBAECU5(+$G(IBDFN1),+$G(IBCLKIE1),"Clocks","Patient has more than one OPEN LTC clocks") Q
 | 
|---|
| 41 |  . . S IBONCE=1
 | 
|---|
| 42 |  . . S IBCLKAD1=""
 | 
|---|
| 43 |  . . ;process the patient
 | 
|---|
| 44 |  . . I $$PROCPAT^IBAECM2(.IBMDS1,IBDFN1,IBSTRTD,IBCLKIE1)=-1 D
 | 
|---|
| 45 |  . . . D ERRLOG^IBAECU5(+$G(IBDFN1),+$G(IBCLKIE1),"Charge","Error with LTC clock creation occured during calculation, no proper charges have been created") Q
 | 
|---|
| 46 |  ;send all errors to user group
 | 
|---|
| 47 |  D SENDERR^IBAECU5 ;send all errors
 | 
|---|
| 48 |  ;if we reach this place that means that we processed everybody
 | 
|---|
| 49 |  ;and we stamp the date into IB SITE PARAMETERS 
 | 
|---|
| 50 |  S $P(^IBE(350.9,1,0),"^",16)=$$TODAY^IBAECN1()
 | 
|---|
| 51 |  ;if Nightly Job founds that date $P(^IBE(350.9,1,0),"^",16) 
 | 
|---|
| 52 |  ;is less that begining of current month than NJ runs MJ again and MJ will 
 | 
|---|
| 53 |  ;process a rest patients
 | 
|---|
| 54 |  Q
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 |  ;-----
 | 
|---|
| 57 |  ;180 clock days issue
 | 
|---|
| 58 |  ;calculates proper LTC Monthly Copay Amount:
 | 
|---|
| 59 |  ;IBDFN2 -patient's ien in file #2
 | 
|---|
| 60 |  ;IBINF - admission info
 | 
|---|
| 61 |  ;IBENROL - enrollment info (returned by $$COPAY^EASECCAL)
 | 
|---|
| 62 |  ;IBADMLEN - admission lenght
 | 
|---|
| 63 |  ;returns:
 | 
|---|
| 64 |  ; 0- if patient does not have >180 days of continious LTC
 | 
|---|
| 65 |  ; 1- if patient has >180 days of continious LTC (only stay days are counted)
 | 
|---|
| 66 |  ;IBAMOUNT - returns back proper amount
 | 
|---|
| 67 | MONTHMAX(IBDFN2,IBINF,IBENROL,IBADMLEN,IBAMOUNT) ;
 | 
|---|
| 68 |  N IB180DS
 | 
|---|
| 69 |  S IBAMOUNT=+$P(IBENROL,"^",3) ;by default is "<=180 days" amount 
 | 
|---|
| 70 |  ;if less or equal 180 days -quit
 | 
|---|
| 71 |  I IBADMLEN=1 Q 0  ;>>QUIT
 | 
|---|
| 72 |  ; how many stay days in this admission:
 | 
|---|
| 73 |  S IB180DS=$$STAYDS^IBAECU2(IBINF(1),IBINF(3),IBINF,IBINF(2))
 | 
|---|
| 74 |  ;if stay days <= 180 then quit & return 
 | 
|---|
| 75 |  I IB180DS<181 Q 0  ;>>QUIT
 | 
|---|
| 76 |  ;if stay days > 180 then we have to check if any treating 
 | 
|---|
| 77 |  ;specialty change breaks this 181+ continious period
 | 
|---|
| 78 |  ; Analyse all this admission period to find out any 180 days clock 
 | 
|---|
| 79 |  ; breaks related to changing specialty. 
 | 
|---|
| 80 |  ;MORE180(IBDFN,IBADM,IBLSTDAY,IBDISCH)
 | 
|---|
| 81 |  I $$MORE180^IBAECU2(IBDFN2,IBINF,IBINF(3),IBINF(2))=0 Q 0  ;>>QUIT
 | 
|---|
| 82 |  ; If there is no any non-LTC specialties during 180 days of stay before 
 | 
|---|
| 83 |  ; discharge or last day of the processing month and stay days >180 :
 | 
|---|
| 84 |  S IBAMOUNT=+$P(IBENROL,"^",4) ;amount for 181+ days
 | 
|---|
| 85 |  Q 1
 | 
|---|
| 86 |  ;---
 | 
|---|
| 87 |  ;finds the length of active LTC admission that started before IBFRST
 | 
|---|
| 88 |  ;IBFRST - first date of the date frame
 | 
|---|
| 89 |  ;IBLAST - last date of the date frame
 | 
|---|
| 90 |  ;IBDFN - ien of the patient in #2
 | 
|---|
| 91 |  ;IBLBL - ^TMP identifier
 | 
|---|
| 92 |  ;returns number of days if found such admission
 | 
|---|
| 93 |  ;returns 1 if not found
 | 
|---|
| 94 |  ;.IBINF returns:
 | 
|---|
| 95 |  ;IBINF - #405 ien
 | 
|---|
| 96 |  ;IBINF(0) total days of admission
 | 
|---|
| 97 |  ;IBINF(1) first day of admission
 | 
|---|
| 98 |  ;IBINF(2) discharge date of admission
 | 
|---|
| 99 |  ;IBINF(3) last_date_of_admission or last date of 
 | 
|---|
| 100 |  ;   this period if vet is not discharged yet
 | 
|---|
| 101 | DAYS180(IBFRST,IBLAST,IBDFN,IBLBL,IBINF) ;
 | 
|---|
| 102 |  N IBV1,IBV2,IBFL,IB405
 | 
|---|
| 103 |  S IBFL=0
 | 
|---|
| 104 |  S IB405=0
 | 
|---|
| 105 |  F  S IB405=+$O(^TMP($J,IBLBL,IBDFN,IB405)) Q:IB405=0!(IBFL>0)  D
 | 
|---|
| 106 |  . ;quit if admission started this month
 | 
|---|
| 107 |  . I +$G(^TMP($J,IBLBL,IBDFN,IB405))'<IBFRST Q
 | 
|---|
| 108 |  . S IBV1=+$O(^TMP($J,IBLBL,IBDFN,IB405,"SD",0))
 | 
|---|
| 109 |  . ;if found stay day in the first day and this is LTC service then quit
 | 
|---|
| 110 |  . I IBV1=IBFRST,$P($G(^TMP($J,IBLBL,IBDFN,IB405,"SD",IBV1)),"^",1)="L" S IBFL=IB405 Q
 | 
|---|
| 111 |  . S IBV1=+$O(^TMP($J,IBLBL,IBDFN,IB405,"LD",0))
 | 
|---|
| 112 |  . ;if found leave day in the first day and this is LTC service then quit
 | 
|---|
| 113 |  . I IBV1=IBFRST,$P($G(^TMP($J,IBLBL,IBDFN,IB405,"LD",IBV1)),"^",1)="L" S IBFL=IB405 Q
 | 
|---|
| 114 |  I IBFL=0 Q 1  ;not found >>QUIT
 | 
|---|
| 115 |  ;if found
 | 
|---|
| 116 |  S IBV1=$G(^TMP($J,IBLBL,IBDFN,IBFL))
 | 
|---|
| 117 |  Q:IBV1="" 1  ;error >>QUIT
 | 
|---|
| 118 |  S IBINF=IBFL ;ien of #405
 | 
|---|
| 119 |  S IBINF(0)=+$P(IBV1,"^",6) ;total number of inpatient days
 | 
|---|
| 120 |  I IBINF(0)>0 D  Q IBINF(0)  ;found >>QUIT
 | 
|---|
| 121 |  . ;first day of admission
 | 
|---|
| 122 |  . S IBINF(1)=+$P(IBV1,"^",1)
 | 
|---|
| 123 |  . ;discharge date of admission
 | 
|---|
| 124 |  . S IBINF(2)=+$P(IBV1,"^",2)
 | 
|---|
| 125 |  . ;last_date_of_admission
 | 
|---|
| 126 |  . S IBINF(3)=+$P(IBV1,"^",3)
 | 
|---|
| 127 |  . ;if no discharge then last day is IBLAST
 | 
|---|
| 128 |  . ;otherwise last day = discharge
 | 
|---|
| 129 |  . S:IBINF(2)=0 IBINF(3)=IBLAST
 | 
|---|
| 130 |  Q 1
 | 
|---|
| 131 |  ;
 | 
|---|
| 132 |  ;clean all ^TMP related to the patient
 | 
|---|
| 133 | CLEAN(IBDFN2) ;
 | 
|---|
| 134 |  K ^TMP($J,"IBLTCARR",IBDFN2)
 | 
|---|
| 135 |  K ^TMP($J,"IBMJINP",IBDFN2)
 | 
|---|
| 136 |  K ^TMP($J,"IBMJOUT",IBDFN2)
 | 
|---|
| 137 |  ;K ^TMP($J,"IB180",IBDFN1)
 | 
|---|
| 138 |  Q
 | 
|---|
| 139 |  ;--
 | 
|---|
| 140 |  ;Returns the last day (in FM format) of the previous month
 | 
|---|
| 141 | PREVMNTH() ;
 | 
|---|
| 142 |  N X,X1,X2
 | 
|---|
| 143 |  D NOW^%DTC
 | 
|---|
| 144 |  S X1=$E(X,1,5)_"01"
 | 
|---|
| 145 |  S X2=-1
 | 
|---|
| 146 |  D C^%DTC
 | 
|---|
| 147 |  Q X
 | 
|---|
| 148 |  ;
 | 
|---|
| 149 |  ;
 | 
|---|
| 150 |  ;runs for each day of the month for the patient
 | 
|---|
| 151 |  ;checks LTC clock and makes necessary adjustments
 | 
|---|
| 152 |  ;Input:
 | 
|---|
| 153 |  ;IBCLIEN Ien of #351.81
 | 
|---|
| 154 |  ;IBDT   Date in FM format
 | 
|---|
| 155 |  ;IBDFN  Patient's ien of #2
 | 
|---|
| 156 |  ;Output:       
 | 
|---|
| 157 |  ;returns current IEN or new one if #351.81 entry has been created
 | 
|---|
| 158 |  ;returns 0 if fatal error
 | 
|---|
| 159 | CH21BFR(IBCLIEN,IBDT,IBDFN) ;
 | 
|---|
| 160 |  N IBCLDATA,IB1,IB2,IBLCKER
 | 
|---|
| 161 |  S IBLCKER=0
 | 
|---|
| 162 |  S IBCLIEN=+IBCLIEN
 | 
|---|
| 163 |  S IB1=IBCLIEN
 | 
|---|
| 164 |  S IBCLDATA=$G(^IBA(351.81,IBCLIEN,0))
 | 
|---|
| 165 |  I IBCLDATA=""!($P(IBCLDATA,"^",1)="")!($P(IBCLDATA,"^",2)="")!($P(IBCLDATA,"^",3)="") D  Q 0
 | 
|---|
| 166 |  . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","0-node data corrupted in LTC clock")
 | 
|---|
| 167 |  ; Check clock expiration date
 | 
|---|
| 168 |  ; if there is no exp date then set it
 | 
|---|
| 169 |  I $P(IBCLDATA,"^",4)="" D
 | 
|---|
| 170 |  . S IB2=+$P(IBCLDATA,"^",3)
 | 
|---|
| 171 |  . S:IB2=0 IB2=IBDT
 | 
|---|
| 172 |  . L +^IBA(351.81,0):10 I '$T D  S IBLCKER=1 Q  ;quit
 | 
|---|
| 173 |  . . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","Lock error: clock was not reset")
 | 
|---|
| 174 |  . D RESET21^IBAECU4(IBCLIEN,IB2,IBDFN) ;set EXPIRATION DATE
 | 
|---|
| 175 |  . D FIX21CLK^IBAECU4(IBCLIEN)
 | 
|---|
| 176 |  . D CLKSTAMP^IBAECU4(IBCLIEN,IBDFN)
 | 
|---|
| 177 |  . L -^IBA(351.81,0)
 | 
|---|
| 178 |  . S IBCLDATA=$G(^IBA(351.81,IBCLIEN,0))
 | 
|---|
| 179 |  Q:IBLCKER=1 IBCLIEN
 | 
|---|
| 180 |  ;if clock expired close existent and set new one
 | 
|---|
| 181 |  I IBDT>$P(IBCLDATA,"^",4) D
 | 
|---|
| 182 |  . L +^IBA(351.81,0):10 I '$T D  Q  ;quit
 | 
|---|
| 183 |  . . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","Lock error: clock was not closed")
 | 
|---|
| 184 |  . D CLOSECLK^IBAECU4(IBCLIEN,IBDFN)
 | 
|---|
| 185 |  . D CLKSTAMP^IBAECU4(IBCLIEN,IBDFN)
 | 
|---|
| 186 |  . S IBCLIEN=$$NEWCLK^IBAECU4(IBDFN,IBDT)
 | 
|---|
| 187 |  . I IBCLIEN=0 D  L -^IBA(351.81,0) Q
 | 
|---|
| 188 |  . . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","Lock error: clock was not created")
 | 
|---|
| 189 |  . D RESET21^IBAECU4(IBCLIEN,IBDT,IBDFN)
 | 
|---|
| 190 |  . D FIX21CLK^IBAECU4(IBCLIEN)
 | 
|---|
| 191 |  . D CLKSTAMP^IBAECU4(IBCLIEN,IBDFN)
 | 
|---|
| 192 |  . L -^IBA(351.81,0)
 | 
|---|
| 193 |  Q IBCLIEN
 | 
|---|
| 194 |  ;add new free day to 21 clock
 | 
|---|
| 195 |  ;Input:
 | 
|---|
| 196 |  ;IBCLIEN Ien of #351.81
 | 
|---|
| 197 |  ;IBDT   Date in FM format
 | 
|---|
| 198 |  ;IBDFN  Patient's ien of #2
 | 
|---|
| 199 | ADD21DAY(IBCLIEN,IBDT,IBDFN) ;
 | 
|---|
| 200 |  N IBCLDATA,IB1,IB2
 | 
|---|
| 201 |  S IBCLIEN=+IBCLIEN
 | 
|---|
| 202 |  S IB1=IBCLIEN
 | 
|---|
| 203 |  S IBCLDATA=$G(^IBA(351.81,IBCLIEN,0))
 | 
|---|
| 204 |  I IBCLDATA="" D  Q
 | 
|---|
| 205 |  . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","0-node data corrupted in LTC clock")
 | 
|---|
| 206 |  ;if clock is not expired & still DAYS REMAINING>0 - do not charge, 
 | 
|---|
| 207 |  ;add exempt day to clock
 | 
|---|
| 208 |  I $P(IBCLDATA,"^",4)="" D RESET21^IBAECU4(IBCLIEN,IBDT,IBDFN),FIX21CLK^IBAECU4(IBCLIEN)
 | 
|---|
| 209 |  I +$P(IBCLDATA,"^",6)=21,+$P(IBCLDATA,"^",3)'=IBDT D RESET21^IBAECU4(IBCLIEN,IBDT,IBDFN) ;if begin date'=1st free day, then fix begin & expir. dates
 | 
|---|
| 210 |  I $P(IBCLDATA,"^",4)'<IBDT,$P(IBCLDATA,"^",6)>0 D
 | 
|---|
| 211 |  . L +^IBA(351.81,0):10 I '$T D  Q  ;quit
 | 
|---|
| 212 |  . . D ERRLOG^IBAECU5(+$G(IBDFN),+$G(IBCLIEN),"Clocks","Lock error: new free day not added")
 | 
|---|
| 213 |  . D ADDEXDAY^IBAECU4(IBCLIEN,IBDT,IBDFN)
 | 
|---|
| 214 |  . D CLKSTAMP^IBAECU4(IBCLIEN,IBDFN)
 | 
|---|
| 215 |  . L -^IBA(351.81,0)
 | 
|---|
| 216 |  Q
 | 
|---|
| 217 |  ;
 | 
|---|
| 218 |  ;entry point ONLY for testing purposes:
 | 
|---|
| 219 |  ;prepare date range for current month
 | 
|---|
| 220 |  ;dates,days for processing month
 | 
|---|
| 221 | TESTMJ ;
 | 
|---|
| 222 |  D NOW^%DTC
 | 
|---|
| 223 |  ;if you want to test MJ for specific month then
 | 
|---|
| 224 |  ;set X to specific date and run TESTX 
 | 
|---|
| 225 | TESTX ;
 | 
|---|
| 226 |  S $P(^IBE(350.9,1,0),"^",16)=0
 | 
|---|
| 227 | THEMONTH ;
 | 
|---|
| 228 |  S IBMDS1(1)=$$LASTDT^IBAECU(X)
 | 
|---|
| 229 |  S IBMDS1(2)=$E(IBMDS1(1),1,5)
 | 
|---|
| 230 |  S IBMDS1(0)=IBMDS1(2)_"01",IBMDS1=$E(IBMDS1(1),6,7)
 | 
|---|
| 231 |  ;run MJ with date range specified outside (above) using MJT entry point 
 | 
|---|
| 232 |  D MJT
 | 
|---|
| 233 |  ;set LAST LTC COMPLETION DATE to 0 to allow event handlers to update LTC clock file;
 | 
|---|
| 234 |  S $P(^IBE(350.9,1,0),"^",16)=0
 | 
|---|
| 235 |  Q
 | 
|---|
| 236 |  ;
 | 
|---|