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

ECXLABR.m

Go to the documentation of this file.
  1. ECXLABR ;ALB/JAP,BIR/CML-LAR Extract for DSS (New Format - With LMIP Codes) ;2/6/19 12:50
  1. ;;3.0;DSS EXTRACTS;**8,24,33,37,39,46,71,80,107,105,112,127,144,154,161,170,174**;Dec 22, 1997;Build 33
  1. BEG ;entry point from option
  1. D SETUP I ECFILE="" Q
  1. D ^ECXTRAC,^ECXKILL
  1. Q
  1. ;
  1. START ; entry when queued
  1. N X,OK,ECTRS,ECTRANS,ECTRIEN,ECDOC,ECDOCPC,ECXESC,ECXECL,ECXCLST,ECCLASS,ECRETM,ECREDT,ECSCDT,ECSCTM,ECXTIME,ECXASIH ;144,154,170
  1. K ^LAR(64.036) S LRSDT=ECSD,LREDT=ECED
  1. D ^LRCAPDAR
  1. ;quit if no completion date for API compile
  1. I '$P($G(^LAR(64.036,1,2,1,0)),U,4) Q
  1. ;process temporary lab file #64.036
  1. S QFLG=0,ECLRN=1
  1. F S ECLRN=$O(^LAR(64.036,ECLRN)) Q:('ECLRN)!(QFLG) D
  1. .I $D(^LAR(64.036,ECLRN,0)) D
  1. ..S EC1=^LAR(64.036,ECLRN,0),ECF=$P(EC1,U,2)
  1. ..Q:ECF=""
  1. ..S (ECXESC,ECXECL,ECXCLST)="" ;144
  1. ..S ECXDFN=$P(EC1,U,3),ECPTPR=$P($G(EC1),U,11),ECCLASS=""
  1. ..S ECXTIME=$S($P(EC1,U,10)="":"000300",1:$P(EC1,U,10))
  1. ..S ECXDATE=$P(EC1,U,9)_"."_$P(EC1,U,10)
  1. ..I ECPTPR S ECCLASS=$$PRVCLASS^ECXUTL(ECPTPR,ECXDATE)
  1. ..I ECPTPR S ECPTNPI=$$NPI^XUSNPI("Individual_ID",ECPTPR,+ECXDATE) D
  1. ...S:+ECPTNPI'>0 ECPTNPI="" S ECPTNPI=$P(ECPTNPI,U)
  1. ..S ECORDT=$$ECXDATE^ECXUTL($P(EC1,U,4),ECXYM)
  1. ..S ECORTM=$$ECXTIME^ECXUTL($P(EC1,U,4)_"."_$P(EC1,U,5))
  1. ..S ECREDT=$$ECXDATE^ECXUTL($P(EC1,U,6),ECXYM)
  1. ..S ECRETM=$$ECXTIME^ECXUTL($P(EC1,U,6)_"."_$P(EC1,U,7))
  1. ..S ECSCDT=$$ECXDATE^ECXUTL($P(EC1,U,9),ECXYM)
  1. ..S ECSCTM=$$ECXTIME^ECXUTL($P(EC1,U,9)_"."_$P(EC1,U,10))
  1. ..S (ECXADMDT,ECXDOM,ECXDSSD,ECXPNM,ECXSSN,ECXA,ECXMN,ECXTS)=""
  1. ..I ECF=2 D Q:'OK
  1. ...K ECXPAT S OK=$$PAT^ECXUTL3(ECXDFN,ECXDATE,"1;5",.ECXPAT) ;154 Added service related information (5) to the list
  1. ...Q:'OK
  1. ...S ECXPNM=ECXPAT("NAME"),ECXSSN=ECXPAT("SSN"),ECXMPI=ECXPAT("MPI")
  1. ...S X=$$INP^ECXUTL2(ECXDFN,ECXDATE),ECXA=$P(X,U),ECXADMDT=$P(X,U,4),ECXASIH=$P(X,U,14) ;170
  1. ...S ECXMN=$P(X,U,2),ECXTS=$P(X,U,3),ECXDOM=$P(X,U,10)
  1. ...S ECXCLST=ECXPAT("CL STAT") ;144
  1. ..;allow for referral patients in future??
  1. ..;I ECF=67 S ECSN="000123456",ECNA="RFRL"
  1. ..;loop on results multiple
  1. ..;
  1. ..;Get production division ECXDIEN added p-80
  1. ..N ECXPDIV,ECXDIEN S ECXDIEN=$O(^DIC(4,"D",ECINST,"")),ECXPDIV=$$RADDIV^ECXDEPT(ECXDIEN) ;p-46
  1. ..K ECXDIEN
  1. ..;- Observation patient indicator (y/n)
  1. ..S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS)
  1. ..;
  1. ..;- If no encounter number don't file record
  1. ..S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,$P(EC1,U,9),ECXTS,ECXOBS,ECHEAD,,) Q:ECXENC=""
  1. ..S ECRES=0
  1. ..F S ECRES=$O(^LAR(64.036,ECLRN,1,ECRES)) Q:('ECRES)!(QFLG) D
  1. ...I $D(^LAR(64.036,ECLRN,1,ECRES,0)) D Q:QFLG
  1. ....S EC2=^LAR(64.036,ECLRN,1,ECRES,0),ECN=$P(EC2,U),ECRS=$P(EC2,U,2)
  1. ....S ECHL=$E($P(EC2,U,3)),ECWC=+$P(EC2,U,4)
  1. ....I ECWC S ECWC=$P(^LAM(ECWC,0),U,2)
  1. ....S ECLNC=$P(EC2,U,5)
  1. .... ; ******* - PATCH 127, ADD PATCAT CODE
  1. ....S ECXPATCAT=$$PATCAT^ECXUTL(ECXDFN)
  1. ....;
  1. ....; - Free text results translation
  1. ....S ECTRANS="",ECTRS=ECRS
  1. ....I +ECTRS S ECTRS=$TR(ECTRS,",","") D
  1. .....I (ECTRS?.N)!(ECTRS?.N1".".N) S ECRS=ECTRS
  1. ....F Q:$E(ECTRS,1)'=" " S ECTRS=$E(ECTRS,2,$L(ECTRS))
  1. ....F Q:$E(ECTRS,$L(ECTRS))'=" " S ECTRS=$E(ECTRS,1,($L(ECTRS)-1))
  1. ....I ECTRS]"" I ECTRS'?.N I ECTRS'?.N1".".N D ;translate
  1. .....S ECTRS=$TR(ECRS,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
  1. .....S ECTRIEN="",ECTRIEN=$O(^ECX(727.7,"B",ECTRS,ECTRIEN))
  1. .....S ECTRANS=$S(ECTRIEN:$P(^ECX(727.7,ECTRIEN,0),U,2),1:5)
  1. ....;
  1. ....I $G(ECXASIH) S ECXA="A" ;170
  1. ....I ECWC]"" D FILE
  1. K ^LAR(64.036) S ^LAR(64.036,0)="LAB DSS LAR EXTRACT^64.036^"
  1. Q
  1. ;
  1. FILE ;file record
  1. ;node0
  1. ;facility (ECINST)^dfn (ECXDFN)^ssn (ECXSSN)^name(ECXPNM)^in/out (ECXA)^
  1. ;day(ECSCDT)^
  1. ;lab test code (ECN)^placehold results (ECRS) - pre-2018^hi/lo indicator (ECHL)^
  1. ;date ordered (ECORDT)^time ordered (ECORTM)^date ready (ECREDT)^
  1. ;time ready (ECRETM)^
  1. ;movement file # (ECXMN)^treating specialty (ECXTS)^
  1. ;workload code(ECWC)^
  1. ;node1
  1. ;mpi (ECXMPI)^placeholder (ECXDSSD)^dom (ECXDOM)^time (ECSCTM)^
  1. ;observ pat ind (ECXOBS)^encounter num (ECXENC)^prod div ECXPDIV^
  1. ;placehold lab results translation ECTRANS^ordering provider (ECPTPR)^
  1. ;ordering provider person class (ECCLASS)^ordering provider npi ECPTNPI^LOINC code ECLNC
  1. ;Patient Category PATCAT^PLACEHOLD Encounter SC ECXESC^Camp Lejeune Status ECXCLST^PLACEHOLD Encounter Camp Lejeune ECXECL^Long Results (ECRS) post-2018
  1. N DA,DIK
  1. S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1
  1. S ECODE=EC7_U_EC23_U_ECINST_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U
  1. S ECODE=ECODE_ECSCDT_U_$$RJ^XLFSTR(ECN,4,0)_U_$S(ECXLOGIC>2018:"",1:$E(ECRS,1,20))_U_ECHL_U_ECORDT_U ;170 Change result field to be null after 2018, otherwise 1st 20 chars
  1. S ECODE=ECODE_$$LJ^XLFSTR(ECORTM,6,0)_U
  1. ;convert specialty to PTF Code for transmission
  1. N ECXDATA,ECXTSC
  1. S ECXDATA=$$TSDATA^DGACT(42.4,+ECXTS,.ECXDATA)
  1. S ECXTSC=$G(ECXDATA(7))
  1. ;done
  1. S ECODE=ECODE_ECREDT_U_$$LJ^XLFSTR(ECRETM,6,0)_U_ECXMN_U_ECXTSC_U_ECWC_U
  1. S ECODE1=ECXMPI_U_ECXDSSD_U_ECXDOM_U_ECSCTM_U_ECXOBS_U_ECXENC_U_ECXPDIV_U_$S(ECXLOGIC>2019:"",1:ECTRANS) ;174 Remove translated results after FY2019
  1. I ECXLOGIC>2004 S ECODE1=ECODE1_U_2_ECPTPR_U_ECCLASS
  1. I ECXLOGIC>2007 S ECODE1=ECODE1_U_ECPTNPI
  1. I ECXLOGIC>2008 S ECODE1=ECODE1_U_ECLNC
  1. I ECXLOGIC>2010 S ECODE1=ECODE1_U_ECXPATCAT
  1. I ECXLOGIC>2013 S ECODE1=ECODE1_U_ECXESC_U_ECXCLST_U_ECXECL ;144
  1. I ECXLOGIC>2018 S ECODE1=ECODE1_U_ECRS ;170 Longer result moved here
  1. S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1,ECRN=ECRN+1
  1. S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA
  1. I $D(ZTQUEUED),$$S^%ZTLOAD S QFLG=1
  1. Q
  1. ;
  1. SETUP ;Set required input for ECXTRAC
  1. S ECHEAD="LAR"
  1. D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
  1. Q
  1. ;
  1. QUE ; entry point for the background requeuing handled by ECXTAUTO
  1. D SETUP,QUE^ECXTAUTO,^ECXKILL Q