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

IBCMDT2.m

Go to the documentation of this file.
  1. IBCMDT2 ;ALB/VD - INSURANCE PLANS MISSING DATA REPORT (COMPILE) ; 10-APR-15
  1. ;;2.0;INTEGRATED BILLING ;**549**; 10-APR-15;Build 54
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. EN ; Queued Entry Point for Report.
  1. ; Required variable input: FLTRS,IBAI, IBAPL, IBGRN, IBPTY, IBTFT, IBEPT,
  1. ; IBCLM, IBBIN, IBNMSPC,IBPCN
  1. ; ^TMP("IBCMDT",IBNMSPC) required if all companies and plans not selected
  1. ;
  1. ; - compile report data
  1. N IBI,IBIC1,IBCNS
  1. S IBI=0 K ^TMP($J,"PR")
  1. S IBIC1=""
  1. F S IBIC1=$O(^TMP("IBCMDT",IBNMSPC,IBIC1)) Q:IBIC1="" D
  1. . S IBCNS=0
  1. . F S IBCNS=$O(^TMP("IBCMDT",IBNMSPC,IBIC1,IBCNS)) Q:'IBCNS D
  1. . . D GATH
  1. Q
  1. ;
  1. GATH ; Gather all data for a company.
  1. N IBCPS,IBCPT,IBCST
  1. S IBI=IBI+1,(IBCPT,IBCPS,IBCST)=0 ; initialize counters
  1. D PLAN ; gather plan info
  1. ;
  1. ; - set final company info
  1. S ^TMP($J,"PR",IBI)=$$COMPINF(IBCNS)_"^"_IBCPT_"^"_IBCPS
  1. Q
  1. ;
  1. PLAN ; Gather Insurance Plan information, if necessary
  1. ; Input: IBCNS -- Pointer to the insurance company in file #36
  1. ; initialized counters, plus the 'Plan' array (^TMP("IBINC",$J))
  1. ;
  1. N FNDONE,IBPTR,PLNDATA,POSWT
  1. S IBPTR=0
  1. S POSWT=$S($$GET1^DIQ(36,IBCNS,.13)="PRESCRIPTION ONLY":1,1:0)
  1. F S IBPTR=$O(^IBA(355.3,"B",IBCNS,IBPTR)) Q:'IBPTR D
  1. . S PLNDATA=$$PLANINF(IBPTR,POSWT)
  1. . Q:(+PLNDATA=-2) ; Skip inactive plans.
  1. . ;
  1. . ; If there's no Missing Plan Data & not looking for coverage limitations.
  1. . I (+PLNDATA=-1),'+$G(IBMDTSPC("IBCLM")) Q
  1. . S ^TMP($J,"PR",IBI,IBPTR)=PLNDATA
  1. . I +$G(IBMDTSPC("IBCLM")) D
  1. . . S FNDONE=+$$GCVLIMS(IBI,IBPTR,1) ; This will create the cov. limit. nodes
  1. . . ;
  1. . . ; No missing coverage limitations AND no other missing data on requested
  1. . . ; Filters found, kill reference to the plan.
  1. . . I '+FNDONE,+PLNDATA=-1 K ^TMP($J,"PR",IBI,IBPTR)
  1. Q
  1. ;
  1. COMPINF(IBCNS) ; Return formatted Insurance Company information
  1. ; Input: IBCNS -- Pointer to the insurance company in file #36
  1. ; Output: company name ^ addr ^ city/st/zip
  1. ;
  1. N POSWT,ST,X
  1. S POSWT=$S($$GET1^DIQ(36,IBCNS,.13)="PRESCRIPTION ONLY":1,1:0)
  1. S ST=$P($G(^DIC(5,+$$GET1^DIQ(36,IBCNS,.115,"I"),0)),U,2)
  1. S X=POSWT_U_$$GET1^DIQ(36,IBCNS,.01)_U_$$GET1^DIQ(36,IBCNS,.111)
  1. S X=X_U_$$GET1^DIQ(36,IBCNS,.114)_", "_ST_" "_$$GET1^DIQ(36,IBCNS,.116)
  1. Q X
  1. ;
  1. PLANINF(PLAN,POSWT) ; Return formatted Insurance Plan information.
  1. ; Input: PLAN - Pointer to the plan in file #355.3
  1. ; POSWT - PRESCRIPTION ONLY indicator
  1. ; Returns: A1^A2^A3^...^A8 Where
  1. ; A1 - -2 if inactive plan, -1 if no missing data found, else 0
  1. ; A2 - Plan Number
  1. ; A3 - Plan Name
  1. ; A4 - Type of Plan (Group or Individual
  1. ; A5 - Electronic Plan Type
  1. ; A6 - Timely filing Time Frame
  1. ; A7 - Banking Identification Number
  1. ; A8 - Process Control Number
  1. ;
  1. N BIN,EPT,NAME,NUM,PCN,TFTF,TYP,VAL
  1. S VAL=-2
  1. I +$$GET1^DIQ(355.3,+PLAN,.11,"I") Q VAL ; INACTIVE Plan, skip
  1. S VAL=-1
  1. S NAME=$E($$GET1^DIQ(355.3,+PLAN,.03),1,45) ; 45 Chars max
  1. S NUM=$$GET1^DIQ(355.3,+PLAN,.04) ; 17 Chars max
  1. S:'$L(NUM) NUM="#######"
  1. I +$G(IBMDTSPC("IBGRN")),NUM="#######" S VAL=0 ; Found Missing data for a Filter
  1. S TYP=$$GET1^DIQ(355.3,+PLAN,.09) ; 40 Chars max
  1. S:'$L(TYP) TYP="#######"
  1. I +$G(IBMDTSPC("IBPTY")),TYP="#######" S VAL=0 ; Found Missing data for a Filter
  1. S EPT=$$GET1^DIQ(355.3,+PLAN,.15) ; 26 Chars max
  1. S:'$L(EPT) EPT="#######"
  1. I +$G(IBMDTSPC("IBEPT")),EPT="#######" S VAL=0 ; Found Missing data for a Filter
  1. S TFTF=$$FTFGP^IBCNEUT7(PLAN,1) ; Around 30 Chars max
  1. I +$G(IBMDTSPC("IBTFT")),TFTF["###" S VAL=0 ; Found Missing data for a Filter
  1. S BIN=$$GET1^DIQ(355.3,+PLAN,6.02) ; 10 Chars max
  1. ;
  1. ; If the plan is Prescription Only AND the Banking Identifier is blank, indicate it
  1. I +POSWT,'$L(BIN) S BIN="#######"
  1. I +$G(IBMDTSPC("IBBIN")),+POSWT,BIN="#######" S VAL=0 ; Found Missing data for a Filter
  1. S PCN=$$GET1^DIQ(355.3,+PLAN,6.03) ; 20 Chars max
  1. ;
  1. ; If the plan is Prescription Only AND the Process Control Number is blank, indicate it
  1. I +POSWT,'$L(PCN) S PCN="#######"
  1. I +$G(IBMDTSPC("IBPCN")),+POSWT,PCN="#######" S VAL=0 ; Found Missing data for a Filter
  1. Q VAL_U_NUM_U_$E(NAME,1,12)_U_$E(TYP,1,12)_U_$E(EPT,1,12)_U_TFTF_U_BIN_U_PCN
  1. ;
  1. GCVLIMS(IBI,PLAN,RECIND) ; Obtain Plans that may have Coverage Limits missing.
  1. ; Input: IBI -- Line counter
  1. ; IBCNS -- Pointer to the insurance company in file #36
  1. ; RECIND -- Indicator to determine if header record for plan is already set
  1. ; 0 means ^TMP($J,"PR",IBI,IBPTR) is already set.
  1. ; 1 means ^TMP($J,"PR",IBI,IBPTR) is not set yet.
  1. ; Output: This will create the ^TMP($J,"PR",IBI,IBPTR,IBCVLM) node
  1. ; FOUND -- 0 means a missing data coverage limitation was not found.
  1. ; 1 means a missing data coverage limitation was found.
  1. ;
  1. N FOUND,IBCAT,IBCOV,IBCPTR,IBCSTA,IBCVDAT,IBEFDT,IBRECDT,IBRECN,IBREC,VAL
  1. S (FOUND,IBCPTR)=0
  1. I '$D(^IBA(355.32,"APCD",PLAN)) D Q +FOUND
  1. . I '+$G(IBMDTSPC("IBCLM")) Q
  1. . S FOUND=1,IBCPTR=IBCPTR+1
  1. . S ^TMP($J,"PR",IBI,IBPTR,IBCPTR)="This plan has no coverage limitations defined."
  1. S IBCAT=0
  1. F S IBCAT=$O(^IBE(355.31,IBCAT)) Q:'+IBCAT D
  1. . I '$D(^IBA(355.32,"APCD",PLAN,IBCAT)) D Q
  1. . . S IBCOV=$$GET1^DIQ(355.31,IBCAT,.01)
  1. . . S IBEFDT="#######",IBCSTA="#######"
  1. . . S IBCVDAT=IBCOV_U_IBEFDT_U_IBCSTA,FOUND=1
  1. . . S IBCPTR=IBCPTR+1
  1. . . S ^TMP($J,"PR",IBI,IBPTR,IBCPTR)=IBCVDAT
  1. F S IBCAT=$O(^IBA(355.32,"APCD",PLAN,IBCAT)) Q:IBCAT="" D
  1. . S IBRECDT=""
  1. . F S IBRECDT=$O(^IBA(355.32,"APCD",PLAN,IBCAT,IBRECDT)) Q:IBRECDT="" D
  1. . . S IBRECN=""
  1. . . F S IBRECN=$O(^IBA(355.32,"APCD",PLAN,IBCAT,IBRECDT,IBRECN)) Q:IBRECN="" D
  1. . . . S IBEFDT=$$DAT1^IBOUTL($$GET1^DIQ(355.32,IBRECN,.03,"I"))
  1. . . . I +$G(IBMDTSPC("IBCLM")) S IBEFDT=$S(+$L(IBEFDT):IBEFDT,1:"#######") ; Effective Date
  1. . . . S IBCOV=$$GET1^DIQ(355.32,IBRECN,.02)
  1. . . . I +$G(IBMDTSPC("IBCLM")) S IBCOV=$S(+$L(IBCOV):IBCOV,1:"#######") ; Coverage Category
  1. . . . S IBCSTA=$$GET1^DIQ(355.32,IBRECN,.04)
  1. . . . I +$G(IBMDTSPC("IBCLM")) S IBCSTA=$S(+$L(IBCSTA):IBCSTA,1:"#######") ; Coverage Status
  1. . . . S IBCVDAT=IBCOV_U_IBEFDT_U_IBCSTA
  1. . . . I IBCVDAT["#######" S FOUND=1
  1. . . . S IBCPTR=IBCPTR+1
  1. . . . I +FOUND S ^TMP($J,"PR",IBI,IBPTR,IBCPTR)=IBCVDAT
  1. Q +FOUND
  1. ;