| [613] | 1 | IVMLINS3 ;ALB/KCL - IVM INSURANCE POLICY TRANSFER ; 01-FEB-94
 | 
|---|
 | 2 |  ;;2.0;INCOME VERIFICATION MATCH;**14,111**; 21-OCT-94
 | 
|---|
 | 3 |  ;;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
 | 4 |  ;
 | 
|---|
 | 5 |  ;
 | 
|---|
 | 6 | TRANSFER(IVMAUTO) ; user has chosen to transfer insurance information,
 | 
|---|
 | 7 |  ; received from HEC, to the MCCR insurance buffer.  this routine
 | 
|---|
 | 8 |  ; will call $$ADDSTF^IBCNBES(3,DFN,IVMIBDAT) to place HEC's insurance
 | 
|---|
 | 9 |  ; information in the MCCR insurance buffer where authorized insurance
 | 
|---|
 | 10 |  ; personnel will either upload or reject the data.
 | 
|---|
 | 11 |  ;      3 indicates that source of information is IVM
 | 
|---|
 | 12 |  ;      IVMIBDAT = data, to be filed in the MCCR buffer, in an array
 | 
|---|
 | 13 |  ;                 subscripted by field number of the data field in
 | 
|---|
 | 14 |  ;                 the INSURANCE BUFFER file (#355.33) 
 | 
|---|
 | 15 |  ; INPUT: IVMAUTO = 1 if auto-filing directly from upload
 | 
|---|
 | 16 |  ;                  0 if using list manager interface to file
 | 
|---|
 | 17 |  ;        THE FOLLOWING ARE ASSUMED TO BE DEFINED:
 | 
|---|
 | 18 |  ;          IVMIN1 (ST/ST1 segment string nodes of file 301.5)
 | 
|---|
 | 19 |  ;          IVMADD (5th "^" piece of IVMIN1 for ins co address data)
 | 
|---|
 | 20 |  ;
 | 
|---|
 | 21 |  N IVMIB,IVMIBDAT,IVMNOI,IVMPRTI
 | 
|---|
 | 22 |  ;
 | 
|---|
 | 23 |  I '$G(IVMAUTO) W !!,"Transferring HEC'S insurance data to the MCCR insurance buffer",!
 | 
|---|
 | 24 |  S IVMNOI=$S($P(IVMIN1,HLFS,17)="v":$P($$PT^IVMUFNC4(DFN),"^"),1:$P(IVMIN1,HLFS,16))
 | 
|---|
 | 25 |  S IVMPRTI=$S($P(IVMIN1,HLFS,17)="v":"01",1:"02")
 | 
|---|
 | 26 |  ;
 | 
|---|
 | 27 |  S IVMIBDAT(20.01)=$E($P(IVMIN1,HLFS,4),1,30) ;ins co name
 | 
|---|
 | 28 |  S IVMIBDAT(20.02)=$E($P(IVMIN1,HLFS,7),1,20) ;phone number
 | 
|---|
 | 29 |  S IVMIBDAT(21.01)=$E($P(IVMADD,"~",1),1,35) ;street add [line 1]
 | 
|---|
 | 30 |  S IVMIBDAT(21.02)=$E($P(IVMADD,"~",2),1,30) ;street add [line 2]
 | 
|---|
 | 31 |  S IVMIBDAT(21.04)=$E($P(IVMADD,"~",3),1,25) ;city
 | 
|---|
 | 32 |  S IVMIBDAT(21.05)=$$STATE1^IVMUFNC4($P(IVMADD,"~",4)) ;state
 | 
|---|
 | 33 |  S IVMIBDAT(21.06)=$E($P(IVMADD,"~",5),1,20) ;zip
 | 
|---|
 | 34 |  S IVMIBDAT(40.02)=$E($P(IVMIN1,HLFS,9),1,20) ;group name
 | 
|---|
 | 35 |  S IVMIBDAT(40.03)=$E($P(IVMIN1,HLFS,8),1,17) ;group number
 | 
|---|
 | 36 |  S IVMIBDAT(40.05)=$S($P(IVMIN1,HLFS,28)=1:1,1:0) ;precertification required
 | 
|---|
 | 37 |  S IVMIBDAT(40.09)=$P(IVMIN1,HLFS,15) ;type of plan
 | 
|---|
 | 38 |  S IVMIBDAT(60.01)=DFN ;patient name
 | 
|---|
 | 39 |  S IVMIBDAT(60.02)=$$FMDATE^HLFNC($P(IVMIN1,HLFS,12)) ;effective date
 | 
|---|
 | 40 |  S IVMIBDAT(60.03)=$$FMDATE^HLFNC($P(IVMIN1,HLFS,13)) ;expiration date
 | 
|---|
 | 41 |  S IVMIBDAT(60.04)=$E($P(IVMIN1,HLFS,36),1,20) ;subcriber id
 | 
|---|
 | 42 |  S IVMIBDAT(60.05)=$P(IVMIN1,HLFS,17) ;whose insurance
 | 
|---|
 | 43 |  S IVMIBDAT(60.06)=IVMPRTI ;pt relationship to insured
 | 
|---|
 | 44 |  S IVMIBDAT(60.07)=IVMNOI ;name of insured
 | 
|---|
 | 45 |  ;
 | 
|---|
 | 46 |  S IVMIB=$$ADDSTF^IBCNBES(3,DFN,.IVMIBDAT)
 | 
|---|
 | 47 |  I 'IVMIB D  Q
 | 
|---|
 | 48 |  .Q:$G(IVMAUTO)
 | 
|---|
 | 49 |  .W !,"The following error occurred when transferring data:"
 | 
|---|
 | 50 |  .W !,$P(IVMIB,"^",2)
 | 
|---|
 | 51 |  .W !,"Please contact your IRM staff for help"
 | 
|---|
 | 52 |  ;
 | 
|---|
 | 53 |  N DA,DIE,DR
 | 
|---|
 | 54 |  S DA=IVMJ,DA(1)=IVMI
 | 
|---|
 | 55 |  ;
 | 
|---|
 | 56 |  ; - delete segment name (.02 field of 301.501 multiple) from IVM PATIENT
 | 
|---|
 | 57 |  ;   file to remove from ASEG cross-reference
 | 
|---|
 | 58 |  S DIE="^IVM(301.5,"_DA(1)_",""IN"",",DR=".02////@" D ^DIE
 | 
|---|
 | 59 |  ;
 | 
|---|
 | 60 |  I $G(IVMAUTO) G IVMQ
 | 
|---|
 | 61 |  ;
 | 
|---|
 | 62 |  W "completed.",!
 | 
|---|
 | 63 |  ;
 | 
|---|
 | 64 |  S DIR(0)="E",DIR("A")="Press RETURN to continue" D ^DIR K DIR
 | 
|---|
 | 65 |  ;
 | 
|---|
 | 66 | REMOVE ; - remove entry from the List Manager display after transferring
 | 
|---|
 | 67 |  K ^TMP("IVMIUPL",$J,IVMNAME,IVMI,IVMJ)
 | 
|---|
 | 68 |  ;
 | 
|---|
 | 69 |  ; - action completed
 | 
|---|
 | 70 |  S IVMDONE=1
 | 
|---|
 | 71 |  ;
 | 
|---|
 | 72 | IVMQ K DIRUT,DTOUT,DUOUT,IVMACT,IVMDA,IVMFLAG,IVMREPTR,X,Y
 | 
|---|
 | 73 |  Q
 | 
|---|
 | 74 |  ;
 | 
|---|
 | 75 | AUTO ; Auto-upload all Z04 entries pending in file 301.501
 | 
|---|
 | 76 |  ; Called by the patch IVM*2*111 post-install
 | 
|---|
 | 77 |  N DFN,IVMI,IVMJ,IVMIN1,IVMADD,IVM0NOD,HLFS
 | 
|---|
 | 78 |  S HLFS=U
 | 
|---|
 | 79 |  ;
 | 
|---|
 | 80 |  S IVMI=0 F  S IVMI=$O(^IVM(301.5,"ASEG","IN1",IVMI)) Q:'IVMI  D
 | 
|---|
 | 81 |  . S IVMJ=0 F  S IVMJ=$O(^IVM(301.5,"ASEG","IN1",IVMI,IVMJ)) Q:'IVMJ  D
 | 
|---|
 | 82 |  .. S IVM0NOD=$G(^IVM(301.5,IVMI,0)) I IVM0NOD']"" Q
 | 
|---|
 | 83 |  .. S DFN=+IVM0NOD
 | 
|---|
 | 84 |  .. I $G(^DPT(+DFN,0))']"" Q
 | 
|---|
 | 85 |  .. Q:$P($G(^IVM(301.5,IVMI,"IN",IVMJ,0)),U,2)'="IN1"
 | 
|---|
 | 86 |  .. S IVMIN1=$$GETIN1^IVMLINS1(IVMI,IVMJ)
 | 
|---|
 | 87 |  .. Q:IVMIN1=""
 | 
|---|
 | 88 |  .. S IVMADD=$P(IVMIN1,U,5)
 | 
|---|
 | 89 |  .. D TRANSFER(1)
 | 
|---|
 | 90 |  ;
 | 
|---|
 | 91 |  Q
 | 
|---|
 | 92 |  ;
 | 
|---|