Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ECXLPRO

ECXLPRO.m

Go to the documentation of this file.
ECXLPRO ;ALB/JAP - PRO Extract YTD Lab Report ;11/19/19  14:00
 ;;3.0;DSS EXTRACTS;**21,24,36,84,144,177**;Dec 22, 1997;Build 2
 ;for data associated with prosthetic items produced by facility laboratory
 ;accumulates extract data by hcpcs code for all extracts in fiscal year date range
 ;if an extract has been purged, then totals will be falsely low
 ;if more than 1 extract exists for a particular month, then totals will be falsely high
 ;if site is multidivisional, then user can generate report for
 ;  any one division - data stored under divisional station# (e.g., 326 or 326AB)
 ;  or for entire facility - data stored under primary station# (e.g., 326) but includes data from all subdivisions
 ;if site is non-divisional, then data stored under facility station#
 ;
EN ;setup & queue
 N DIC,DA,DR,DIQ,DIR,DIRUT,DTOUT,DUOUT,DIV,LAST,OUT,ECXPORT,CNT
 S ECXERR=0
 S ECXHEAD="PRO"
 W !!,"Setup for PRO Extract YTD Laboratory Report --",!
 ;determine primary division
 W !,"If you belong to more than one Primary Division, you must"
 W !,"select a Primary Division for the report.",!
 S ECXPRIME=$$PDIV^ECXPUTL
 I ECXPRIME=0 D ^ECXKILL Q
 S DA=ECXPRIME,DIC="^DIC(4,",DIQ(0)="I",DIQ="ECXDIC",DR=".01;99" D EN^DIQ1
 S ECXPRIME=ECXPRIME_U_$G(ECXDIC(4,DA,99,"I"))_U_$G(ECXDIC(4,DA,.01,"I"))
 ;get all prosthetics divisions for report
 S ECXALL=1
 D PDIV3^ECXPUTL(DUZ,ECXPRIME,.ECXDIV)
 I ECXERR D  Q
 .D ^ECXKILL W !!,?5,"Try again later... exiting.",!
 ;determine fiscal year of report
 S DIR(0)="SMBA^C:CURRENT;P:PREVIOUS",DIR("A")="Select C(urrent) or P(revious) Fiscal Year: ",DIR("B")="CURRENT"
 W ! K X,Y D ^DIR K DIR
 I $D(DUOUT)!($D(DTOUT)) D  Q
 .D ^ECXKILL W !!,?5,"Try again later... exiting.",!
 I Y="C" D
 .S X=$$CYFY^ECXUTL1(DT),ECXARRAY("START")=$P(X,U,3),ECXARRAY("END")=$P(X,U,4)
 I Y="P" D
 .S YR=$E(DT,1,3),MON=$E(DT,4,5) S:+MON<10 YR=YR-1 S X1=YR_"0930"
 .S X=$$CYFY^ECXUTL1(X1),ECXARRAY("START")=$P(X,U,3),ECXARRAY("END")=$P(X,U,4)
 .K C,MON,YR,X1
 ;setup variables for taskmanager
 S ECXPGM="PROCESS^ECXLPRO",ECXDESC="PRO Extract YTD HCPCS Report"
 S ECXSAVE("ECXHEAD")="",ECXSAVE("ECXDIV(")="",ECXSAVE("ECXARRAY(")="",ECXSAVE("ECXPRIME")="",ECXSAVE("ECXALL")=""
 ;determine output device and queue if requested
 S ECXPORT=$$EXPORT^ECXUTL1 Q:ECXPORT=-1  I ECXPORT D  Q  ;144
 .K ^TMP($J,"ECXPORT") ;144
 .S ^TMP($J,"ECXPORT",0)="REPORT TYPE^PSAS HCPCS^LOCAL QTY^LOCAL LABOR COST^LOCAL MATERIAL COST^LOCAL AVE COST^ALL OTHER QTY^ALL OTHER LABOR COST^ALL OTHER MATERIAL COST^ALL OTHER AVE COST" ;144
 .S CNT=1 ;144
 .D PROCESS ;144
 .D EXPDISP^ECXUTL1 ;144
 .D ^ECXKILL ;144
 W !!,"Please note: The PRO Extract YTD Laboratory Report requires 132 columns."
 W !,"             Select an appropriate device for output."
 W ! D DEVICE^ECXUTLA(ECXPGM,ECXDESC,.ECXSAVE)
 I ECXSAVE("POP")=1 W ! D ^ECXKILL Q
 I ECXSAVE("ZTSK")=0 D
 .K ECXSAVE,ECXPGM,ECXDESC
 .D PROCESS
 ;clean-up and close
 I IO'=IO(0) D ^%ZISC
 D HOME^%ZIS
 Q
 ;
