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

IBOHDT.m

Go to the documentation of this file.
  1. IBOHDT ;ALB/EMG - REPORT OF CHARGES ON HOLD > 60 DAYS ;FEB 14 1997
  1. ;;2.0;INTEGRATED BILLING;**70,95,142,347,555**;21-MAR-94;Build 22
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. MAIN ;
  1. N DIRUT,DTOUT,DUOUT,IBNUM,IBQUIT,POP,VA,ZTIO,Y S (IBQUIT,IBNUM)=0
  1. W !!
  1. S DIR(0)="NO",DIR("B")=60,DIR("A")="Enter number of days",DIR("A",1)="This report is used to follow-up on charges that have been on hold for an"
  1. S DIR("A",2)="extended period of time. Press return to print a list of charges on hold",DIR("A",3)="for longer than 60 days. You may limit your search to older charges"
  1. S DIR("A",4)="by typing a higher number. (For example, type 80 to see charges on hold",DIR("A",5)="for longer than 80 days.)",DIR("A",6)=""
  1. D ^DIR K DIR S IBNUM=+Y Q:$D(DIRUT)
  1. QUEUED ; entry point if queued
  1. ;***
  1. K ^TMP($J)
  1. D:'$G(IBQUIT) DEVICE D:'$G(IBQUIT) CHRGS,REPORT^IBOHDT1
  1. D EXIT
  1. ;***
  1. Q
  1. EXIT ;
  1. K ^TMP($J)
  1. K IBRDT,IBRF,IBRX,IBRXN
  1. I $D(ZTQUEUED) S ZTREQ="@" Q
  1. D ^%ZISC
  1. Q
  1. DEVICE ;
  1. I $D(ZTQUEUED) Q
  1. W !!,*7,"*** Margin width of this output is 132 ***"
  1. W !,"*** This output should be queued ***"
  1. S %ZIS="QM" D ^%ZIS I POP S IBQUIT=1 Q
  1. I $D(IO("Q")) S ZTRTN="QUEUED^IBOHDT",ZTIO=ION,ZTDESC="HELD CHARGES REPORT",ZTSAVE("IB*")="" D ^%ZTLOAD W !,$S($D(ZTSK):"REQUEST QUEUED TASK="_ZTSK,1:"REQUEST CANCELLED") D HOME^%ZIS K ZTSK S IBQUIT=1 Q
  1. U IO
  1. Q
  1. ; indexes records that should be included in report
  1. ;
  1. CHRGS ; charges on hold
  1. N DFN,IBDT,IBN,IBNAME,IBND,IBPID,IBTYPE,X1,X2
  1. S X1=DT,X2=(-IBNUM) D C^%DTC S IBTO=X
  1. S IBPID=0 F S IBPID=$O(^IB("AHDT",IBPID)) Q:'IBPID S IBDT=0 F S IBDT=$O(^IB("AHDT",IBPID,8,IBDT)) Q:'IBDT!(IBDT>IBTO) S IBN=0 F S IBN=$O(^IB("AHDT",IBPID,8,IBDT,IBN)) Q:IBN="" D
  1. .S IBND=$G(^IB(IBN,0)) Q:'IBND
  1. .S DFN=+$P(IBND,"^",2) D ;fetch patient name
  1. ..N VAERR,VADM D DEM^VADPT I VAERR K VADM
  1. ..S IBNAME=$G(VADM(1))
  1. ..Q
  1. .S IBTYPE=$P($G(^IBE(350.1,+$P(IBND,"^",3),0)),"^"),IBATYPE=$S(IBTYPE["OPT":"O",IBTYPE["PSO":"RX",1:"I")
  1. .S ^TMP($J,"HOLD",IBNAME,DFN,IBATYPE,IBN)=""
  1. .D BILLS
  1. Q
  1. PAT ; patient name
  1. N VAERR,VADM D DEM^VADPT I VAERR K VADM
  1. S IBNAME=$G(VADM(1)) S:IBNAME="" IBNAME=" "
  1. Q
  1. BILLS ; find bills for charges on hold
  1. N IBFR,IBT,IBATYPE,IBTO
  1. S IBATYPE=$S($P($G(^IBE(350.1,+$P(IBND,"^",3),0)),"^")["OPT":"O",$P($G(^IBE(350.1,+$P(IBND,"^",3),0)),"^")["PSO":"RX",1:"I")
  1. S IBFR=$P(IBND,"^",14),IBTO=$P(IBND,"^",15)
  1. I IBATYPE="I" D INP
  1. I IBATYPE="O" D OPT
  1. E D RX,OPT
  1. Q
  1. INP ; inpatient bills
  1. N IBEV,IBBILL,IBT,X,IBEND,IBOK
  1. S IBEV=$P(IBND,"^",16) Q:'IBEV ; parent event
  1. S IBEV=($P($G(^IB(IBEV,0)),"^",17)\1) Q:'IBEV ; date of parent event
  1. S X1=IBEV,X2=1 D C^%DTC S IBEND=X
  1. S IBT=(IBEV-.0001) F S IBT=$O(^DGCR(399,"D",IBT)) Q:'IBT!(IBT'<IBEND) S IBBILL=0 F S IBBILL=$O(^DGCR(399,"D",IBT,IBBILL)) Q:IBBILL="" D
  1. .D INPTCK
  1. .I IBOK S ^TMP($J,"HOLD",IBNAME,DFN,IBATYPE,IBN,IBBILL)=""
  1. Q
  1. ;
  1. INPTCK ; does bill belong to charge? returns IBOK=0 if no
  1. N IBBILL0,IBBILLU
  1. S IBBILL0=$G(^DGCR(399,IBBILL,0)),IBBILLU=$G(^("U"))
  1. S IBOK=1
  1. CK1 ; for same patient?
  1. I DFN=$P(IBBILL0,"^",2)
  1. S IBOK=$T
  1. Q:'IBOK
  1. CK2 ; same type- inp or opt?
  1. N B S B=$S(+$P(IBBILL0,"^",5)<3:"I",1:"O")
  1. I B=IBATYPE
  1. S IBOK=$T
  1. Q:'IBOK
  1. CK3 ; overlap in date range?
  1. N F,T
  1. S F=+IBBILLU,T=$P(IBBILLU,"^",2)
  1. I (IBTO<F)!(IBFR>T)
  1. S IBOK='$T
  1. Q:'IBOK
  1. CK4 ; insurance bill?
  1. I $P(IBBILL0,"^",11)="i"
  1. S IBOK=$T
  1. Q
  1. OPT ; outpatient bills
  1. N X,IBV,IBBILL,IBOK,IBBILL0
  1. S IBV=(IBFR\1)-.0001 F S IBV=$O(^DGCR(399,"AOPV",DFN,IBV)) Q:'IBV!(IBV>IBTO) S IBBILL=0 D
  1. .F S IBBILL=$O(^DGCR(399,"AOPV",DFN,IBV,IBBILL)) Q:('IBBILL) D
  1. ..Q:$D(^TMP($J,"HOLD",IBNAME,DFN,IBATYPE,IBN,IBBILL))
  1. ..S IBBILL0=$G(^DGCR(399,IBBILL,0)) D CK4 Q:'IBOK
  1. ..S ^TMP($J,"HOLD",IBNAME,DFN,IBATYPE,IBN,IBBILL)=""
  1. Q
  1. RX ; rx refill bills
  1. S (IBRX,IBRXN,IBRF,IBRDT)=0 N IENS
  1. I $P(IBND,"^",4)'["52:" Q
  1. ;
  1. S IBRXN=$P($P(IBND,"^",4),":",2),IBRX=$P($P(IBND,"^",8),"-"),IBRF=$P($P(IBND,"^",4),":",3)
  1. ;
  1. I +IBRF>0 S IBRDT=$$SUBFILE^IBRXUTL(+IBRXN,IBRF,52,.01)
  1. I +IBRF=0 S IBRDT=$$FILE^IBRXUTL(+IBRXN,22)
  1. ;
  1. Q:(IBRX="")!('IBRDT)
  1. N X,IBBILL,IBBILL0,IBFILL,IBFILL0,IBOK S IBBILL=0
  1. S IBFILL=0 F S IBFILL=$O(^IBA(362.4,"B",IBRX,IBFILL)) Q:IBFILL="" D
  1. .S IBFILL0=$G(^IBA(362.4,IBFILL,0)) I $P(IBFILL0,"^",3)'=IBRDT Q
  1. .S IBBILL=+$P(IBFILL0,"^",2) I 'IBBILL Q
  1. .S IBBILL0=$G(^DGCR(399,IBBILL,0)) D CK4 I 'IBOK Q
  1. .S ^TMP($J,"HOLD",IBNAME,DFN,IBATYPE,IBN,IBBILL)=""
  1. Q