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

IBAMTS.m

Go to the documentation of this file.
  1. IBAMTS ;ALB/CPM - APPOINTMENT EVENT DRIVER INTERFACE ;20-JUL-93
  1. ;;2.0;INTEGRATED BILLING;**52,115,132,153,164,156,171,247,312,341,339**;21-MAR-94;Build 2
  1. ;;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. EN ; Main interface entry point.
  1. ;
  1. N IBSWINFO S IBSWINFO=$$SWSTAT^IBBAPI() ;IB*2.0*312
  1. I '$G(DUZ) D DUZ^XUP(.5) ;IB*2.0*341 Setting of DUZ covered by IA 4129
  1. ;
  1. S IBJOB=5,IBWHER="",IBDUZ=DUZ,IBY=1
  1. ; Do Transfer Pricing
  1. I '+IBSWINFO D ^IBATEO ;IB*2.0*312
  1. ; Check Encounter Related to LTC
  1. N IBALTC D EN^IBAECO
  1. I '$$BILST^DGMTUB(DFN) G ENQ ; never Means Test billable
  1. I '$$CHECK^IBECEAU(0) D ^IBAERR1 G ENQ ; can't set vital parameters
  1. ;
  1. ; - process all parent outpatient encounters
  1. S IBORG=0 F S IBORG=$O(^TMP("SDEVT",$J,SDHDL,IBORG)) Q:'IBORG D
  1. .S IBOE=0 F S IBOE=$O(^TMP("SDEVT",$J,SDHDL,IBORG,"SDOE",IBOE)) Q:'IBOE S IBEVT=$G(^(IBOE,0,"AFTER")),IBEV0=$G(^("BEFORE")) D
  1. ..;
  1. ..S IBDT=$S(IBEVT:+IBEVT,1:+IBEV0),IBDAT=$P(IBDT,".")
  1. ..; Do NOT PROCESS on VistA if IBDAT>=Switch Eff Date ;CCR-930
  1. ..I +IBSWINFO,(IBDAT+1)>$P(IBSWINFO,"^",2) Q ;IB*2.0*312
  1. ..;
  1. ..S IBAPTY=$S(IBEVT:$P(IBEVT,"^",10),1:$P(IBEV0,"^",10))
  1. ..S IBBILLED=$$BFO^IBECEAU(DFN,IBDAT),IBY=1
  1. ..;
  1. ..; - if C&P encounter, cancel charges for the day and quit
  1. ..I IBAPTY=1!(IBALTC) D:IBBILLED Q
  1. ...S IBCRES=+$O(^IBE(350.3,"B",$S(IBALTC:"BILLED LTC CHARGE",1:"COMP & PENSION VISIT RECORDED"),0))
  1. ...S:'IBCRES IBCRES=23 S IBWHER=""
  1. ...D CANCH^IBECEAU4(IBBILLED,IBCRES,0)
  1. ..;
  1. ..; - quit if there are any C&P encounters on the visit date
  1. ..Q:$$CNP^IBECEAU(DFN,IBDAT)
  1. ..;
  1. ..; - quit if there are any LTC encounters on the visit date
  1. ..Q:$$LTCENC^IBAECU(DFN,IBDAT)
  1. ..;
  1. ..; - don't process child events
  1. ..I IBEVT]"" Q:$P(IBEVT,"^",6)
  1. ..I IBEVT="",IBEV0]"" Q:$P(IBEV0,"^",6)
  1. ..;
  1. ..; - get statuses
  1. ..S IBAST=+$P(IBEVT,"^",12),IBBST=+$P(IBEV0,"^",12)
  1. ..;
  1. ..; - do either NEW or UPDATED processing
  1. ..I IBAST=2,IBBST'=2 D NEW^IBAMTS1 Q
  1. ..D UPD^IBAMTS2
  1. ;
  1. ENQ K IBJOB,IBWHER,IBORG,IBOE,IBEVT,IBEV0,IBAST,IBBST,IBDUZ,IBY
  1. K IBDT,IBDAT,IBAPTY,IBBILLED,IBSERV,IBSITE,IBFAC,IBCRES,IBRTED
  1. Q
  1. ;
  1. BULL ; Send bulletin when classified patients are billed stops which
  1. ; are exempt from the classification process.
  1. N IBT,IBC,IBPT,IBDUZ,IBX S IBPT=$$PT^IBEFUNC(DFN),IBX=$$CLTY
  1. S XMSUB="CHARGE FOR STOP CODE EXEMPT FROM CLASSIFICATION"
  1. S IBT(1)="The following patient, who "_$S(IBX="SC":"has a service connected disability,",IBX="CV":"is Combat Veteran",1:"has claimed exposure to "_IBX_",")
  1. S IBT(2)="was billed the Means Test outpatient copay for a stop code which is"
  1. S IBT(3)="exempt from classification:"
  1. S IBT(4)=" " S IBC=4
  1. S IBDUZ=DUZ D PAT^IBAERR1
  1. S Y=IBDAT D DD^%DT
  1. S IBC=IBC+1,IBT(IBC)="Stop Date: "_Y
  1. S IBC=IBC+1,IBT(IBC)="Stop Code: "_$P($G(^DIC(40.7,+$P(IBEVT,"^",3),0)),"^")
  1. S IBC=IBC+1,IBT(IBC)=" "
  1. S IBC=IBC+1,IBT(IBC)="Please check this patient's medical record to determine if the care provided"
  1. S IBC=IBC+1,IBT(IBC)="was related to the "_$S(IBX="SC":"SC disability",IBX="CV":"Combat Veteran status",1:"claimed exposure")_", and, if related, cancel the charge."
  1. D MAIL^IBAERR1
  1. K X,Y,XMSUB,XMY,XMTEXT,XMDUZ
  1. Q
  1. ;
  1. CLTY() ; Return the classification type
  1. N IBARR,Y D CL^SDCO21(DFN,IBDAT,"",.IBARR) S Y=""
  1. I $D(IBARR(3)) S Y="SC" G CLTYQ
  1. I $D(IBARR(7)),+$$CVEDT^IBACV(DFN,IBDAT) S Y="CV" G CLTYQ
  1. I $D(IBARR(1)) S Y="Agent Orange" G CLTYQ
  1. I $D(IBARR(2)) S Y="Ionizing Radiation" G CLTYQ
  1. I $D(IBARR(4)) S Y="Southwest Asia" G CLTYQ
  1. I $D(IBARR(8)) S Y="Project 112/SHAD" G CLTYQ
  1. I $D(IBARR(5)) S Y="Military Sexual Trauma" G CLTYQ
  1. I $D(IBARR(6)) S Y="Head/Neck Cancer" G CLTYQ
  1. CLTYQ Q Y