PROCESS ;begin processing
 N DIVISION,E,EXTRACT,REC,NODE0,NODE1,LASTDAY,NODE2 ;177 Node2 will hold new cost data
 K ^TMP($J,"ECXP") S LASTDAY=""
 ;determine which extracts contain data for report
 S (EXTRACT,E)=0
 F  S E=$O(^ECX(727,"E",ECXHEAD,E)) Q:'E  D
 .Q:'$D(^ECX(727,E,0))
 .Q:$P($G(^ECX(727,E,0)),U,4)<ECXARRAY("START")
 .Q:$P($G(^ECX(727,E,0)),U,4)>ECXARRAY("END")
 .Q:$G(^ECX(727,E,"DIV"))'=+ECXPRIME
 .S EXTRACT(E)=^ECX(727,E,0)
 .I $P(EXTRACT(E),U,5)>LASTDAY S LASTDAY=$P(EXTRACT(E),U,5)
 ;setup array of station numbers included in report
 F DIV=0:0 S DIV=$O(ECXDIV(DIV)) Q:'DIV  S ECXSTAT=$P(ECXDIV(DIV),U,2),DIVISION(ECXSTAT)=ECXDIV(DIV)
 ;get the extract data
 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
 .S NODE0=$G(^ECX(727.826,REC,0)),NODE1=$G(^ECX(727.826,REC,1)),NODE2=$G(^ECX(727.826,REC,2)) Q:NODE0=""  ;177 Grab node 2 to get new cost data
 .S (ECXCTAMT,ECXLLC,ECXLMC)=0
 .S ECXFELOC=$P(NODE0,U,10),ECXFEKEY=$P(NODE0,U,11)
 .;ignore any record which isn't for lab receiving station
 .Q:ECXFELOC'["LAB"
 .S ECXHCPC=$P(NODE0,U,33),ECXTYPE=$E(ECXFEKEY,6),ECXREQ=$P($E(ECXFEKEY,8,99),"REQ",1)
 .S ECXQTY=$P(NODE0,U,12),ECXCTAMT=$P(NODE0,U,25)+$P(NODE2,U,25),ECXGRPR=$P(NODE1,U,4) ;177 Pre-FY20 cost data is in NODE0, FY20 and beyond cost data is in NODE2
 .S ECXSTAT=$P(ECXFELOC,"LAB",1),ECXFORM="LAB"
 .S ECXLLC=$P(NODE0,U,26)+$P(NODE2,U,26),ECXLMC=$P(NODE0,U,27)+$P(NODE2,U,27) ;177 Pre FY20 cost data is in NODE0, FY20 and beyond cost data is in NODE2
 .;ignore record if division not included in this report
 .Q:ECXSTAT=""  Q:'$D(DIVISION(ECXSTAT))
 .;set in ^tmp using primary station#; determine if requesting station is same as or part of this station
 .S ECXLAB="",ECXSTAT=+ECXSTAT,ECXLAB=$S(ECXREQ'[ECXSTAT:"OTHER",1:"SAME")
 .;be sure there's no padding on cost variables
 .S ECXCTAMT=+$TR(ECXCTAMT," ",0),ECXLLC=+$TR(ECXLLC," ",0),ECXLMC=+$TR(ECXLMC," ",0)
 .;tmp global holds - lab qty^lab labor cost^lab matrl cost
 .I '$D(^TMP($J,"ECXP",ECXTYPE,ECXHCPC)) S ^TMP($J,"ECXP",ECXTYPE,ECXHCPC,"SAME")="0^0^0",^TMP($J,"ECXP",ECXTYPE,ECXHCPC,"OTHER")="0^0^0"
 .S $P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,1)=$P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,1)+ECXQTY
 .S $P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,2)=$P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,2)+ECXLLC
 .S $P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,3)=$P(^TMP($J,"ECXP",ECXTYPE,ECXHCPC,ECXLAB),U,3)+ECXLMC
 ;setup hcpcs descriptions
 D HCPCS^ECXCPRO
 ;print report
 D PRINT^ECXLPRO1
 ;cleanup
 I '$G(ECXPORT) D AUDIT^ECXKILL ;144
 Q
 ;
HCPCS ;setup hcpcs cross-reference
 N H,CPT,CPTNM,DESC
 S H=0
 F  S H=$O(^RMPR(661.1,H)) Q:+H<1  D
 .;don't skip inactive hcpcs in case doing previous fy
 .S CPTNM="",CPT=$P(^RMPR(661.1,H,0),U,4)
 .I +CPT>0 S CPTNM=$P(^ICPT(CPT,0),U,1),DESC=$E($P(^ICPT(CPT,0),U,2),1,26)
 .Q:CPTNM=""
 .S ^TMP($J,"HCPCS",CPTNM)=DESC
 Q