[613] | 1 | ECXCPRO ;ALB/JAP - PRO Extract YTD Report ; 8/23/05 1:36pm
|
---|
| 2 | ;;3.0;DSS EXTRACTS;**21,24,33,84**;Dec 22, 1997
|
---|
| 3 | ;accumulates extract data by hcpcs code for all extracts in fiscal year date range
|
---|
| 4 | ;if an extract has been purged, then totals will be falsely low
|
---|
| 5 | ;if more than 1 extract exists for a particular month, then totals will be falsely high
|
---|
| 6 | ;if site is multidivisional, then user can generate report for
|
---|
| 7 | ; any one division - data stored under divisional station# (e.g., 326 or 326AB)
|
---|
| 8 | ; or for entire facility - data stored under primary station# (e.g., 326) but includes data from all subdivisions
|
---|
| 9 | ;if site is non-divisional, then data stored under facility station#
|
---|
| 10 | ;
|
---|
| 11 | ;
|
---|
| 12 | EN ;setup & queue
|
---|
| 13 | N DIC,DA,DR,DIQ,DIR,DIRUT,DTOUT,DUOUT,DIV,LAST,OUT
|
---|
| 14 | S ECXERR=0
|
---|
| 15 | S ECXHEAD="PRO"
|
---|
| 16 | W !!,"Setup for PRO Extract YTD HCPCS Report --",!
|
---|
| 17 | ;determine primary division
|
---|
| 18 | W !,"If you belong to more than one Primary Division, you must"
|
---|
| 19 | W !,"select a Primary Division for the report.",!
|
---|
| 20 | S ECXPRIME=$$PDIV^ECXPUTL
|
---|
| 21 | I ECXPRIME=0 D ^ECXKILL Q
|
---|
| 22 | S DA=ECXPRIME,DIC="^DIC(4,",DIQ(0)="I",DIQ="ECXDIC",DR=".01;99" D EN^DIQ1
|
---|
| 23 | S ECXPRIME=ECXPRIME_U_$G(ECXDIC(4,DA,99,"I"))_U_$G(ECXDIC(4,DA,.01,"I"))
|
---|
| 24 | ;select 1 or more prosthetics divisions for report
|
---|
| 25 | D PRO^ECXDVSN2(DUZ,ECXPRIME,.ECXDIV,.ECXALL,.ECXERR)
|
---|
| 26 | I ECXERR D Q
|
---|
| 27 | .D ^ECXKILL W !!,?5,"Try again later... exiting.",!
|
---|
| 28 | ;determine fiscal year of report
|
---|
| 29 | S DIR(0)="SMBA^C:CURRENT;P:PREVIOUS",DIR("A")="Select C(urrent) or P(revious) Fiscal Year: ",DIR("B")="CURRENT"
|
---|
| 30 | W ! K X,Y D ^DIR K DIR
|
---|
| 31 | I $D(DUOUT)!($D(DTOUT)) D Q
|
---|
| 32 | .D ^ECXKILL W !!,?5,"Try again later... exiting.",!
|
---|
| 33 | I Y="C" D
|
---|
| 34 | .S X=$$CYFY^ECXUTL1(DT),ECXARRAY("START")=$P(X,U,3),ECXARRAY("END")=$P(X,U,4)
|
---|
| 35 | I Y="P" D
|
---|
| 36 | .S YR=$E(DT,1,3),MON=$E(DT,4,5) S:+MON<10 YR=YR-1 S X1=YR_"0930"
|
---|
| 37 | .S X=$$CYFY^ECXUTL1(X1),ECXARRAY("START")=$P(X,U,3),ECXARRAY("END")=$P(X,U,4)
|
---|
| 38 | .K C,MON,YR,X1
|
---|
| 39 | ;setup variables for taskmanager
|
---|
| 40 | S ECXPGM="PROCESS^ECXCPRO",ECXDESC="PRO Extract YTD Lab Report"
|
---|
| 41 | S ECXSAVE("ECXHEAD")="",ECXSAVE("ECXDIV(")="",ECXSAVE("ECXARRAY(")="",ECXSAVE("ECXPRIME")="",ECXSAVE("ECXALL")=""
|
---|
| 42 | ;determine output device and queue if requested
|
---|
| 43 | W !!,"Please note: The PRO Extract YTD HCPCS Report requires 132 columns."
|
---|
| 44 | W !," Select an appropriate device for output."
|
---|
| 45 | W ! D DEVICE^ECXUTLA(ECXPGM,ECXDESC,.ECXSAVE)
|
---|
| 46 | I ECXSAVE("POP")=1 W ! D ^ECXKILL Q
|
---|
| 47 | I ECXSAVE("ZTSK")=0 D
|
---|
| 48 | .K ECXSAVE,ECXPGM,ECXDESC
|
---|
| 49 | .D PROCESS
|
---|
| 50 | ;clean-up and close
|
---|
| 51 | I IO'=IO(0) D ^%ZISC
|
---|
| 52 | D HOME^%ZIS
|
---|
| 53 | Q
|
---|
| 54 | ;
|
---|
| 55 | PROCESS ;begin processing
|
---|
| 56 | N DIVISION,E,EXTRACT,REC,NODE0,NODE1,LASTDAY
|
---|
| 57 | K ^TMP($J,"ECXP") S LASTDAY=""
|
---|
| 58 | ;determine which extracts contain data for report
|
---|
| 59 | S (EXTRACT,E)=0
|
---|
| 60 | F S E=$O(^ECX(727,"E",ECXHEAD,E)) Q:'E D
|
---|
| 61 | .Q:'$D(^ECX(727,E,0))
|
---|
| 62 | .Q:$P($G(^ECX(727,E,0)),U,4)<ECXARRAY("START")
|
---|
| 63 | .Q:$P($G(^ECX(727,E,0)),U,4)>ECXARRAY("END")
|
---|
| 64 | .Q:$G(^ECX(727,E,"DIV"))'=+ECXPRIME
|
---|
| 65 | .S EXTRACT(E)=^ECX(727,E,0)
|
---|
| 66 | .I $P(EXTRACT(E),U,5)>LASTDAY S LASTDAY=$P(EXTRACT(E),U,5)
|
---|
| 67 | ;setup array of station numbers included in report
|
---|
| 68 | F DIV=0:0 S DIV=$O(ECXDIV(DIV)) Q:'DIV S ECXSTAT=$P(ECXDIV(DIV),U,2),DIVISION(ECXSTAT)=ECXDIV(DIV)
|
---|
| 69 | ;get the extract data
|
---|
| 70 | S E=0 F S E=$O(EXTRACT(E)) Q:'E S REC=0 I $D(^ECX(727.826,"AC",E)) F S REC=$O(^ECX(727.826,"AC",E,REC)) Q:'REC D
|
---|
| 71 | .S NODE0=$G(^ECX(727.826,REC,0)),NODE1=$G(^ECX(727.826,REC,1)) Q:NODE0=""
|
---|
| 72 | .S (ECXCTAMT,ECXLLC,ECXLMC)=0
|
---|
| 73 | .S ECXFELOC=$P(NODE0,U,10),ECXFEKEY=$P(NODE0,U,11)
|
---|
| 74 | .S ECXHCPC=$P(NODE0,U,33),ECXTYPE=$E(ECXFEKEY,6),ECXSRCE=$E(ECXFEKEY,7)
|
---|
| 75 | .S ECXQTY=$P(NODE0,U,12),ECXCTAMT=$P(NODE0,U,25),ECXGRPR=$P(NODE1,U,4)
|
---|
| 76 | .I ECXFELOC["NONL" S ECXSTAT=$P(ECXFELOC,"NONL",1),ECXFORM="NONL"
|
---|
| 77 | .;if this station is lab requesting station, then count lab transaction
|
---|
| 78 | .I ECXFELOC["ORD" D
|
---|
| 79 | ..S ECXSTAT=$P(ECXFELOC,"ORD",1),ECXFORM="ORD"
|
---|
| 80 | ..S ECXLLC=$P(NODE0,U,26),ECXLMC=$P(NODE0,U,27)
|
---|
| 81 | .;ignore record for receiving station feeder location
|
---|
| 82 | .Q:ECXFELOC["LAB"
|
---|
| 83 | .;ignore record if division not included in this report
|
---|
| 84 | .Q:ECXSTAT="" Q:'$D(DIVISION(ECXSTAT))
|
---|
| 85 | .;if combining data from all subdivisions, then set in ^tmp using primary station#
|
---|
| 86 | .I ECXALL=1 S ECXSTAT=$P(ECXPRIME,U,2)
|
---|
| 87 | .;be sure there's no padding on cost variables
|
---|
| 88 | .S ECXCTAMT=+$TR(ECXCTAMT," ",0),ECXLLC=+$TR(ECXLLC," ",0),ECXLMC=+$TR(ECXLMC," ",0)
|
---|
| 89 | .;tmp global holds - com qty^com cost^va nonlab qty^va nonlab cost^lab qty^lab labor cost^lab matrl cost
|
---|
| 90 | .I '$D(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC)) S ^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC)="0^0^0^0^0^0^0"
|
---|
| 91 | .I ECXSRCE="C",ECXFORM="NONL" D
|
---|
| 92 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,1)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,1)+ECXQTY
|
---|
| 93 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,2)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,2)+ECXCTAMT
|
---|
| 94 | .I ECXSRCE="V",ECXFORM="NONL" D
|
---|
| 95 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,3)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,3)+ECXQTY
|
---|
| 96 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,4)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,4)+ECXCTAMT
|
---|
| 97 | .I ECXFORM="ORD" D
|
---|
| 98 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,5)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,5)+ECXQTY
|
---|
| 99 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,6)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,6)+ECXLLC
|
---|
| 100 | ..S $P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,7)=$P(^TMP($J,"ECXP",ECXSTAT,ECXTYPE,ECXHCPC),U,7)+ECXLMC
|
---|
| 101 | ;setup hcpcs descriptions
|
---|
| 102 | D HCPCS
|
---|
| 103 | ;print report
|
---|
| 104 | D PRINT^ECXCPRO1
|
---|
| 105 | ;cleanup
|
---|
| 106 | D AUDIT^ECXKILL
|
---|
| 107 | Q
|
---|
| 108 | ;
|
---|
| 109 | HCPCS ;setup hcpcs cross-reference
|
---|
| 110 | N H,HCPCS,CODE,CPTNM,DESC
|
---|
| 111 | S H=0
|
---|
| 112 | F S H=$O(^RMPR(661.1,H)) Q:+H<1 D
|
---|
| 113 | .;don't skip inactive hcpcs in case doing previous fy
|
---|
| 114 | .S HCPCS="",HCPCS=$P(^RMPR(661.1,H,0),U,1)
|
---|
| 115 | .S CODE=$$CPT^ICPTCOD(HCPCS)
|
---|
| 116 | .I +CODE>0 S CPTNM=$P(CODE,U,2),DESC=$E($P(CODE,U,3),1,26)
|
---|
| 117 | .Q:CPTNM=""
|
---|
| 118 | .S ^TMP($J,"HCPCS",CPTNM)=DESC
|
---|
| 119 | Q
|
---|