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

DGRODEBR.m

Go to the documentation of this file.
  1. DGRODEBR ;DJH/AMA,TDM - ROM DATA ELEMENT BUSINESS RULES ; 10/20/10 9:59am
  1. ;;5.3;Registration;**533,572,754,797**;Aug 13, 1993;Build 24
  1. ;
  1. ;BUSINESS RULES TO BE CHECKED JUST BEFORE FILING THE
  1. ;PATIENT DATA RETRIEVED FROM THE LAST SITE TREATED (LST)
  1. ;
  1. ;* DG*5.3*572 changed "I"nternal references to "E"xternal references
  1. POW(DGDATA,DFN,LSTDFN) ;POW STATUS INDICATED?
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N RSPOW ;REQUESTING SITE POW STATUS INDICATED
  1. N LSTPOW ;LAST SITE TREATED POW STATUS INDICATED
  1. S RSPOW=$$GET1^DIQ(2,DFN,.525)
  1. S LSTPOW=$G(@DGDATA@(2,LSTDFN_",",.525,"E"))
  1. ;If either of the POW STATUS INDICATED? flags
  1. ;are "N"o, don't file the POW data element(s)
  1. I (RSPOW="NO")!(LSTPOW="NO") D
  1. . N FIELD
  1. . F FIELD=.525:.001:.528 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. AO(DGDATA,DFN,LSTDFN) ;AGENT ORANGE EXPOSURE INDICATED?
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N RSAO ;R.S. AGENT ORANGE EXPOSURE INDICATED
  1. N LSTAO ;LST AGENT ORANGE EXPOSURE INDICATED
  1. S RSAO=$$GET1^DIQ(2,DFN,.32102)
  1. S LSTAO=$G(@DGDATA@(2,LSTDFN_",",.32102,"E"))
  1. ;If either of the AGENT ORANGE EXPOSURE INDICATED?
  1. ;flags are "N"o, delete the AO data element(s)
  1. I (RSAO="NO")!(LSTAO="NO") D
  1. . N FIELD
  1. . ;added AO LOCATION OF EXPOSURE (2/.3213) for DG*5.3*572 DJH
  1. . F FIELD=.32102,.32107,.32108,.32109,.3211,.3213 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. IR(DGDATA,DFN,LSTDFN) ;RADIATION EXPOSURE INDICATED?
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N RSIR ;R.S. RADIATION EXPOSURE INDICATED
  1. N LSTIR ;LST RADIATION EXPOSURE INDICATED
  1. S RSIR=$$GET1^DIQ(2,DFN,.32103)
  1. S LSTIR=$G(@DGDATA@(2,LSTDFN_",",.32103,"E"))
  1. ;If either of the RADIATION EXPOSURE INDICATED
  1. ;flags are "N"o, delete the IR data elements
  1. I (RSIR="NO")!(LSTIR="NO") D
  1. . N FIELD
  1. . F FIELD=.32103,.32111,.3212 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. INC(DGDATA,DFN,LSTDFN) ;RATED INCOMPETENT (Y/N)
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N RSIN ;RATED INCOMPETENT (Y/N)
  1. N LSTIN ;LST RATED INCOMPETENT (Y/N)
  1. S RSIN=$$GET1^DIQ(2,DFN,.293)
  1. S LSTIN=$G(@DGDATA@(2,LSTDFN_",",.293,"E"))
  1. ;If either of the RATED INCOMPETENT
  1. ;flags are "N"o, delete the IR data elements
  1. I (RSIN="NO")!(LSTIN="NO") D
  1. . N FIELD
  1. . F FIELD=.292,.293 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. INE(DGDATA,DFN,LSTDFN) ;INELIGIBLE DATA
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. ;
  1. N LSTID ;INELIGIBLE DATE
  1. S LSTID=$G(@DGDATA@(2,LSTDFN_",",.152,"E"))
  1. ;
  1. ;If no INELIGIBLE DATE from LST don't upload ineligible fields.
  1. I LSTID="" D
  1. . N FIELD
  1. . F FIELD=.152,.307,.1651,.1653,.1654,.1656 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. DOD(DGDATA,DFN,LSTDFN) ;DATE OF DEATH
  1. ;Retrieve all DATE OF DEATH data elements, but instead of being filed,
  1. ;they will be placed into a mail message to the appropriate group.
  1. ;
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. ;
  1. N DGMSG,FLD
  1. ;Only send messages if actual DOD is defined (field # .351) ;DG*5.3*572
  1. I $D(@DGDATA@(2,LSTDFN_",",.351)) D
  1. . D DODMAIL^DGROMAIL(DGDATA,DFN,LSTDFN)
  1. . S DGMSG(1)=" "
  1. . S DGMSG(2)="Date of Death information has been retrieved from the LST."
  1. . S DGMSG(3)="This information has NOT been filed into the patient's record."
  1. . S DGMSG(4)="A mail message has been sent to the Register Once mail group."
  1. . D EN^DDIOL(.DGMSG) R A:5
  1. ;Delete DoD fields from FDA array so they're not filed.
  1. F FLD=.351:.001:.355 K @DGDATA@(2,LSTDFN_",",FLD) ;DG*5.3*572 - added .355
  1. Q
  1. ;
  1. TA(DGDATA,LSTDFN) ;TEMPORARY ADDRESS
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N LSTTAED ;LST TEMPORARY ADDRESS END DATE (EXTERNAL)
  1. N LSTTAEDF ;LST TEMPORARY ADDRESS END DATE FILEMAN (DG*5.3*572)
  1. S LSTTAED=$G(@DGDATA@(2,LSTDFN_",",.1218,"E"))
  1. ;*Convert External LST date to Fileman date (DG*5.3*572)
  1. S X=LSTTAED
  1. S %DT="RSN"
  1. D ^%DT
  1. S LSTTAEDF=Y
  1. ;If the TEMPORARY ADDRESS END DATE is less than the
  1. ;date of the query, delete the TA data elements
  1. I (LSTTAEDF>0),(LSTTAEDF<DT) D
  1. . N FIELD
  1. . F FIELD=.12105,.12111,.12112,.1211:.0001:.1219 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. K X,%DT,Y
  1. Q
  1. ;
  1. SP(DGDATA,DFN,LSTDFN) ;SENSITIVE PATIENT
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. ;
  1. N RSSP ;R.S. SENSITIVE PATIENT
  1. N LSTSP ;LST SENSITIVE PATIENT
  1. S RSSP=$$GET1^DIQ(38.1,DFN,2)
  1. S LSTSP=$G(@DGDATA@(38.1,LSTDFN_",",2,"E"))
  1. ;
  1. ;* Remove code deleting Primary Eligibility Code (DG*5.3*572)
  1. ;* In all cases, delete Patient Type
  1. K @DGDATA@(2,LSTDFN_",",391)
  1. ;
  1. ;If the SENSITIVE PATIENT flag is received from the HEC -- OR -- if the
  1. ;flag is NOT received from both the HEC and LST, retrieve and file all
  1. ;Sensitive data elements, but NOT the fields for the Security Log file.
  1. I '((RSSP'="SENSITIVE")&(LSTSP="SENSITIVE")) D I 1
  1. . K @DGDATA@(38.1)
  1. E D
  1. . ;Otherwise (flag not received from the HEC but is from the LST),
  1. . ;send a mail message to the ISO and the "Register Once" mail
  1. . ;group that this patient is listed as Sensitive
  1. . D SPMAIL^DGROMAIL(DFN)
  1. . N DGMSG
  1. . S DGMSG(1)=" "
  1. . S DGMSG(2)="Sensitive Patient information has been retrieved from the LST."
  1. . S DGMSG(3)="This information has been filed into the patient's record."
  1. . S DGMSG(4)="A mail message has been sent to the Register Once mail group"
  1. . S DGMSG(5)="and the ISO explaining that this information has been received."
  1. . D EN^DDIOL(.DGMSG) R A:5
  1. Q
  1. ;
  1. SWA(DGDATA,DFN,LSTDFN) ;SOUTHWEST ASIA CONDITIONS
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N RSSWA ;REQUESTING SITE SOUTHWEST ASIA CONDITIONS
  1. N LSTSWA ;LAST SITE TREATED SOUTHWEST ASIA CONDITIONS
  1. S RSSWA=$$GET1^DIQ(2,DFN,.322013)
  1. S LSTSWA=$G(@DGDATA@(2,LSTDFN_",",.322013,"E"))
  1. ;If either of the SOUTHWEST ASIA CONDITIONS flags
  1. ;are "N"o, don't file the SOUTWEST ASIA CONDITION data element(s)
  1. I (RSSWA="NO")!(LSTSWA="NO") D
  1. . N FIELD
  1. . F FIELD=.322013,322014,322015 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. RE ;RACE AND ETHNICITY
  1. ;If the RACE AND ETHNICITY data not already
  1. ;populated, file it (already the basic rule)
  1. Q
  1. ;
  1. CA(DGDATA,LSTDFN) ;CONFIDENTIAL ADDRESS
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N LSTCAAF ;LST CONFIDENTIAL ADDRESS ACTIVE FLAG
  1. N LSTCAED ;LST CONFIDENTIAL ADDRESS END DATE
  1. N LSTCAEDF ;LST CONFIDENTIAL ADDRESS END DATE FILEMAN (DG*5.3*572)
  1. S LSTCAAF=$G(@DGDATA@(2,LSTDFN_",",.14105,"E"))
  1. S LSTCAED=$G(@DGDATA@(2,LSTDFN_",",.1418,"E"))
  1. ;*Convert LSTCAED to Fileman format date for compare (DG*5.3*572)
  1. S X=LSTCAED
  1. S %DT="SN"
  1. D ^%DT
  1. S LSTCAEDF=Y
  1. ;If the CONFIDENTIAL ADDRESS FLAG from the Last Site Treated is "N"o,
  1. ; OR if the C.A. END DATE from the LST is less than the Query date,
  1. ;delete the C.A. data elements
  1. I (LSTCAAF'="YES")!((LSTCAEDF>0)&(LSTCAEDF<DT)) D
  1. . N FIELD
  1. . F FIELD=.1315,.14105,.14111:.00001:.14116,.1411:.0001:.1418 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. . K @DGDATA@(2.141)
  1. ;Else the Confidential Address information will be filed
  1. ;and a User Interface message will be displayed.
  1. E D
  1. . N DGMSG
  1. . N DATEFM ;*DATE converted to Fileman format (DG*5.3*572)
  1. . S DGMSG(1)=" "
  1. . S DGMSG(2)="Confidential Address information has been retrieved from the LST."
  1. . S DGMSG(3)="This information has been filed into the patient's record."
  1. . S DATE=$G(@DGDATA@(2,LSTDFN_",",.1417,"E"))
  1. . ;* Convert DATE to FM format (DG*5.3*572)
  1. . K X,%DT,Y
  1. . S X=DATE
  1. . S %DT="SN"
  1. . D ^%DT
  1. . S DATEFM=Y
  1. . I DATEFM>DT D
  1. . . S DGMSG(4)=" NOTE: Confidential Address Start Date is in the future, "_DATE
  1. . . S DGMSG(5)=" "
  1. . D EN^DDIOL(.DGMSG) R A:5
  1. K X,%DT,Y
  1. Q
  1. ;
  1. PA(DGDATA,LSTDFN) ;PERMANENT ADDRESS
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N LSTBAI ;LST BAD ADDRESS INDICATOR
  1. S LSTBAI=$G(@DGDATA@(2,LSTDFN_",",.121,"E"))
  1. ;If the BAD ADDRESS INDICATOR from LST is NOT null,
  1. ;delete the PERMANENT ADDRESS data elements
  1. I LSTBAI'="" D
  1. . N FIELD
  1. . F FIELD=.1112,.111:.001:.119,.12,.121 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. RDOC(DGDATA,DFN,LSTDFN) ;RECENT DATE(S) OF CARE
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; DFN - Pointer to the PATIENT (#2) file
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. N LSTRCP ;LST RECEIVED VA CARE PREVIOUSLY?
  1. N LSTLOC1 ;LST MOST RECENT LOCATION OF CARE
  1. S LSTRCP=$G(@DGDATA@(2,LSTDFN_",",1010.15,"E"))
  1. S LSTLOC1=$G(@DGDATA@(2,LSTDFN_",",1010.152,"E"))
  1. ;
  1. ;If the RECEIVED VA CARE PREVIOUSLY? from LST is not YES,
  1. ; OR the MOST RECENT LOCATION OF CARE from LST is NULL,
  1. ;delete all the RDOC fields.
  1. I (LSTRCP'="YES")!(LSTLOC1="") D
  1. . N FIELD
  1. . F FIELD=1010.15,1010.151,1010.152,1010.153,1010.154 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q
  1. ;
  1. MSE(DGDATA,LSTDFN) ;MILITARY SERVICE EPISODES
  1. ; DGDATA - Data element array from LST, ^TMP("DGROFDA",$J)
  1. ; LSTDFN - Pointer to the patient data from the LST, in DGDATA
  1. ;
  1. ;If new format MSE data exists from last site visited then do
  1. ;NOT load old format MSE data.
  1. ;
  1. I $D(@DGDATA@(2.3216)) D
  1. .N FIELD
  1. .F FIELD=.324,.325,.326,.327,.328,.3285,.329,.3291,.32911,.32912,.32913,.3292,.3293,.3294,.32945,.3295,.3296,.3297,.3298,.3299 K @DGDATA@(2,LSTDFN_",",FIELD)
  1. Q