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

EASEC100.m

Go to the documentation of this file.
  1. EASEC100 ;ALB/BRM,LBD - Print 1010EC LTC Enrollment form ; 3/1/02 8:22am
  1. ;;1.0;ENROLLMENT APPLICATION SYSTEM;**5,7,16,40,45**;Mar 15, 2001
  1. ;
  1. ; This routine is called by EASEC10E to gather veteran data to be
  1. ; printed in the 1010EC (Long Term Care) form.
  1. ;
  1. GETDATA(EASDFN,EAINFO) ;get veterans LTC data to be printed
  1. ;Input:
  1. ; EASDFN - DFN for the Patient file (#2)
  1. ;Output:
  1. ; ^TMP("1010EC",$J
  1. ;
  1. N EASROOT,DGINC,DGINR,DGREL,DGDEP
  1. S EASROOT="^TMP(""1010EC"",$J,"_EASDFN_","
  1. ; data for section 1
  1. D DATA1(EASDFN,.EAINFO,EASROOT)
  1. ; data for section 2
  1. D DATA2(EASDFN,EASROOT)
  1. ; data for section 3
  1. D DATA3(EASDFN,.EAINFO,EASROOT,.DGINC)
  1. ; data for section 4 and part of section 5
  1. D DATA4(EASDFN,EASROOT,.DGINC)
  1. ; data for section 5
  1. D DATA5(EASDFN,EASROOT,.DGINC)
  1. ; data for section 6
  1. D DATA6(EASDFN,EASROOT,.DGINC)
  1. ; data for section 8
  1. D DATA8(EASROOT,.EAINFO)
  1. Q
  1. ;
  1. DATA1(EASDFN,EAINFO,EASROOT) ;data for section 1
  1. N EASINS,INSTMP,MDATA,EASROOT1,MPA,MPB,MPADT,MPBDT,MCN
  1. S EASROOT1=EASROOT_"1)"
  1. S @EASROOT1@(1)=$G(EAINFO("VET")) ;name
  1. S @EASROOT1@(2)=$G(EAINFO("SSN")) ;ssn
  1. S @EASROOT1@(3)=$$GET1^DIQ(2,EASDFN_",",".381","E") ;medicaid
  1. ; ** determine medicare info
  1. S EASINS=0,(MPA,MPB)="NO",(MPADT,MPBDT,MCN)=""
  1. N EAX,INSUR
  1. I $$INSUR^IBBAPI(EASDFN,,"RA",.EAX,"*") ; Retrieve all active insurance
  1. I $D(EAX) D
  1. . M INSUR=EAX("IBBAPI","INSUR")
  1. . S EASINS=0
  1. . F S EASINS=$O(INSUR(EASINS)) Q:'EASINS D
  1. . . Q:$P(INSUR(EASINS,1),U,2)'["MEDICARE (WNR)" ; Look for MEDICARE insurance
  1. . . I $P(INSUR(EASINS,8),U,2)="PART A" S MPA="YES",MPADT=$$FMTE^XLFDT(INSUR(EASINS,10)),MCN=INSUR(EASINS,14) Q ; If Policy Name is "PART A", set the Part A variables
  1. . . I $P(INSUR(EASINS,8),U,2)="PART B" S MPB="YES",MPBDT=$$FMTE^XLFDT(INSUR(EASINS,10)),MCN=INSUR(EASINS,14) Q ; If Policy Name is "PART B", set the Part B variables
  1. S @EASROOT1@(4)=MPA ;medicare part a
  1. S @EASROOT1@(5)=MPADT ;medicare part a effective date
  1. S @EASROOT1@(6)=MPB ;medicare part b
  1. S @EASROOT1@(7)=MPBDT ;medicare part b effective date
  1. S @EASROOT1@(8)=MCN ;medicare claim number
  1. Q
  1. DATA2(EASDFN,EASROOT) ;data for section 2
  1. N EASI,EASINS,X,Z,EASROOT2,EASINS,CNT,NUM,EASIN1I,GRPIEN,INSUR,DGX
  1. S EASROOT2=EASROOT_"2)"
  1. S @EASROOT2@(1)=$$GET1^DIQ(2,EASDFN_",",".3192","E") ;covered by ins
  1. ; Set up array by defining "null" palce holders
  1. F X=2:1:22 S @EASROOT2@(X)=""
  1. F I=3,10,17 F Z=.111:.001:.116 S @EASROOT2@(I,Z)=""
  1. ;
  1. S EASI=0,CNT=2
  1. I $$INSUR^IBBAPI(EASDFN,"","ARB",.DGX,"*") ; Call Insurance API for data
  1. M INSUR=DGX("IBBAPI","INSUR") ; Reformat insurance array into more friendly format
  1. F S EASI=$O(INSUR(EASI)) Q:'EASI!(CNT>16) D ; Print out only first 3 entries found.
  1. . S @EASROOT2@(CNT+3)=$G(INSUR(EASI,13)) ; SUBSCRIBER NAME
  1. . S @EASROOT2@(CNT+4)=$P($G(INSUR(EASI,19)),U,2) ;relationship
  1. . S @EASROOT2@(CNT+5)=$G(INSUR(EASI,14)) ;policy # (SUBSCRIBER ID)
  1. . S @EASROOT2@(CNT+6)=$P($G(INSUR(EASI,8)),U,2) ; GROUP NAME
  1. .; Set Insurance Company Information
  1. . S @EASROOT2@(CNT)=$P($G(INSUR(EASI,1)),U,2) ; Insurance Co. Name
  1. . S @EASROOT2@(CNT+2)=$G(INSUR(EASI,6)) ; ins. phone
  1. . S @EASROOT2@((CNT+1),.111)=$G(INSUR(EASI,2)) ; INS. ADDRESS
  1. . S @EASROOT2@((CNT+1),.114)=$G(INSUR(EASI,3)) ; INS. CITY
  1. . S @EASROOT2@((CNT+1),.115)=$P($G(INSUR(EASI,4)),U,2) ; INS. STATE
  1. . S @EASROOT2@((CNT+1),.116)=$G(INSUR(EASI,5)) ; INS. ZIP
  1. .S CNT=CNT+7
  1. Q
  1. INSDAT(EASINS,CNT) ;obtain insurance information from the insurance file (#36)
  1. Q:'EASINS
  1. N X,INSDAT,ERR
  1. D GETS^DIQ(36,EASINS_",",".01;.111:.116;.131","E","INSDAT","ERR")
  1. Q:$D(ERR)
  1. S @EASROOT2@(CNT)=$G(INSDAT(36,EASINS_",",.01,"E")) ;insurance name
  1. F X=.111:.001:.116 S @EASROOT2@((CNT+1),X)=$G(INSDAT(36,EASINS_",",X,"E")) ;insurance address
  1. S @EASROOT2@(CNT+2)=$G(INSDAT(36,EASINS_",",.131,"E")) ;ins. phone
  1. Q
  1. DATA3(EASDFN,EAINFO,EASROOT,DGINC) ;data for section 3
  1. N INFO13,DEP1,DEP,X,I,EASROOT3,SSN
  1. S EASROOT3=EASROOT_"3)"
  1. F X=0:1:11 S @EASROOT3@(X)=""
  1. D ALL^EASECU21(EASDFN,"SCV",EAINFO("MTDT"),"IPR",$G(EAINFO("DGMTIEN")))
  1. ;Marital Status added for LTC Phase IV (EAS*1*40)
  1. S @EASROOT3@(0)=$$GET1^DIQ(2,EASDFN,".05","E")
  1. S:$$GET1^DIQ(408.22,+$G(DGINR("V")),".17","I") @EASROOT3@(0)="LEGALLY SEPARATED"
  1. D:$D(DGREL("S"))
  1. .S INFO13=$G(^DGPR(408.13,+$P(DGREL("S"),"^",2),0))
  1. .S @EASROOT3@(1)=$P(INFO13,"^") ;Spouse Name
  1. .S SSN=$P(INFO13,"^",9) ;Spouse SSN
  1. .S @EASROOT3@(3)=$E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,9)
  1. .S:$G(DGINR("V")) @EASROOT3@(2)=$$GET1^DIQ(408.22,DGINR("V"),".16","E") ;Spouse Residing in the Community?
  1. Q:'$D(DGREL("C"))
  1. S DEP=""
  1. F S DEP=$O(DGREL("C",DEP)) Q:'DEP!(DEP>2) D
  1. .Q:'$D(^DGPR(408.13,+$P(DGREL("C",DEP),"^",2),0))
  1. .S INFO13=$G(^DGPR(408.13,+$P(DGREL("C",DEP),"^",2),0))
  1. .S DEP1=$S(DEP=1:4,DEP=2:8)
  1. .S @EASROOT3@(DEP1)=$P(INFO13,"^") ;Dependent Name
  1. .S @EASROOT3@(DEP1+1)=$$FMTE^XLFDT($P(INFO13,"^",3)) ;Dependent DOB
  1. .S SSN=$P(INFO13,"^",9) ;Dependent SSN
  1. .S @EASROOT3@(DEP1+2)=$E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,9)
  1. .S:$G(DGINR("C",DEP)) @EASROOT3@(DEP1+3)=$$GET1^DIQ(408.22,DGINR("C",DEP),".16","E") ;Dependent Living in Community?
  1. Q
  1. DATA4(EASDFN,EASROOT,DGINC) ;data for section 4 and the first part of 5
  1. N EASROOT4,EASROOT5,ASSETV,ASSETS,NUM,X,ASSETRT,IENS,I
  1. S EASROOT4=EASROOT_"4)"
  1. S EASROOT5=EASROOT_"5)"
  1. ;Add subscripts to array to store assets for spouse (needed for new
  1. ;10-10EC form). LTC Phase IV (EAS*1*40)
  1. F I=1:.5:4.5 S @EASROOT4@(I)=""
  1. F I=1:.5:5.5 S @EASROOT5@(I)=""
  1. F X="V","S" Q:'$D(DGINC(X)) D
  1. .D GETS^DIQ(408.21,+DGINC(X),"2.01;2.02;2.06:2.09","I","ASSET"_X)
  1. .S NUM=$S(X="V":1,1:1.5)
  1. .S IENS=+DGINC(X)_","
  1. .S ASSETRT="ASSET"_X_"(408.21,"_""""_IENS_""""_","
  1. .;Fixed Assets
  1. .S @EASROOT4@(NUM)=+$G(@(ASSETRT_"2.06,""I"")")) ;Residence
  1. .S @EASROOT4@(NUM+1)=+$G(@(ASSETRT_"2.07,""I"")")) ;Land/Farm
  1. .S @EASROOT4@(NUM+2)=+$G(@(ASSETRT_"2.08,""I"")")) ;Vehicles
  1. .;Liquid Assets
  1. .S @EASROOT5@(NUM)=+$G(@(ASSETRT_"2.01,""I"")")) ;Cash
  1. .S @EASROOT5@(NUM+1)=+$G(@(ASSETRT_"2.02,""I"")")) ;Stocks
  1. .S @EASROOT5@(NUM+2)=+$G(@(ASSETRT_"2.09,""I"")")) ;Other
  1. .;Subtotals
  1. .F I=NUM:1:(NUM+2) S @EASROOT4@(NUM+3)=@EASROOT4@(NUM+3)+@EASROOT4@(I),@EASROOT5@(NUM+3)=@EASROOT5@(NUM+3)+@EASROOT5@(I) ;Sub-totals
  1. S @EASROOT5@(5)=@EASROOT4@(4)+@EASROOT5@(4) ;Total Assets Vet
  1. S @EASROOT5@(5.5)=@EASROOT4@(4.5)+@EASROOT5@(4.5) ;Total Assets Spouse
  1. Q
  1. DATA5(EASDFN,EASROOT,DGINC) ;data for section 5 (the rest of it)
  1. N EASROOT5,ASSETV,ASSETS,NUM,X,ASSETRT,IENS,I
  1. S EASROOT5=EASROOT_"5)"
  1. F I=6:1:35 S @EASROOT5@(I)=""
  1. F X="V","S" Q:'$D(DGINC(X)) D ;
  1. .D GETS^DIQ(408.21,+DGINC(X),".06:.2","I","ASSET"_X)
  1. .S NUM=$S(X="V":6,X="S":7)
  1. .S IENS=+DGINC(X)_","
  1. .S ASSETRT="ASSET"_X_"(408.21,"_""""_IENS_""""_","
  1. .S @EASROOT5@(NUM)=+$G(@(ASSETRT_".14,""I"")")) ;Gross Income
  1. .S @EASROOT5@(NUM+2)=+$G(@(ASSETRT_".08,""I"")")) ;Soc. Security
  1. .S @EASROOT5@(NUM+4)=+$G(@(ASSETRT_".15,""I"")")) ;Interest/Div
  1. .S @EASROOT5@(NUM+6)=+$G(@(ASSETRT_".06,""I"")")) ;Retire/Pension
  1. .S @EASROOT5@(NUM+8)=+$G(@(ASSETRT_".09,""I"")")) ;Civil Service
  1. .S @EASROOT5@(NUM+10)=+$G(@(ASSETRT_".1,""I"")")) ;US Railroad
  1. .S @EASROOT5@(NUM+12)=+$G(@(ASSETRT_".07,""I"")")) ;VA Pension
  1. .S @EASROOT5@(NUM+14)=+$G(@(ASSETRT_".19,""I"")")) ;Spouse Disab
  1. .S @EASROOT5@(NUM+16)=+$G(@(ASSETRT_".12,""I"")")) ;Unemployment
  1. .S @EASROOT5@(NUM+18)=+$G(@(ASSETRT_".16,""I"")")) ;Workers Comp,etc
  1. .S @EASROOT5@(NUM+20)=+$G(@(ASSETRT_".11,""I"")")) ;Military Retire
  1. .S @EASROOT5@(NUM+22)=+$G(@(ASSETRT_".13,""I"")")) ;Other Retire
  1. .S @EASROOT5@(NUM+24)=+$G(@(ASSETRT_".2,""I"")")) ;Court Mandated
  1. .S @EASROOT5@(NUM+26)=+$G(@(ASSETRT_".17,""I"")")) ;Other Income
  1. .F I=NUM:2:NUM+26 S @EASROOT5@(NUM+28)=@EASROOT5@(NUM+28)+@EASROOT5@(I) ;Total Income
  1. Q
  1. DATA6(EASDFN,EASROOT,DGINC) ;
  1. N IENS,EXPRT,EASROOT6,EXPENSE
  1. S EASROOT6=EASROOT_"6)"
  1. F I=1:1:11 S @EASROOT6@(I)=""
  1. Q:'$G(DGINC("V"))
  1. D GETS^DIQ(408.21,+DGINC("V"),"1.01:1.1","I","EXPENSE")
  1. S IENS=+DGINC("V")_","
  1. S EXPRT="EXPENSE(408.21,"_""""_IENS_""""_","
  1. S @EASROOT6@(1)=+$G(@(EXPRT_"1.03,""I"")")) ;Education
  1. S @EASROOT6@(2)=+$G(@(EXPRT_"1.02,""I"")")) ;Funeral and Burial
  1. S @EASROOT6@(3)=+$G(@(EXPRT_"1.04,""I"")")) ;Rent/Mortgage
  1. S @EASROOT6@(4)=+$G(@(EXPRT_"1.05,""I"")")) ;Utilities
  1. S @EASROOT6@(5)=+$G(@(EXPRT_"1.06,""I"")")) ;Car Payment
  1. S @EASROOT6@(6)=+$G(@(EXPRT_"1.07,""I"")")) ;Food
  1. S @EASROOT6@(7)=+$G(@(EXPRT_"1.01,""I"")")) ;Medical Expenses
  1. S @EASROOT6@(8)=+$G(@(EXPRT_"1.08,""I"")")) ;Court-Ordered Payments
  1. S @EASROOT6@(9)=+$G(@(EXPRT_"1.09,""I"")")) ;Insurance
  1. S @EASROOT6@(10)=+$G(@(EXPRT_"1.1,""I"")")) ;Taxes (Income, etc)
  1. F I=1:1:10 S @EASROOT6@(11)=@EASROOT6@(11)+@EASROOT6@(I) ;Total Expenses
  1. Q
  1. DATA8(EASROOT,EAINFO) ;get the word processing field for section 8
  1. N LINE,X,EASROOT8,IENS,WP
  1. S EASROOT8=EASROOT_"8)",LINE=0
  1. Q:'EAINFO("DGMTIEN")
  1. S IENS=EAINFO("DGMTIEN")_","
  1. S X=$$GET1^DIQ(408.31,IENS,50,"","WP")
  1. F S LINE=$O(WP(LINE)) Q:'LINE S @EASROOT8@(LINE)=$G(WP(LINE))
  1. Q