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