DGENUPL7 ;ISA/KWP,CKN,TMK,TDM,LBD,HM,KUM - PROCESS INCOMING (Z11 EVENT TYPE) HL7 MESSAGES ;9/12/20 5:48pm
;;5.3;REGISTRATION;**232,367,397,417,379,431,513,628,673,653,742,688,797,871,972,952,977,993,1014,1027,1045,1082,1090,1111**;Aug 13,1993;Build 18
;Per VHA Directive 2004-038, this routine should not be modified.
;
;Phase II split from DGENUPL
Z11(MSGIEN,MSGID,CURLINE,DFN,ERRCOUNT) ;
;Description: This is used to process a single ORU~Z11 or ORF~Z11 msg.
;Input:
; MSGIEN - the internal entry number of the HL7 message in the
; HL7 MESSAGE TEXT file (772)
; MSGID -message control id of HL7 msg in the MSH segment
; CURLINE - the subscript of the MSH segment of the current message (pass by reference)
; DFN - identifies the patient, is the ien of a record in the PATIENT file.
; ERRCOUNT - is a count of the number of messages in the batch that can not be processed (pass by reference)
;
;Output:
; CURLINE - upon leaving the procedure this parameter should be set to the end of the current message. (pass by reference)
; ERRCOUNT - set to count of messages that were not processed due to errors encountered (pass by reference)
;
N DGELG,DGENR,DGPAT,DGCDIS,DGOEIF,ERROR,ERRMSG,MSGS,DGELGSUB,DGENUPLD,DGCON,DGNMSE,DGCCPG,DGSUB,DGFDA,DGERR,DGIENS
N DGNEWVAL,DIV,SUB,OLDELG,OLDPAT,OLDDCDIS,OLDEIF,DGSEC,OLDSEC,DGNTR,DGMST,DGPHINC,DGHBP,DGOTH,DGSUB,DGCOVF,DGESCO,DGCOV
N DGELCV,DGOAPP,DGZHF
;
;some process is killing these HL7 variables, so need to protect them
S SUB=HLFS
S DIV=HLECH
N HLDA,HLDAN,HLDAP,HLDT,HLDT1,HLECH,HLFS,HLNDAP,HLNDAP0,HLPID,HLQ,HLVER,HLERR,HLMTN,HLSDT
S HLFS=SUB
S HLECH=DIV
S HLQ=""""""
K DIV,SUB
;DG*5.3*1090 - Kill ^TMP global Combat Vet Elig End Date Source
K ^TMP("DGCVE",$J,"COMBAT VET ELIG END DATE SOURCE",DFN)
;
;drops out of block on error
D
.;DG*5.3*1082 - Add ZHF Parsing to load DGZHF array
.Q:'$$PARSE^DGENUPL1(MSGIEN,MSGID,.CURLINE,.ERRCOUNT,.DGPAT,.DGELG,.DGENR,.DGCDIS,.DGOEIF,.DGSEC,.DGNTR,.DGMST,.DGNMSE,.DGHBP,.DGOTH,.DGZHF)
.; DG*5.3*1014 - Capture Z11 eligibilities
.M DGELCV=DGELG
.D GETLOCKS^DGENUPL5(DFN)
.;
.;Used by cross-references to determine if an upload is in progress.
.S DGENUPLD="ENROLLMENT/ELIGIBILITY UPLOAD IN PROGRESS"
.;
.;Update the PATIENT, ELIGIBILITY, CATASTROPHIC DISABILITY objects in memory
.Q:'$$UOBJECTS^DGENUPL4(DFN,.DGPAT,.DGELG,.DGCDIS,.DGOEIF,MSGID,.ERRCOUNT,.MSGS,.OLDPAT,.OLDELG,.OLDCDIS,.OLDEIF)
.;DG*5.3*1014 - Delete Vista secondary eligibilities from DGELG array
.S DGSUB=0 F S DGSUB=$O(DGELG("ELIG","CODE",DGSUB)) Q:'DGSUB D
..I '$D(DGELCV("ELIG","CODE",DGSUB)) K DGELG("ELIG","CODE",DGSUB)
.;
.S ERROR=0
.;if the msg contains patient security, process it
.I $D(DGSEC) D Q:ERROR
..S DGSEC("DFN")=DFN
..S DGSEC("USER")=.5
..I DGSEC("LEVEL")'="" D
...I DGSEC("DATETIME")="" S DGSEC("DATETIME")=$$NOW^XLFDT ;DG*5.3*653
..;
..; check consistency of patient security record
..I '$$CHECK^DGENSEC(.DGSEC,.ERRMSG) D Q
...S ERROR=1
...D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
..;
..; upload patient security, consistency checks passed
..D SECUPLD^DGENUPL5(DFN,.DGSEC,.OLDSEC)
.;
.; KUM - DG*5.3*1014 - BEGIN
.; Upload Community Care Program Data to Patient file (#2)
.;
.; End date all CCPs and Set Archive flag if COV is removed from eligibilities
.S DGCOV=$$FIND1^DIC(8,"","B","COLLATERAL OF VET")
.S DGCOVF=""
.S DGESCO=""
.I $$GET1^DIQ(2,DFN_",",".361","I")=$G(DGCOV) S DGCOVF="Y"
.S DGSUB=0 F S DGSUB=$O(^DPT(DFN,"E",DGSUB)) Q:'DGSUB D
..I +$G(^DPT(DFN,"E",DGSUB,0))=$G(DGCOV) S DGCOVF="Y"
.I DGELCV("ELIG","CODE")=$G(DGCOV) S DGESCO="Y"
.S DGSUB=0 F S DGSUB=$O(DGELCV("ELIG","CODE",DGSUB)) Q:'DGSUB D
..I DGSUB=$G(DGCOV) S DGESCO="Y"
.I DGCOVF="Y",DGESCO'="Y" D ARCHALL^DGRP1152U(DFN)
.;
.; Allow moving of cov from Primary to Other
.; Removing COV from patient eligibilities is not allowed if there are active CCPs
.; But uisng Z11, moving COV from primary to Other eligibilities is allowed, in this Case, bypassing the Check
.I DGELG("ELIG","CODE")'=$G(DGCOV),$$GET1^DIQ(2,DFN_",",".361","I")=$G(DGCOV),DGESCO="Y" D
..S $P(^DPT(DFN,.36),"^",1)=""
.;
.S DGSUB=""
.F S DGSUB=$O(DGCCPG(DGSUB)) Q:DGSUB="" D
..N DGMAT,DGPGCD,DGEFDT,DGEDDT,DGLUTS,DGZ,IENS,DGPGC1,DGEFD1
..S DGMAT="N"
..S DGPGCD=$P(DGCCPG(DGSUB),"^",1)
..S DGEFDT=$P(DGCCPG(DGSUB),"^",2)
..S DGEDDT=$P(DGCCPG(DGSUB),"^",3)
..I $G(DGEDDT)="@" S DGEDDT=""
..I $G(DGEDDT)="" S DGEDDT=""
..S DGLUTS=$P(DGCCPG(DGSUB),"^",4)
..S DGZ=0 F S DGZ=$O(^DPT(DFN,5,"AC",$G(DGEFDT),DGZ)) Q:'DGZ D
...S IENS=DGZ_","_DFN_","
...I $$GET1^DIQ(2.191,IENS,4,"I")'=1 D
....S DGPGC1=$$GET1^DIQ(2.191,IENS,1,"I")
....S DGEFD1=$$GET1^DIQ(2.191,IENS,2,"I")
....I ($G(DGPGCD)=$G(DGPGC1)),($G(DGEFDT)=$G(DGEFD1)) S DGMAT="Y" D CCCUPD
..I DGMAT'="Y" D CCCADD
.Q:ERROR
.; KUM - DG*5.3*1014 - END
.;
.;if the msg has an enrollment process it
.I DGENR("STATUS")!DGENR("APP") D Q:ERROR
..N DGENRYN,DGSTS
..S DGENRYN=""
..S DGSTS=DGENR("STATUS")
..I DGSTS=25 S DGENRYN=0 ;DG*5.3*993
..I DGSTS'=25,'$$PREEXIST^DGREG(DFN) S DGENRYN=1
..;use $$PRIORITY to get the eligibility data used to compute priority
..I $$PRIORITY^DGENELA4(DFN,.DGELG,.DGELGSUB,DGENR("DATE"),DGENR("APP"),$G(DGENRYN)) ;DG*5.3*993 Added DGENRYN REGISTRATION ONLY
..;
..;store the eligibility data in the enrollment record and other missing fields
..M DGENR("ELIG")=DGELGSUB
..S DGENR("ELIG","OTHTYPE")=$G(DGELG("OTHTYPE")) ; DG*5.3*952
..S DGENR("DFN")=DFN
..S DGENR("PRIORREC")=""
..S DGENR("USER")=.5
..S DGENR("DATETIME")=$$NOW^XLFDT
..;
..;Allow null overwrites of Ineligible data (Ineligible Project):
..I $D(DGENR("DATE")),DGENR("DATE")="" S DGENR("DATE")="@"
..I $D(DGENR("FACREC")),DGENR("FACREC")="" S DGENR("FACREC")="@"
..;
..;check the consistency of the enrollment record
..I '$$CHECK^DGENA3(.DGENR,.DGPAT,.ERRMSG) D Q
...S ERROR=1
...D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
..;
..;DG5.3*1027 - Do not reject Z11 when VistA stored YES for DO YOU WISH TO ENROLL and receive NO from HEC
..; DG*5.3*993 - BEGIN
..;Find patient's current enrollment record
..;N DGENRIEN,DGENRYN
..;S DGENRIEN=""
..;S DGENRYN=""
..;S DGENRIEN=$$FINDCUR^DGENA(DFN)
..;I DGENRIEN S:$G(DGENRYN)="" DGENRYN=$$GET1^DIQ(27.11,DGENRIEN_",",.14,"I") ;DG*5.3*993 Added REGISTRATION ONLY
..;I DGENRYN=1,DGENR("PTAPPLIED")=0,DGPAT("VETERAN")="Y" D Q
..;S ERROR=1
..;S ERRMSG="Veteran has applied for enrollment. Do You Wish to Enroll cannot be No."
..;D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
..;
..; DG*5.3*993 - END
..;DG*5.3*1027 - END
..;
..; removed EGT consistency check with DG*5.3*628
..;Phase II EGT consistency checks (SRS 6.5.1.3)
..; DG*5.3*1111 - ENROLLMENT STATUS (file #27.15) entries of REJECTED renamed to DEFERRED. Comment below modified
..;Only do the EGT consistency checks for Deferred-Fiscal Year (11),Deferred-Mid Cycle (12),Deferred-Stop enrolling new apps (13),Deferred-Initial App by VAMC (14),Deferred below EGT threshold (22)
..;I "^11^12^13^14^22^"[("^"_DGENR("STATUS")_"^"),$$ABOVE^DGENEGT1(DGENR("DFN"),DGENR("PRIORITY"),DGENR("SUBGRP"),"","",1) D Q
..;.S ERROR=1
..;.S ERRMSG="THE ENROLLMENT RECORD DID NOT PASS THE EGT CONSISTENCY CHECKS."
..;.D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
..;
..;Allow null overwrites for Ineligible vets (Ineligible Project):
..I $G(DGPAT("INELDATE"))'="" S (DGENR("PRIORITY"),DGENR("SUBGRP"))=""
..I DGENR("DATE")="@" S DGENR("DATE")=""
..I DGENR("FACREC")="@" S DGENR("FACREC")=""
..;
..D ENRUPLD^DGENUPL8(.DGENR,.DGPAT)
.;
.;Store the PATIENT, ELIGIBILITY, & CAT. DISB. objects
.I $$STORE^DGENPTA1(.DGPAT,,1)
.I $$STORE^DGENELA1(.DGELG,.DGPAT,.DGCDIS,,1)
.I $G(DGCDIS("VCD"))'="",$$STORE^DGENCDA2(DFN,.DGCDIS) ;checks first if there is catastrophic disability information
.; store OTH data
.D OTHUPLD^DGENUPL8(DFN,.DGOTH,$G(DGPAT("SSN")),$G(DGELG("ELIG","CODE"))) ; DG*5.3*952
.;
.;Call PIMS api to file NTR data.
.I $D(DGNTR),$$ENRUPD^DGNTAPI1(DFN,.DGNTR)
.;
.;Call PIMS api to file MST data.
.I DGMST("MSTSTAT")'="",DGMST("MSTDT")'="",DGMST("MSTST")'="" D
..I $$NEWSTAT^DGMSTAPI(DFN,DGMST("MSTSTAT"),DGMST("MSTDT"),".5",DGMST("MSTST"),0)
..Q
.; create new entry in sub-file 33.02
.D CRTEELCH^DGOTHEL(DFN,$$HASENTRY^DGOTHD2(DFN),$G(DGELG("OTHTS"))) ; DG*5.3*977 OTH-EXT - moved after MST data update
.;
.;Since HEC is authoritative source, If no OEF/OIF data in Z11, set count to 0 so existing data in VistA will be deleted.
.I '$D(DGOEIF) S DGOEIF("COUNT")=0
.;Call PIMS api to file OEF/OIF data.
.I $D(DGOEIF) D OEIFUPD^DGCLAPI1(DFN,.DGOEIF)
.;
.;File the Military Service Episode (MSE) data (DG*5.3*797)
.I $D(DGNMSE) D UPDMSE^DGMSEUTL(DFN,.DGNMSE)
.;
.;File the Health Benefit Plan (HBP) data
.D HL7UPD^DGHBPUTL(DFN,.DGHBP,MSHDT)
.;DG*5.3*1082 - File the Health Factor Segment (ZHF) data
.D ZHFUPD
.;
.;if the current enrollment is a local then log patient for transmission
.;DG*5.3*1045 - Don't trigger Z07 if source is VAMC
.;I $$SOURCE^DGENA(DFN)=1!$G(DGPHINC) K DGENUPLD,DGPHINC D EVENT^IVMPLOG(DFN)
.I $G(DGPHINC) K DGENUPLD,DGPHINC D EVENT^IVMPLOG(DFN)
.;
.;create the audit trail
.K OLDPAT("MOH"),DGPAT("MOH") ;remove MOH from audit demographics report DG*5.3*972 HM
.I $$AUDIT^DGENUPA1(,MSGID,.OLDPAT,.DGPAT,.OLDELG,.DGELG,.OLDCDIS,.DGCDIS,.DGSEC,.OLDSEC)
.;send notifications
.D NOTIFY^DGENUPL3(.DGPAT,.MSGS)
.;
.;invoke registration consistency checker
.D REGCHECK^DGENUPL2(DFN)
;
D UNLOCK^DGENUPL5(DFN)
;DG*5.3*1090 - Kill ^TMP global Combat Vet Elig End Date Source
K ^TMP("DGCVE",$J,"COMBAT VET ELIG END DATE SOURCE",DFN)
Q
CCCADD ; Add new entry to #2.191
N DGERR,DGIENS,DGFDA
S DGERR=0
S DGIENS=DFN_","
S DGIENS="+1,"_DGIENS
S DGFDA(2.191,DGIENS,.01)=$G(DGLUTS)
S DGFDA(2.191,DGIENS,1)=$G(DGPGCD)
S DGFDA(2.191,DGIENS,2)=$G(DGEFDT)
S DGFDA(2.191,DGIENS,3)=$G(DGEDDT)
D UPDATE^DIE("","DGFDA","","DGERR")
I DGERR D
.S ERROR=1
.D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$G(DGERR("DIERR",1,"TEXT",1)),.ERRCOUNT)
Q
CCCUPD ; Update entry in #2.191
N DGFDA,DGERR,DGIENS,DGTMTS
S DGERR=0
S DGIENS=IENS
S DGTMTS=+$$GET1^DIQ(2.191,DGIENS,.01,"I")
I $G(DGLUTS)>$G(DGTMTS) D
.S DGFDA(2.191,DGIENS,.01)=$G(DGLUTS)
.S DGFDA(2.191,DGIENS,3)=$G(DGEDDT)
.S DGFDA(2.191,DGIENS,4)=0
.D FILE^DIE("","DGFDA","DGERR")
.I DGERR D
..S ERROR=1
..D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$G(DGERR("DIERR",1,"TEXT",1)),.ERRCOUNT)
Q
ZHFUPD ; DG*5.3*1082 - Update database with the ZHF data
; a date is always expected when updating.
I $G(DGZHF("PPCATCHGDT"))'="" D
.; Update Presumptive Psychosis Category (#.5601) field in the Patient (#2) file, and the Presumptive Psychosis Category Change (#33.1) file.
.I '$$PT^DGPPSYCH(DFN,DGZHF("PPCATEGORY"),DGZHF("PPCATCHGDT")) D
..S ERRMSG="FILEMAN FAILED TO UPDATE PRESUMPTIVE PSYCHOSIS CATEGORY"
..S ERROR=1
..D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$G(ERRMSG),.ERRCOUNT) Q
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HDGENUPL7 11226 printed Dec 13, 2024@02:43:22 Page 2
DGENUPL7 ;ISA/KWP,CKN,TMK,TDM,LBD,HM,KUM - PROCESS INCOMING (Z11 EVENT TYPE) HL7 MESSAGES ;9/12/20 5:48pm
+1 ;;5.3;REGISTRATION;**232,367,397,417,379,431,513,628,673,653,742,688,797,871,972,952,977,993,1014,1027,1045,1082,1090,1111**;Aug 13,1993;Build 18
+2 ;Per VHA Directive 2004-038, this routine should not be modified.
+3 ;
+4 ;Phase II split from DGENUPL
Z11(MSGIEN,MSGID,CURLINE,DFN,ERRCOUNT) ;
+1 ;Description: This is used to process a single ORU~Z11 or ORF~Z11 msg.
+2 ;Input:
+3 ; MSGIEN - the internal entry number of the HL7 message in the
+4 ; HL7 MESSAGE TEXT file (772)
+5 ; MSGID -message control id of HL7 msg in the MSH segment
+6 ; CURLINE - the subscript of the MSH segment of the current message (pass by reference)
+7 ; DFN - identifies the patient, is the ien of a record in the PATIENT file.
+8 ; ERRCOUNT - is a count of the number of messages in the batch that can not be processed (pass by reference)
+9 ;
+10 ;Output:
+11 ; CURLINE - upon leaving the procedure this parameter should be set to the end of the current message. (pass by reference)
+12 ; ERRCOUNT - set to count of messages that were not processed due to errors encountered (pass by reference)
+13 ;
+14 NEW DGELG,DGENR,DGPAT,DGCDIS,DGOEIF,ERROR,ERRMSG,MSGS,DGELGSUB,DGENUPLD,DGCON,DGNMSE,DGCCPG,DGSUB,DGFDA,DGERR,DGIENS
+15 NEW DGNEWVAL,DIV,SUB,OLDELG,OLDPAT,OLDDCDIS,OLDEIF,DGSEC,OLDSEC,DGNTR,DGMST,DGPHINC,DGHBP,DGOTH,DGSUB,DGCOVF,DGESCO,DGCOV
+16 NEW DGELCV,DGOAPP,DGZHF
+17 ;
+18 ;some process is killing these HL7 variables, so need to protect them
+19 SET SUB=HLFS
+20 SET DIV=HLECH
+21 NEW HLDA,HLDAN,HLDAP,HLDT,HLDT1,HLECH,HLFS,HLNDAP,HLNDAP0,HLPID,HLQ,HLVER,HLERR,HLMTN,HLSDT
+22 SET HLFS=SUB
+23 SET HLECH=DIV
+24 SET HLQ=""""""
+25 KILL DIV,SUB
+26 ;DG*5.3*1090 - Kill ^TMP global Combat Vet Elig End Date Source
+27 KILL ^TMP("DGCVE",$JOB,"COMBAT VET ELIG END DATE SOURCE",DFN)
+28 ;
+29 ;drops out of block on error
+30 Begin DoDot:1
+31 ;DG*5.3*1082 - Add ZHF Parsing to load DGZHF array
+32 if '$$PARSE^DGENUPL1(MSGIEN,MSGID,.CURLINE,.ERRCOUNT,.DGPAT,.DGELG,.DGENR,.DGCDIS,.DGOEIF,.DGSEC,.DGNTR,.DGMST,.DGNMSE,.DGHBP,.DGOTH,.DGZHF)
QUIT
+33 ; DG*5.3*1014 - Capture Z11 eligibilities
+34 MERGE DGELCV=DGELG
+35 DO GETLOCKS^DGENUPL5(DFN)
+36 ;
+37 ;Used by cross-references to determine if an upload is in progress.
+38 SET DGENUPLD="ENROLLMENT/ELIGIBILITY UPLOAD IN PROGRESS"
+39 ;
+40 ;Update the PATIENT, ELIGIBILITY, CATASTROPHIC DISABILITY objects in memory
+41 if '$$UOBJECTS^DGENUPL4(DFN,.DGPAT,.DGELG,.DGCDIS,.DGOEIF,MSGID,.ERRCOUNT,.MSGS,.OLDPAT,.OLDELG,.OLDCDIS,.OLDEIF)
QUIT
+42 ;DG*5.3*1014 - Delete Vista secondary eligibilities from DGELG array
+43 SET DGSUB=0
FOR
SET DGSUB=$ORDER(DGELG("ELIG","CODE",DGSUB))
if 'DGSUB
QUIT
Begin DoDot:2
+44 IF '$DATA(DGELCV("ELIG","CODE",DGSUB))
KILL DGELG("ELIG","CODE",DGSUB)
End DoDot:2
+45 ;
+46 SET ERROR=0
+47 ;if the msg contains patient security, process it
+48 IF $DATA(DGSEC)
Begin DoDot:2
+49 SET DGSEC("DFN")=DFN
+50 SET DGSEC("USER")=.5
+51 IF DGSEC("LEVEL")'=""
Begin DoDot:3
+52 ;DG*5.3*653
IF DGSEC("DATETIME")=""
SET DGSEC("DATETIME")=$$NOW^XLFDT
End DoDot:3
+53 ;
+54 ; check consistency of patient security record
+55 IF '$$CHECK^DGENSEC(.DGSEC,.ERRMSG)
Begin DoDot:3
+56 SET ERROR=1
+57 DO ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
End DoDot:3
QUIT
+58 ;
+59 ; upload patient security, consistency checks passed
+60 DO SECUPLD^DGENUPL5(DFN,.DGSEC,.OLDSEC)
End DoDot:2
if ERROR
QUIT
+61 ;
+62 ; KUM - DG*5.3*1014 - BEGIN
+63 ; Upload Community Care Program Data to Patient file (#2)
+64 ;
+65 ; End date all CCPs and Set Archive flag if COV is removed from eligibilities
+66 SET DGCOV=$$FIND1^DIC(8,"","B","COLLATERAL OF VET")
+67 SET DGCOVF=""
+68 SET DGESCO=""
+69 IF $$GET1^DIQ(2,DFN_",",".361","I")=$GET(DGCOV)
SET DGCOVF="Y"
+70 SET DGSUB=0
FOR
SET DGSUB=$ORDER(^DPT(DFN,"E",DGSUB))
if 'DGSUB
QUIT
Begin DoDot:2
+71 IF +$GET(^DPT(DFN,"E",DGSUB,0))=$GET(DGCOV)
SET DGCOVF="Y"
End DoDot:2
+72 IF DGELCV("ELIG","CODE")=$GET(DGCOV)
SET DGESCO="Y"
+73 SET DGSUB=0
FOR
SET DGSUB=$ORDER(DGELCV("ELIG","CODE",DGSUB))
if 'DGSUB
QUIT
Begin DoDot:2
+74 IF DGSUB=$GET(DGCOV)
SET DGESCO="Y"
End DoDot:2
+75 IF DGCOVF="Y"
IF DGESCO'="Y"
DO ARCHALL^DGRP1152U(DFN)
+76 ;
+77 ; Allow moving of cov from Primary to Other
+78 ; Removing COV from patient eligibilities is not allowed if there are active CCPs
+79 ; But uisng Z11, moving COV from primary to Other eligibilities is allowed, in this Case, bypassing the Check
+80 IF DGELG("ELIG","CODE")'=$GET(DGCOV)
IF $$GET1^DIQ(2,DFN_",",".361","I")=$GET(DGCOV)
IF DGESCO="Y"
Begin DoDot:2
+81 SET $PIECE(^DPT(DFN,.36),"^",1)=""
End DoDot:2
+82 ;
+83 SET DGSUB=""
+84 FOR
SET DGSUB=$ORDER(DGCCPG(DGSUB))
if DGSUB=""
QUIT
Begin DoDot:2
+85 NEW DGMAT,DGPGCD,DGEFDT,DGEDDT,DGLUTS,DGZ,IENS,DGPGC1,DGEFD1
+86 SET DGMAT="N"
+87 SET DGPGCD=$PIECE(DGCCPG(DGSUB),"^",1)
+88 SET DGEFDT=$PIECE(DGCCPG(DGSUB),"^",2)
+89 SET DGEDDT=$PIECE(DGCCPG(DGSUB),"^",3)
+90 IF $GET(DGEDDT)="@"
SET DGEDDT=""
+91 IF $GET(DGEDDT)=""
SET DGEDDT=""
+92 SET DGLUTS=$PIECE(DGCCPG(DGSUB),"^",4)
+93 SET DGZ=0
FOR
SET DGZ=$ORDER(^DPT(DFN,5,"AC",$GET(DGEFDT),DGZ))
if 'DGZ
QUIT
Begin DoDot:3
+94 SET IENS=DGZ_","_DFN_","
+95 IF $$GET1^DIQ(2.191,IENS,4,"I")'=1
Begin DoDot:4
+96 SET DGPGC1=$$GET1^DIQ(2.191,IENS,1,"I")
+97 SET DGEFD1=$$GET1^DIQ(2.191,IENS,2,"I")
+98 IF ($GET(DGPGCD)=$GET(DGPGC1))
IF ($GET(DGEFDT)=$GET(DGEFD1))
SET DGMAT="Y"
DO CCCUPD
End DoDot:4
End DoDot:3
+99 IF DGMAT'="Y"
DO CCCADD
End DoDot:2
+100 if ERROR
QUIT
+101 ; KUM - DG*5.3*1014 - END
+102 ;
+103 ;if the msg has an enrollment process it
+104 IF DGENR("STATUS")!DGENR("APP")
Begin DoDot:2
+105 NEW DGENRYN,DGSTS
+106 SET DGENRYN=""
+107 SET DGSTS=DGENR("STATUS")
+108 ;DG*5.3*993
IF DGSTS=25
SET DGENRYN=0
+109 IF DGSTS'=25
IF '$$PREEXIST^DGREG(DFN)
SET DGENRYN=1
+110 ;use $$PRIORITY to get the eligibility data used to compute priority
+111 ;DG*5.3*993 Added DGENRYN REGISTRATION ONLY
IF $$PRIORITY^DGENELA4(DFN,.DGELG,.DGELGSUB,DGENR("DATE"),DGENR("APP"),$GET(DGENRYN))
+112 ;
+113 ;store the eligibility data in the enrollment record and other missing fields
+114 MERGE DGENR("ELIG")=DGELGSUB
+115 ; DG*5.3*952
SET DGENR("ELIG","OTHTYPE")=$GET(DGELG("OTHTYPE"))
+116 SET DGENR("DFN")=DFN
+117 SET DGENR("PRIORREC")=""
+118 SET DGENR("USER")=.5
+119 SET DGENR("DATETIME")=$$NOW^XLFDT
+120 ;
+121 ;Allow null overwrites of Ineligible data (Ineligible Project):
+122 IF $DATA(DGENR("DATE"))
IF DGENR("DATE")=""
SET DGENR("DATE")="@"
+123 IF $DATA(DGENR("FACREC"))
IF DGENR("FACREC")=""
SET DGENR("FACREC")="@"
+124 ;
+125 ;check the consistency of the enrollment record
+126 IF '$$CHECK^DGENA3(.DGENR,.DGPAT,.ERRMSG)
Begin DoDot:3
+127 SET ERROR=1
+128 DO ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
End DoDot:3
QUIT
+129 ;
+130 ;DG5.3*1027 - Do not reject Z11 when VistA stored YES for DO YOU WISH TO ENROLL and receive NO from HEC
+131 ; DG*5.3*993 - BEGIN
+132 ;Find patient's current enrollment record
+133 ;N DGENRIEN,DGENRYN
+134 ;S DGENRIEN=""
+135 ;S DGENRYN=""
+136 ;S DGENRIEN=$$FINDCUR^DGENA(DFN)
+137 ;I DGENRIEN S:$G(DGENRYN)="" DGENRYN=$$GET1^DIQ(27.11,DGENRIEN_",",.14,"I") ;DG*5.3*993 Added REGISTRATION ONLY
+138 ;I DGENRYN=1,DGENR("PTAPPLIED")=0,DGPAT("VETERAN")="Y" D Q
+139 ;S ERROR=1
+140 ;S ERRMSG="Veteran has applied for enrollment. Do You Wish to Enroll cannot be No."
+141 ;D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
+142 ;
+143 ; DG*5.3*993 - END
+144 ;DG*5.3*1027 - END
+145 ;
+146 ; removed EGT consistency check with DG*5.3*628
+147 ;Phase II EGT consistency checks (SRS 6.5.1.3)
+148 ; DG*5.3*1111 - ENROLLMENT STATUS (file #27.15) entries of REJECTED renamed to DEFERRED. Comment below modified
+149 ;Only do the EGT consistency checks for Deferred-Fiscal Year (11),Deferred-Mid Cycle (12),Deferred-Stop enrolling new apps (13),Deferred-Initial App by VAMC (14),Deferred below EGT threshold (22)
+150 ;I "^11^12^13^14^22^"[("^"_DGENR("STATUS")_"^"),$$ABOVE^DGENEGT1(DGENR("DFN"),DGENR("PRIORITY"),DGENR("SUBGRP"),"","",1) D Q
+151 ;.S ERROR=1
+152 ;.S ERRMSG="THE ENROLLMENT RECORD DID NOT PASS THE EGT CONSISTENCY CHECKS."
+153 ;.D ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),ERRMSG,.ERRCOUNT)
+154 ;
+155 ;Allow null overwrites for Ineligible vets (Ineligible Project):
+156 IF $GET(DGPAT("INELDATE"))'=""
SET (DGENR("PRIORITY"),DGENR("SUBGRP"))=""
+157 IF DGENR("DATE")="@"
SET DGENR("DATE")=""
+158 IF DGENR("FACREC")="@"
SET DGENR("FACREC")=""
+159 ;
+160 DO ENRUPLD^DGENUPL8(.DGENR,.DGPAT)
End DoDot:2
if ERROR
QUIT
+161 ;
+162 ;Store the PATIENT, ELIGIBILITY, & CAT. DISB. objects
+163 IF $$STORE^DGENPTA1(.DGPAT,,1)
+164 IF $$STORE^DGENELA1(.DGELG,.DGPAT,.DGCDIS,,1)
+165 ;checks first if there is catastrophic disability information
IF $GET(DGCDIS("VCD"))'=""
IF $$STORE^DGENCDA2(DFN,.DGCDIS)
+166 ; store OTH data
+167 ; DG*5.3*952
DO OTHUPLD^DGENUPL8(DFN,.DGOTH,$GET(DGPAT("SSN")),$GET(DGELG("ELIG","CODE")))
+168 ;
+169 ;Call PIMS api to file NTR data.
+170 IF $DATA(DGNTR)
IF $$ENRUPD^DGNTAPI1(DFN,.DGNTR)
+171 ;
+172 ;Call PIMS api to file MST data.
+173 IF DGMST("MSTSTAT")'=""
IF DGMST("MSTDT")'=""
IF DGMST("MSTST")'=""
Begin DoDot:2
+174 IF $$NEWSTAT^DGMSTAPI(DFN,DGMST("MSTSTAT"),DGMST("MSTDT"),".5",DGMST("MSTST"),0)
+175 QUIT
End DoDot:2
+176 ; create new entry in sub-file 33.02
+177 ; DG*5.3*977 OTH-EXT - moved after MST data update
DO CRTEELCH^DGOTHEL(DFN,$$HASENTRY^DGOTHD2(DFN),$GET(DGELG("OTHTS")))
+178 ;
+179 ;Since HEC is authoritative source, If no OEF/OIF data in Z11, set count to 0 so existing data in VistA will be deleted.
+180 IF '$DATA(DGOEIF)
SET DGOEIF("COUNT")=0
+181 ;Call PIMS api to file OEF/OIF data.
+182 IF $DATA(DGOEIF)
DO OEIFUPD^DGCLAPI1(DFN,.DGOEIF)
+183 ;
+184 ;File the Military Service Episode (MSE) data (DG*5.3*797)
+185 IF $DATA(DGNMSE)
DO UPDMSE^DGMSEUTL(DFN,.DGNMSE)
+186 ;
+187 ;File the Health Benefit Plan (HBP) data
+188 DO HL7UPD^DGHBPUTL(DFN,.DGHBP,MSHDT)
+189 ;DG*5.3*1082 - File the Health Factor Segment (ZHF) data
+190 DO ZHFUPD
+191 ;
+192 ;if the current enrollment is a local then log patient for transmission
+193 ;DG*5.3*1045 - Don't trigger Z07 if source is VAMC
+194 ;I $$SOURCE^DGENA(DFN)=1!$G(DGPHINC) K DGENUPLD,DGPHINC D EVENT^IVMPLOG(DFN)
+195 IF $GET(DGPHINC)
KILL DGENUPLD,DGPHINC
DO EVENT^IVMPLOG(DFN)
+196 ;
+197 ;create the audit trail
+198 ;remove MOH from audit demographics report DG*5.3*972 HM
KILL OLDPAT("MOH"),DGPAT("MOH")
+199 IF $$AUDIT^DGENUPA1(,MSGID,.OLDPAT,.DGPAT,.OLDELG,.DGELG,.OLDCDIS,.DGCDIS,.DGSEC,.OLDSEC)
+200 ;send notifications
+201 DO NOTIFY^DGENUPL3(.DGPAT,.MSGS)
+202 ;
+203 ;invoke registration consistency checker
+204 DO REGCHECK^DGENUPL2(DFN)
End DoDot:1
+205 ;
+206 DO UNLOCK^DGENUPL5(DFN)
+207 ;DG*5.3*1090 - Kill ^TMP global Combat Vet Elig End Date Source
+208 KILL ^TMP("DGCVE",$JOB,"COMBAT VET ELIG END DATE SOURCE",DFN)
+209 QUIT
CCCADD ; Add new entry to #2.191
+1 NEW DGERR,DGIENS,DGFDA
+2 SET DGERR=0
+3 SET DGIENS=DFN_","
+4 SET DGIENS="+1,"_DGIENS
+5 SET DGFDA(2.191,DGIENS,.01)=$GET(DGLUTS)
+6 SET DGFDA(2.191,DGIENS,1)=$GET(DGPGCD)
+7 SET DGFDA(2.191,DGIENS,2)=$GET(DGEFDT)
+8 SET DGFDA(2.191,DGIENS,3)=$GET(DGEDDT)
+9 DO UPDATE^DIE("","DGFDA","","DGERR")
+10 IF DGERR
Begin DoDot:1
+11 SET ERROR=1
+12 DO ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$GET(DGERR("DIERR",1,"TEXT",1)),.ERRCOUNT)
End DoDot:1
+13 QUIT
CCCUPD ; Update entry in #2.191
+1 NEW DGFDA,DGERR,DGIENS,DGTMTS
+2 SET DGERR=0
+3 SET DGIENS=IENS
+4 SET DGTMTS=+$$GET1^DIQ(2.191,DGIENS,.01,"I")
+5 IF $GET(DGLUTS)>$GET(DGTMTS)
Begin DoDot:1
+6 SET DGFDA(2.191,DGIENS,.01)=$GET(DGLUTS)
+7 SET DGFDA(2.191,DGIENS,3)=$GET(DGEDDT)
+8 SET DGFDA(2.191,DGIENS,4)=0
+9 DO FILE^DIE("","DGFDA","DGERR")
+10 IF DGERR
Begin DoDot:2
+11 SET ERROR=1
+12 DO ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$GET(DGERR("DIERR",1,"TEXT",1)),.ERRCOUNT)
End DoDot:2
End DoDot:1
+13 QUIT
ZHFUPD ; DG*5.3*1082 - Update database with the ZHF data
+1 ; a date is always expected when updating.
+2 IF $GET(DGZHF("PPCATCHGDT"))'=""
Begin DoDot:1
+3 ; Update Presumptive Psychosis Category (#.5601) field in the Patient (#2) file, and the Presumptive Psychosis Category Change (#33.1) file.
+4 IF '$$PT^DGPPSYCH(DFN,DGZHF("PPCATEGORY"),DGZHF("PPCATCHGDT"))
Begin DoDot:2
+5 SET ERRMSG="FILEMAN FAILED TO UPDATE PRESUMPTIVE PSYCHOSIS CATEGORY"
+6 SET ERROR=1
+7 DO ADDERROR^DGENUPL(MSGID,DGPAT("SSN"),$GET(ERRMSG),.ERRCOUNT)
QUIT
End DoDot:2
End DoDot:1
+8 QUIT