| 1 | IBCVC   ;ALB/WCJ - VALUE CODE FUNCTIONALITY ;25-JUN-07
 | 
|---|
| 2 |         ;;2.0;INTEGRATED BILLING;**371**;21-MAR-94;Build 57
 | 
|---|
| 3 |         ;;Per VHA Directive 2004-038, this routine should not be modified.
 | 
|---|
| 4 |         G AWAY
 | 
|---|
| 5 | AWAY    Q
 | 
|---|
| 6 |         ;
 | 
|---|
| 7 | ALLOWVC(IBIFN,Y)          ; see if the value code is obsolete.
 | 
|---|
| 8 |         ; returns 0 = Not Allowed/Obsolete
 | 
|---|
| 9 |         ; returns 1 = Allowed
 | 
|---|
| 10 |         ;
 | 
|---|
| 11 |         N OBSDT,SCF
 | 
|---|
| 12 |         S OBSDT=$$GET1^DIQ(399.1,Y,.26,"I")
 | 
|---|
| 13 |         D CLEAN^DILF
 | 
|---|
| 14 |         Q:'+OBSDT 1  ; If there is no obsolete date, were cool
 | 
|---|
| 15 |         ;
 | 
|---|
| 16 |         S SCF=$$GET1^DIQ(399,IBIFN,151,"I")  ; get the statement covers from date to compare with
 | 
|---|
| 17 |         D CLEAN^DILF
 | 
|---|
| 18 |         I 'SCF Q 0  ; if there is none, not sure where to go with this.  It's required so I say fail.
 | 
|---|
| 19 |         ;
 | 
|---|
| 20 |         I SCF>OBSDT Q 0
 | 
|---|
| 21 |         ;
 | 
|---|
| 22 |         Q 1
 | 
|---|
| 23 |         ;
 | 
|---|
| 24 | HELP    ;
 | 
|---|
| 25 |         Q:'$G(DA)
 | 
|---|
| 26 |         Q:'$G(DA(1))
 | 
|---|
| 27 |         Q:'$D(^DGCR(399,DA(1),"CV",DA,0))
 | 
|---|
| 28 |         N VCPTR
 | 
|---|
| 29 |         S VCPTR=$P($G(^DGCR(399,DA(1),"CV",DA,0)),U)
 | 
|---|
| 30 |         Q:VCPTR=""
 | 
|---|
| 31 |         Q:'$D(^DGCR(399.1,VCPTR,1))
 | 
|---|
| 32 |         N LOOP
 | 
|---|
| 33 |         S LOOP=0 F  S LOOP=$O(^DGCR(399.1,VCPTR,1,LOOP)) Q:'+LOOP  D
 | 
|---|
| 34 |         . W !,$G(^(LOOP,0))
 | 
|---|
| 35 |         Q
 | 
|---|
| 36 |         ;
 | 
|---|
| 37 | FORMCHK(X,DA)   ; Check to make sure that the VALUE is in the correct format base on the VALUE CODE.
 | 
|---|
| 38 |         ; This tag is the input transform for the VALUE field (Sub-File 399.047, field .02).
 | 
|---|
| 39 |         ; 
 | 
|---|
| 40 |         ; X = data being verified
 | 
|---|
| 41 |         ; DA = subfile entry
 | 
|---|
| 42 |         ; DA(1) = IEN to 399
 | 
|---|
| 43 |         ; 
 | 
|---|
| 44 |         ; returns
 | 
|---|
| 45 |         ; 0 = invalid format
 | 
|---|
| 46 |         ; 1 = valid format
 | 
|---|
| 47 |         ; 
 | 
|---|
| 48 |         Q:'$G(DA) 0
 | 
|---|
| 49 |         Q:'$G(DA(1)) 0
 | 
|---|
| 50 |         Q:'$D(^DGCR(399,DA(1),"CV",DA,0)) 0
 | 
|---|
| 51 |         ;
 | 
|---|
| 52 |         N VCPTR
 | 
|---|
| 53 |         S VCPTR=$P($G(^DGCR(399,DA(1),"CV",DA,0)),U)
 | 
|---|
| 54 |         Q:VCPTR="" 0
 | 
|---|
| 55 |         ; 
 | 
|---|
| 56 |         Q $$CHK(VCPTR,X)
 | 
|---|
| 57 |         ;
 | 
|---|
| 58 | CHK(VCPTR,X)    ; This tag is called from the input transform above and also from the IB edit check routines (IBCBB*) 
 | 
|---|
| 59 |         ; This function is passed in:
 | 
|---|
| 60 |         ; VCPTR - pointer into file #399.1
 | 
|---|
| 61 |         ; X - the VALUE being checked
 | 
