| 1 | ECXMOV ;ALB/JAP,BIR/DMA,PTD-Transfer and Discharge Extract ; 8/19/05 9:13am
|
---|
| 2 | ;;3.0;DSS EXTRACTS;**8,24,33,39,41,42,46,65,84**;Dec 22, 1997
|
---|
| 3 | BEG ;entry point from option
|
---|
| 4 | D SETUP I ECFILE="" Q
|
---|
| 5 | D ^ECXTRAC,^ECXKILL
|
---|
| 6 | Q
|
---|
| 7 | ;
|
---|
| 8 | START ; start package specific extract
|
---|
| 9 | N ECXDSC,W,WTO,X1,X2,X,ECXDPRPC,ECXDAPPC
|
---|
| 10 | K ECXDD D FIELD^DID(405,.19,,"SPECIFIER","ECXDD")
|
---|
| 11 | S ECPRO=$E(+$P(ECXDD("SPECIFIER"),"P",2)) K ECXDD
|
---|
| 12 | S ECED=ECED+.3,QFLG=0
|
---|
| 13 | F ECM=2,3 S ECARG="ATT"_ECM,ECD=ECSD1 D Q:QFLG
|
---|
| 14 | .F S ECD=$O(^DGPM(ECARG,ECD)),ECDA=0 Q:('ECD)!(ECD>ECED) D Q:QFLG
|
---|
| 15 | ..F S ECDA=$O(^DGPM(ECARG,ECD,ECDA)) Q:'ECDA D Q:QFLG
|
---|
| 16 | ...Q:'$D(^DGPM(ECDA,0)) S EC=^(0)
|
---|
| 17 | ...S ECXDFN=+$P(EC,U,3),ECMT=$P(EC,U,18),ECXDATE=ECD
|
---|
| 18 | ...K ECXPAT S OK=$$PAT^ECXUTL3(ECXDFN,$P(ECXDATE,"."),"1;",.ECXPAT)
|
---|
| 19 | ...I 'OK K ECXPAT Q
|
---|
| 20 | ...S ECXPNM=ECXPAT("NAME"),ECXSSN=ECXPAT("SSN"),ECXMPI=ECXPAT("MPI")
|
---|
| 21 | ...S ECTM=$$ECXTIME^ECXUTL(ECD)
|
---|
| 22 | ...S WTO=$P(EC,U,6),ECXWTO=$P($G(^DIC(42,+WTO,44)),U)
|
---|
| 23 | ...;
|
---|
| 24 | ...;reset EC to admission movement
|
---|
| 25 | ...S ECCA=$P(EC,U,14),EC=^DGPM(ECCA,0),ECA=$P(EC,U)
|
---|
| 26 | ...;
|
---|
| 27 | ...;if date of previous xfer movement is greater than admit date,
|
---|
| 28 | ...;then reset EC to that previous xfer movement
|
---|
| 29 | ...S ECDL=9999999.9999999-ECD,ECDL=+$O(^DGPM("ATID2",ECXDFN,ECDL))
|
---|
| 30 | ...S ECDAL=+$O(^DGPM("ATID2",ECXDFN,ECDL,0))
|
---|
| 31 | ...I $D(^DGPM(ECDAL,0)),$P(^(0),U)>$P(EC,U) S EC=^(0)
|
---|
| 32 | ...;
|
---|
| 33 | ...I ECM=2 D
|
---|
| 34 | ....;if transact=Transfer,ECD (time)=ASIH (7chars) and >0,set ECXDATE
|
---|
| 35 | ....;to Admit DT/time before calling funct to get in/out stat & TS
|
---|
| 36 | ....I $L($P(ECD,".",2))=7,+$E($P(ECD,".",2),7)>0 S ECXDATE=ECA
|
---|
| 37 | ....S W=$P(EC,U,6)
|
---|
| 38 | ...;
|
---|
| 39 | ...I ECM=3 D
|
---|
| 40 | ....;subtract 1 second from dischg DT so IN5^VADPT call (in ECXUTL2
|
---|
| 41 | ....;API) will pick up discharge movmement record
|
---|
| 42 | ....S ECXDATE=$$FMADD^XLFDT(ECXDATE,,,,-1)
|
---|
| 43 | ....;set losing ward to ward at discharge
|
---|
| 44 | ....N WARD S WARD=$$GET1^DIQ(405,ECDA,200)
|
---|
| 45 | ....I WARD'="" S W=+$O(^DIC(42,"B",WARD,0))
|
---|
| 46 | ...;
|
---|
| 47 | ...;-Gets inpat/outpat status, DOM, Treating Spec (TS)
|
---|
| 48 | ...S X=$$INP^ECXUTL2(ECXDFN,ECXDATE),ECXA=$P(X,U),ECXDOM=$P(X,U,10),ECXTS=$P(X,U,3)
|
---|
| 49 | ...;
|
---|
| 50 | ...S (ECXWRD,ECXFAC,ECXDSSD)=""
|
---|
| 51 | ...I W'="" D
|
---|
| 52 | ....S ECXWRD=$P($G(^DIC(42,W,44)),U),ECXFAC=$P($G(^DIC(42,W,0)),U,11)
|
---|
| 53 | ....S ECXDSSD=$P($G(^ECX(727.4,W,0)),U,2)
|
---|
| 54 | ...S ECDI=$S(ECM=2:"",1:$$ECXDATE^ECXUTL(ECD,ECXYM))
|
---|
| 55 | ...S X1=ECD,X2=$P(EC,U) D ^%DTC S ECXLOS=X
|
---|
| 56 | ...;
|
---|
| 57 | ...;- Get discharge PC Team, Primary and Assoc Primary Provider
|
---|
| 58 | ...S (ECXDPCT,ECXDPR,ECXDAPR,ECXDPRPC,ECXDAPPC)=""
|
---|
| 59 | ...I ECM=3 D
|
---|
| 60 | ....S ECXDSC=$$PRIMARY^ECXUTL2(ECXDFN,ECD)
|
---|
| 61 | ....S ECXDPCT=$P(ECXDSC,U),ECXDPR=$P(ECXDSC,U,2),ECXDAPR=$P(ECXDSC,U,5),ECXDPRPC=$P(ECXDSC,U,3),ECXDAPPC=$P(ECXDSC,U,6)
|
---|
| 62 | ...;
|
---|
| 63 | ...;Get production division ;p-46
|
---|
| 64 | ...N ECXPDIV S ECXPDIV=$$GETDIV^ECXDEPT(ECXFAC) ;p-46
|
---|
| 65 | ...;- Observation patient indicator (YES/NO)
|
---|
| 66 | ...S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS)
|
---|
| 67 | ...;
|
---|
| 68 | ...;- If no encounter number, don't file record
|
---|
| 69 | ...S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECA,,ECXTS,ECXOBS,ECHEAD,,)
|
---|
| 70 | ...D:ECXENC'="" FILE
|
---|
| 71 | Q
|
---|
| 72 | ;
|
---|
| 73 | FILE ;file the extract record
|
---|
| 74 | ;node0
|
---|
| 75 | ;fac ECXFAC^dfn ECXDFN^ssn ECXSSN^name ECXPNM^in/out ECXA^
|
---|
| 76 | ;day (ECD)^^adm date (ECA)^disc date ECDI^mov # ECDA^
|
---|
| 77 | ;type ECM^losing ward ECXWARD^treat spec ^los ECXLOS^^
|
---|
| 78 | ;movement type ECMT^mov time ECTM^gaining ward ECXWTO^
|
---|
| 79 | ;adm time (ECA)^^^
|
---|
| 80 | ;node1
|
---|
| 81 | ;mpi ECXMPI^dss dept ECXDSSD^dom ECXDOM^observ pat ind ECXOBS^
|
---|
| 82 | ;encounter num ECXENC^disch prim prov ECXDPR^disch PC team ECXDPCT^
|
---|
| 83 | ;disch assoc prim prov ECXDAPR^production division ECXPDIV
|
---|
| 84 | ;^disch prov person class ECXDPRPC^disch assoc prov pe-
|
---|
| 85 | ;rson person class
|
---|
| 86 | N DA,DIK
|
---|
| 87 | S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1
|
---|
| 88 | S ECODE=EC7_U_EC23_U_ECXFAC_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U
|
---|
| 89 | S ECODE=ECODE_$$ECXDATE^ECXUTL(ECD,ECXYM)_U_U
|
---|
| 90 | S ECODE=ECODE_$$ECXDATE^ECXUTL(ECA,ECXYM)_U_ECDI_U_ECDA_U_ECM_U_ECXWRD_U
|
---|
| 91 | S ECODE=ECODE_U_ECXLOS_U_U_ECMT_U_ECTM_U_ECXWTO_U
|
---|
| 92 | S ECODE=ECODE_$$ECXTIME^ECXUTL(ECA)_U_U_U
|
---|
| 93 | S ECODE1=ECXMPI_U_ECXDSSD_U_ECXDOM_U_ECXOBS_U_ECXENC_U_ECXDPR_U
|
---|
| 94 | S ECODE1=ECODE1_ECXDPCT_U_ECXDAPR_U_ECXPDIV ;p-46 added ECXPDIV
|
---|
| 95 | I ECXLOGIC>2005 S ECODE1=ECODE1_U_ECXDPRPC_U_ECXDAPPC
|
---|
| 96 | S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1,ECRN=ECRN+1
|
---|
| 97 | S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA
|
---|
| 98 | I $D(ZTQUEUED),$$S^%ZTLOAD S QFLG=1
|
---|
| 99 | Q
|
---|
| 100 | ;
|
---|
| 101 | SETUP ;Set required input for ECXTRAC
|
---|
| 102 | S ECHEAD="MOV"
|
---|
| 103 | D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
|
---|
| 104 | Q
|
---|
| 105 | ;
|
---|
| 106 | QUE ; entry point for the background requeuing handled by ECXTAUTO
|
---|
| 107 | D SETUP,QUE^ECXTAUTO,^ECXKILL Q
|
---|