| [613] | 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 | 
|---|