Changeset 623 for WorldVistAEHR/trunk/r/DSS_EXTRACTS-ECX/ECXNUT.m
- Timestamp:
- Dec 4, 2009, 12:11:15 AM (14 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
WorldVistAEHR/trunk/r/DSS_EXTRACTS-ECX/ECXNUT.m
r613 r623 1 ECXNUT ;ALB/JRC Nutrition DSS Extract ; 9/24/07 9:33am 2 ;;3.0;DSS EXTRACTS;**92,107,105**;Dec 22, 1997;Build 70 3 BEG ;entry point from option 4 N EC23,EC7,ECED,ECFILE,ECGRP,ECHEAD,ECINST,ECPACK,ECPIECE,ECRN,ECRTN,ECSD1,ECVER,ECXYM 5 D SETUP I ECFILE="" Q 6 D ^ECXTRAC,^ECXKILL 7 Q 8 ; 9 START ; start package specific extract 10 ;Init variables 11 N ECSD,ARRAY 12 S ECED=ECED+.3,ECSD=ECSD1,ARRAY="^TMP($J,""FH"")" 13 K @ARRAY 14 ; 15 ;Call n&fs api and store in ^TMP($J,"FH" global 16 D DATA^FHDSSAPI(ECSD,ECED) 17 ; 18 ;Get n&fs records from ^TMP($J,"FH" global and file 19 D GETMEALS^ECXNUT1 20 ; 21 ;kill ^tmp global 22 K @ARRAY 23 ; 24 Q 25 ; 26 GET ;gather extract data 27 ;Init variables 28 N ECXORDPC,ECXSSN,ECXPNM,ECXSEX,ECXDOB,ECXMPI,ECXRC1,ECXETH,ECXVET,ECXENRL,ECXELIG,ECXMST,ECXPST,ECXPLOC,ECXPHI,ECXMNS,ECXSTATE,ECXCNTY,ECXZIP,ECXPOS,ECXAST,ECXAOL,ECXRST,ECXEST,ECXTM,ECXDATE,ECXMN,ECXSPC 29 N ECXADMDT,ECXWRD,ECXFAC,ECXPRV,ECXPRNPI,ECXATT,ECXATNPI,ECXDOM,ECXATTPC,ECXPRVPC,ECXPDIV,ECXCBOC,ECPTPR,ECCLASS,ECPTTM,ECXOBS,ECXHNCI,ECXNPRFI,ECXERI,ECXENC,ECPAT,ECXERR,ADM,W,X,ECXCAT,ECXCVE,ECXPRIOR,ECXPTYPE,ECXSTAT,ECXUESTA,ECXA,ECORNPI 30 N ECXOEF,ECXOEFDT 31 ; 32 ;- Prefix ordering pro with a 2 and get person class 33 S ECXORDPC=$$PRVCLASS^ECXUTL(+ECXORDPH,DATE) 34 S ECORNPI=$$NPI^XUSNPI("Individual_ID",+ECXORDPH,DATE) 35 S:+ECORNPI'>0 ECORNPI="" S ECORNPI=$P(ECORNPI,U) 36 S ECXORDPH=$S(ECXORDPH:2_ECXORDPH,1:"") 37 ; 38 ;set patient file (#2) dfn and get patient demographics 39 S ECXDFN=$P($G(^TMP($J,"FH","ZN",FHDFN)),U,3) 40 S ECXERR=0 D PAT(ECXDFN) 41 Q:ECXERR 42 ;Set demographic variables 43 S ECXSSN=ECPAT("SSN"),ECXPNM=ECPAT("NAME"),ECXSEX=ECPAT("SEX"),ECXDOB=ECPAT("DOB"),ECXMPI=ECPAT("MPI"),ECXRC1=ECPAT("RACE1"),ECXETH=ECPAT("ETHNIC"),ECXVET=ECPAT("VET"),ECXENRL=ECPAT("ENROLL LOC"),ECXELIG=ECPAT("ELIG") 44 S ECXMST=ECPAT("MST STAT"),ECXPST=ECPAT("POW STAT"),ECXPLOC=ECPAT("POW LOC"),ECXPHI=ECPAT("PHI"),ECXMNS=ECPAT("MEANS"),ECXSTATE=ECPAT("STATE"),ECXCNTY=ECPAT("COUNTY"),ECXZIP=ECPAT("ZIP") 45 S ECXPOS=ECPAT("POS"),ECXAST=ECPAT("AO STAT"),ECXAOL=ECPAT("AOL"),ECXRST=ECPAT("IR STAT"),ECXEST=ECPAT("EC STAT") 46 ; 47 ;Get oef/oif data 48 S ECXOEF=ECPAT("ECXOEF") 49 S ECXOEFDT=ECPAT("ECXOEFDT") 50 ; 51 ;Get enrollment status 52 I $$ENROLLM^ECXUTL2(ECXDFN) 53 ; 54 S ECXTM=$$ECXTIME^ECXUTL(DATE) 55 S ECXDATE=$$ECXDATE^ECXUTL(+DATE,ECXYM) 56 ; 57 ;- Use movement record date & time 58 S ADM=$$INP^ECXUTL2(ECXDFN,DATE),ECXA=$P(ADM,U) 59 S ECXMN=$P(ADM,U,2),ECXSPC=$P(ADM,U,3),ECXADMDT=$P(ADM,U,4) 60 S W=$P(ADM,U,9),ECXWRD=$P(W,";",1),ECXFAC=$P(W,";",2) 61 S ECXPRV=$P(ADM,U,7),ECXPRNPI="",ECXATT=$P(ADM,U,8),ECXATNPI="" 62 S ECXDOM=$P(ADM,U,10),ECXATTPC=$P(ADM,U,12),ECXPRVPC=$P(ADM,U,11) 63 ; 64 S ECXPDIV=$$GETDIV^ECXDEPT(ECXFAC) ;Get production division 65 S ECXCBOC=$$CBOC^ECXSCX2(+ECXFAC) ;Get cboc facility 66 ; 67 ;- Get primary care data 68 S X=$$PRIMARY^ECXUTL2(ECXDFN,DATE) 69 S ECPTPR=$P(X,U,2),ECCLASS=$P(X,U,3),ECPTTM=$P(X,U),ECPTNPI=$P(X,U,4) 70 ; 71 ;- Observation patient indicator (YES/NO) 72 S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXSPC) 73 ; 74 ;- Get head and neck cancer indicator 75 S ECXHNCI=$$HNCI^ECXUTL4(ECXDFN) 76 ; 77 ;- Get national patient record flag indicator 78 N ECXNPRFI D NPRF^ECXUTL5 79 ; 80 ;- National response indicator 81 S ECXERI=$$EMGRES^DGUTL(ECXDFN) 82 ; 83 ;- If null encounter number, don't file record 84 S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,DATE,ECXSPC,ECXOBS,ECHEAD,,) 85 D:ECXENC'="" FILE 86 Q 87 ; 88 PAT(ECXDFN) ;get/set patient data 89 ; INPUT - ECXDFN = patient ien (DFN) 90 ; OUTPUT - ECPAT array: 91 ; ECPAT("SSN") 92 ; ECPAT("NAME") 93 ; returns 0 or 1 in ECXERR - 0=successful 94 ; 1=error condition 95 N X,OK 96 ;get data 97 S ECXERR=0 98 K ECXPAT S OK=$$PAT^ECXUTL3(ECXDFN,"","1;2;3;5",.ECPAT) 99 I 'OK S ECXERR=1 100 Q ECXERR 101 ; 102 FILE ;file the n&fs extract record 103 ;node 104 ;facility^dfn^ssn^name^in/out^day^time^treating specialty^ 105 ;ordering provider^ordering provider person class^primary 106 ;care provider^primary person class^primary care team^mpi^dob^sex^ 107 ;race 1^ethnicity^veteran^enrollment status^enrollment location^ 108 ;enrollment category^enrollment priority^eligibility^period of 109 ;service^agent orange status^agent orange location^radiation status 110 ;^environmental contaminants^mst status^head & neck cancer indicator 111 ;pow status^pow location^purple heart indicator^means test^state code 112 ;^county code^zip+4^observation patient indicator^rrtp,prrtp and 113 ;saartp indicator^encounter number^patient division^food production 114 ;division^delivery division^product feeder key^food production 115 ;facility^delivery location type^delivery feeder location^quantity^ 116 ;cboc^status^user enrollee^patient type^cv status eligibility^ 117 ;national patient record flag^emergency response indicator^admission 118 ;date^oef/oif ECXOEF^oef/oif return date ECXOEFDT^ordering provider 119 ;npi ECORNPI^primary care provider npi ECPTNPI 120 ; 121 N DA,DIK,ECODE,ECODE1 122 S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1 123 S ECODE=EC7_U_EC23_U_ECINST_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U 124 ; 125 ;convert specialty to PTF Code 126 ; 127 N ECXDATA 128 S ECXDATA=$$TSDATA^DGACT(42.4,+ECXSPC,.ECXDATA) 129 S ECXSPC=$G(ECXDATA(7)) 130 ; 131 S ECODE=ECODE_ECXDATE_U_ECXTM_U_ECXSPC_U_ECXORDPH_U_ECXORDPC_U 132 S ECODE=ECODE_ECPTPR_U_ECCLASS_U_ECPTTM_U_ECXMPI_U_ECXDOB_U_ECXSEX_U 133 S ECODE=ECODE_ECXRC1_U_ECXETH_U_ECXVET_U_ECXSTAT_U_ECXENRL_U_ECXCAT_U 134 S ECODE=ECODE_ECXPRIOR_U_ECXELIG_U_ECXPOS_U_ECXAST_U_ECXAOL_U_ECXRST 135 S ECODE=ECODE_U_ECXEST_U_ECXMST_U_ECXHNCI_U_ECXPST_U_ECXPLOC_U_ECXPHI 136 S ECODE=ECODE_U_ECXMNS_U_ECXSTATE_U_ECXCNTY_U 137 S ECODE1=ECXZIP_U_ECXOBS_U_ECXDOM_U_ECXENC_U_ECXPDIV_U_ECXFPD_U 138 S ECODE1=ECODE1_ECXFDD_U_ECXKEY_U_ECXFPF_U_ECXDLT_U_ECXDFL_U_ECXQTY_U 139 S ECODE1=ECODE1_ECXCBOC_U_ECXUESTA_U_ECXPTYPE_U_ECXCVE_U_ECXNPRFI_U 140 S ECODE1=ECODE1_ECXERI_U_$S(ECXADMDT:$$ECXDATE^ECXUTL(ECXADMDT,ECXYM),1:"") 141 I ECXLOGIC>2007 S ECODE1=ECODE1_U_ECXOEF_U_ECXOEFDT_U_$G(ECXTFU)_U_ECORNPI_U_ECPTNPI 142 S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1 143 S ECRN=ECRN+1 144 S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA 145 Q 146 ; 147 SETUP ;Set required input for ECXTRAC. 148 S ECHEAD="NUT" 149 D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER) 150 Q 1 ECXNUT ;ALB/JRC Nutrition DSS Extract ; 4/2/2007 2 ;;3.0;DSS EXTRACTS;**92,107**;Dec 22, 1997;Build 9 3 BEG ;entry point from option 4 N EC23,EC7,ECED,ECFILE,ECGRP,ECHEAD,ECINST,ECPACK,ECPIECE,ECRN,ECRTN,ECSD1,ECVER,ECXYM 5 D SETUP I ECFILE="" Q 6 D ^ECXTRAC,^ECXKILL 7 Q 8 ; 9 START ; start package specific extract 10 ;Init variables 11 N ECSD 12 S ECED=ECED+.3,ECSD=ECSD1 13 K ^TMP($J,"FH") 14 ; 15 ;Call n&fs api and store in ^TMP($J,"FH" global 16 D DATA^FHDSSAPI(ECSD,ECED) 17 ; 18 ;Get n&fs records from ^TMP($J,"FH" global and file 19 D GETMEALS^ECXNUT1 20 ; 21 ;kill ^tmp global 22 K ^TMP($J,"FH") 23 ; 24 Q 25 ; 26 GET ;gather extract data 27 ;Init variables 28 N ECXORDPC,ECXSSN,ECXPNM,ECXSEX,ECXDOB,ECXMPI,ECXRC1,ECXETH,ECXVET,ECXENRL,ECXELIG,ECXMST,ECXPST,ECXPLOC,ECXPHI,ECXMNS,ECXSTATE,ECXCNTY,ECXZIP,ECXPOS,ECXAST,ECXAOL,ECXRST,ECXEST,ECXTM,ECXDATE,ECXMN,ECXSPC 29 N ECXADMDT,ECXWRD,ECXFAC,ECXPRV,ECXPRNPI,ECXATT,ECXATNPI,ECXDOM,ECXATTPC,ECXPRVPC,ECXPDIV,ECXCBOC,ECPTPR,ECCLASS,ECPTTM,ECXOBS,ECXHNCI,ECXNPRFI,ECXERI,ECXENC,ECPAT,ECXERR,ADM,W,X,ECXCAT,ECXCVE,ECXPRIOR,ECXPTYPE,ECXSTAT,ECXUESTA,ECXA 30 ; 31 ;- Prefix ordering pro with a 2 and get person class 32 S ECXORDPC=$$PRVCLASS^ECXUTL(+ECXORDPH,DATE) 33 S ECXORDPH=$S(ECXORDPH:2_ECXORDPH,1:"") 34 ; 35 ;set patient file (#2) dfn and get patient demographics 36 S ECXDFN=$P($G(^TMP($J,"FH","ZN",FHDFN)),U,3) 37 S ECXERR=0 D PAT(ECXDFN) 38 Q:ECXERR 39 ;Set demographic variables 40 S ECXSSN=ECPAT("SSN"),ECXPNM=ECPAT("NAME"),ECXSEX=ECPAT("SEX"),ECXDOB=ECPAT("DOB"),ECXMPI=ECPAT("MPI"),ECXRC1=ECPAT("RACE1"),ECXETH=ECPAT("ETHNIC"),ECXVET=ECPAT("VET"),ECXENRL=ECPAT("ENROLL LOC"),ECXELIG=ECPAT("ELIG") 41 S ECXMST=ECPAT("MST STAT"),ECXPST=ECPAT("POW STAT"),ECXPLOC=ECPAT("POW LOC"),ECXPHI=ECPAT("PHI"),ECXMNS=ECPAT("MEANS"),ECXSTATE=ECPAT("STATE"),ECXCNTY=ECPAT("COUNTY"),ECXZIP=ECPAT("ZIP") 42 S ECXPOS=ECPAT("POS"),ECXAST=ECPAT("AO STAT"),ECXAOL=ECPAT("AOL"),ECXRST=ECPAT("IR STAT"),ECXEST=ECPAT("EC STAT") 43 ; 44 ;Get enrollment status 45 I $$ENROLLM^ECXUTL2(ECXDFN) 46 ; 47 S ECXTM=$$ECXTIME^ECXUTL(DATE) 48 S ECXDATE=DATE 49 ; 50 ;- Use movement record date & time 51 S ADM=$$INP^ECXUTL2(ECXDFN,DATE),ECXA=$P(ADM,U) 52 S ECXMN=$P(ADM,U,2),ECXSPC=$P(ADM,U,3),ECXADMDT=$P(ADM,U,4) 53 S W=$P(ADM,U,9),ECXWRD=$P(W,";",1),ECXFAC=$P(W,";",2) 54 S ECXPRV=$P(ADM,U,7),ECXPRNPI="",ECXATT=$P(ADM,U,8),ECXATNPI="" 55 S ECXDOM=$P(ADM,U,10),ECXATTPC=$P(ADM,U,12),ECXPRVPC=$P(ADM,U,11) 56 ; 57 S ECXPDIV=$$GETDIV^ECXDEPT(ECXFAC) ;Get production division 58 S ECXCBOC=$$CBOC^ECXSCX2(+ECXFAC) ;Get cboc facility 59 ; 60 ;- Get primary care data 61 S X=$$PRIMARY^ECXUTL2(ECXDFN,DATE) 62 S ECPTPR=$P(X,U,2),ECCLASS=$P(X,U,3),ECPTTM=$P(X,U) 63 ; 64 ;- Observation patient indicator (YES/NO) 65 S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXSPC) 66 ; 67 ;- Get head and neck cancer indicator 68 S ECXHNCI=$$HNCI^ECXUTL4(ECXDFN) 69 ; 70 ;- Get national patient record flag indicator 71 N ECXNPRFI D NPRF^ECXUTL5 72 ; 73 ;- National response indicator 74 S ECXERI=$$EMGRES^DGUTL(ECXDFN) 75 ; 76 ;- If null encounter number, don't file record 77 S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,DATE,ECXSPC,ECXOBS,ECHEAD,,) 78 D:ECXENC'="" FILE 79 Q 80 ; 81 PAT(ECXDFN) ;get/set patient data 82 ; INPUT - ECXDFN = patient ien (DFN) 83 ; OUTPUT - ECPAT array: 84 ; ECPAT("SSN") 85 ; ECPAT("NAME") 86 ; returns 0 or 1 in ECXERR - 0=successful 87 ; 1=error condition 88 N X,OK 89 ;get data 90 S ECXERR=0 91 K ECXPAT S OK=$$PAT^ECXUTL3(ECXDFN,"","1;2;3;5",.ECPAT) 92 I 'OK S ECXERR=1 93 Q ECXERR 94 ; 95 FILE ;file the n&fs extract record 96 ;node 97 ;facility^dfn^ssn^name^in/out^day^time^treating specialty^ 98 ;ordering provider^ordering provider person class^primary 99 ;care provider^primary person class^primary care team^mpi^dob^sex^ 100 ;race 1^ethnicity^veteran^enrollment status^enrollment location^ 101 ;enrollment category^enrollment priority^eligibility^period of 102 ;service^agent orange status^agent orange location^radiation status 103 ;^environmental contaminants^mst status^head & neck cancer indicator 104 ;pow status^pow location^purple heart indicator^means test^state code 105 ;^county code^zip+4^observation patient indicator^rrtp,prrtp and 106 ;saartp indicator^encounter number^patient division^food production 107 ;division^delivery division^product feeder key^food production 108 ;facility^delivery location type^delivery feeder location^quantity^ 109 ;cboc^status^user enrollee^patient type^cv status eligibility^ 110 ;national^patient record flag^emergency response indicator^admission 111 ;date 112 ; 113 N DA,DIK,ECODE,ECODE1 114 S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1 115 S ECODE=EC7_U_EC23_U_ECINST_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U 116 ; 117 ;convert specialty to PTF Code 118 ; 119 N ECXDATA 120 S ECXDATA=$$TSDATA^DGACT(42.4,+ECXSPC,.ECXDATA) 121 S ECXSPC=$G(ECXDATA(7)) 122 ; 123 S ECODE=ECODE_$$ECXDATE^ECXUTL(DATE,ECXYM)_U_ECXTM_U_ECXSPC_U_ECXORDPH_U_ECXORDPC_U 124 S ECODE=ECODE_ECPTPR_U_ECCLASS_U_ECPTTM_U_ECXMPI_U_ECXDOB_U_ECXSEX_U 125 S ECODE=ECODE_ECXRC1_U_ECXETH_U_ECXVET_U_ECXSTAT_U_ECXENRL_U_ECXCAT_U 126 S ECODE=ECODE_ECXPRIOR_U_ECXELIG_U_ECXPOS_U_ECXAST_U_ECXAOL_U_ECXRST 127 S ECODE=ECODE_U_ECXEST_U_ECXMST_U_ECXHNCI_U_ECXPST_U_ECXPLOC_U_ECXPHI 128 S ECODE=ECODE_U_ECXMNS_U_ECXSTATE_U_ECXCNTY_U 129 S ECODE1=ECXZIP_U_ECXOBS_U_ECXDOM_U_ECXENC_U_ECXPDIV_U_ECXFPD_U 130 S ECODE1=ECODE1_ECXFDD_U_ECXKEY_U_ECXFPF_U_ECXDLT_U_ECXDFL_U_ECXQTY_U 131 S ECODE1=ECODE1_ECXCBOC_U_ECXUESTA_U_ECXPTYPE_U_ECXCVE_U_ECXNPRFI_U 132 S ECODE1=ECODE1_ECXERI_U_$S(ECXADMDT:$$ECXDATE^ECXUTL(ECXADMDT,ECXYM),1:"") 133 S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1 134 S ECRN=ECRN+1 135 S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA 136 Q 137 ; 138 SETUP ;Set required input for ECXTRAC. 139 S ECHEAD="NUT" 140 D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER) 141 Q
Note:
See TracChangeset
for help on using the changeset viewer.