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/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
     1DGRUGA08 ;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 ;
     6EN(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.