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

ECXSURG.m

Go to the documentation of this file.
  1. ECXSURG ;ALB/JA,BIR/DMA,PTD-Surgery Extract for DSS ;4/5/19 15:40
  1. ;;3.0;DSS EXTRACTS;**1,11,8,13,25,24,33,39,41,42,46,50,71,84,92,99,105,112,128,127,132,144,149,154,161,166,170,174,184**;Dec 22, 1997;Build 124
  1. ;
  1. ; Reference to ^SRF in ICR #103
  1. ;
  1. BEG ;entry point from option
  1. D SETUP I ECFILE="" Q
  1. D ^ECXTRAC,^ECXKILL
  1. Q
  1. ;
  1. START ;
  1. K ^TMP($J,"ECXS"),^TMP($J,"ECXCL")
  1. S QFLG=0,ECED=ECED+.3,ECD=ECSD1
  1. F S ECD=$O(^SRF("AC",ECD)),ECD0=0 Q:('ECD)!(ECD>ECED)!(QFLG) D
  1. .F S ECD0=$O(^SRF("AC",ECD,ECD0)) Q:'ECD0 D
  1. ..I $D(^SRF(ECD0,0)) S EC=^SRF(ECD0,0),ECXDFN=+$P(EC,U),ECXVISIT=$P(EC,U,15) D STUFF Q:QFLG
  1. K ^TMP($J,"ECXS"),^TMP($J,"ECXCL")
  1. Q
  1. ;
  1. STUFF ;gather data
  1. N J,X,Y,PP,DATA1,DATA2,DATAOP,ARR,ERR,SUB,MOD,TIMEDIF ;174 Removed retired variables
  1. N ECPRO,ECXORCT,ECXPTHA,ECXNPRFI,ECXPA,ECXPAPC,ECSRPC,ECATPC,ECSAPC
  1. N ECXCRST,ECXSTCD,ECXCLIN,EC1A,EC2A,ECPQ,ECQA,EC1APC,EC2APC,ECPQPC
  1. N ECQAPC,EC1ANPI,EC2ANPI,ECPQNPI,ECQANPI
  1. N ECXORCET,ECXORCST,ECXTPOOR ;ECX*128
  1. N ECICD10,ECICD101,ECICD102,ECICD103,ECICD104,ECICD105,ECXCONC ;ECX*144 CVW
  1. N ECXCLST,ECXECL,CODE,ECNTIME,ECSTIME,ECATIME,ECXNONMS ;144,154,161,166
  1. N ECXTEMPW,ECXTEMPD,ECXSTANO ;166 Patient Division
  1. N ECXORG1,ECXORG2,ECXORG3,ORG,TYPE,NUM ;166 Organs to be transplanted
  1. N ECXASIH ;170
  1. N ECXNMPI,ECXCERN,ECXSIGI ;184
  1. S (ECXPODX,ECXPODX1,ECXPODX2,ECXPODX3,ECXPODX4,ECXPODX5)="" ;161 Old ICD9 codes, now placeholders and set to null
  1. S ECXDATE=ECD,ECXERR=0,ECXQ="",ECXCONC=""
  1. ;retrieve demographic variables
  1. Q:'$$PATDEM^ECXUTL2(ECXDFN,ECXDATE,"1;2;3;5;")
  1. I ECXADMDT="" S ECXADD=ECXADMDT
  1. I ECXADMDT'="" S ECXADD=$$ECXDATE^ECXUTL(ECXADMDT,ECXYM)
  1. S OK=$$PAT^ECXUTL3(ECXDFN,ECXDATE,"1;5",.ECXPAT)
  1. I 'OK S ECXERR=1 K ECXPAT Q
  1. S ECXNMPI=ECXPAT("MPI") ;184 New MPI
  1. S ECXSIGI=ECXPAT("SIGI") ;184 Self Identified Gender
  1. ;OEF/OIF DATA
  1. S ECXOEF=ECXPAT("ECXOEF")
  1. S ECXOEFDT=ECXPAT("ECXOEFDT")
  1. S ECXVNS=ECXPAT("VIETNAM") ; 144 Vietnam Status
  1. S ECXCLST=ECXPAT("CL STAT") ;144
  1. S ECXSVCI=ECXPAT("COMBSVCI") ;149 COMBAT SVC IND
  1. S ECXSVCL=ECXPAT("COMBSVCL") ;149 COMBAT SVC LOC
  1. S EC0=^SRF(ECD0,0)
  1. S DATA1=$S($D(^SRF(ECD0,.1)):^(.1),1:"")
  1. S DATA2=$S($D(^SRF(ECD0,.2)):^(.2),1:"")
  1. S DATAOP=$S($D(^SRO(136,ECD0,0)):^(0),1:"")
  1. S ECNO=$G(^SRF(ECD0,"NON"))
  1. ; if VISIT data exist get encounter data
  1. ; ECX*112
  1. S ECXVST=$P(^SRF(ECD0,0),U,15) D:ECXVST'=""
  1. . Q:'$D(^AUPNVSIT(ECXVST,800))
  1. . S ECENSC=$P(^AUPNVSIT(ECXVST,800),U,1)
  1. . S ECENSC=$S(ECENSC=0:"N",ECENSC=1:"Y",1:"")
  1. ;get data
  1. S ECSR=$P(DATA1,U,4),(ECATNPI,ECSANPI,ECSRNPI)="",ECAT=$P(DATA1,U,13)
  1. S ECSRNPI=$$NPI^XUSNPI("Individual_ID",ECSR,ECXDATE)
  1. S:+ECSRNPI'>0 ECSRNPI="" S ECSRNPI=$P(ECSRNPI,U)
  1. ;-Time patient in OR room (Nurse Time)
  1. S ECXTM=$$ECXTIME^ECXUTL($P(DATA2,U,10))
  1. S ECXDIV=$S($D(^SRF(ECD0,8)):^(8),1:ECINST)
  1. N ECXPDIV S ECXPDIV=$$RADDIV^ECXDEPT(ECXDIV) ;Production Division
  1. S ECSA=$P($G(^SRF(ECD0,.3)),U,4),ECO=$P(EC0,U,2)
  1. S ECSANPI=$$NPI^XUSNPI("Individual_ID",ECSA,ECXDATE)
  1. S:+ECSANPI'>0 ECSANPI="" S ECSANPI=$P(ECSANPI,U)
  1. ;get principle anesthetist and person class DBIA #103
  1. S ECXPA=$P($G(^SRF(ECD0,.3)),U,1)
  1. S ECPANPI=$$NPI^XUSNPI("Individual_ID",ECXPA,ECXDATE)
  1. S:+ECPANPI'>0 ECPANPI="" S ECPANPI=$P(ECPANPI,U)
  1. S ECXPAPC=$$PRVCLASS^ECXUTL(ECXPA,ECXDATE)
  1. ;get first asst, 2nd asst, perfusionist, and asst perfusionist
  1. S EC1A=$P(DATA1,U,5),EC2A=$P(DATA1,U,6),ECPQ=$P(DATA1,U,19),ECQA=$P(DATA1,U,20)
  1. S EC1ANPI=$$NPI^XUSNPI("Individual_ID",EC1A,ECXDATE)
  1. S:+EC1ANPI'>0 EC1ANPI="" S EC1ANPI=$P(EC1ANPI,U)
  1. S EC2ANPI=$$NPI^XUSNPI("Individual_ID",EC2A,ECXDATE)
  1. S:+EC2ANPI'>0 EC2ANPI="" S EC2ANPI=$P(EC2ANPI,U)
  1. S ECPQNPI=$$NPI^XUSNPI("Individual_ID",ECPQ,ECXDATE)
  1. S:+ECPQNPI'>0 ECPQNPI="" S ECPQNPI=$P(ECPQNPI,U)
  1. S ECQANPI=$$NPI^XUSNPI("Individual_ID",ECQA,ECXDATE)
  1. S:+ECQANPI'>0 ECQANPI="" S ECQANPI=$P(ECQANPI,U)
  1. S ECORTY=$P($G(^SRS(+ECO,2)),U),ECO=$P($G(^SRS(+ECO,0)),U)
  1. S ECSS=$P($G(^SRO(137.45,+$P(EC0,U,4),0)),U,2)
  1. S ECSS=$$RJ^XLFSTR($P($G(^DIC(45.3,+ECSS,0)),U),3,0)
  1. S:ECSS="000" ECSS="999"
  1. ;get classification information
  1. S (ECXAO,ECXHNC,ECXSHAD,ECXSHADI,ECXECL)="" I ECXVISIT'="" D ;144
  1. .D VISIT^ECXSCX1(ECXDFN,ECXVISIT,.ECXVIST,.ECXERR) I ECXERR K ECXERR
  1. .S ECXAO=$G(ECXVIST("AO")),ECXHNC=$G(ECXVIST("HNC"))
  1. .S ECENRI=$G(ECXVIST("IR")),ECENMST=$G(ECXVIST("MST"))
  1. .S ECENEC=$G(ECXVIST("PGE")),ECXSHAD=$G(ECXVIST("SHAD"))
  1. .S ECXECL=$G(ECXVIST("ENCCL")) ;144
  1. ; - Head and Neck Cancer Indicator
  1. S ECXHNCI=$$HNCI^ECXUTL4(ECXDFN)
  1. ; - Shad Encounter Field
  1. S ECXSHADI=$$SHAD^ECXUTL4(ECXDFN)
  1. ;look for non-OR
  1. S (ECNT,ECNL,ECXDSSD,ECXSTCD,ECXCLIN,ECXCRST,ECXNONMS)="" ;174
  1. I $P(ECNO,U)="Y" D
  1. .S ECSR=$P(ECNO,U,6),ECAT=$P(ECNO,U,7)
  1. .S ECSRNPI=$$NPI^XUSNPI("Individual_ID",ECSR,ECXDATE)
  1. .S:+ECSRNPI'>0 ECSRNPI="" S ECSRNPI=$P(ECSRNPI,U)
  1. .S ECATNPI=$$NPI^XUSNPI("Individual_ID",ECAT,ECXDATE)
  1. .S:+ECATNPI'>0 ECATNPI="" S ECATNPI=$P(ECATNPI,U)
  1. .S ECXTM=$$ECXTIME^ECXUTL($P(ECNO,U,4))
  1. .S A1=$P(ECNO,U,5),A2=$P(ECNO,U,4),TIME="##" D:(A1&A2) TIME S ECNT=TIME
  1. .S ECNL=+$P(ECNO,U,2),ECNL=$P($G(^ECX(728.44,ECNL,0)),U,9) ;174
  1. .S:ECNL="" ECNL="UNKNOWN"
  1. .; tjl 166 - Get medical specialty of non-OR provider
  1. .S ECXNONMS=$P(ECNO,U,8)
  1. ;
  1. ;- Get credit stop, stop code and clinic
  1. D SUR^ECXUTL6(.ECXCRST,.ECXSTCD,.ECXCLIN) ;174
  1. ;166 tjl - Set Patient Division based on Movement Number
  1. S ECXSTANO="" I $D(^DGPM(+ECXMN,0)) D
  1. . S ECXTEMPW=$P($G(^DGPM(ECXMN,0)),U,6)
  1. . S ECXTEMPD=$P($G(^DIC(42,+ECXTEMPW,0)),U,11)
  1. . S ECXSTANO=$$GETDIV^ECXDEPT(ECXTEMPD)
  1. ;
  1. ;166 For non-OR cases where Pat Div is empty, get value based on Clinic
  1. I $P(ECNO,U)="Y",ECXSTANO="" S ECXSTANO=$$GETDIV^ECXDEPT($$GET1^DIQ(44,ECXCLIN,3.5,"I"))
  1. ;
  1. ;166 If Patient Division is still empty, set it to the Prod Div Code
  1. I ECXSTANO="" S ECXSTANO=ECXPDIV
  1. ;
  1. ;- If surgery cancelled/aborted quit and go to next record
  1. S ECCAN=$P($G(^SRF(ECD0,30)),U)
  1. I +ECCAN S ECCAN=$$CANC^ECXUTL4(ECNL,$P(DATA2,U,10))
  1. ;on hold for ECXDSSD and ECXDSSP I $P($G(^SRF(ECD0,30)),U) Q
  1. ;get service of attending surgeon
  1. S ECATSV=$P($G(^DIC(49,+$G(^VA(200,+ECAT,5)),730)),U)
  1. ;
  1. ;get surgeon, attending and anesthesia super person classes
  1. ;get 1st asst, 2nd asst, perfusionist, and asst perfusionst person class
  1. S ECSRPC=$$PRVCLASS^ECXUTL(ECSR,ECXDATE)
  1. S ECATPC=$$PRVCLASS^ECXUTL(ECAT,ECXDATE)
  1. S ECSAPC=$$PRVCLASS^ECXUTL(ECSA,ECXDATE)
  1. S EC1APC=$$PRVCLASS^ECXUTL(EC1A,ECXDATE)
  1. S EC2APC=$$PRVCLASS^ECXUTL(EC2A,ECXDATE)
  1. S ECPQPC=$$PRVCLASS^ECXUTL(ECPQ,ECXDATE)
  1. S ECQAPC=$$PRVCLASS^ECXUTL(ECQA,ECXDATE)
  1. ;
  1. ;add leading 2s for pointer to 200
  1. S:ECAT ECAT="2"_ECAT S:ECSR ECSR="2"_ECSR S:ECSA ECSA="2"_ECSA
  1. ;add leading 2 to principle anesthetist IEN
  1. S:ECXPA ECXPA="2"_ECXPA
  1. ;add leading 2s for 1st asst, 2nd asst, perfusionist, asst perfusionist
  1. S:EC1A EC1A="2"_EC1A S:EC2A EC2A="2"_EC2A S:ECPQ ECPQ="2"_ECPQ S:ECQA ECQA="2"_ECQA
  1. ;anesthesia technique
  1. S ECANE="",PP=""
  1. I $D(^SRF(ECD0,6,0)) S ECXJ=0 D
  1. .F S ECXJ=$O(^SRF(ECD0,6,ECXJ)) Q:('ECXJ)!(ECANE]"") D
  1. ..S PP=$P($G(^(ECXJ,0)),U,3) S:PP="Y" ECANE=$P(^(0),U,1)
  1. .I ECANE="" S ECXJ=$O(^SRF(ECD0,6,0)) I ECXJ S ECANE=$P(^SRF(ECD0,6,ECXJ,0),U,1)
  1. ;get primary procedure
  1. ;ecode0=p^cpt code^^patient time^operation time^anesthesia time
  1. S ECPT=+$P(DATAOP,U,2),ECXCMOD=""
  1. K ARR,ERR D FIELD^DID(130,28,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
  1. .K ARR,ERR D FIELD^DID(130,28,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
  1. .Q:$D(ERR("DIERR"))
  1. .S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
  1. .F S MOD=$O(^SRF(ECD0,SUB,MOD)) Q:MOD'>0 D
  1. ..S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
  1. S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
  1. S ECODE0="P"_U_U ;ECPT_U
  1. S (ECNTIME,ECSTIME,ECATIME)="" ;161
  1. F J="10,12","2,3","1,4" D
  1. .S A2=$P(DATA2,U,$P(J,",")),A1=$P(DATA2,U,$P(J,",",2)),TIME="##"
  1. .I (A1&A2)&(+J=10) D TIME S ECNTIME=TIME
  1. .I +J=1 D ANTIME S ECATIME=TIME ;161
  1. .I (A1&A2)&(+J=2) D
  1. ..;
  1. ..;-Operation Time (Surgeon Time)
  1. ..;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
  1. ..S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
  1. ..S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
  1. ..S TIME=$TR($J(TIMEDIF,4,0)," ")
  1. ..S:TIME<0 TIME="###"
  1. ..S:TIME ECSTIME=TIME
  1. .S ECODE0=ECODE0_U_TIME K TIME
  1. ; -Recovery Room Time
  1. S ECRR=""
  1. I $D(^SRF(ECD0,1.1)) D
  1. .S A1=$P(^(1.1),U,8),A2=$P(^(1.1),U,7),TIME="##" D:(A1&A2) TIME
  1. .S ECRR=TIME K TIME
  1. I ECNL]"" S $P(ECODE0,U,5)=ECNT
  1. ;
  1. ; -OR Clean Time in 15 min increments DBIA #103
  1. ;
  1. ; ECX*3.0*128 - Correct the calculation of OR Clean Time.
  1. S ECXORCT=0
  1. ; Set local variables. ECX*128
  1. S ECXTPOOR=$P($G(DATA2),U,12),ECXORCST=$P($G(DATA2),U,13),ECXORCET=$P($G(DATA2),U,14)
  1. I (ECXORCET'=""),(ECXORCST'="") D
  1. .S ECXORCT=($$FMDIFF^XLFDT(ECXORCET,ECXORCST,2)/60)/15
  1. I 'ECXORCT,(ECXORCET'=""),(ECXTPOOR'="") D
  1. .S ECXORCT=($$FMDIFF^XLFDT(ECXORCET,ECXTPOOR,2)/60)/15
  1. ; Make sure the final OR CLEAN TIME is an integer by rounding
  1. ; up for any decimal value ECX*3.0*128
  1. I ECXORCT>0 S ECXORCT=$J(ECXORCT+.4999,0,0)
  1. ; -If no OR clean time recorded set it to 2
  1. I ECXORCT'>0 S ECXORCT=2
  1. ;
  1. ; -PT in hold area time in 15 min increments DBIA #103
  1. I $P($G(DATA2),U,10),$P($G(DATA2),U,15) D
  1. .S ECXPTHA=($$FMDIFF^XLFDT($P($G(DATA2),U,10),$P($G(DATA2),U,15),2)/60)/15
  1. .S CON=$P($G(^SRF(ECD0,"CON")),U)
  1. .I CON S ECXPTHA=ECXPTHA/2,ECXCONC="C" ;144 Concurrent Case
  1. .S ECXPTHA=$TR($J(ECXPTHA,3,0)," ")
  1. ; -If hold time is =<0 set it to ""
  1. S:$G(ECXPTHA)'>0 ECXPTHA=""
  1. ;
  1. ;- get ASA CLASS
  1. S ECASA=$$GET1^DIQ(132.8,$$GET1^DIQ(130,ECD0,1.13,"I"),.01)
  1. ;
  1. ;- Observation Patient Indicator (yes/no)
  1. S ECXOBS=$$OBSPAT^ECXUTL4(ECXA,ECXTS,ECNL)
  1. ;
  1. ; ******* - PATCH 127, ADD PATCAT CODE ********
  1. S ECXPATCAT=$$PATCAT^ECXUTL(ECXDFN)
  1. ;- set national patient record flag if exist
  1. D NPRF^ECXUTL5
  1. ;
  1. ;- If no encounter number don't file record
  1. S ECXENC=$$ENCNUM^ECXUTL4(ECXA,ECXSSN,ECXADMDT,ECXDATE,ECXTS,ECXOBS,ECHEAD,ECXSTCD,ECSS) Q:ECXENC=""
  1. ;
  1. ;- Get postop diagnosis codes
  1. I $$SURPODX^ECXUTL6(.ECICD10,.ECICD101,.ECICD102,.ECICD103,.ECICD104,.ECICD105) ;161
  1. ;166 Get organs transplanted (max 3)
  1. I $D(^SRF(ECD0,63)) S NUM=0 F S NUM=$O(^SRF(ECD0,63,NUM)) Q:'+NUM!($G(ORG)'<3) D
  1. .S TYPE=$P($G(^SRF(ECD0,63,NUM,0)),U)
  1. .I TYPE'="" S ORG=+$G(ORG)+1 S @("ECXORG"_ORG)=$S(TYPE=1:"HART",TYPE=2:"LUNG",TYPE=3:"KDNY",TYPE=4:"LIVR",TYPE=5:"PCRS",TYPE=6:"INTN",TYPE=7:"OTHR",1:"")
  1. .Q
  1. ;
  1. I $G(ECXASIH) S ECXA="A" ;170
  1. D FILE^ECXSURG1
  1. ;get secondary procedures
  1. ;ecode0=s^cpt code
  1. S ECXJ=0
  1. F S ECXJ=$O(^SRO(136,ECD0,3,ECXJ)) Q:'ECXJ I $D(^(ECXJ,0)),$D(^(0)),$P(^(0),"^")]"" D
  1. .;S ECPT=$P(^SRF(ECD0,13,ECXJ,2),U),ECXCMOD=""
  1. .S ECPT=$P(^SRO(136,ECD0,3,ECXJ,0),U),ECXMOD=""
  1. .S ECPT=$P(^(0),"^"),ECXCMOD=""
  1. .K ARR,ERR
  1. .D FIELD^DID(130.16,4,,"LABEL","ARR","ERR") I $D(ARR("LABEL")) D
  1. ..K ARR,ERR
  1. ..D FIELD^DID(130.16,4,,"GLOBAL SUBSCRIPT LOCATION","ARR","ERR")
  1. ..Q:$D(ERR("DIERR"))
  1. ..S SUB=$P(ARR("GLOBAL SUBSCRIPT LOCATION"),";"),MOD=0
  1. ..F S MOD=$O(^SRF(ECD0,13,ECXJ,SUB,MOD)) Q:MOD'>0 S ECXCMOD=ECXCMOD_$P(^(MOD,0),U)_";"
  1. .S ECXCPT=$$CPT^ECXUTL3(ECPT,ECXCMOD)
  1. .S ECODE0="S"_U ;_ECPT
  1. .D FILE^ECXSURG1
  1. ;get prostheses
  1. ;ecode0=i^^^^^^prosthesis^old qty field (null)
  1. S ECXJ=0
  1. F S ECXJ=$O(^SRF(ECD0,1,ECXJ)) Q:'ECXJ I $D(^(ECXJ,0)) D
  1. .S ECXP=+^SRF(ECD0,1,ECXJ,0),ECXQ=$P($G(^(1)),U,2) S:'ECXQ ECXQ=1
  1. .S ECODE0="I"_U_U_U_U_U_U_ECXP_U_U
  1. .D FILE^ECXSURG1
  1. Q
  1. ;
  1. ;
  1. TIME ; given date/time get increment
  1. ;A1=later, A2=earlier, TIME=difference
  1. N CON,TIMEDIF
  1. S CON=$P($G(^SRF(ECD0,"CON")),U)
  1. ;
  1. ;-Get time diff (in secs) & set to .5 if < 7.5 minutes (rounds to 1)
  1. S TIMEDIF=$$FMDIFF^XLFDT(A1,A2,2)/900
  1. S TIMEDIF=$S(TIMEDIF>0&(TIMEDIF<.5):.5,1:TIMEDIF)
  1. I 'CON D
  1. .S TIME=$J($TR($J(TIMEDIF,4,0)," "),2,1)
  1. .S:TIME>"99.0" TIME="99.0"
  1. I CON D
  1. .S TIME=$J(($TR($J(TIMEDIF,4,0)," ")/2),2,1)
  1. .S:TIME>"99.5" TIME="99.5"
  1. S:TIME<0 TIME="###"
  1. Q
  1. ;
  1. ANTIME ;161 Section added to determine anesthesia time
  1. N STDT,ENDT,SUB,NODE,VCODES
  1. S TIME=""
  1. I A1&(A2) D TIME Q ;If anesthesia fields have values, determine time
  1. ;If either anesthesia time field is null, search anes multiple
  1. S (STDT,ENDT)="",SUB=0
  1. F S SUB=$O(^SRF(ECD0,50,SUB)) Q:'+SUB S NODE=$G(^SRF(ECD0,50,SUB,0)) D
  1. .I $P(NODE,U) S STDT=$S(STDT="":$P(NODE,U),$P(NODE,U)<STDT:$P(NODE,U),1:STDT) ;find earliest start date
  1. .I $P(NODE,U,2) S ENDT=$S($P(NODE,U,2)>ENDT:$P(NODE,U,2),1:ENDT) ;find latest end date
  1. I STDT&(ENDT) S A1=ENDT,A2=STDT D TIME Q ;Use anes multiple dates to determine time
  1. S VCODES="^V180200^V180201^V180202^V180203^V180204^V180205^V100500^V110400^V110401^V110402^V110403^" ;VA person class list
  1. I VCODES[("^"_ECSAPC_"^")!(VCODES[("^"_ECXPAPC_"^")) I ECNTIME,ECNTIME'>97.5 S TIME=$J(ECNTIME+2,2,1) ;If principle anesthetist or supervising anesthesiologis has one of the person classes, add two 15 minute segments to the patient's room time
  1. Q ;If no calculations done, time will be returned as null
  1. SETUP ;Set required input for ECXTRAC
  1. S ECHEAD="SUR"
  1. D ECXDEF^ECXUTL2(ECHEAD,.ECPACK,.ECGRP,.ECFILE,.ECRTN,.ECPIECE,.ECVER)
  1. Q
  1. ;