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/ECXSURG.m

    r613 r623  
    1 ECXSURG ;ALB/JA,BIR/DMA,PTD-Surgery Extract for DSS ; 11/20/07 8:13am
    2         ;;3.0;DSS EXTRACTS;**1,11,8,13,25,24,33,39,41,42,46,50,71,84,92,99,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   ;
    9         S QFLG=0,ECED=ECED+.3,ECD=ECSD1
    10         F  S ECD=$O(^SRF("AC",ECD)),ECD0=0 Q:('ECD)!(ECD>ECED)!(QFLG)  D
    11         .F  S ECD0=$O(^SRF("AC",ECD,ECD0)) Q:'ECD0  D
    12         ..I $D(^SRF(ECD0,0)) S EC=^SRF(ECD0,0),ECXDFN=+$P(EC,U),ECXVISIT=$P(EC,U,15) D STUFF Q:QFLG
    13         Q
    14         ;
    15 STUFF   ;gather data
    16         N J,X,Y,PP,DATA1,DATA2,DATAOP,ARR,ERR,SUB,MOD,ECXNONL,ECXSTOP,TIMEDIF
    17         N ECPRO,ECXORCT,ECXPTHA,ECXNPRFI,ECXPA,ECXPAPC,ECSRPC,ECATPC,ECSAPC
    18         N ECXCRST,ECXSTCD,ECXCLIN
    19         S ECXDATE=ECD,ECXERR=0,ECXQ=""
    20         Q:'$$PATDEM^ECXUTL2(ECXDFN,ECXDATE,"1;2;3;5;")
    21         I ECXADMDT="" S ECXADD=ECXADMDT
    22         I ECXADMDT'="" S ECXADD=$$ECXDATE^ECXUTL(ECXADMDT,ECXYM)
    23         S OK=$$PAT^ECXUTL3(ECXDFN,ECXDATE,"1;5",.ECXPAT)
    24         I 'OK S ECXERR=1 K ECXPAT Q
    25         ;OEF/OIF DATA
    26         S ECXOEF=ECXPAT("ECXOEF")
    27         S ECXOEFDT=ECXPAT("ECXOEFDT")
    28         S EC0=^SRF(ECD0,0)
    29         S DATA1=$S($D(^SRF(ECD0,.1)):^(.1),1:"")
    30         S DATA2=$S($D(^SRF(ECD0,.2)):^(.2),1:"")
    31         S DATAOP=$S($D(^SRO(136,ECD0,0)):^(0),1:"")
    32         S ECNO=$G(^SRF(ECD0,"NON"))
    33         ;get data
    34         S ECSR=$P(DATA1,U,4),(ECATNPI,ECSANPI,ECSRNPI)="",ECAT=$P(DATA1,U,13)
    35         S ECSRNPI=$$NPI^XUSNPI("Individual_ID",ECSR,ECXDATE)
    36         S:+ECSRNPI'>0 ECSRNPI="" S ECSRNPI=$P(ECSRNPI,U)
    37         ;-Time patient in OR room (Nurse Time)
    38         S ECXTM=$$ECXTIME^ECXUTL($P(DATA2,U,10))
    39         S ECXDIV=$S($D(^SRF(ECD0,8)):^(8),1:ECINST)
    40         N ECXPDIV S ECXPDIV=$$RADDIV^ECXDEPT(ECXDIV)  ;Production Division
    41         S ECSA=$P($G(^SRF(ECD0,.3)),U,4),ECO=$P(EC0,U,2)
    42         S ECSANPI=$$NPI^XUSNPI("Individual_ID",ECSA,ECXDATE)
    43         S:+ECSANPI'>0 ECSANPI="" S ECSANPI=$P(ECSANPI,U)
    44         ;get principle anesthetist and person class DBIA #103
    45         S ECXPA=$P($G(^SRF(ECD0,.3)),U,1)
    46         S ECPANPI=$$NPI^XUSNPI("Individual_ID",ECXPA,ECXDATE)
    47         S:+ECPANPI'>0 ECPANPI="" S ECPANPI=$P(ECPANPI,U)
    48         S ECXPAPC=$$PRVCLASS^ECXUTL(ECXPA,ECXDATE)
    49         S ECORTY=$P($G(^SRS(+ECO,2)),U),ECO=$P($G(^SRS(+ECO,0)),U)
    50         S ECSS=$P($G(^SRO(137.45,+$P(EC0,U,4),0)),U,2)
    51         S ECSS=$$RJ^XLFSTR($P($G(^DIC(45.3,+ECSS,0)),U),3,0)
    52         S:ECSS="000" ECSS="999"
    53         ;get classification information
    54         S (ECXAO,ECXHNC)="" I ECXVISIT'="" D
    55         .D VISIT^ECXSCX1(ECXDFN,ECXVISIT,.ECXVIST,.ECXERR) I ECXERR K ECXERR
    56         .S ECXAO=$G(ECXVIST("AO")),ECXHNC=$G(ECXVIST("HNC"))
    57         ; - Head and Neck Cancer Indicator
    58         S ECXHNCI=$$HNCI^ECXUTL4(ECXDFN)
    59         ;look for non-OR
    60         S (ECNT,ECNL,ECXDSSD,ECXNONL,ECXSTOP)=""
    61         I $P(ECNO,U)="Y" D
    62         .S ECSR=$P(ECNO,U,6),ECAT=$P(ECNO,U,7)
    63         .S ECSRNPI=$$NPI^XUSNPI("Individual_ID",ECSR,ECXDATE)
    64         .S:+ECSRNPI'>0 ECSRNPI="" S ECSRNPI=$P(ECSRNPI,U)
    65         .S ECATNPI=$$NPI^XUSNPI("Individual_ID",ECAT,ECXDATE)
    66         .S:+ECATNPI'>0 ECATNPI="" S ECATNPI=$P(ECATNPI,U)
    67         .S ECXTM=$$ECXTIME^ECXUTL($P(ECNO,U,4))
    68         .S A1=$P(ECNO,U,5),A2=$P(ECNO,U,4),TIME="##" D:(A1&A2) TIME S ECNT=TIME
    69         .S (ECXNONL,ECNL)=+$P(ECNO,U,2),ECNL=$P($G(^ECX(728.44,ECNL,0)),U,9)
    70         .S:ECNL="" ECNL="UNKNOWN"
    71         .;
    72         .;- Get DSS Stop Code to use in encounter number
    73         .S ECXSTOP=$P($G(^ECX(728.44,ECXNONL,0)),U,4)
    74         ;
    75         ;- Get credit stop, stop code and clinic
    76         I $$SUR^ECXUTL6(.ECXCRST,.ECXSTCD,.ECXCLIN)
    77         ;
    78         ;- If surgery cancelled/aborted quit and go to next record
    79         S ECCAN=$P($G(^SRF(ECD0,30)),U)
    80         I +ECCAN S ECCAN=$$CANC^ECXUTL4(ECNL,$P(DATA2,U,10))
    81         ;on hold for ECXDSSD and ECXDSSP I $P($G(^SRF(ECD0,30)),U) Q
    82         ;get service of attending surgeon
    83         S ECATSV=$P($G(^DIC(49,+$G(^VA(200,+ECAT,5)),730)),U)
    84         ;
    85         ;get surgeon, attending and anesthesia super person classes
    86         S ECSRPC=$$PRVCLASS^ECXUTL(ECSR,ECXDATE)
    87         S ECATPC=$$PRVCLASS^ECXUTL(ECAT,ECXDATE)
    88         S ECSAPC=$$PRVCLASS^ECXUTL(ECSA,ECXDATE)
    89         ;
    90         ;add leading 2s for pointer to 200
    91         S:ECAT ECAT="2"_ECAT S:ECSR ECSR="2"_ECSR S:ECSA ECSA="2"_ECSA
    92         ;add leading 2 to principle anesthetist IEN
    93         S:ECXPA ECXPA="2"_ECXPA
    94         ;anesthesia technique
    95         S ECANE="",PP=""
    96         I $D(^SRF(ECD0,6,0)) S ECXJ=0 D
    97         .F  S ECXJ=$O(^SRF(ECD0,6,ECXJ)) Q:('ECXJ)!(ECANE]"")  D
    98         ..S PP=$P($G(^(ECXJ,0)),U,3) S:PP="Y" ECANE=$P(^(0),U,1)
    99         .I ECANE="" S ECXJ=$O(^SRF(ECD0,6,0)) I ECXJ S ECANE=$P(^SRF(ECD0,6,ECXJ,0),U,1)
    100         ;get primary procedure
    101         ;ecode0=p^cpt code^^patient time^operation time^anesthesia time
    102         S ECPT=+$P(DATAOP,U,2),ECXCMOD=""
    103         K ARR,ERR D FIELD^DID(130,28,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
    104         .K ARR,ERR D FIELD^DID(130,28,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
    105         .Q:$D(ERR("DIERR"))
    106         .S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
    107         .F  S MOD=$O(^SRF(ECD0,SUB,MOD)) Q:MOD'>0  D
    108         ..S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
    109         S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
    110         S ECODE0="P"_U_U  ;ECPT_U
    111         F J="10,12","2,3","1,4" D
    112         .N ECNTIME,ECSTIME,ECATIME
    113         .S A2=$P(DATA2,U,$P(J,",")),A1=$P(DATA2,U,$P(J,",",2)),TIME="##"
    114         .I (A1&A2)&(+J=10) D TIME  S ECNTIME=TIME
    115         .I (A1&A2)&(+J=1) D TIME  S ECATIME=TIME
    116         .I (A1&A2)&(+J=2) D
    117         ..;
    118         ..;-Operation Time (Surgeon Time)
    119         ..;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
    120         ..S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
    121         ..S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
    122         ..S TIME=$TR($J(TIMEDIF,4,0)," ")
    123         ..S:TIME<0 TIME="###"
    124         ..S:TIME ECSTIME=TIME
    125         .S ECODE0=ECODE0_U_TIME K TIME
    126         ; -Recovery Room Time
    127         S ECRR=""
    128         I $D(^SRF(ECD0,1.1)) D
    129         .S A1=$P(^(1.1),U,8),A2=$P(^(1.1),U,7),TIME="##" D:(A1&A2) TIME
    130         .S ECRR=TIME K TIME
    131         I ECNL]"" S $P(ECODE0,U,5)=ECNT
    132         ;
    133         ; -OR Clean Time in 15 min increments DBIA #103
    134         S ECXORCT=($$FMDIFF^XLFDT($P($G(DATA2),U,14),$P($G(DATA2),U,13),2)/60)/15
    135         ; -If no OR clean time recorded set it to 2
    136         I ECXORCT'>0 S ECXORCT=2
    137         ;
    138         ; -PT in hold area time in 15 min increments DBIA #103
    139         I $P($G(DATA2),U,10),$P($G(DATA2),U,15) D
    140         .S ECXPTHA=($$FMDIFF^XLFDT($P($G(DATA2),U,10),$P($G(DATA2),U,15),2)/60)/15
    141         .S CON=$P($G(^SRF(ECD0,"CON")),U)
    142         .I CON S ECXPTHA=ECXPTHA/2
    143         .S ECXPTHA=$TR($J(ECXPTHA,3,0)," ")
    144         ; -If hold time is =<0 set it to ""
    145         S:$G(ECXPTHA)'>0 ECXPTHA=""
    146         ;
    147         ;- Observation Patient Indicator (yes/no)
    148         S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS,ECNL)
    149         ;
    150         ;- set national patient record flag if exist
    151         D NPRF^ECXUTL5
    152         ;
    153         ;- If no encounter number don't file record
    154         S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,ECXDATE,ECXTS,ECXOBS,ECHEAD,ECXSTOP,ECSS) Q:ECXENC=""
    155         ;
    156         ;- Get postop diagnosis codes
    157         I $$SURPODX^ECXUTL6(.ECXPODX,.ECXPODX1,.ECXPODX2,.ECXPODX3,.ECXPODX4,.ECXPODX5)
    158         ;
    159         D FILE^ECXSURG1
    160         ;get secondary procedures
    161         ;ecode0=s^cpt code
    162         S ECXJ=0
    163         F  S ECXJ=$O(^SRO(136,ECD0,3,ECXJ)) Q:'ECXJ  I $D(^(ECXJ,0)),$D(^(0)),$P(^(0),"^")]"" D
    164         .;S ECPT=$P(^SRF(ECD0,13,ECXJ,2),U),ECXCMOD=""
    165         .S ECPT=$P(^SRO(136,ECD0,3,ECXJ,0),U),ECXMOD=""
    166         .S ECPT=$P(^(0),"^"),ECXCMOD=""
    167         .K ARR,ERR
    168         .D FIELD^DID(130.16,4,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
    169         ..K ARR,ERR
    170         ..D FIELD^DID(130.16,4,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
    171         ..Q:$D(ERR("DIERR"))
    172         ..S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
    173         ..F  S MOD=$O(^SRF(ECD0,13,ECXJ,SUB,MOD)) Q:MOD'>0  S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
    174         .S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
    175         .S ECODE0="S"_U   ;_ECPT
    176         .D FILE^ECXSURG1
    177         ;get prostheses
    178         ;ecode0=i^^^^^^prosthesis^old qty field (null)
    179         S ECXJ=0
    180         F  S ECXJ=$O(^SRF(ECD0,1,ECXJ)) Q:'ECXJ  I $D(^(ECXJ,0)) D
    181         .S ECXP=+^SRF(ECD0,1,ECXJ,0),ECXQ=$P($G(^(1)),U,2) S:'ECXQ ECXQ=1
    182         .S ECODE0="I"_U_U_U_U_U_U_ECXP_U_U
    183         .D FILE^ECXSURG1
    184         Q
    185         ;
    186         ;
    187 TIME    ; given date/time get increment
    188         ;A1=later, A2=earlier, TIME=difference
    189         N CON,TIMEDIF
    190         S CON=$P($G(^SRF(ECD0,"CON")),U)
    191         ;
    192         ;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
    193         S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
    194         S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
    195         I 'CON D
    196         .S TIME=$J($TR($J(TIMEDIF,4,0)," "),2,1)
    197         .S:TIME>"99.0" TIME="99.0"
    198         I CON D
    199         .S TIME=$J(($TR($J(TIMEDIF,4,0)," ")/2),2,1)
    200         .S:TIME>"99.5" TIME="99.5"
    201         S:TIME<0 TIME="###"
    202         Q
    203         ;
    204 SETUP   ;Set required input for ECXTRAC
    205         S ECHEAD="SUR"
    206         D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
    207         Q
    208         ;
    209 QUE     ; entry point for the background requeuing handled by ECXTAUTO
    210         D SETUP,QUE^ECXTAUTO,^ECXKILL Q
     1ECXSURG ;ALB/JA,BIR/DMA,PTD-Surgery Extract for DSS ; 11/2/06 9:00am
     2 ;;3.0;DSS EXTRACTS;**1,11,8,13,25,24,33,39,41,42,46,50,71,84,92,99**;Dec 22, 1997;Build 2
     3BEG ;entry point from option
     4 D SETUP I ECFILE="" Q
     5 D ^ECXTRAC,^ECXKILL
     6 Q
     7 ;
     8START ;
     9 S QFLG=0,ECED=ECED+.3,ECD=ECSD1
     10 F  S ECD=$O(^SRF("AC",ECD)),ECD0=0 Q:('ECD)!(ECD>ECED)!(QFLG)  D
     11 .F  S ECD0=$O(^SRF("AC",ECD,ECD0)) Q:'ECD0  D
     12 ..I $D(^SRF(ECD0,0)) S EC=^SRF(ECD0,0),ECXDFN=+$P(EC,U),ECXVISIT=$P(EC,U,15) D STUFF Q:QFLG
     13 Q
     14 ;
     15STUFF ;gather data
     16 N J,X,Y,PP,DATA1,DATA2,DATAOP,ARR,ERR,SUB,MOD,ECXNONL,ECXSTOP,TIMEDIF
     17 N ECPRO,ECXORCT,ECXPTHA,ECXNPRFI,ECXPA,ECXPAPC,ECSRPC,ECATPC,ECSAPC
     18 S ECXDATE=ECD,ECXERR=0,ECXQ=""
     19 Q:'$$PATDEM^ECXUTL2(ECXDFN,ECXDATE,"1;2;3;5;")
     20 I ECXADMDT="" S ECXADD=ECXADMDT
     21 I ECXADMDT'="" S ECXADD=$$ECXDATE^ECXUTL(ECXADMDT,ECXYM)
     22 S EC0=^SRF(ECD0,0)
     23 S DATA1=$S($D(^SRF(ECD0,.1)):^(.1),1:"")
     24 S DATA2=$S($D(^SRF(ECD0,.2)):^(.2),1:"")
     25 ;S DATAOP=$S($D(^SRF(ECD0,"OP")):^("OP"),1:"")
     26 S DATAOP=$S($D(^SRO(136,ECD0,0)):^(0),1:"")
     27 S ECNO=$G(^SRF(ECD0,"NON"))
     28 ;get data
     29 S ECSR=$P(DATA1,U,4),(ECATNPI,ECSANPI,ECSRNPI)="",ECAT=$P(DATA1,U,13)
     30 ;-Time patient in OR room (Nurse Time)
     31 S ECXTM=$$ECXTIME^ECXUTL($P(DATA2,U,10))
     32 S ECXDIV=$S($D(^SRF(ECD0,8)):^(8),1:ECINST)
     33 N ECXPDIV S ECXPDIV=$$RADDIV^ECXDEPT(ECXDIV)  ;Production Division
     34 S ECSA=$P($G(^SRF(ECD0,.3)),U,4),ECO=$P(EC0,U,2)
     35 ;get principle anesthetist and person class DBIA #103
     36 S ECXPA=$P($G(^SRF(ECD0,.3)),U,1)
     37 S ECXPAPC=$$PRVCLASS^ECXUTL(ECXPA,ECXDATE)
     38 S ECORTY=$P($G(^SRS(+ECO,2)),U),ECO=$P($G(^SRS(+ECO,0)),U)
     39 S ECSS=$P($G(^SRO(137.45,+$P(EC0,U,4),0)),U,2)
     40 S ECSS=$$RJ^XLFSTR($P($G(^DIC(45.3,+ECSS,0)),U),3,0)
     41 S:ECSS="000" ECSS="999"
     42 ;get classification information
     43 S (ECXAO,ECXHNC)="" I ECXVISIT'="" D
     44 .D VISIT^ECXSCX1(ECXDFN,ECXVISIT,.ECXVIST,.ECXERR) I ECXERR K ECXERR
     45 .S ECXAO=$G(ECXVIST("AO")),ECXHNC=$G(ECXVIST("HNC"))
     46 ; - Head and Neck Cancer Indicator
     47 S ECXHNCI=$$HNCI^ECXUTL4(ECXDFN)
     48 ;look for non-OR
     49 S (ECNT,ECNL,ECXDSSD,ECXNONL,ECXSTOP)=""
     50 I $P(ECNO,U)="Y" D
     51 .S ECSR=$P(ECNO,U,6),ECAT=$P(ECNO,U,7)
     52 .S ECXTM=$$ECXTIME^ECXUTL($P(ECNO,U,4))
     53 .S A1=$P(ECNO,U,5),A2=$P(ECNO,U,4),TIME="##" D:(A1&A2) TIME S ECNT=TIME
     54 .S (ECXNONL,ECNL)=+$P(ECNO,U,2),ECNL=$P($G(^ECX(728.44,ECNL,0)),U,9)
     55 .S:ECNL="" ECNL="UNKNOWN"
     56 .;
     57 .;- Get DSS Stop Code to use in encounter number
     58 .S ECXSTOP=$P($G(^ECX(728.44,ECXNONL,0)),U,4)
     59 ;
     60 ;- If surgery cancelled/aborted quit and go to next record
     61 S ECCAN=$P($G(^SRF(ECD0,30)),U)
     62 I +ECCAN S ECCAN=$$CANC^ECXUTL4(ECNL,$P(DATA2,U,10))
     63 ;on hold for ECXDSSD and ECXDSSP I $P($G(^SRF(ECD0,30)),U) Q
     64 ;get service of attending surgeon
     65 S ECATSV=$P($G(^DIC(49,+$G(^VA(200,+ECAT,5)),730)),U)
     66 ;
     67 ;get surgeon, attending and anesthesia super person classes
     68 S ECSRPC=$$PRVCLASS^ECXUTL(ECSR,ECXDATE)
     69 S ECATPC=$$PRVCLASS^ECXUTL(ECAT,ECXDATE)
     70 S ECSAPC=$$PRVCLASS^ECXUTL(ECSA,ECXDATE)
     71 ;
     72 ;add leading 2s for pointer to 200
     73 S:ECAT ECAT="2"_ECAT S:ECSR ECSR="2"_ECSR S:ECSA ECSA="2"_ECSA
     74 ;add leading 2 to principle anesthetist IEN
     75 S:ECXPA ECXPA="2"_ECXPA
     76 ;anesthesia technique
     77 S ECANE="",PP=""
     78 I $D(^SRF(ECD0,6,0)) S ECXJ=0 D
     79 .F  S ECXJ=$O(^SRF(ECD0,6,ECXJ)) Q:('ECXJ)!(ECANE]"")  D
     80 ..S PP=$P($G(^(ECXJ,0)),U,3) S:PP="Y" ECANE=$P(^(0),U,1)
     81 .I ECANE="" S ECXJ=$O(^SRF(ECD0,6,0)) I ECXJ S ECANE=$P(^SRF(ECD0,6,ECXJ,0),U,1)
     82 ;get primary procedure
     83 ;ecode0=p^cpt code^^patient time^operation time^anesthesia time
     84 S ECPT=+$P(DATAOP,U,2),ECXCMOD=""
     85 K ARR,ERR D FIELD^DID(130,28,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
     86 .K ARR,ERR D FIELD^DID(130,28,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
     87 .Q:$D(ERR("DIERR"))
     88 .S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
     89 .F  S MOD=$O(^SRF(ECD0,SUB,MOD)) Q:MOD'>0  D
     90 ..S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
     91 S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
     92 S ECODE0="P"_U_U  ;ECPT_U
     93 F J="10,12","2,3","1,4" D
     94 .N ECNTIME,ECSTIME,ECATIME
     95 .S A2=$P(DATA2,U,$P(J,",")),A1=$P(DATA2,U,$P(J,",",2)),TIME="##"
     96 .I (A1&A2)&(+J=10) D TIME  S ECNTIME=TIME
     97 .I (A1&A2)&(+J=1) D TIME  S ECATIME=TIME
     98 .I (A1&A2)&(+J=2) D
     99 ..;
     100 ..;-Operation Time (Surgeon Time)
     101 ..;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
     102 ..S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
     103 ..S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
     104 ..S TIME=$TR($J(TIMEDIF,4,0)," ")
     105 ..S:TIME<0 TIME="###"
     106 ..S:TIME ECSTIME=TIME
     107 .S ECODE0=ECODE0_U_TIME K TIME
     108 ; -Recovery Room Time
     109 S ECRR=""
     110 I $D(^SRF(ECD0,1.1)) D
     111 .S A1=$P(^(1.1),U,8),A2=$P(^(1.1),U,7),TIME="##" D:(A1&A2) TIME
     112 .S ECRR=TIME K TIME
     113 I ECNL]"" S $P(ECODE0,U,5)=ECNT
     114 ;
     115 ; -OR Clean Time in 15 min increments DBIA #103
     116 S ECXORCT=($$FMDIFF^XLFDT($P($G(DATA2),U,14),$P($G(DATA2),U,13),2)/60)/15
     117 ; -If no OR clean time recorded set it to 2
     118 I ECXORCT'>0 S ECXORCT=2
     119 ;
     120 ; -PT in hold area time in 15 min increments DBIA #103
     121 I $P($G(DATA2),U,10),$P($G(DATA2),U,15) D
     122 .S ECXPTHA=($$FMDIFF^XLFDT($P($G(DATA2),U,10),$P($G(DATA2),U,15),2)/60)/15
     123 .S CON=$P($G(^SRF(ECD0,"CON")),U)
     124 .I CON S ECXPTHA=ECXPTHA/2
     125 .S ECXPTHA=$TR($J(ECXPTHA,3,0)," ")
     126 ; -If hold time is =<0 set it to ""
     127 S:$G(ECXPTHA)'>0 ECXPTHA=""
     128 ;
     129 ;- Observation Patient Indicator (yes/no)
     130 S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS,ECNL)
     131 ;
     132 ;- set national patient record flag if exist
     133 D NPRF^ECXUTL5
     134 ;
     135 ;- If no encounter number don't file record
     136 S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,ECXDATE,ECXTS,ECXOBS,ECHEAD,ECXSTOP,ECSS) Q:ECXENC=""
     137 ;
     138 D FILE
     139 ;get secondary procedures
     140 ;ecode0=s^cpt code
     141 S ECXJ=0
     142 ;F  S ECXJ=$O(^SRF(ECD0,13,ECXJ)) Q:'ECXJ  I $D(^(ECXJ,0)),$D(^(2)),$P(^(2),U)]"" D
     143 F  S ECXJ=$O(^SRO(136,ECD0,3,ECXJ)) Q:'ECXJ  I $D(^(ECXJ,0)),$D(^(0)),$P(^(0),"^")]"" D
     144 .;S ECPT=$P(^SRF(ECD0,13,ECXJ,2),U),ECXCMOD=""
     145 . S ECPT=$P(^SRO(136,ECD0,3,ECXJ,0),"^"),ECXCMOD=""
     146 .K ARR,ERR
     147 .D FIELD^DID(130.16,4,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
     148 ..K ARR,ERR
     149 ..D FIELD^DID(130.16,4,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
     150 ..Q:$D(ERR("DIERR"))
     151 ..S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
     152 ..F  S MOD=$O(^SRF(ECD0,13,ECXJ,SUB,MOD)) Q:MOD'>0  S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
     153 .S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
     154 .S ECODE0="S"_U   ;_ECPT
     155 .D FILE
     156 ;get prostheses
     157 ;ecode0=i^^^^^^prosthesis^old qty field (null)
     158 S ECXJ=0
     159 F  S ECXJ=$O(^SRF(ECD0,1,ECXJ)) Q:'ECXJ  I $D(^(ECXJ,0)) D
     160 .S ECXP=+^SRF(ECD0,1,ECXJ,0),ECXQ=$P($G(^(1)),U,2) S:'ECXQ ECXQ=1
     161 .S ECODE0="I"_U_U_U_U_U_U_ECXP_U_U
     162 .D FILE
     163 Q
     164 ;
     165FILE ;file record
     166 ;node0
     167 ;division^dfn^ssn^name^in/out (ECXA)^day^case #^
     168 ;surg specialty^or room #^
     169 ;surgeon^attending^anesthesia supervisor^anesthesia technique^
     170 ;primary/secondary/prostheses^cpt^^pt time^op time^anes time^
     171 ;prostheses^qty^^
     172 ;movement number^treating specialty^cancel/abort (ECCAN)^time^or type^
     173 ;attending's service^non-or dss id^recovery room time^^
     174 ;primary care team^primary care provider^admission date
     175 ;node1
     176 ;mpi^dss dept ECXDSSD^surgeon npi^attending npi^anes supervisor npi^
     177 ;pc provider npi^pc prov person class^
     178 ;assoc pc provider^assoc pc prov person class^assoc pc prov npi^
     179 ;cpt&modifiers ECXCPT^dom ECXDOM^enrollment category ECXCAT^
     180 ;enrollment status ECXSTAT^enrollment priority ECXPRIOR^
     181 ;period of service ECXPOS^purple heart indicator ECXPHI^
     182 ;observ pat ind ECXOBS^encounter num ECXENC^ao loc ECXAOL^
     183 ;production division ECXPDIV^head & neck canc ind ECXHNCI^
     184 ;ethnicity ECXETH^race1 ECXRC1^new quantity ECXQ^
     185 ;^user enrollee ECXUESTA^patient type ECXPTYPE^combat vet elig
     186 ;ECXCVE^combat vet elig end date ECXCVEDT^enc cv eligible ECXCVENC
     187 ;or clean time ECXORCT^time pt in hold area ECXPTHA^national patient
     188 ;record flag ECXNPRFI^princ anesthetist ECXPA^surgeon per class ECSRPC
     189 ;node2
     190 ;atten surgeon per class ECATPC^anesthesia super person class ECSAPC^
     191 ;princ anesthetist PC ECXPAPC^emergency response indicator(FEMA) ECXERI^
     192 ;agent orange indic ECXAO^head/neck cancer ECXHNC
     193 ;
     194 N DA,DIK,STR
     195 S EC7=$O(^ECX(ECFILE,999999999),-1),EC7=EC7+1
     196 S ECODE=EC7_U_EC23_U_ECXDIV_U_ECXDFN_U_ECXSSN_U_ECXPNM_U_ECXA_U
     197 S ECODE=ECODE_$$ECXDATE^ECXUTL(ECXDATE,ECXYM)_U_ECD0_U_ECSS_U_ECO_U
     198 S ECODE=ECODE_ECSR_U_ECAT_U_ECSA_U_ECANE_U_ECODE0_U
     199 S STR=ECXMN_U_ECXTS_U_$S(ECCAN'="":ECCAN,1:"")_U_ECXTM_U_ECORTY_U
     200 S STR=STR_ECATSV_U_ECNL_U_ECRR_U_U_ECPTTM_U_ECPTPR_U_ECXADD_U
     201 S $P(ECODE,U,26,38)=STR
     202 S ECODE1=ECXMPI_U_ECXDSSD_U_ECSRNPI_U_ECATNPI_U_ECSANPI_U_ECPTNPI_U
     203 S ECODE1=ECODE1_ECCLAS_U_ECASPR_U_ECCLAS2_U_ECASNPI_U_ECXCPT_U_ECXDOM_U
     204 S ECODE1=ECODE1_ECXCAT_U_ECXSTAT_U_$S(ECXLOGIC<2005:ECXPRIOR,1:"")_U_ECXPOS_U_ECXPHI_U
     205 S ECODE1=ECODE1_ECXOBS_U_ECXENC_U_ECXAOL_U_ECXPDIV_U_ECXHNCI_U
     206 S ECODE1=ECODE1_ECXETH_U_ECXRC1_U_ECXQ_U
     207 I ECXLOGIC>2004 S ECODE1=ECODE1_U_ECXPRIOR_ECXSBGRP_U_ECXUESTA_U_ECXPTYPE_U_ECXCVE_U_ECXCVEDT_U_ECXCVENC_U_ECXORCT_U_ECXPTHA_U_ECXNPRFI
     208 I ECXLOGIC>2005 S ECODE1=ECODE1_U_ECXPA_U_ECSRPC_U,ECODE2=ECATPC_U_ECSAPC_U_ECXPAPC
     209 I ECXLOGIC>2006 S ECODE2=ECODE2_U_ECXERI_U_ECXAO_U_ECXHNC
     210 S ^ECX(ECFILE,EC7,0)=ECODE,^ECX(ECFILE,EC7,1)=ECODE1,^ECX(ECFILE,EC7,2)=ECODE2,ECRN=ECRN+1
     211 S DA=EC7,DIK="^ECX("_ECFILE_"," D IX1^DIK K DIK,DA
     212 I $D(ZTQUEUED),$$S^%ZTLOAD S QFLG=1
     213 ;
     214TIME ; given date/time get increment
     215 ;A1=later, A2=earlier, TIME=difference
     216 N CON,TIMEDIF
     217 S CON=$P($G(^SRF(ECD0,"CON")),U)
     218 ;
     219 ;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
     220 S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
     221 S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
     222 I 'CON D
     223 .S TIME=$J($TR($J(TIMEDIF,4,0)," "),2,1)
     224 .S:TIME>"99.0" TIME="99.0"
     225 I CON D
     226 .S TIME=$J(($TR($J(TIMEDIF,4,0)," ")/2),2,1)
     227 .S:TIME>"99.5" TIME="99.5"
     228 S:TIME<0 TIME="###"
     229 Q
     230 ;
     231SETUP ;Set required input for ECXTRAC
     232 S ECHEAD="SUR"
     233 D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
     234 Q
     235 ;
     236QUE ; entry point for the background requeuing handled by ECXTAUTO
     237 D SETUP,QUE^ECXTAUTO,^ECXKILL Q
Note: See TracChangeset for help on using the changeset viewer.