| 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 | ; | 
|---|