Changeset 623 for WorldVistAEHR/trunk/r/REGISTRATION-DGQE-DG-DPT-GRPX-VAD-VAF-VAS-VAT-VAU--VA-VIC--DGBT--DGJ--DGYA--VALM/DGRUGA08.m
- Timestamp:
- Dec 4, 2009, 12:11:15 AM (14 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
WorldVistAEHR/trunk/r/REGISTRATION-DGQE-DG-DPT-GRPX-VAD-VAF-VAS-VAT-VAU--VA-VIC--DGBT--DGJ--DGYA--VALM/DGRUGA08.m
r613 r623 1 DGRUGA08 ;ALB/GRR - HL7 ADT A08 MESSAGE BUILDER ; 10/11/07 9:24am 2 ;;5.3;Registration;**190,312,328,721,762**;Aug 13, 1993;Build 3 3 ; 4 ;This routine will build a ADT A08 (Patient Update) HL7 message for an inpatient. 5 ; 6 EN(DFN,DGMIEN,DGARRAY,DGDC,DGSSNC) ;Entry point of routine 7 ;DFN - Patient Internal Entry Number 8 ;DGMIEN - Patient Movement Internal Entry Number 9 ;DGARRAY - Name of output array by reference where built message will be contained. 10 ;DGDC - date type~prior date (date type is A, T, or D) (Required for date change only) [Optional] 11 ;DGSSNC - Prior SSN (Required for SSN Change only) [Optional] 12 ; 13 ;The HL7 variables must be initialized before calling this routine! 14 ;HL("FS"),HL("ECH"),HLFS,HLECH, and HLQ are used by segment builders called by this routine 15 ; 16 N DGPV1,DGHOLD,DGCNT,DGMDT,DGCDT,DGOADT,DGIN1,DGLMT,DGZEL,DGICD,DGICDCNT,DGIN,DGINCNT S DGCNT=0 17 Q:DGARRAY="" ;Required output variable name was not passed 18 K @DGARRAY ;Kill output array to insure erroneous data does not exist 19 I DGMIEN="" N VAIP D NOW^%DTC S VAIP("D")=% D IN5^VADPT S DGMIEN=$G(VAIP(1)) K VAIP Q:DGMIEN="" ;changed p-328 20 D NOW^%DTC S DGCDT=$$HLDATE^HLFNC(%) ;Get current date/time and convert to HL7 format 21 S DGMDT=$$GET1^DIQ(405,DGMIEN,".01","I") 22 S DGCNT=DGCNT+1 ;Increment node counter by one for first segment 23 S @DGARRAY@(DGCNT)=$$EVN^VAFHLEVN("A08","05",DGMDT) ;Create Event segment and store in output array 24 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 25 S @DGARRAY@(DGCNT)=$$EN^VAFCPID(DFN,",2,5,7,8,10,11,13,16,17,19,23,29",1) ;Create PID segment using segment sequence numbers passed and store in output array 26 S DGHOLD=$$EN^VAFHLNK1(DFN,DGMIEN,",2,3,4,5,") ;Create the NK1 segment using the segment sequence numbers passed, and store in output array 27 I DGHOLD]"" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGHOLD 28 S DGCNT=DGCNT+1 ;Increment node counter by one to store next segment 29 S DGPV1=$$IN^VAFHLPV1(DFN,DGMDT,",2,3,6,7,10,17,44,45,",DGMIEN,"","") ;Create the PV1 segment based on sequence numbers passed 30 S DGOADT=$$CKADMIT^DGRUUTL1(DFN) ;check if integrated site get original admit date/time 31 I DGOADT]"" S $P(DGPV1,HL("FS"),45)=$$HLDATE^HLFNC(DGOADT) 32 S DGPV1=$$DOCID^DGRUUTL(DGPV1) 33 I $G(DGLMT)=1,$E($G(DGDC))="D" S $P(DGPV1,HL("FS"),4)=$P(DGPV1,HL("FS"),7) ;This is a change to a prior HL7, move prior location to current 34 N VAIP D IN5^VADPT S $P(DGPV1,HL("FS"),11)=$$GET1^DIQ(45.7,+VAIP(8),1,"I") K VAIP ; p-721 35 K ATTDOC S ATTDOC=$$ATTDOC^DGRUUTL(.ATTDOC) S $P(DGPV1,HL("FS"),18)=ATTDOC K ATTDOC ; P-762 36 S @DGARRAY@(DGCNT)=$$LOCTRAN^DGRUUTL1(DGPV1) 37 S DGCNT=DGCNT+1 ;Increment node counter to store next segment 38 S @DGARRAY@(DGCNT)=$$EN^VAFHLPV2(DFN,DGMIEN,",3,") ;Create PV2 segment 39 D IN^VAFHLDG1(DFN,DGMIEN,",2,3,5,","DGICD") ;Create the DG1 segment(s) and store in a temporary array 40 I $O(DGICD(0))>0 D ;DG1 segment were built 41 .S DGICDCNT=0 F S DGICDCNT=$O(DGICD(DGICDCNT)) Q:DGICDCNT="" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGICD(DGICDCNT,0) ;Loop through temporary array and store DG1 segment(s) in output array 42 S DGIN1=$$IN1^DGRUUTL1(DFN) 43 S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGIN1 44 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 45 S @DGARRAY@(DGCNT)=$$EN^VAFHLIN2(DFN,DGMIEN,",2,3,6,8,") ;Create and store IN2 segment in output array 46 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 47 S DGZEL=$$EN^VAFHLZEL(DFN,",1,8,",1) ;Create ZEL segment (only primary eligibility - param 3 = 1) 48 I $P(DGZEL,HL("FS"),9)'=0&($P(DGZEL,HL("FS"),9)'=1) S $P(DGZEL,HL("FS"),9)=1 ;stuff patient as veteran 49 S @DGARRAY@(DGCNT)=DGZEL 50 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 51 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEM(DFN,",1,5,",1,1) ;Create ZEM segment for Patient (param 3 = 1) 52 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 53 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEN(DFN,",1,9,",1,"",HL("FS")) ;Create ZEN segment and add to message array 54 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 55 S @DGARRAY@(DGCNT)=$$EN^VAFHLZMH(DFN,DGMIEN,",4,") ;Create the ZMH segment and store in the output array 56 S DGDC=$G(DGDC),DGSSNC=$G(DGSSNC) 57 I DGDC]""!(DGSSNC]"") D ;date or ssn change 58 .I DGDC]""&'("ADT"[$E(DGDC)) Q 59 .S DGCNT=DGCNT+1 60 .S @DGARRAY@(DGCNT)=$$EN^DGRUGZDC(DFN,DGDC,DGSSNC,DGMDT) 61 Q 1 DGRUGA08 ;ALB/GRR - HL7 ADT A08 MESSAGE BUILDER ; 21 Sep 2006 8:24 AM 2 ;;5.3;Registration;**190,312,328,721**;Aug 13, 1993;Build 3 3 ; 4 ;This routine will build a ADT A08 (Patient Update) HL7 message for an inpatient. 5 ; 6 EN(DFN,DGMIEN,DGARRAY,DGDC,DGSSNC) ;Entry point of routine 7 ;DFN - Patient Internal Entry Number 8 ;DGMIEN - Patient Movement Internal Entry Number 9 ;DGARRAY - Name of output array by reference where built message will be contained. 10 ;DGDC - date type~prior date (date type is A, T, or D) (Required for date change only) [Optional] 11 ;DGSSNC - Prior SSN (Required for SSN Change only) [Optional] 12 ; 13 ;The HL7 variables must be initialized before calling this routine! 14 ;HL("FS"),HL("ECH"),HLFS,HLECH, and HLQ are used by segment builders called by this routine 15 ; 16 N DGPV1,DGHOLD,DGCNT,DGMDT,DGCDT,DGOADT,DGIN1,DGLMT,DGZEL,DGICD,DGICDCNT,DGIN,DGINCNT S DGCNT=0 17 Q:DGARRAY="" ;Required output variable name was not passed 18 K @DGARRAY ;Kill output array to insure erronuous data does not exist 19 I DGMIEN="" N VAIP D NOW^%DTC S VAIP("D")=% D IN5^VADPT S DGMIEN=$G(VAIP(1)) K VAIP Q:DGMIEN="" ;changed p-328 20 D NOW^%DTC S DGCDT=$$HLDATE^HLFNC(%) ;Get current date/time and convert to HL7 format 21 S DGMDT=$$GET1^DIQ(405,DGMIEN,".01","I") 22 S DGCNT=DGCNT+1 ;Increment node counter by one for first segment 23 S @DGARRAY@(DGCNT)=$$EVN^VAFHLEVN("A08","05",DGMDT) ;Create Event segment and store in output array 24 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 25 S @DGARRAY@(DGCNT)=$$EN^VAFCPID(DFN,",2,5,7,8,10,11,13,16,17,19,23,29",1) ;Create PID segment using segment sequence numbers passed and store in output array 26 S DGHOLD=$$EN^VAFHLNK1(DFN,DGMIEN,",2,3,4,5,") ;Create the NK1 segment using the segment sequence numbers passed, and store in output array 27 I DGHOLD]"" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGHOLD 28 S DGCNT=DGCNT+1 ;Increment node counter by one to store next segment 29 S DGPV1=$$IN^VAFHLPV1(DFN,DGMDT,",2,3,6,7,10,17,44,45,",DGMIEN,"","") ;Create the PV1 segment based on sequence numbers passed 30 S DGOADT=$$CKADMIT^DGRUUTL1(DFN) ;check if integrated site get original admit date/time 31 I DGOADT]"" S $P(DGPV1,HL("FS"),45)=$$HLDATE^HLFNC(DGOADT) 32 S DGPV1=$$DOCID^DGRUUTL(DGPV1) 33 I $G(DGLMT)=1,$E($G(DGDC))="D" S $P(DGPV1,HL("FS"),4)=$P(DGPV1,HL("FS"),7) ;This is a change to a prior HL7, move prior location to current 34 N VAIP D IN5^VADPT S $P(DGPV1,HL("FS"),11)=$$GET1^DIQ(45.7,+VAIP(8),1,"I") K VAIP ; p-721 35 S @DGARRAY@(DGCNT)=$$LOCTRAN^DGRUUTL1(DGPV1) 36 S DGCNT=DGCNT+1 ;Increment node counter to store next segment 37 S @DGARRAY@(DGCNT)=$$EN^VAFHLPV2(DFN,DGMIEN,",3,") ;Create PV2 segment 38 D IN^VAFHLDG1(DFN,DGMIEN,",2,3,5,","DGICD") ;Create the DG1 segment(s) and store in a temporary array 39 I $O(DGICD(0))>0 D ;DG1 segment were built 40 .S DGICDCNT=0 F S DGICDCNT=$O(DGICD(DGICDCNT)) Q:DGICDCNT="" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGICD(DGICDCNT,0) ;Loop through temporary array and store DG1 segment(s) in output array 41 S DGIN1=$$IN1^DGRUUTL1(DFN) 42 S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGIN1 43 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 44 S @DGARRAY@(DGCNT)=$$EN^VAFHLIN2(DFN,DGMIEN,",2,3,6,8,") ;Create and store IN2 segment in output array 45 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 46 S DGZEL=$$EN^VAFHLZEL(DFN,",1,8,",1) ;Create ZEL segment (only primary eligibility - param 3 = 1) 47 I $P(DGZEL,HL("FS"),9)'=0&($P(DGZEL,HL("FS"),9)'=1) S $P(DGZEL,HL("FS"),9)=1 ;stuff patient as veteran 48 S @DGARRAY@(DGCNT)=DGZEL 49 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 50 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEM(DFN,",1,5,",1,1) ;Create ZEM segment for Patient (param 3 = 1) 51 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 52 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEN(DFN,",1,9,",1,"",HL("FS")) ;Create ZEN segment and add to message array 53 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 54 S @DGARRAY@(DGCNT)=$$EN^VAFHLZMH(DFN,DGMIEN,",4,") ;Create the ZMH segment and store in the output array 55 S DGDC=$G(DGDC),DGSSNC=$G(DGSSNC) 56 I DGDC]""!(DGSSNC]"") D ;date or ssn change 57 .I DGDC]""&'("ADT"[$E(DGDC)) Q 58 .S DGCNT=DGCNT+1 59 .S @DGARRAY@(DGCNT)=$$EN^DGRUGZDC(DFN,DGDC,DGSSNC,DGMDT) 60 Q
Note:
See TracChangeset
for help on using the changeset viewer.