|---|
| 62 |         ; Returns:
 | 
|---|
| 63 |         ; 0 or false - Invalid format or can't figure it out.
 | 
|---|
| 64 |         ; 1 or true  - valid format (or in the case of 24, defined at the state level)
 | 
|---|
| 65 |         ; 
 | 
|---|
| 66 |         N CODE,OK
 | 
|---|
| 67 |         S CODE=$$GET1^DIQ(399.1,VCPTR_",",.02,"I")
 | 
|---|
| 68 |         D CLEAN^DILF
 | 
|---|
| 69 |         Q:CODE="" 0
 | 
|---|
| 70 |         ;
 | 
|---|
| 71 |         N AMTFLG
 | 
|---|
| 72 |         ;
 | 
|---|
| 73 |         ; Check to see if it goes out as a monetary amount.
 | 
|---|
| 74 |         S AMTFLG=$$GET1^DIQ(399.1,VCPTR_",",.19,"I")
 | 
|---|
| 75 |         D CLEAN^DILF
 | 
|---|
| 76 |         I AMTFLG Q X?1(1.7N,.7N1"."1.2N)
 | 
|---|
| 77 |         ;
 | 
|---|
| 78 |         ; Medicaid Rate Code (This is defined at the state level)
 | 
|---|
| 79 |         Q:CODE=24 1
 | 
|---|
| 80 |         ;
 | 
|---|
| 81 |         ; Accident Hour
 | 
|---|
| 82 |         I CODE=45 Q ".00.01.02.03.04.05.06.07.08.09.10.11.12.13.14.15.16.17.18.19.20.21.22.23.99."[("."_X_".")
 | 
|---|
| 83 |         ;
 | 
|---|
| 84 |         ; Whole Numbers
 | 
|---|
| 85 |         I ".37.38.39.46.50.51.52.53.56.57.58.59.67.68."[("."_CODE_".") Q X?1.7N
 | 
|---|
| 86 |         ;
 | 
|---|
| 87 |         ; Zip
 | 
|---|
| 88 |         I CODE="A0" Q X?5N
 | 
|---|
| 89 |         ;
 | 
|---|
| 90 |         I ".48.49."[("."_CODE_".") S OK=1 D  Q OK
 | 
|---|
| 91 |         . I $P(X,".")'?.2N S OK=0 Q
 | 
|---|
| 92 |         . I $P(X,".",2,999)'?.1N S OK=0 Q
 | 
|---|
| 93 |         . I $E(X,$L(X))="." S OK=0 Q
 | 
|---|
| 94 |         ;
 | 
|---|
| 95 |         ; Alpha Numeric, no punctuation
 | 
|---|
| 96 |         I ".60.61."[("."_CODE_".") Q X?1.7AN
 | 
|---|
| 97 |         Q 1
 | 
|---|
| 98 |         ;
 | 
|---|
| 99 | REMOVE(DA)      ; Remove the VALUE field since it's in the wrong format.
 | 
|---|
| 100 |         ; This is called from a NEW STYLE X-REF "AC" in file 399.047 field .01
 | 
|---|
| 101 |         N IENS,FDA
 | 
|---|
| 102 |         Q:'$G(DA)!'$G(DA(1))
 | 
|---|
| 103 |         S IENS=DA_","_DA(1)_","
 | 
|---|
| 104 |         S FDA(399.047,IENS,.02)="@"
 | 
|---|
| 105 |         D FILE^DIE(,"FDA")
 | 
|---|
| 106 |         D CLEAN^DILF
 | 
|---|
| 107 |         Q
 | 
|---|
| 108 |         ;
 | 
|---|
| 109 | COND(DA,OLDVC,NEWVC)    ; Check if the VALUE is in a valid format for the new VALUE CODE.
 | 
|---|
| 110 |         ; This is called from a NEW STYLE X-REF "AC" in file 399.047 field .01
 | 
|---|
| 111 |         ; This function will return:
 | 
|---|
| 112 |         ; 1 - Means that this VALUE should be deleted (It's in the wrong format)
 | 
|---|
| 113 |         ; 0 - Means that this VALUE should NOT be deleted
 | 
|---|
| 114 |         Q:'$G(OLDVC) 0
 | 
|---|
| 115 |         Q:'$G(DA)!'$G(DA(1)) 0
 | 
|---|
| 116 |         N OLDVALUE
 | 
|---|
| 117 |         S OLDVALUE=$P($G(^DGCR(399,DA(1),"CV",DA,0)),U,2)
 | 
|---|
| 118 |         Q:OLDVALUE="" 0
 | 
|---|
| 119 |         Q '$$CHK(NEWVC,OLDVALUE)
 | 
|---|