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)
|
---|