source: WorldVistAEHR/trunk/r/INTEGRATED_BILLING-IB-PRQ--IBD--IBQ--PRQS/IBAECM3.m@ 956

Last change on this file since 956 was 613, checked in by George Lilly, 16 years ago

initial load of WorldVistAEHR

File size: 3.7 KB
Line 
1IBAECM3 ;WOIFO/SS-LTC PHASE 2 MONTHLY JOB PART 3 ; 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 ;
5MJ1ST ;entry for the first Monthly Calculation Process
6 N IBMDS1
7 ;------ variables
8 N IBMJ1ST S IBMJ1ST="MJ1ST" ;to identify 1st MJ in IBAECU4
9 N IBPRMNTH S IBPRMNTH=$$PREVMNTH^IBAECM1() ;last day of previous month
10 N IBCLKAD1 ; variable to return back from PROCPAT info for clock adjustment
11 N IBDFN,IBMNS,IBVAR
12 N IBCLKIE1
13 N IBCLKDAT ;clock data
14 N IBSTRTD ;EFFECTIVE DATE
15 S (IBMNS,IBMDS1)=""
16 S IBSTRTD=$$BILDATE^IBAECN1()
17 K ^TMP($J,"IBMJERR")
18 K ^TMP($J,"IBMJINP")
19 K ^TMP($J,"IBMJOUT")
20 ;prepare arrays for months since the effective date
21 D PRMONTHS(.IBMNS,IBPRMNTH)
22 ;go thru all patients in #351.81
23 S IBDFN1=0
24 ;for each patient in file 351.81
25 F S IBDFN1=$O(^IBA(351.81,"C",IBDFN1)) Q:+IBDFN1=0 D
26 . S IBCLKIE1=0,IBERR=""
27 . F S IBCLKIE1=+$O(^IBA(351.81,"C",IBDFN1,IBCLKIE1)) Q:+IBCLKIE1=0 D
28 . . S IBCLKDAT=^IBA(351.81,IBCLKIE1,0)
29 . . ; quit if STATUS'=OPEN
30 . . Q:$P(IBCLKDAT,"^",5)'=1
31 . . ; quit if CURRENT EVENTS DATE="" i.e. no LTC events happend
32 . . ; this month for the patient
33 . . Q:$P(IBCLKDAT,"^",7)=""
34 . . ; quit if CURRENT EVENTS DATE>last day of "real-time" previous month -the veteran
35 . . ; has been processed for all months in the past
36 . . Q:$P(IBCLKDAT,"^",7)>IBPRMNTH
37 . . ; if error save it in ^TMP for further e-mail
38 . . S IBCLKAD1=""
39 . . ;process the patient
40 . . S IBVAR=0
41 . . F S IBVAR=$O(IBMNS(IBVAR)) Q:+IBVAR=0 D
42 . . . Q:$$CHKXTMP(IBDFN1,IBVAR) ;check if it was a crush and the month has been already processed
43 . . . M IBMDS1=IBMNS(IBVAR) ;set month to process
44 . . . S IBMDS1=$E(IBMDS1(1),6,7)
45 . . . D CHNGEVEN^IBAECU4(IBCLKIE1,IBDFN1,IBMDS1(0)) ;set CURRENT EVENT DATE to a date of the MONTH (say,1st day)
46 . . . I $$PROCPAT^IBAECM2(.IBMDS1,IBDFN1,IBSTRTD,IBCLKIE1)=-1 D ;perform calcualtion
47 . . . . D ERRLOG^IBAECU5(+$G(IBDFN1),+$G(IBCLKIE1),"Charge","Error with LTC clock creation occured during calculation, no proper charges have been created") Q
48 . . . D UPDXTMP(IBDFN1,IBVAR) ;mark the month as done
49 . . D DELXTMP(IBDFN1)
50 ;send all errors to user group
51 D SENDERR^IBAECU5 ;send all errors
52 ;if we reach this place that means that we processed everybody
53 ;and we stamp the date into IB SITE PARAMETERS
54 S $P(^IBE(350.9,1,0),"^",16)=$$TODAY^IBAECN1()
55 ;if Nightly Job founds that date $P(^IBE(350.9,1,0),"^",16)
56 ;is less that begining of current month than NJ runs MJ again and MJ will
57 ;process a rest patients
58 D KILLXTMP ;delete ^XTMP
59 Q
60 ;IBALLM - Array with month info
61 ; IBALLM (0)-first day of the month
62 ; IBALLM (1)-last day of the month
63 ; IBALLM (2)-yyymm in Fileman format (like 30201 - for Jan 2002)
64 ;IBPRMNTH -Last day of the last mont
65PRMONTHS(IBALLM,IBPRMNTH) ;prepare months
66 S IBALLM=""
67 N X,IB176YM,IB176TMP
68 S IB176YM=$E($$BILDATE^IBAECN1(),1,5)
69 F Q:IB176YM>$E(IBPRMNTH,1,5) D
70 . S X=IB176YM_"01"
71 . S IBALLM(IB176YM,1)=$$LASTDT^IBAECU(X)
72 . S IBALLM(IB176YM,2)=$E(IBALLM(IB176YM,1),1,5)
73 . S IBALLM(IB176YM,0)=IBALLM(IB176YM,2)_"01",IBALLM=$E(IBALLM(IB176YM,1),6,7)
74 . I +$E(IB176YM,4,5)=12 S IB176YM=$E(IB176YM,1,3)+1,IB176YM=IB176YM_"01" Q
75 . S IB176YM=IB176YM+1
76 Q
77 ;
78KILLXTMP ;
79 K ^XTMP("IBAEC-P176")
80 Q
81 ;
82 ;IBDFN - ien of #2
83 ;IBYM - year_month in yyymm format
84CHKXTMP(IBDFN,IBYM) ;check if ^XTMP for the patient and month is exist
85 Q $D(^XTMP("IBAEC-P176",IBDFN,IBYM))>0
86 ;
87 ;IBDFN - ien of #2
88 ;IBYM - year_month in yyymm format
89UPDXTMP(IBDFN,IBYM) ;update XTMP with new info
90 N IBDT S IBDT=$$TODAY^IBAECN1()
91 S ^XTMP("IBAEC-P176",0)=$$CHNGDATE^IBAECU4(IBDT,30)_"^"_IBDT_"^1st LTC copay calculation"
92 S ^XTMP("IBAEC-P176",+IBDFN,IBYM)=""
93 Q
94 ;
95 ;IBDFN - ien of #2
96DELXTMP(IBDFN) ;Kills ^XTMP node for the patient.
97 K ^XTMP("IBAEC-P176",+IBDFN)
98 Q
99 ;
Note: See TracBrowser for help on using the repository browser.