Changeset 623 for WorldVistAEHR/trunk/r/REGISTRATION-DGQE-DG-DPT-GRPX-VAD-VAF-VAS-VAT-VAU--VA-VIC--DGBT--DGJ--DGYA--VALM/DGRUGA01.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/DGRUGA01.m
r613 r623 1 DGRUGA01 ;ALB/GRR - HL7 ADT A01 MESSAGE BUILDER ; 11/27/07 1:43pm 2 ;;5.3;Registration;**190,303,762**;Aug 13, 1993;Build 3 3 ; 4 ;This routine will build a ADT A01 (Admit) HL7 message for an inpatient. 5 ; 6 EN(DFN,DGMIEN,DGARRAY) ;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 ; 11 ;The HL7 variables must be initialized before calling this routine! 12 ;HL("FS"),HL("ECH"),HLFS,HLECH, and HLQ are used by segment builders called by this routine 13 ; 14 N DGPV1,DGHOLD,DGCNT,DGMDT,DGCDT,DGOADT,DGZEL,DGICD,DGICDCNT,DGIN,DGIN1,DGRB,DGW,DGINCNT S DGCNT=0 15 Q:DGARRAY="" ;Required output variable name was not passed 16 K @DGARRAY ;Kill output array to insure erroneous data does not exist 17 Q:DGMIEN="" 18 S DGMDT=$$GET1^DIQ(405,DGMIEN,".01","I") 19 D NOW^%DTC S DGCDT=$$HLDATE^HLFNC(%) ;Get current date/time and convert to HL7 format 20 S DGCNT=DGCNT+1 ;Increment node counter by one for first segment 21 S @DGARRAY@(DGCNT)=$$EVN^VAFHLEVN("A01","05",DGMDT) ;Create Event segment and store in output array 22 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 23 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 24 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 25 I DGHOLD]"" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGHOLD 26 S DGCNT=DGCNT+1 ;Increment node counter by one to store next segment 27 S DGPV1=$$IN^VAFHLPV1(DFN,DGMDT,",2,3,6,7,10,17,44,",$G(DGMIEN),"","") ;Create the PV1 segment based on sequence numbers passed, and store in output array 28 S DGOADT=$$CKADMIT^DGRUUTL1(DFN) ;Check if integrated site and get original admit date 29 ;Check if doing data seed of RAI/MDS machine 30 I $G(DGSEED)=1 D 31 .N VAIP,DGPCPNM,DGPCPPTR,DGWPTR,DGRBPTR,DGWTRAN,DGRBTRAN 32 .D IN5^VADPT 33 .;Put current Primary Care Physician into PV1 segment 34 .S DGPCPPTR=+$G(VAIP(7)) 35 .S DGPCPNM=$$HLNAME^HLFNC($P($G(VAIP(7)),"^",2)) 36 .S:DGPCPNM="" DGPCPNM=HL("Q") 37 .S $P(DGPV1,HL("FS"),8)=DGPCPPTR_$E(HL("ECH"))_DGPCPNM 38 .K ATTDOC S ATTDOC=$$ATTDOC^DGRUUTL(.ATTDOC) S $P(DGPV1,HL("FS"),18)=ATTDOC K ATTDOC ; P-762 39 .;Get current ward & room/bed 40 .S DGW=$$GET1^DIQ(2,DFN,.1,"I") 41 .S DGRB=$$GET1^DIQ(2,DFN,.101,"I") 42 .;Convert ward & room/bed to pointers 43 .S DGWPTR=$$FIND1^DIC(42,,"XQ",DGW) 44 .S DGRBPTR=$$FIND1^DIC(405.4,,"XQ",DGRB) 45 .;Translate ward & room/bed 46 .S DGWTRAN=$$WARDTRAN^DGRUUTL1(DGWPTR,DGW) 47 .S DGRBTRAN=$$RBTRAN^DGRUUTL1(DGRBPTR,DGRB) 48 .;Put translated ward & room/bed into PV1 segment 49 .S $P(DGPV1,HL("FS"),4)=DGWTRAN_$E(HL("ECH"))_$P(DGRBTRAN,"-")_$E(HL("ECH"))_$P(DGRBTRAN,"-",2) 50 I DGOADT]"" S $P(DGPV1,HL("FS"),45)=$$HLDATE^HLFNC(DGOADT) S $P(@DGARRAY@(1),HL("FS"),7)=$$HLDATE^HLFNC(DGOADT) 51 S DGPV1=$$DOCID^DGRUUTL(DGPV1) 52 K ATTDOC S ATTDOC=$$ATTDOC^DGRUUTL(.ATTDOC) S $P(DGPV1,HL("FS"),18)=ATTDOC K ATTDOC ; P-762 53 ;TRANSLATE WARD AND ROOM-BED NAMES IF NEEDED (ALREADY DONE IF SEEDING) 54 S:'$G(DGSEED) DGPV1=$$LOCTRAN^DGRUUTL1(DGPV1) 55 S @DGARRAY@(DGCNT)=DGPV1 56 S DGCNT=DGCNT+1 ;Increment node counter to store next segment 57 S @DGARRAY@(DGCNT)=$$EN^VAFHLPV2(DFN,DGMIEN,",3,") ;Create PV2 segment 58 D IN^VAFHLDG1(DFN,DGMIEN,",2,3,5,","DGICD",DGMDT) ;Create the DG1 segment(s) and store in a temporary array 59 I $O(DGICD(0))>0 D ;DG1 segment were built 60 .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 61 S DGIN1=$$IN1^DGRUUTL1(DFN) 62 S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGIN1 63 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 64 S @DGARRAY@(DGCNT)=$$EN^VAFHLIN2(DFN,DGMIEN,",2,3,6,8,") ;Create and store IN2 segment in output array 65 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 66 S DGZEL=$$EN^VAFHLZEL(DFN,",1,8,",1) ;Create ZEL segment (only primary eligibility - param 3 = 1) 67 I $P(DGZEL,HL("FS"),9)'=0&($P(DGZEL,HL("FS"),9)'=1) S $P(DGZEL,HL("FS"),9)=1 ;stuff patient as veteran 68 S @DGARRAY@(DGCNT)=DGZEL 69 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 70 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEM(DFN,",1,5,",1,1) ;Create ZEM segment for Patient (param 3 = 1) 71 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 72 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEN(DFN,",1,9,",1,"",HL("FS")) ;Create ZEN segment and add to message array 73 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 74 S @DGARRAY@(DGCNT)=$$EN^VAFHLZMH(DFN,DGMIEN,",4,") ;Create the ZMH segment and store in the output array 75 Q 1 DGRUGA01 ;ALB/GRR - HL7 ADT A01 MESSAGE BUILDER ;06/08/99 2 ;;5.3;Registration;**190,303**;Aug 13, 1993 3 ; 4 ;This routine will build a ADT A01 (Admit) HL7 message for an inpatient. 5 ; 6 EN(DFN,DGMIEN,DGARRAY) ;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 ; 11 ;The HL7 variables must be initialized before calling this routine! 12 ;HL("FS"),HL("ECH"),HLFS,HLECH, and HLQ are used by segment builders called by this routine 13 ; 14 N DGPV1,DGHOLD,DGCNT,DGMDT,DGCDT,DGOADT,DGZEL,DGICD,DGICDCNT,DGIN,DGIN1,DGRB,DGW,DGINCNT S DGCNT=0 15 Q:DGARRAY="" ;Required output variable name was not passed 16 K @DGARRAY ;Kill output array to insure erroneous data does not exist 17 Q:DGMIEN="" 18 S DGMDT=$$GET1^DIQ(405,DGMIEN,".01","I") 19 D NOW^%DTC S DGCDT=$$HLDATE^HLFNC(%) ;Get current date/time and convert to HL7 format 20 S DGCNT=DGCNT+1 ;Increment node counter by one for first segment 21 S @DGARRAY@(DGCNT)=$$EVN^VAFHLEVN("A01","05",DGMDT) ;Create Event segment and store in output array 22 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 23 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 24 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 25 I DGHOLD]"" S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGHOLD 26 S DGCNT=DGCNT+1 ;Increment node counter by one to store next segment 27 S DGPV1=$$IN^VAFHLPV1(DFN,DGMDT,",2,3,6,7,10,17,44,",$G(DGMIEN),"","") ;Create the PV1 segment based on sequence numbers passed, and store in output array 28 S DGOADT=$$CKADMIT^DGRUUTL1(DFN) ;Check if integrated site and get original admit date 29 ;Check if doing data seed of RAI/MDS machine 30 I $G(DGSEED)=1 D 31 .N VAIP,DGPCPNM,DGPCPPTR,DGWPTR,DGRBPTR,DGWTRAN,DGRBTRAN 32 .D IN5^VADPT 33 .;Put current Primary Care Physician into PV1 segment 34 .S DGPCPPTR=+$G(VAIP(7)) 35 .S DGPCPNM=$$HLNAME^HLFNC($P($G(VAIP(7)),"^",2)) 36 .S:DGPCPNM="" DGPCPNM=HL("Q") 37 .S $P(DGPV1,HL("FS"),8)=DGPCPPTR_$E(HL("ECH"))_DGPCPNM 38 .;Get current ward & room/bed 39 .S DGW=$$GET1^DIQ(2,DFN,.1,"I") 40 .S DGRB=$$GET1^DIQ(2,DFN,.101,"I") 41 .;Convert ward & room/bed to pointers 42 .S DGWPTR=$$FIND1^DIC(42,,"XQ",DGW) 43 .S DGRBPTR=$$FIND1^DIC(405.4,,"XQ",DGRB) 44 .;Translate ward & room/bed 45 .S DGWTRAN=$$WARDTRAN^DGRUUTL1(DGWPTR,DGW) 46 .S DGRBTRAN=$$RBTRAN^DGRUUTL1(DGRBPTR,DGRB) 47 .;Put translated ward & room/bed into PV1 segment 48 .S $P(DGPV1,HL("FS"),4)=DGWTRAN_$E(HL("ECH"))_$P(DGRBTRAN,"-")_$E(HL("ECH"))_$P(DGRBTRAN,"-",2) 49 I DGOADT]"" S $P(DGPV1,HL("FS"),45)=$$HLDATE^HLFNC(DGOADT) S $P(@DGARRAY@(1),HL("FS"),7)=$$HLDATE^HLFNC(DGOADT) 50 S DGPV1=$$DOCID^DGRUUTL(DGPV1) 51 ;TRANSLATE WARD AND ROOM-BED NAMES IF NEEDED (ALREADY DONE IF SEEDING) 52 S:'$G(DGSEED) DGPV1=$$LOCTRAN^DGRUUTL1(DGPV1) 53 S @DGARRAY@(DGCNT)=DGPV1 54 S DGCNT=DGCNT+1 ;Increment node counter to store next segment 55 S @DGARRAY@(DGCNT)=$$EN^VAFHLPV2(DFN,DGMIEN,",3,") ;Create PV2 segment 56 D IN^VAFHLDG1(DFN,DGMIEN,",2,3,5,","DGICD",DGMDT) ;Create the DG1 segment(s) and store in a temporary array 57 I $O(DGICD(0))>0 D ;DG1 segment were built 58 .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 59 S DGIN1=$$IN1^DGRUUTL1(DFN) 60 S DGCNT=DGCNT+1,@DGARRAY@(DGCNT)=DGIN1 61 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 62 S @DGARRAY@(DGCNT)=$$EN^VAFHLIN2(DFN,DGMIEN,",2,3,6,8,") ;Create and store IN2 segment in output array 63 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 64 S DGZEL=$$EN^VAFHLZEL(DFN,",1,8,",1) ;Create ZEL segment (only primary eligibility - param 3 = 1) 65 I $P(DGZEL,HL("FS"),9)'=0&($P(DGZEL,HL("FS"),9)'=1) S $P(DGZEL,HL("FS"),9)=1 ;stuff patient as veteran 66 S @DGARRAY@(DGCNT)=DGZEL 67 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 68 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEM(DFN,",1,5,",1,1) ;Create ZEM segment for Patient (param 3 = 1) 69 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 70 S @DGARRAY@(DGCNT)=$$EN^VAFHLZEN(DFN,",1,9,",1,"",HL("FS")) ;Create ZEN segment and add to message array 71 S DGCNT=DGCNT+1 ;Increment node counter by one for next segment 72 S @DGARRAY@(DGCNT)=$$EN^VAFHLZMH(DFN,DGMIEN,",4,") ;Create the ZMH segment and store in the output array 73 Q
Note:
See TracChangeset
for help on using the changeset viewer.