| [613] | 1 | IBCRLI ;ALB/ARH - RATES: DISPLAY CHARGE ITEMS ; 16-MAY-1996 | 
|---|
|  | 2 | ;;2.0;INTEGRATED BILLING;**52,106,245**;21-MAR-94 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | ; if Charge Set/Rates Billable Item is Bedsection then default display is current charge for all items | 
|---|
|  | 6 | ; all other Charge Sets display all charges for a user selected item | 
|---|
|  | 7 | ; this is due to unknown number of possible entries, for example a CPT set may have thousands of current charges | 
|---|
|  | 8 | ; | 
|---|
|  | 9 | EN ; -- main entry point for IBCR CHARGE ITEM | 
|---|
|  | 10 | D EN^VALM("IBCR CHARGE ITEM") | 
|---|
|  | 11 | Q | 
|---|
|  | 12 | ; | 
|---|
|  | 13 | HDR ; -- header code | 
|---|
|  | 14 | N IBY,IBX,IBZ,IBI,IBK S IBI=1,(IBX,IBY,IBZ,IBK,VALMHDR(1),VALMHDR(2))="" | 
|---|
|  | 15 | ; | 
|---|
|  | 16 | I +$P(IBCS0,U,5) S IBK="Default Revenue Code: "_$P($G(^DGCR(399.2,+$P(IBCS0,U,5),0)),U,1) | 
|---|
|  | 17 | ; | 
|---|
|  | 18 | S IBZ=IBBRBIN_$S(+IBSRNITM:" ",1:"")_$P(IBSRNITM,U,2)_" items billable to Charge Set " | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | S IBX=$P(IBCS0,U,1) I +$G(IBSRNBDT)!(+$G(IBSRNEDT)) D | 
|---|
|  | 21 | . I IBSRNBDT=IBSRNEDT S IBX=$E(IBX,1,28),IBY=" on "_$$DATE(IBSRNBDT) Q | 
|---|
|  | 22 | . I 'IBSRNBDT S IBY=" on or before "_$$DATE(IBSRNEDT) Q | 
|---|
|  | 23 | . I 'IBSRNEDT S IBY=" on or after "_$$DATE(IBSRNBDT) Q | 
|---|
|  | 24 | . I IBSRNBDT'=IBSRNEDT S IBY=" between "_$$DATE(IBSRNBDT)_" and "_$$DATE(IBSRNEDT) | 
|---|
|  | 25 | ; | 
|---|
|  | 26 | S VALMHDR(1)=IBZ_IBX | 
|---|
|  | 27 | I ($L(IBZ)+$L(IBX)+$L(IBY))<80 S VALMHDR(1)=VALMHDR(1)_IBY,IBY="" | 
|---|
|  | 28 | S VALMHDR(2)=IBK_$J("",(80-($L(IBK)+$L(IBY))))_IBY | 
|---|
|  | 29 | Q | 
|---|
|  | 30 | ; | 
|---|
|  | 31 | INIT ; -- init variables and list array  IBCSFN required | 
|---|
|  | 32 | K ^TMP("IBCRLI",$J) | 
|---|
|  | 33 | I '$G(IBCSFN) S IBCSFN=$$GETCS^IBCRU1 I IBCSFN'>0 S VALMQUIT="" Q | 
|---|
|  | 34 | I $$GET(IBCSFN)<0 S VALMQUIT="" Q | 
|---|
|  | 35 | D BLD | 
|---|
|  | 36 | Q | 
|---|
|  | 37 | ; | 
|---|
|  | 38 | HELP ; -- help code | 
|---|
|  | 39 | S X="?" D DISP^XQORM1 W !! | 
|---|
|  | 40 | Q | 
|---|
|  | 41 | ; | 
|---|
|  | 42 | EXIT ; -- exit code | 
|---|
|  | 43 | K ^TMP("IBCRLI",$J),IBCS0,IBBRBI,IBBRBIN,IBSRNITM,IBSRNBDT,IBSRNEDT | 
|---|
|  | 44 | D CLEAR^VALM1,CLEAN^VALM10 | 
|---|
|  | 45 | Q | 
|---|
|  | 46 | ; | 
|---|
|  | 47 | BLD ; build array for display for Charge Item display: charge set required | 
|---|
|  | 48 | N IBITEM,IBDT1,IBCIFN,IBLN,IBX,IBY S VALMCNT=0 K ^TMP($J,"IBCRCI") | 
|---|
|  | 49 | S IBSRNITM=$G(IBSRNITM),IBSRNBDT=$G(IBSRNBDT),IBSRNEDT=$G(IBSRNEDT) | 
|---|
|  | 50 | ; | 
|---|
|  | 51 | I (IBBRBI=1)!(+IBSRNITM) D SORTCI(IBCSFN,$G(IBSRNITM),$G(IBSRNBDT),$G(IBSRNEDT)) | 
|---|
|  | 52 | ; | 
|---|
|  | 53 | ; create LM diplay array of charge items | 
|---|
|  | 54 | S IBITEM="" F  S IBITEM=$O(^TMP($J,"IBCRCI",IBITEM)) Q:IBITEM=""  D | 
|---|
|  | 55 | . S IBDT1="" F  S IBDT1=$O(^TMP($J,"IBCRCI",IBITEM,IBDT1)) Q:IBDT1=""  D | 
|---|
|  | 56 | .. S IBCIFN=0 F  S IBCIFN=$O(^TMP($J,"IBCRCI",IBITEM,IBDT1,IBCIFN)) Q:'IBCIFN  D | 
|---|
|  | 57 | ... ; | 
|---|
|  | 58 | ... S IBLN=$G(^IBA(363.2,IBCIFN,0)),IBY="" | 
|---|
|  | 59 | ... S IBX=$$EXPAND^IBCRU1(363.2,.01,$P(IBLN,U,1)) | 
|---|
|  | 60 | ... I +$P(IBLN,U,7) S IBX=IBX_" - "_$$EXPAND^IBCRU1(363.2,.07,+$P(IBLN,U,7)) | 
|---|
|  | 61 | ... S IBY=$$SETFLD^VALM1(IBX,IBY,"ITEM") | 
|---|
|  | 62 | ... S IBX=$J($P(IBLN,U,5),8,2),IBY=$$SETFLD^VALM1(IBX,IBY,"UCHG") | 
|---|
|  | 63 | ... S IBX=$J($P(IBLN,U,8),8,2),IBY=$$SETFLD^VALM1(IBX,IBY,"BCHG") | 
|---|
|  | 64 | ... S IBX=$P($G(^DGCR(399.2,+$P(IBLN,U,6),0)),U,1),IBY=$$SETFLD^VALM1(IBX,IBY,"RVCD") | 
|---|
|  | 65 | ... S IBX=$$DATE($P(IBLN,U,3)),IBY=$$SETFLD^VALM1(IBX,IBY,"EFFDT") | 
|---|
|  | 66 | ... S IBX=$P(IBLN,U,4) | 
|---|
|  | 67 | ... I +IBX S IBY=$$SETFLD^VALM1("-",IBY,"DS"),IBX=$$DATE(IBX),IBY=$$SETFLD^VALM1(IBX,IBY,"INADT") | 
|---|
|  | 68 | ... D SET(IBY) | 
|---|
|  | 69 | ; | 
|---|
|  | 70 | I VALMCNT=0 D SET(" ") D | 
|---|
|  | 71 | . I 'IBBRBI D SET("The Billing Rate of this Set has no Billable Item defined, therefore no"),SET("Charge Items may be defined for it.  (The charges may be calculated amounts.)") Q | 
|---|
|  | 72 | . I '$D(^IBA(363.2,"AIVDTS"_+$G(IBCSFN))) D SET("No Charge Items defined for this Set.") Q | 
|---|
|  | 73 | . I +IBSRNITM,'$D(^IBA(363.2,"AIVDTS"_+$G(IBCSFN),+IBSRNITM)) D SET(IBBRBIN_" "_$P(IBSRNITM,U,2)_" has no charges for this set.") Q | 
|---|
|  | 74 | . I 'IBSRNITM,IBBRBI'=1 D SET("No Charge Item chosen for display:"),SET("       - Non-bedsection type Items must be specifically chosen for display."),SET("       - Use the CI action and select an item to display.") Q | 
|---|
|  | 75 | . I 'IBSRNITM D SET("This set has no charges in this date range.") Q | 
|---|
|  | 76 | . D SET(IBBRBIN_" "_$P(IBSRNITM,U,2)_" has no charges for this set in this date range.") | 
|---|
|  | 77 | ; | 
|---|
|  | 78 | K ^TMP($J,"IBCRCI") | 
|---|
|  | 79 | Q | 
|---|
|  | 80 | ; | 
|---|
|  | 81 | DATE(X) ; date in external format | 
|---|
|  | 82 | N Y S Y="" I $G(X)?7N.E S Y=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) | 
|---|
|  | 83 | Q Y | 
|---|
|  | 84 | ; | 
|---|
|  | 85 | SET(X) ; set up list manager screen array | 
|---|
|  | 86 | S VALMCNT=VALMCNT+1 | 
|---|
|  | 87 | S ^TMP("IBCRLI",$J,VALMCNT,0)=X | 
|---|
|  | 88 | Q | 
|---|
|  | 89 | ; | 
|---|
|  | 90 | ; | 
|---|
|  | 91 | SORTCI(IBCSFN,IBITM,IBDT1,IBDT2) ; sort a charge sets items by item name and inverse effective date | 
|---|
|  | 92 | ; if ITEM is not defined than dates should be, if ITEM or dates not defined then assumes all should be included | 
|---|
|  | 93 | ; ^TMP("IBCRCI",$J, item name, - effective date, ITEM IFN)="" | 
|---|
|  | 94 | ; | 
|---|
|  | 95 | N IBXRF,IBBITM,IBEITM,IBITEM,IBBDT,IBEDT,IBEFDT,IBCIFN,IBLN,IBITEMN | 
|---|
|  | 96 | ; | 
|---|
|  | 97 | S IBXRF="AIVDTS"_+$G(IBCSFN) | 
|---|
|  | 98 | S IBBITM=+$G(IBITM)-.0001,IBEITM=$S(+$G(IBITM):IBITM,1:9999999999) | 
|---|
|  | 99 | S IBBDT=$S(+$G(IBDT1):-IBDT1,1:-1000000),IBEDT=$S(+$G(IBDT2):-(IBDT2+.01),1:-9999999) Q:IBBDT<IBEDT | 
|---|
|  | 100 | ; | 
|---|
|  | 101 | S IBITEM=IBBITM F  S IBITEM=$O(^IBA(363.2,IBXRF,IBITEM)) Q:'IBITEM!(IBITEM>IBEITM)  D | 
|---|
|  | 102 | . S IBEFDT=IBEDT F  S IBEFDT=$O(^IBA(363.2,IBXRF,IBITEM,IBEFDT)) Q:'IBEFDT  D  Q:(IBEFDT'<IBBDT) | 
|---|
|  | 103 | .. S IBCIFN=0 F  S IBCIFN=$O(^IBA(363.2,IBXRF,IBITEM,IBEFDT,IBCIFN)) Q:'IBCIFN  D | 
|---|
|  | 104 | ... S IBLN=$G(^IBA(363.2,IBCIFN,0)),IBITEMN=$$EXPAND^IBCRU1(363.2,.01,$P(IBLN,U,1))_" - " | 
|---|
|  | 105 | ... I +$P(IBLN,U,7) S IBITEMN=IBITEMN_$$EXPAND^IBCRU1(363.2,.07,+$P(IBLN,U,7)) | 
|---|
|  | 106 | ... I $P(IBLN,U,4),+$P(IBLN,U,4)<-IBBDT Q | 
|---|
|  | 107 | ... S ^TMP($J,"IBCRCI",IBITEMN,IBEFDT,IBCIFN)="" | 
|---|
|  | 108 | Q | 
|---|
|  | 109 | ; | 
|---|
|  | 110 | GET(IBCSFN) ; get item to display on screen for specific charge set, set up general variables required | 
|---|
|  | 111 | ; (returns 0 if error, -1 if ^) all active bedsections or all entries for a specific CPT or NDC # | 
|---|
|  | 112 | ; | 
|---|
|  | 113 | ; returns general data on the Charge set to be diplayed, may ask user for a specific item | 
|---|
|  | 114 | ; variables defined on exit: IBCS0,IBBRBI,IBBRBIN,IBSRNITM,IBSRNBDT,IBSRNEDT | 
|---|
|  | 115 | ; if billable item is bedsection returns current date but no item | 
|---|
|  | 116 | ; if billable item is anything else asks user for specific item but returns no date | 
|---|
|  | 117 | ; | 
|---|
|  | 118 | N IBX S IBX=1,(IBBRBI,IBBRBIN,IBSRNITM,IBSRNBDT,IBSRNEDT)="" | 
|---|
|  | 119 | S IBCS0=$G(^IBE(363.1,+$G(IBCSFN),0)) I IBCS0="" S IBX=0 G GETQ | 
|---|
|  | 120 | S IBBRBI=$P($G(^IBE(363.3,+$P(IBCS0,U,2),0)),U,4) I 'IBBRBI S IBX=0 G GETQ | 
|---|
|  | 121 | S IBBRBIN=$$EXPAND^IBCRU1(363.3,.04,IBBRBI) | 
|---|
|  | 122 | I IBBRBI>1 W !!,"Select a billable ",IBBRBIN," to display for Charge Set ",$P(IBCS0,U,1),! | 
|---|
|  | 123 | ; | 
|---|
|  | 124 | I IBBRBI=1 S (IBSRNBDT,IBSRNEDT)=DT ; all currently active charges (bedsection) | 
|---|
|  | 125 | I IBBRBI=2 S (IBX,IBSRNITM)=$$GETCPT^IBCRU1("",1) ; all charges for a specific CPT | 
|---|
|  | 126 | I IBBRBI=3 S (IBX,IBSRNITM)=$$GETNDC^IBCRU1 ; all charges for a specific NDC # | 
|---|
|  | 127 | I IBBRBI=4 S (IBX,IBSRNITM)=$$GETDRG^IBCRU1 ; all charges for a specific DRG | 
|---|
|  | 128 | I IBBRBI=9 S (IBX,IBSRNITM)=$$GETMISC^IBCRU1 ; all charges for a specific MISCELLANEOUS item | 
|---|
|  | 129 | GETQ Q IBX | 
|---|