Ignore:
Timestamp:
Dec 4, 2009, 12:11:15 AM (14 years ago)
Author:
George Lilly
Message:

revised back to 6/30/08 version

File:
1 edited

Legend:

Unmodified
Added
Removed
  • WorldVistAEHR/trunk/r/DSS_EXTRACTS-ECX/ECXMOV.m

    r613 r623  
    1 ECXMOV  ;ALB/JAP,BIR/DMA,PTD-Transfer and Discharge Extract ; 6/6/07 6:46am
    2         ;;3.0;DSS EXTRACTS;**8,24,33,39,41,42,46,65,84,107,105**;Dec 22, 1997;Build 70
    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         ....S ECDAPRNP=$P(ECXDSC,U,7),ECDPRNPI=$P(ECXDSC,U,4)
    63         ...;
    64         ...;Get production division ;p-46
    65         ...N ECXPDIV S ECXPDIV=$$GETDIV^ECXDEPT(ECXFAC) ;p-46
    66         ...;- Observation patient indicator (YES/NO)
    67         ...S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS)
    68         ...;
    69         ...;- If no encounter number, don't file record
    70         ...S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECA,,ECXTS,ECXOBS,ECHEAD,,)
    71         ...D:ECXENC'="" FILE
    72         Q
    73         ;
    74 FILE    ;file the extract record
    75         ;node0
    76         ;fac ECXFAC^dfn ECXDFN^ssn ECXSSN^name ECXPNM^in/out ECXA^
    77         ;day (ECD)^^adm date (ECA)^disc date ECDI^mov # ECDA^
    78         ;type ECM^losing ward ECXWARD^treat spec ^los ECXLOS^^
    79         ;movement type ECMT^mov time ECTM^gaining ward ECXWTO^
    80         ;adm time (ECA)^^^
    81         ;node1
    82         ;mpi ECXMPI^dss dept ECXDSSD^dom ECXDOM^observ pat ind ECXOBS^
    83         ;encounter num ECXENC^disch prim prov ECXDPR^disch PC team ECXDPCT^
    84         ;disch assoc prim prov ECXDAPR^production division ECXPDIV
    85         ;^disch prov person class ECXDPRPC^disch assoc prov pe-
    86         ;rson person class^disch assoc pc prov npi ECDAPRNP^discharge pc provider npi ECDPRNPI
    87         N DA,DIK
    88         S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1
    89         S ECODE=EC7_U_EC23_U_ECXFAC_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U
    90         S ECODE=ECODE_$$ECXDATE^ECXUTL(ECD,ECXYM)_U_U
    91         S ECODE=ECODE_$$ECXDATE^ECXUTL(ECA,ECXYM)_U_ECDI_U_ECDA_U_ECM_U_ECXWRD_U
    92         S ECODE=ECODE_U_ECXLOS_U_U_ECMT_U_ECTM_U_ECXWTO_U
    93         S ECODE=ECODE_$$ECXTIME^ECXUTL(ECA)_U_U_U
    94         S ECODE1=ECXMPI_U_ECXDSSD_U_ECXDOM_U_ECXOBS_U_ECXENC_U_ECXDPR_U
    95         S ECODE1=ECODE1_ECXDPCT_U_ECXDAPR_U_ECXPDIV ;p-46 added ECXPDIV
    96         I ECXLOGIC>2005 S ECODE1=ECODE1_U_ECXDPRPC_U_ECXDAPPC
    97         I ECXLOGIC>2007 S ECODE1=ECODE1_U_$G(ECDAPRNP)_U_$G(ECDPRNPI)
    98         S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1,ECRN=ECRN+1
    99         S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA
    100         I $D(ZTQUEUED),$$S^%ZTLOAD S QFLG=1
    101         Q
    102         ;
    103 SETUP   ;Set required input for ECXTRAC
    104         S ECHEAD="MOV"
    105         D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
    106         Q
    107         ;
    108 QUE     ; entry point for the background requeuing handled by ECXTAUTO
    109         D SETUP,QUE^ECXTAUTO,^ECXKILL Q
     1ECXMOV ;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
     3BEG ;entry point from option
     4 D SETUP I ECFILE="" Q
     5 D ^ECXTRAC,^ECXKILL
     6 Q
     7 ;
     8START ; 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 ;
     73FILE ;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 ;
     101SETUP ;Set required input for ECXTRAC
     102 S ECHEAD="MOV"
     103 D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
     104 Q
     105 ;
     106QUE ; entry point for the background requeuing handled by ECXTAUTO
     107 D SETUP,QUE^ECXTAUTO,^ECXKILL Q
Note: See TracChangeset for help on using the changeset viewer.