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