1 | BPSRPT7 ;BHAM ISC/BEE - ECME REPORTS ;14-FEB-05
|
---|
2 | ;;1.0;E CLAIMS MGMT ENGINE;**1,3,5**;JUN 2004;Build 45
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | Q
|
---|
6 | ;
|
---|
7 | ;Routine to Display the Reports (Continued)
|
---|
8 | ;
|
---|
9 | ; Input Variables -> BPCLM = Array of report data by date
|
---|
10 | ; BPDIV,BPSUMDET,GTOT
|
---|
11 | ; Returned Value -> Cumulative Grand Totals
|
---|
12 | ;
|
---|
13 | PTBDT(BPDIV,BPSUMDET,BPCLM,GTOT) N DIFF,I,NP,RDT,TOT,X
|
---|
14 | ;
|
---|
15 | ;Loop through compiled array and display
|
---|
16 | S TOT=""
|
---|
17 | S RDT="" F S RDT=$O(BPCLM(RDT)) Q:RDT="" D Q:BPQ
|
---|
18 | .S NP=$$CHKP^BPSRPT5(1) Q:BPQ
|
---|
19 | .S X=$G(BPCLM(RDT))
|
---|
20 | .;
|
---|
21 | .;Print Details - Report
|
---|
22 | .I BPSUMDET=0,'BPEXCEL D
|
---|
23 | ..W !,$$DATTIM^BPSRPT1(RDT) ;Date
|
---|
24 | ..W ?15,$J(+$P(X,U),17) ;#Claims
|
---|
25 | ..W ?33,$J(+$P(X,U,2),17,2) ;Amount Submitted
|
---|
26 | ..W ?51,$J(+$P(X,U,3),17,2) ;Returned Rejected
|
---|
27 | ..W ?69,$J(+$P(X,U,4),17,2) ;Returned Payable
|
---|
28 | ..W ?87,$J(+$P(X,U,5),17,2) ;Amount to Receive
|
---|
29 | ..;
|
---|
30 | ..;Difference
|
---|
31 | ..S DIFF=+$P(X,U,4)-$P(X,U,5)
|
---|
32 | ..I DIFF<0 S DIFF="<"_$TR($J(-DIFF,15,2)," ")_">" W ?117,$J(DIFF,15)
|
---|
33 | ..E W ?116,$J(DIFF,15,2)
|
---|
34 | ..;
|
---|
35 | ..;Print Details - Excel
|
---|
36 | .I BPSUMDET=0,BPEXCEL D
|
---|
37 | ..;
|
---|
38 | ..;Division
|
---|
39 | ..W !,$S(BPDIV=0:"BLANK",$$DIVNAME^BPSSCRDS(BPDIV)]"":$$DIVNAME^BPSSCRDS(BPDIV),1:BPDIV),U
|
---|
40 | ..W $$DATTIM^BPSRPT1(RDT),U ;Date
|
---|
41 | ..W +$P(X,U),U ;#Claims
|
---|
42 | ..W $TR($J(+$P(X,U,2),17,2)," "),U ;Amount Submitted
|
---|
43 | ..W $TR($J(+$P(X,U,3),17,2)," "),U ;Returned Rejected
|
---|
44 | ..W $TR($J(+$P(X,U,4),17,2)," "),U ;Returned Payable
|
---|
45 | ..W $TR($J(+$P(X,U,5),17,2)," "),U ;Amount to Receive
|
---|
46 | ..;
|
---|
47 | ..;Difference
|
---|
48 | ..S DIFF=+$P(X,U,4)-$P(X,U,5)
|
---|
49 | ..W $TR($J(DIFF,15,2)," ")
|
---|
50 | .;
|
---|
51 | .;Save Totals
|
---|
52 | .F I=1:1:5 S $P(TOT,U,I)=$P(TOT,U,I)+$P(X,U,I),$P(GTOT,U,I)=$P($G(GTOT),U,I)+$P(X,U,I)
|
---|
53 | ;
|
---|
54 | ;Print Totals
|
---|
55 | Q:BPEXCEL
|
---|
56 | Q:BPQ S NP=$$CHKP^BPSRPT5(2) Q:BPQ
|
---|
57 | D ULINE^BPSRPT5("-")
|
---|
58 | W !,"TOTALS"
|
---|
59 | W ?15,$J(+$P(TOT,U),17)
|
---|
60 | W ?33,$J(+$P(TOT,U,2),17,2)
|
---|
61 | W ?51,$J(+$P(TOT,U,3),17,2)
|
---|
62 | W ?69,$J(+$P(TOT,U,4),17,2)
|
---|
63 | W ?87,$J(+$P(TOT,U,5),17,2)
|
---|
64 | S X=$S((+$P(TOT,U,4))=0:0,1:(+$P(TOT,U,5))/(+$P(TOT,U,4)))
|
---|
65 | S DIFF=+$P(TOT,U,4)-$P(TOT,U,5)
|
---|
66 | I DIFF<0 S DIFF="<"_$TR($J(-DIFF,15,2)," ")_">" W ?117,$J(DIFF,15)
|
---|
67 | E W ?116,$J(DIFF,15,2)
|
---|
68 | Q
|
---|
69 | ;
|
---|
70 | ;Print Grand Totals - Report 6
|
---|
71 | ;
|
---|
72 | PGTOT6(GTOT) N DIFF,NP,X
|
---|
73 | Q:BPQ S NP=$$CHKP^BPSRPT5(2) Q:BPQ
|
---|
74 | D ULINE^BPSRPT5("-")
|
---|
75 | W !,"GRAND TOTALS"
|
---|
76 | W ?15,$J(+$P(GTOT,U),17)
|
---|
77 | W ?33,$J(+$P(GTOT,U,2),17,2)
|
---|
78 | W ?51,$J(+$P(GTOT,U,3),17,2)
|
---|
79 | W ?69,$J(+$P(GTOT,U,4),17,2)
|
---|
80 | W ?87,$J(+$P(GTOT,U,5),17,2)
|
---|
81 | S X=$S((+$P(GTOT,U,4))=0:0,1:(+$P(GTOT,U,5))/(+$P(GTOT,U,4)))
|
---|
82 | S DIFF=+$P(GTOT,U,4)-$P(GTOT,U,5)
|
---|
83 | I DIFF<0 S DIFF="<"_$TR($J(-DIFF,15,2)," ")_">" W ?117,$J(DIFF,15)
|
---|
84 | E W ?116,$J(DIFF,15,2)
|
---|
85 | Q
|
---|
86 | ;
|
---|
87 | ;Print Grand Totals - Reports 1,2,3,4,5,7
|
---|
88 | ;
|
---|
89 | PGTOT(BPRTYPE,BPGBIL,BPGINS,BPGCOLL,BPGCNT,BPGELTM) ;
|
---|
90 | I (BPRTYPE=1)!(BPRTYPE=4) D Q
|
---|
91 | .W !!,?78,"----------",?100,"----------",?122,"----------"
|
---|
92 | .W !,"GRAND TOTALS",?78,$J(BPGBIL,10,2),?100,$J(BPGINS,10,2),?122,$J(BPGCOLL,10,2)
|
---|
93 | .W !,"COUNT",?78,$J(BPGCNT,10),?100,$J(BPGCNT,10),?122,$J(BPGCNT,10)
|
---|
94 | .W:BPGCNT !,"MEAN",?78,$J(BPGBIL/BPGCNT,10,2),?100,$J(BPGINS/BPGCNT,10,2),?122,$J(BPGCOLL/BPGCNT,10,2)
|
---|
95 | I BPRTYPE=3 D Q
|
---|
96 | .W !!,?100,"----------",?122,"----------"
|
---|
97 | .W !,"GRAND TOTALS",?100,$J(BPGBIL,10,2),?122,$J(BPGINS,10,2)
|
---|
98 | .W !,"COUNT",?100,$J(BPGCNT,10),?122,$J(BPGCNT,10)
|
---|
99 | .W:BPGCNT !,"MEAN",?100,$J(BPGBIL/BPGCNT,10,2),?122,$J(BPGINS/BPGCNT,10,2)
|
---|
100 | I BPRTYPE=2 D Q
|
---|
101 | .W !!,?41,"----------"
|
---|
102 | .W !,"GRAND TOTALS",?41,$J(BPGBIL,10,2)
|
---|
103 | .W !,"COUNT",?41,$J(BPGCNT,10)
|
---|
104 | .W:BPGCNT !,"MEAN",?41,$J(BPGBIL/BPGCNT,10,2)
|
---|
105 | I (BPRTYPE=5) D Q
|
---|
106 | .W !!,"GRAND TOTALS (ALL DIVISIONS)",?65,"---------------"
|
---|
107 | .W !,"TOTAL CLAIMS",?65,$J(BPGCNT,15)
|
---|
108 | .W !,"AVERAGE ELAPSED TIME PER CLAIM",?65,$J($S(BPGCNT=0:"0",1:(BPGELTM\BPGCNT)),15)
|
---|
109 | I (BPRTYPE=7) D Q
|
---|
110 | .W !!,"GRAND TOTALS (ALL DIVISIONS) BY BILLER"
|
---|
111 | .N BPBILR,BPDIV S BPDIV="ALL DIVISIONS"
|
---|
112 | .S BPBILR="" F S BPBILR=$O(BPGCNT(BPBILR)) Q:BPBILR="" D Q:BPQ
|
---|
113 | ..S NP=$$CHKP^BPSRPT5(1) Q:BPQ
|
---|
114 | ..W !,?3,BPBILR,?65,$J($G(BPGCNT(BPBILR)),5)
|
---|
115 | .Q:$G(BPQ)
|
---|
116 | .W !,?65,"-----"
|
---|
117 | .W !,"CLOSED CLAIMS GRAND TOTAL",?65,$J(BPGCNT,5)
|
---|
118 | ;
|
---|
119 | Q
|
---|
120 | ;
|
---|
121 | ;Get Close Reason
|
---|
122 | ;
|
---|
123 | ; Input Variable -> BP59 = ptr to BPS TRANSACTIONS
|
---|
124 | ; Returned Value -> Claim Close Reason
|
---|
125 | ;
|
---|
126 | CLRSN(BP59) N BP02,CIEN,CL
|
---|
127 | S CL=""
|
---|
128 | S BP02=+$P($G(^BPST(BP59,0)),U,4)
|
---|
129 | S CIEN=+$P($G(^BPSC(BP02,900)),U,4)
|
---|
130 | I CIEN'=0 S CL=$$GETCLR^BPSRPT6(CIEN)
|
---|
131 | Q CIEN_"^"_CL
|
---|
132 | ;
|
---|
133 | ;Get Reversal Reason
|
---|
134 | ;
|
---|
135 | ; Input Variable -> BP59 = ptr to BPS TRANSACTIONS
|
---|
136 | ; Returned Value -> Claim Reversal Reason
|
---|
137 | ;
|
---|
138 | RVSRSN(BP59) Q $P($G(^BPST(BP59,4)),U,4)
|
---|
139 | ;
|
---|
140 | ;Return the Billed Amount
|
---|
141 | ;
|
---|
142 | BILLED(BP59) ;
|
---|
143 | Q +$P($G(^BPST(BP59,5)),U,5)
|
---|
144 | ;
|
---|
145 | ;Return the Transaction Type - SUBMIT or REVERSAL
|
---|
146 | ;
|
---|
147 | TTYPE(BPRX,BPREF) N BPSTATUS,TTYPE
|
---|
148 | S TTYPE="SUBMIT"
|
---|
149 | S BPSTATUS=$$STATUS^BPSRPT6(BPRX,BPREF)
|
---|
150 | I BPSTATUS["REVERSAL" S TTYPE="REVERSAL"
|
---|
151 | Q TTYPE
|
---|
152 | ;
|
---|
153 | ;Return the payer response
|
---|
154 | ;
|
---|
155 | RESPONSE(BPRX,BPREF) Q $P($$STATUS^BPSRPT6(BPRX,BPREF),U)
|
---|
156 | ;
|
---|
157 | ;Print Report Subtotals
|
---|
158 | ;
|
---|
159 | TOTALS(BPRTYPE,BPDIV,BPTBIL,BPTINS,BPTCOLL,BPCNT,BPELTM) ;
|
---|
160 | I (BPRTYPE=1)!(BPRTYPE=4) D Q
|
---|
161 | .W !!,?78,"----------",?100,"----------",?122,"----------"
|
---|
162 | .W !,"SUBTOTALS for DIV:",$E($$BPDIV(BPDIV),1,52),?78,$J(BPTBIL,10,2),?100,$J(BPTINS,10,2),?122,$J(BPTCOLL,10,2)
|
---|
163 | .W !,"COUNT",?78,$J(BPCNT,10),?100,$J(BPCNT,10),?122,$J(BPCNT,10)
|
---|
164 | .W:BPCNT !,"MEAN",?78,$J(BPTBIL/BPCNT,10,2),?100,$J(BPTINS/BPCNT,10,2),?122,$J(BPTCOLL/BPCNT,10,2)
|
---|
165 | I BPRTYPE=3 D Q
|
---|
166 | .W !!,?100,"----------",?122,"----------"
|
---|
167 | .W !,"SUBTOTALS for DIV:",$E($$BPDIV(BPDIV),1,52),?100,$J(BPTBIL,10,2),?122,$J(BPTINS,10,2)
|
---|
168 | .W !,"COUNT",?100,$J(BPCNT,10),?122,$J(BPCNT,10)
|
---|
169 | .W:BPCNT !,"MEAN",?100,$J(BPTBIL/BPCNT,10,2),?122,$J(BPTINS/BPCNT,10,2)
|
---|
170 | I BPRTYPE=2 D Q
|
---|
171 | .W !!,?41,"----------"
|
---|
172 | .W !,"SUBTOTALS for DIV:",$E($$BPDIV(BPDIV),1,22),?41,$J(BPTBIL,10,2)
|
---|
173 | .W !,"COUNT",?41,$J(BPCNT,10)
|
---|
174 | .W:BPCNT !,"MEAN",?41,$J(BPTBIL/BPCNT,10,2)
|
---|
175 | I (BPRTYPE=5) D Q
|
---|
176 | .W !!,"SUBTOTALS for DIV: ",$E($$BPDIV(BPDIV),1,43),?65,"---------------"
|
---|
177 | .W !,"TOTAL CLAIMS",?65,$J(BPCNT,15)
|
---|
178 | .W !,"AVERAGE ELAPSED TIME PER CLAIM",?65,$J($S(BPCNT=0:"0",1:(BPELTM\BPCNT)),15)
|
---|
179 | I (BPRTYPE=7) D Q
|
---|
180 | .W !!,"SUBTOTALS for DIV:",$E($$BPDIV(BPDIV),1,43)
|
---|
181 | .N BPBILR
|
---|
182 | .S BPBILR="" F S BPBILR=$O(BPCNT(BPBILR)) Q:BPBILR="" D Q:BPQ
|
---|
183 | ..S NP=$$CHKP^BPSRPT5(1) Q:BPQ
|
---|
184 | ..W !,?3,BPBILR,?65,$J($G(BPCNT(BPBILR)),5)
|
---|
185 | .Q:$G(BPQ)
|
---|
186 | .W !,?65,"-----"
|
---|
187 | .W !,"CLOSED CLAIMS SUBTOTAL",?65,$J(BPCNT,5)
|
---|
188 | ;
|
---|
189 | Q
|
---|
190 | ;
|
---|
191 | ;Print Report Header
|
---|
192 | ; Input variables (defined in BPSRPT0) - BPPHARM,BPSUMDET,BPNOW,BPMWC,BPRTBCK,BPINSINF
|
---|
193 | ; BPREJCD,BPCCRSN,BPAUTREV,BPACREJ,BPQSTDRG
|
---|
194 | ; BPDRUG,BPDRGCL,BPRLNRL,BPSORT,BPBEGDT,BPENDDT
|
---|
195 | ; Output variable - BPSDATA -> Reset to 0 to show no actual data has been printed
|
---|
196 | ; on the screen
|
---|
197 | ; BPPAGE -> First set in BPSRPT0
|
---|
198 | ; BPBLINE -> Controls whether to print a blank line
|
---|
199 | ;
|
---|
200 | HDR(BPRTYPE,BPRPTNAM,BPPAGE) ;
|
---|
201 | ;Display Excel Header
|
---|
202 | I BPEXCEL D HDR^BPSRPT8(BPRTYPE) Q
|
---|
203 | ;
|
---|
204 | ; Define BPPDATA - Tells whether data has been displayed for a screen
|
---|
205 | S BPSDATA=0
|
---|
206 | S BPBLINE=""
|
---|
207 | S BPPAGE=$G(BPPAGE)+1
|
---|
208 | W @IOF
|
---|
209 | W "ECME "_BPRPTNAM_" "_$S(BPSUMDET=1:"SUMMARY",1:"DETAIL")_" REPORT"
|
---|
210 | W ?89,"Print Date: "_$G(BPNOW)_" Page:",$J(BPPAGE,3)
|
---|
211 | W !,"DIVISION(S): ",$$GETDIVS^BPSRPT4(75,.BPPHARM)
|
---|
212 | W ?93,"Fill Locations: "_$S(BPMWC="A":"C,M,W",1:BPMWC)
|
---|
213 | W ?116,"Fill type: "_$S(BPRTBCK=2:"RT",BPRTBCK=3:"BB",1:"RT,BB")
|
---|
214 | W !,"Insurance: "_$E($S(BPINSINF=0:"ALL",1:BPINSINF),1,30)
|
---|
215 | I (",2,")[BPRTYPE W ?44,"Reject Code: ",$E($$GETREJ^BPSRPT4(BPREJCD),1,28)
|
---|
216 | I (",7,")[BPRTYPE W ?44,"Close Reason: ",$E($$GETCLR^BPSRPT6(BPCCRSN),1,26)
|
---|
217 | I (",4,")[BPRTYPE W ?44,$J($S(BPAUTREV=0:"ALL",1:"AUTO"),4)," Reversals"
|
---|
218 | I (",4,")[BPRTYPE W ?60,$J($S(BPACREJ=1:"REJECTED",BPACREJ=2:"ACCEPTED",1:"ALL"),8)," Returned Status"
|
---|
219 | W ?87,"Drugs/Classes: "_$S(BPQSTDRG=2:$$DRGNAM^BPSRPT6(BPDRUG,30),BPQSTDRG=3:$E(BPDRGCL,1,30),1:"ALL")
|
---|
220 | W !,$S(BPRTYPE=5:"PRESCRIPTIONS",BPRLNRL=2:"RELEASED PRESCRIPTIONS",BPRLNRL=3:"PRESCRIPTIONS (NOT RELEASED)",1:"ALL PRESCRIPTIONS")
|
---|
221 | W " BY "_$S(BPRTYPE=7:"CLOSE",1:"TRANSACTION")_" DATE: "
|
---|
222 | W "From "_$$DATTIM^BPSRPT1(BPBEGDT)_" through "_$$DATTIM^BPSRPT1($P(BPENDDT,"."))
|
---|
223 | ;
|
---|
224 | D ULINE^BPSRPT5("=") Q:$G(BPQ)
|
---|
225 | D HEADLN1^BPSRPT4(BPRTYPE)
|
---|
226 | D HEADLN2^BPSRPT4(BPRTYPE)
|
---|
227 | D HEADLN3^BPSRPT4(BPRTYPE)
|
---|
228 | D ULINE^BPSRPT5("=")
|
---|
229 | ;
|
---|
230 | ;Print Division
|
---|
231 | I $G(BPDIV)]"" D
|
---|
232 | .W !,"DIVISION: ",$S(BPDIV=0:"BLANK",BPDIV="ALL DIVISIONS":"ALL DIVISIONS",$$DIVNAME^BPSSCRDS(BPDIV)]"":$$DIVNAME^BPSSCRDS(BPDIV),1:BPDIV)
|
---|
233 | .I BPRTYPE=5!(BPRTYPE=6)!(BPSUMDET=1)!(BPGRPLAN="") D ULINE^BPSRPT5("-")
|
---|
234 | ;
|
---|
235 | ;Print Insurance If Defined
|
---|
236 | I BPSUMDET=0,$G(BPGRPLAN)]"",$G(BPGRPLAN)'=0,$G(BPGRPLAN)'="~" D WRPLAN^BPSRPT5(BPGRPLAN)
|
---|
237 | Q
|
---|
238 | ;
|
---|
239 | ;Special Division Handling
|
---|
240 | ;
|
---|
241 | BPDIV(BPDIV) Q $S(BPDIV=0:"BLANK",$$DIVNAME^BPSSCRDS(BPDIV)]"":$$DIVNAME^BPSSCRDS(BPDIV),1:BPDIV)
|
---|