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

IB20P555.m

Go to the documentation of this file.
  1. IB20P555 ;ALB/CXW - IB*2*555 POST INIT: DENTAL COST-BASED/INTERAGENCY RATE; 09/12/2015
  1. ;;2.0;INTEGRATED BILLING;**555**;21-MAR-94;Build 22
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. ;
  1. ; Add FY2015 Dental Cost Based and Interagency Charges to the Charge Master
  1. Q
  1. ;
  1. POST ;
  1. N IBEFFDT,IBA,U S U="^"
  1. D MSG(" IB*2.0*555 Post-Install .....")
  1. S IBEFFDT=3141104 ; effective date of 11/04/2014
  1. D ADDCI(IBEFFDT) ; add Charge Items (363.2) with new 2 dental rates
  1. D ADDRS
  1. D MSG(" IB*2*555 Post-Install Complete")
  1. Q
  1. ;
  1. ADDCI(IBEFFDT) ; Add Charge Items (363.2) needs Charge Sets, pass in the effective date of the new charges
  1. N IBCHG,IBCHZ,IBCNT,IBCNT1,IBCI,IBCS0,IBCS,IBDFLTDT,IBDT,IBFN,IBI,IBLN,IBRVCD,IBX,IBXRF,IBZ,DD,DO,DLAYGO,DIC,DIE,DA,DR,X,Y
  1. ;
  1. D MSG("")
  1. S (IBCNT,IBCNT1)=0,IBDFLTDT=+$G(IBEFFDT)
  1. I 'IBDFLTDT D MSG("** Error: No Effective Date, No Charges Added") G CIQ
  1. ;
  1. F IBI=1:1 S IBLN=$P($T(CIF+IBI),";;",2) Q:IBLN="QUIT" D SETCI
  1. ;
  1. CIQ D MSG(" >> "_IBCNT_" Dental for Cost Based/Interagency Charge Items added (#363.2)")
  1. D MSG("")
  1. Q
  1. ;
  1. SETCI ; set Charge Item (duplicates based on item, CS, eff dt, rev cd)
  1. ;
  1. S IBCS0=$P(IBLN,U,2),IBCS=+$O(^IBE(363.1,"B",IBCS0,0)) I 'IBCS D MSG("** Error: Charge Set "_$P(IBLN,U,2)_" undefined") Q
  1. S IBCI=+$$MCCRUTL($P(IBLN,U,1),5) I 'IBCI D MSG("** Error: Bed Section "_$P(IBLN,U,1)_" undefined") Q
  1. S IBDT=IBDFLTDT I +$P(IBLN,U,3) S IBDT=+$P(IBLN,U,3)
  1. S IBRVCD=$$RVCD($P(IBLN,U,4))
  1. S IBCHG=+$P(IBLN,U,5)
  1. S IBXRF="AIVDTS"_IBCS
  1. ;
  1. S IBX=0 F S IBX=$O(^IBA(363.2,IBXRF,IBCI,-IBDT,IBX)) Q:'IBX S IBZ=$G(^IBA(363.2,IBX,0)) I $P(IBZ,U,6)=IBRVCD D
  1. . S IBCI=0,IBCNT1=IBCNT1+1,IBCHZ=+$P(IBZ,U,5) D MSG("** "_$S(IBCHZ'=IBCHG:"Error: ",1:"")_"Charge Item "_IBCS0_" with "_$S(IBCHZ'=IBCHG:"wrong ",1:"")_"charge $"_$P(IBZ,U,5)_" already exists, not re-added")
  1. Q:'IBCI
  1. ;
  1. K DD,DO S DLAYGO=363.2,DIC="^IBA(363.2,",DIC(0)="L",X=IBCI_";DGCR(399.1," D FILE^DICN K DIC,DLAYGO
  1. I Y<1 D MSG("** Error: when adding the charge item "_IBCS_" with rate "_IBCHG_" to the file, Log a Remedy ticket!") K X,Y Q
  1. S IBFN=+Y,IBCNT=IBCNT+1
  1. ;
  1. S DR=".02///"_IBCS_";.03///"_IBDT_";.05///"_IBCHG I +IBRVCD S DR=DR_";.06///"_IBRVCD
  1. S DIE="^IBA(363.2,",DA=+IBFN D ^DIE K DIE,DA,DR,X,Y
  1. Q
  1. ;
  1. ADDRS ; add Charge Sets to Rate Schedules (363)
  1. N IBCNT,IBCS,IBCSY,IBI,IBLN,IBRS,IBRSN,IBX,DA,DD,DO,DLAYGO,DIC,DIE,DR,X,Y
  1. S IBCNT=0
  1. F IBI=1:1 S IBLN=$P($T(RSF+IBI),";;",2) Q:IBLN="QUIT" D
  1. . S IBRS=$P(IBLN,U)
  1. . S IBCS=$P(IBLN,U,6)
  1. . S IBCSY=$O(^IBE(363.1,"B",IBCS,0))
  1. . I 'IBCSY D MSG("** Error: Charge Set "_IBCS_" undefined, not added") Q
  1. . ; remove auto add for the old cs ia-opt vst
  1. . S IBRSN=$O(^IBE(363,"B",IBRS,0))
  1. . I $O(^IBE(363,"B",IBRS,IBRSN))'="" D
  1. .. S IBX=$O(^IBE(363,IBRSN,11,"B",+$O(^IBE(363.1,"B","IA-OPT VST",0)),0)) Q:'IBX
  1. .. S DA(1)=IBRSN,DA=IBX,DIE="^IBE(363,"_DA(1)_",11,"
  1. .. S DR=".02///@" D ^DIE
  1. . ; find the latest entry
  1. . S IBRSN=+$O(^IBE(363,"B",IBRS,99999),-1)
  1. . I 'IBRSN D MSG("** Error: Rate Schedule "_IBRS_" undefined, Charge Set "_IBCS_" not added") Q
  1. . I $P($G(^IBE(363,IBRSN,0)),U,6)'="" D MSG("** Error: Rate Schedule "_IBRS_" inactivated, Charge Set "_IBCS_" not added") Q
  1. . I $O(^IBE(363,IBRSN,11,"B",IBCSY,0)) D MSG("** Rate Schedule "_IBRS_" with "_IBCS_" already exists, not re-added") Q
  1. . ;
  1. . K DD,DO S DLAYGO=363,DA(1)=+IBRSN,DIC="^IBE(363,"_DA(1)_",11,",DIC(0)="L",X=+IBCSY,DIC("P")="363.0011P" D FILE^DICN K DIC,DA,DLAYGO
  1. . I Y<1 D MSG("** Error: when adding the Charge Set "_IBCS_" to Rate Schedule "_IBRS_" in the file, Log a Remedy ticket!") K X,Y Q
  1. . S IBCNT=IBCNT+1
  1. RSQ ;
  1. D MSG(" >> "_IBCNT_" Rate Schedules updated (#363)")
  1. D MSG("")
  1. Q
  1. ;
  1. MCCRUTL(X,P) ; returns IFN of item in 399.1 if Name is found and piece P is true
  1. N IBX,IBY S IBY=""
  1. I $G(X)'="" S IBX=0 F S IBX=$O(^DGCR(399.1,"B",X,IBX)) Q:'IBX I $P($G(^DGCR(399.1,IBX,0)),U,+$G(P)) S IBY=IBX
  1. Q IBY
  1. ;
  1. RVCD(RVCD) ; returns IFN if revenue code is valid and active
  1. N IBX,IBY S IBY=""
  1. I +$G(RVCD) S IBX=$G(^DGCR(399.2,+RVCD,0)) I +$P(IBX,U,3) S IBY=+RVCD
  1. Q IBY
  1. ;
  1. MSG(IBA) ;
  1. D MES^XPDUTL(IBA)
  1. Q
  1. ;
  1. CIF ; Dental Tortiously Liable/Interagency: Bedsection^Charge Set^Effective Date^Revenue Code^Charge
  1. ;;OUTPATIENT DENTAL^TL-OPT DENTAL^^^236
  1. ;;OUTPATIENT DENTAL^IA-OPT DENTAL^^^222
  1. ;;QUIT
  1. Q
  1. ;
  1. RSF ; Rate Schedule: Name^Rate Type^Bill Type^Effective Date^Inactive Date^Charge Set
  1. ;;DNTL-OPT DENTAL^DENTAL^OUTPATIENT^^^TL-OPT DENTAL
  1. ;;IA-OPT^INTERAGENCY^OUTPATIENT^^^IA-OPT DENTAL
  1. ;;QUIT
  1. Q