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

IBCNEDE7.m

Go to the documentation of this file.
IBCNEDE7 ;DAOU/DAC - eIV DATA EXTRACTS ; 04-JUN-2002
 ;;2.0;INTEGRATED BILLING;**271,416,438,497,601,621,668,702,737,771**;21-MAR-94;Build 26
 ;;Per VA Directive 6402, this routine should not be modified.
 ;
 Q    ; no direct calls allowed
 ; 
SETTINGS(EXTNUM) ; Check site parameter settings for the extracts
 ; IB*737/TAZ - Removed reference to Non-Verified which is being pulled from VistA.
 ; Input Parameter:
 ;
 ; IB*2.0*621/DM reimplement extract (#4), now EICD, formerly No Insurance   
 ; EXTNUM is either 1, 2, 4 to represent the different extracts
 ; 1 - Insurance Buffer extract
 ; 2 - Pre-Reg (appointments)
 ; 4 - EICD
 ;
 ; Output parameters:
 ; Returns a "^" delimited string passing back:
 ;    EACTIVE - A flag of whether to consider the extract active
 ;    XDAYS - Number of days to look back in the past when extracting data
 ;    MAXCNT - Max Number of entries you are allowed to set into the eIV 
 ;          Transmission Queue file.  If null, # of entries allowed is unlimited.
 ;    SUPPBUFF - Suppress Buffer Flag - Either '0' (No) or '1' (Yes)
 ;          1 will suppress the creation of buffer entries
 ;          0 will not
 ;          Applies to #2 (Appointment), and #4 (EICD) 
 ; 
 ;    For now, the next three parameters are only used by the EICD (#4) extract  
 ;    STARTDYS - number of days from today to form the extract's start date  
 ;    DYSAFTER - number of days added to the start date to form the extract's end date
 ;    FREQ - how long the extract must wait before an attempt to re-verify for the patient
 ;
 N DIC,DISYS,DA,X,Y,EACTIVE,XDAYS,MAXCNT,OK,SUPPBUFF
 N STARTDYS,DYSAFTER,FREQ
 S EACTIVE=0,(XDAYS,MAXCNT,SUPPBUFF,STARTDYS,DYSAFTER,FREQ)=""
 S OK=$S(EXTNUM=1:1,EXTNUM=2:1,EXTNUM=4:1,1:0)
 I 'OK G EXIT
 S DA=1,DIC="^IBE(350.9,"_DA_",51.17,",DIC(0)="X",X=EXTNUM D ^DIC
 ;
 I Y<1 G EXIT  ; extract not defined in the IB Site Parameter
 ;
 S EACTIVE=$G(^IBE(350.9,1,51.17,+Y,0))
 S XDAYS=$P(EACTIVE,U,3)
 S MAXCNT=$P(EACTIVE,U,5)
 S SUPPBUFF=$P(EACTIVE,U,6)
 S STARTDYS=$P(EACTIVE,U,7)
 S DYSAFTER=$P(EACTIVE,U,8)
 S FREQ=$P(EACTIVE,U,9)
 I SUPPBUFF="" S SUPPBUFF=0
 S EACTIVE=$P(EACTIVE,U,2)
EXIT ;
 I EXTNUM=2,(XDAYS="") S EACTIVE=0  ; missing required data
 I EXTNUM=4,((STARTDYS="")!(DYSAFTER="")!(FREQ="")) S EACTIVE=0  ; missing required data
 ; IB*737/TAZ 3RD Piece below is left blank on purpose.
 Q EACTIVE_U_XDAYS_U_U_MAXCNT_U_SUPPBUFF_U_STARTDYS_U_DYSAFTER_U_FREQ
 ;
SETTQ(DATA1,DATA2,ORIG,OVERRIDE,DATA5) ;Set extract data in TQ file 365.1
 ;
 ; DATA1, DATA2, ORIG & DATA5 are "^" delimited variables containing the data
 ; listed below
 ;
 ; OVERRIDE - flag indicates that this entry is a result of the 
 ;         'Request Re-Verification' menu option.
 ;
 ; IB*737/TAZ - Removed references to "~NO PAYER"
 ;
 N BUFFIEN,FDA,IENARRAY,ERROR,TRANSNO,DFN,SRVCODE
 S BUFFIEN=$P(DATA1,U,4),SRVCODE=0
 ;IB*2.0*621/DM make sure SRVCODE is populated
 S:BUFFIEN SRVCODE=+$$GET1^DIQ(355.33,BUFFIEN_",",80.01,"I") ; "INQ SERVICE TYPE CODE 1"
 S:'SRVCODE SRVCODE=+$$GET1^DIQ(350.9,"1,",60.01,"I")        ; "DEFAULT SERVICE TYPE CODE 1"
 S TRANSNO=$P($G(^IBCN(365.1,0)),U,3)+1
 S FDA(365.1,"+1,",.01)=TRANSNO             ; Transaction #
 ;
 S DFN=$P(DATA1,U)
 S FDA(365.1,"+1,",.02)=DFN                 ; patient DFN
 S FDA(365.1,"+1,",.03)=$P(DATA1,U,2)       ; ien of payer
 S FDA(365.1,"+1,",.04)=$P(DATA1,U,3)       ; ien of transmission status
 S FDA(365.1,"+1,",.15)=DT                  ; trans status date
 S FDA(365.1,"+1,",.05)=BUFFIEN             ; ien of buffer
 ;
 S FDA(365.1,"+1,",.06)=$$NOW^XLFDT         ; creation date/time
 S FDA(365.1,"+1,",.07)=0                   ; transmission retries
 S FDA(365.1,"+1,",.08)=0                   ; number of retries
 I $D(OVERRIDE) S FDA(365.1,"+1,",.14)=OVERRIDE  ; override flag
 S FDA(365.1,"+1,",.16)=$P(DATA1,U,5)        ; Sub. ID
 S FDA(365.1,"+1,",.17)=$P(DATA1,U,6)        ; Freshness Date
 S FDA(365.1,"+1,",.18)=$P(DATA1,U,7)        ; Pass Buffer ien?
 S FDA(365.1,"+1,",.19)=$P(DATA1,U,8)        ; Patient ID
 S FDA(365.1,"+1,",.2)=SRVCODE               ; Service code
 ;
 I $D(DATA2) D
 . S FDA(365.1,"+1,",.1)=$P(DATA2,U)          ; which extract (ien)
 . S FDA(365.1,"+1,",.11)=$P(DATA2,U,2)       ; query flag
 . S FDA(365.1,"+1,",.12)=$P(DATA2,U,3)       ; service date
 . S FDA(365.1,"+1,",.13)=$P(DATA2,U,4)       ; patient insur. ien
 ;
 I $D(ORIG) D
 . S FDA(365.1,"+1,",1.02)=$P(ORIG,U)     ; original ins co (in buffer)
 . S FDA(365.1,"+1,",1.03)=$P(ORIG,U,2)   ; grp number (in buffer or patient record) ;IB*771/CKB
 . S FDA(365.1,"+1,",1.04)=$P(ORIG,U,3)   ; grp name (in buffer or patient record) ;IB*771/CKB
 . S FDA(365.1,"+1,",1.05)=$P(ORIG,U,4)   ; original subscriber ID
 ;
 I $D(DATA5) D
 . S FDA(365.1,"+1,",3.02)=$P(DATA5,U)   ; source of information ien, IB*2*601/DM
 . S FDA(365.1,"+1,",.21)=$P(DATA5,U,2)  ; EICD INS-FND IEN, IB*2*621/DM 
 ;
 D UPDATE^DIE("","FDA","IENARRAY","ERROR")
 ;
 I $G(ERROR("DIERR",1,"TEXT",1))'="" D  ; MailMan msg
 . N MGRP,XMSUB,MSG
 . ;
 . ; Set to IB site parameter MAILGROUP
 . S MGRP=$$MGRP^IBCNEUT5()
 . ;
 . S XMSUB="eIV Problem: Trouble setting entry in File 365.1"
 . S MSG(1)="Tried to create an entry in the eIV Transmission Queue File #365.1 without"
 . S MSG(2)="success."
 . S MSG(3)=""
 . S MSG(4)="Error encountered: "_$G(ERROR("DIERR",1,"TEXT",1))
 . S MSG(5)=""
 . S MSG(6)="The data that was to be stored is as follows:"
 . S MSG(7)=""
 . S MSG(8)="Transaction #: "_TRANSNO
 . S MSG(9)="Patient: "_$P($G(^DPT(DFN,0)),U)_$$SSN^IBCNEDEQ(DFN)
 . S MSG(10)="Extract: "_$P($G(DATA2),U,1)
 . S MSG(11)="Payer: "
 . S:$P(DATA1,U,2)'="" MSG(11)=MSG(11)_$P($G(^IBE(365.12,$P(DATA1,U,2),0)),U,1)
 . S MSG(12)="Please call the Help Desk about this problem."
 . D MSG^IBCNEUT5(MGRP,XMSUB,"MSG(")
 ;
 Q $G(IENARRAY(1))
 ;
PYRACTV(PIEN) ; check if given payer is nationally enabled for eIV
 ; returns 1 if payer is nationally enabled, 0 otherwise
 ;IB*668/TAZ - Changed field names to enabled and Payer Application from IIV to EIV
 N APPIEN,RES
 S RES=0
 I +$G(PIEN)'>0 G PYRACTVX
 S APPIEN=$$PYRAPP^IBCNEUT5("EIV",PIEN)
 I +$G(APPIEN)'>0 G PYRACTVX
 I $P($G(^IBE(365.12,PIEN,1,APPIEN,0)),U,2)=1 S RES=1
PYRACTVX ;
 Q RES