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 | ;
|
---|