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

IVM273A.m

Go to the documentation of this file.
  1. IVM273A ;ALB/PDJ IVM*2.0*73 - CLEANUP IVM PATIENT FILE;02/07/2003
  1. ;;2.0;INCOME VERIFICATION MATCH;**73**; 21-OCT-94
  1. ;
  1. EN N DFN,I,R3015,SEG,TEXT,TYPE,X,X1,X2,%,XTPAT,IVMPH,IVMAD
  1. ;
  1. D BMES^XPDUTL(" ")
  1. D BMES^XPDUTL(" The Post Install will now process through the IVM PATIENT")
  1. D BMES^XPDUTL(" FILE to remove entries which do not contain any uploadable")
  1. D BMES^XPDUTL(" or non-uploadable fields.")
  1. D BMES^XPDUTL(" ")
  1. ;
  1. I $D(XPDNM) D
  1. . I $$VERCP^XPDUTL("R3015")'>0 D
  1. . . S %=$$NEWCP^XPDUTL("R3015","","0")
  1. ;
  1. F I="PATREC" D
  1. . I $D(^XTMP("IVM*2.0*73-"_I)) Q
  1. . S X1=DT
  1. . S X2=30
  1. . D C^%DTC
  1. . S TEXT=X_"^"_$$DT^XLFDT_"^IVM*2.0*73 POST-INSTALL "
  1. . S TEXT=TEXT_$S(I="PATREC":"IVM Patient Records",1:"filing errors")
  1. . S ^XTMP("IVM*2.0*73-"_I,0)=TEXT
  1. ;
  1. S XTPAT="IVM*2.0*73-PATREC"
  1. ;
  1. I '$D(XPDNM) D
  1. . S ^XTMP(XTPAT,1)=0
  1. I $D(XPDNM)&'$D(^XTMP(XTPAT,1)) S ^XTMP(XTPAT,1)=0
  1. I $D(XPDNM) S %=$$VERCP^XPDUTL("R3015")
  1. I $G(%)="" S %=0
  1. I %=0 D EN1
  1. Q
  1. ;
  1. EN1 I '$D(XPDNM) S R3015=0
  1. I $D(XPDNM) S R3015=$$PARCP^XPDUTL("R3015")
  1. F S R3015=$O(^IVM(301.5,R3015)) Q:'R3015 D
  1. . S SEG="B"
  1. . F S SEG=$O(^IVM(301.5,R3015,"IN",SEG),-1) Q:'SEG D
  1. . . S (IVMAD,IVMPH)=0
  1. . . S DFN=+$P($G(^IVM(301.5,R3015,0)),U,1) Q:'DFN
  1. . . S TYPE=$P($G(^IVM(301.5,R3015,"IN",SEG,0)),U,2) Q:TYPE'="PID"
  1. . . D CHKREC
  1. . . S TYPE=$P($G(^IVM(301.5,R3015,"IN",SEG,0)),U,2)
  1. . . I TYPE="" D PROCREC
  1. . I $D(XPDNM) S %=$$UPCP^XPDUTL("R3015",R3015)
  1. ;
  1. D MAIL^IVM273M
  1. I $D(XPDNM) S %=$$COMCP^XPDUTL("R3015")
  1. D BMES^XPDUTL(" Cleanup of IVM PATIENT file is complete.")
  1. Q
  1. ;
  1. CHKREC ; Check Demographic fields
  1. N DEMO,DATA0,FLDLOC,IVMDATA,PATPH,PH
  1. S DEMO=0
  1. F S DEMO=$O(^IVM(301.5,R3015,"IN",SEG,"DEM",DEMO)) Q:'DEMO D
  1. . S DATA0=$G(^IVM(301.5,R3015,"IN",SEG,"DEM",DEMO,0)) Q:DATA0=""
  1. . S FLDLOC=$P(DATA0,"^",1),IVMDATA=$P(DATA0,"^",2)
  1. . I IVMDATA="" D Q
  1. . . ; only process address fields
  1. . . I '$D(^IVM(301.92,"AD",FLDLOC)) Q
  1. . . S IVMAD=1 D DELFLD
  1. . I FLDLOC=11 D
  1. . . S PATPH=$$CONVPH^IVMPREC8($P($G(^DPT(DFN,.13)),"^",1))
  1. . . S PH=$$CONVPH^IVMPREC8(IVMDATA)
  1. . . ; quit if the phone numbers are the same, otherwise delete
  1. . . ; the field from the IVM PATIENT file
  1. . . I PATPH'=PH Q
  1. . . S IVMPH=1 D DELFLD
  1. ; If no uploadable and no non-uploadable fields delete then entry
  1. I '$$DEMO^IVMLDEM5(R3015,SEG,0),'$$DEMO^IVMLDEM5(R3015,SEG,1) D
  1. . D DELETE^IVMLDEM5(R3015,SEG,"NAME,DUMMY")
  1. Q
  1. ;
  1. DELFLD ; Delete null field
  1. N DA,DIE,DR
  1. S DA=DEMO,DA(1)=SEG,DA(2)=R3015
  1. S DIE="^IVM(301.5,"_DA(2)_",""IN"","_DA(1)_",""DEM"","
  1. S DR=".01////@" D ^DIE
  1. Q
  1. ;
  1. PROCREC ; Save processed records to the XTMP file
  1. N DATA,NAME,SSN
  1. S DATA=$G(^DPT(DFN,0)) Q:DATA=""
  1. S NAME=$P(DATA,"^",1)
  1. S SSN=$P(DATA,"^",9)
  1. ;
  1. ; Only count the record once even if more than one entry was
  1. ; updated.
  1. ;
  1. I '$D(^XTMP(XTPAT,"RECS",DFN)) S ^XTMP(XTPAT,1)=$G(^XTMP(XTPAT,1))+1
  1. S ^XTMP(XTPAT,"RECS",DFN)=R3015_U_NAME_U_SSN
  1. I IVMAD S $P(^XTMP(XTPAT,"RECS",DFN),U,4)=1
  1. I IVMPH S $P(^XTMP(XTPAT,"RECS",DFN),U,5)=1
  1. Q
  1. ;
  1. CLEANUP ; Used to cleanup XTMP global for testing only
  1. S XTPAT="IVM*2.0*73-PATREC"
  1. ;
  1. K ^XTMP(XTPAT)
  1. Q