| 1 | IBCRLR ;ALB/ARH - RATES: DISPLAY BILLING RATES ; 16-MAY-1996 | 
|---|
| 2 | ;;Version 2.0 ; INTEGRATED BILLING ;**52**; 21-MAR-94 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | EN ; -- main entry point for IBCR BILLING RATE | 
|---|
| 6 | D EN^VALM("IBCR BILLING RATE") | 
|---|
| 7 | Q | 
|---|
| 8 | ; | 
|---|
| 9 | HDR ; -- header code | 
|---|
| 10 | S VALMHDR(1)="" | 
|---|
| 11 | Q | 
|---|
| 12 | ; | 
|---|
| 13 | INIT ; -- init variables and list array | 
|---|
| 14 | K ^TMP("IBCRLR",$J) | 
|---|
| 15 | D BLD | 
|---|
| 16 | Q | 
|---|
| 17 | ; | 
|---|
| 18 | HELP ; -- help code | 
|---|
| 19 | S X="?" D DISP^XQORM1 W !! | 
|---|
| 20 | Q | 
|---|
| 21 | ; | 
|---|
| 22 | EXIT ; -- exit code | 
|---|
| 23 | K ^TMP("IBCRLR",$J) | 
|---|
| 24 | D CLEAR^VALM1,CLEAN^VALM10 | 
|---|
| 25 | Q | 
|---|
| 26 | ; | 
|---|
| 27 | BLD ; build array for billing rate display | 
|---|
| 28 | N IBDSTR,IBBRN,IBBRFN,IBLN,IBCNT,IBX,IBY S VALMCNT=0,IBCNT=0 K ^TMP($J,"IBCRBR") | 
|---|
| 29 | ; | 
|---|
| 30 | D SORTBR | 
|---|
| 31 | ; | 
|---|
| 32 | ; create LM display array | 
|---|
| 33 | S IBDSTR=0 F  S IBDSTR=$O(^TMP($J,"IBCRBR",IBDSTR)) Q:'IBDSTR  D | 
|---|
| 34 | . D SET("") | 
|---|
| 35 | . S IBBRN="" F  S IBBRN=$O(^TMP($J,"IBCRBR",IBDSTR,IBBRN)) Q:IBBRN=""  D | 
|---|
| 36 | .. S IBBRFN=0 F  S IBBRFN=$O(^TMP($J,"IBCRBR",IBDSTR,IBBRN,IBBRFN)) Q:'IBBRFN  D | 
|---|
| 37 | ... ; | 
|---|
| 38 | ... S IBLN=$G(^IBE(363.3,IBBRFN,0)) Q:IBLN="" | 
|---|
| 39 | ... S IBCNT=IBCNT+1,IBY="" | 
|---|
| 40 | ... S IBX=$P(IBLN,U,1),IBY=$$SETFLD^VALM1(IBX,IBY,"RATE") | 
|---|
| 41 | ... S IBX=$P(IBLN,U,2),IBY=$$SETFLD^VALM1(IBX,IBY,"ABBV") | 
|---|
| 42 | ... S IBX=$$EXPAND^IBCRU1(363.3,.03,$P(IBLN,U,3)),IBY=$$SETFLD^VALM1(IBX,IBY,"DSTR") | 
|---|
| 43 | ... S IBX=$$EXPAND^IBCRU1(363.3,.04,$P(IBLN,U,4)),IBY=$$SETFLD^VALM1(IBX,IBY,"BITM") | 
|---|
| 44 | ... S IBX=$$EXPAND^IBCRU1(363.3,.05,$P(IBLN,U,5)),IBY=$$SETFLD^VALM1(IBX,IBY,"CMTHD") | 
|---|
| 45 | ... D SET(IBY) | 
|---|
| 46 | ; | 
|---|
| 47 | I VALMCNT=0 D SET(" "),SET("No Billing Rates defined") | 
|---|
| 48 | ; | 
|---|
| 49 | K ^TMP($J,"IBCRBR") | 
|---|
| 50 | Q | 
|---|
| 51 | ; | 
|---|
| 52 | SET(X) ; set up list manager screen array | 
|---|
| 53 | S VALMCNT=VALMCNT+1 | 
|---|
| 54 | S ^TMP("IBCRLR",$J,VALMCNT,0)=X | 
|---|
| 55 | Q | 
|---|
| 56 | ; | 
|---|
| 57 | SORTBR ; sort billing rates by distribution and billing rate name | 
|---|
| 58 | ; ^TMP($J,"IBCRBR", national/local grouping , billing rate name, IBBRFN)="" | 
|---|
| 59 | N IBBRFN,IBLN,IBDSTR | 
|---|
| 60 | S IBBRFN=0 F  S IBBRFN=$O(^IBE(363.3,IBBRFN)) Q:'IBBRFN  D | 
|---|
| 61 | . S IBLN=$G(^IBE(363.3,IBBRFN,0)) Q:IBLN="" | 
|---|
| 62 | . S IBDSTR=$P(IBLN,U,3) I IBDSTR=2,IBBRFN<1000 S IBDSTR=1.5 | 
|---|
| 63 | . I 'IBDSTR S IBDSTR=9999 | 
|---|
| 64 | . S ^TMP($J,"IBCRBR",IBDSTR,$P(IBLN,U,1),IBBRFN)="" | 
|---|
| 65 | Q | 
|---|