1 | BPSOSHF ;BHAM ISC/SD/lwj/DLF - Get/Format/Set value for DUR/PPS segment ;06/01/2004
|
---|
2 | ;;1.0;E CLAIMS MGMT ENGINE;**1,5**;JUN 2004;Build 45
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | ; This routine is an addendum to BPSOSCF. Its purpose is to handle
|
---|
6 | ; some of the repeating fields that now exist in NCPDP 5.1.
|
---|
7 | ; The logic was put in here rather than BPSOSCF to keep the original
|
---|
8 | ; routine (BPSOSCF) from growing too large and too cumbersome to
|
---|
9 | ; maintain.
|
---|
10 | ;
|
---|
11 | ; At this point, the only repeating fields we handle in this routine
|
---|
12 | ; are those contained in the DUR/PPS segment.
|
---|
13 | ;
|
---|
14 | DURPPS(FORMAT,NODE,MEDN) ;EP called from BPSOSCF
|
---|
15 | ;---------------------------------------------------------------
|
---|
16 | ;NCPDP 5.1 changes
|
---|
17 | ; Processing of the 5.1 DUR/PPS segment is much different than the
|
---|
18 | ; conventional segments of 3.2, simply because all of its fields
|
---|
19 | ; are optional, and repeating. The repeating portion of this
|
---|
20 | ; causes us to have yet another index we have to account for, and
|
---|
21 | ; we must be able to tell which of the fields really needs to be
|
---|
22 | ; populated. The population of this segment is based on those
|
---|
23 | ; values found for the prescription or refill in the BPS DUR/PPS
|
---|
24 | ; file. The file's values are temporarily stored in the
|
---|
25 | ; BPS("RX",MEDN,DUR....) array for easy access and reference.
|
---|
26 | ; (Special note - Overrides are not allowed on this multiple since
|
---|
27 | ; they can simply update the DUR/PPS filed directly. For the same
|
---|
28 | ; reason, "special" code is not accounted for either.
|
---|
29 | ;---------------------------------------------------------------
|
---|
30 | ;
|
---|
31 | ; first order of business - check the BPS("RX",MEDN,"DUR") array
|
---|
32 | ; for values - if there aren't any, we don't need to write this
|
---|
33 | ; segment
|
---|
34 | ;
|
---|
35 | N FIELD,RECCNT,DUR,FLD,OVERRIDE,FLAG,ORD,FLDIEN,FLDNUM,FLDNUMB,FOUND
|
---|
36 | S FLAG="FS"
|
---|
37 | I ^BPS(9002313.99,1,"CERTIFIER")=DUZ S FLAG="GFS"
|
---|
38 | ;
|
---|
39 | Q:'$D(BPS("RX",MEDN,"DUR"))
|
---|
40 | ;
|
---|
41 | ;next we need to figure out which fields on this format are really
|
---|
42 | ; needed, then we will loop through and populate them
|
---|
43 | ;
|
---|
44 | D GETFLDS(FORMAT,NODE,.FIELD)
|
---|
45 | ;
|
---|
46 | ; now lets get, format and set the field
|
---|
47 | S (ORD,RECCNT,DUR)=0
|
---|
48 | S RECCNT=RECCNT+1
|
---|
49 | F S DUR=$O(BPS("RX",MEDN,"DUR",DUR)) Q:DUR="" D
|
---|
50 | . S FLDNUM="" F S FLDNUM=$O(BPS("RX",MEDN,"DUR",DUR,FLDNUM)) Q:FLDNUM="" D
|
---|
51 | .. S ORD="",FOUND=0
|
---|
52 | .. F S ORD=$O(FIELD(ORD)) Q:ORD="" D Q:FOUND
|
---|
53 | ... S FLDNUMB="",FLDNUMB=$P(FIELD(ORD),U,2) Q:FLDNUMB'=FLDNUM
|
---|
54 | ... S FLDIEN="",FLDIEN=$P(FIELD(ORD),U)
|
---|
55 | ... S BPS("X")=BPS("RX",MEDN,"DUR",DUR,FLDNUM)
|
---|
56 | ... S FOUND=1
|
---|
57 | ... D XFLDCODE^BPSOSCF(NODE,FLDIEN,FLAG) ;format/set
|
---|
58 | ;
|
---|
59 | ; this sets the record count and last record on the subfile
|
---|
60 | S ^BPSC(BPS(9002313.02),400,BPS(9002313.0201),473.01,0)="^9002313.1001A^"_RECCNT_"^"_RECCNT
|
---|
61 | ;
|
---|
62 | Q
|
---|
63 | GETFLDS(FORMAT,NODE,FIELD) ;EP NCPDP 5.1
|
---|
64 | ;---------------------------------------------------------------
|
---|
65 | ;This routine will get the list of repeating fields that must be
|
---|
66 | ; be worked with separately
|
---|
67 | ; (This was originally coded for the DUR/PPS segment - I'm not
|
---|
68 | ; 100% sure how and if it will work for the other repeating
|
---|
69 | ; fields that exist within a segment.)
|
---|
70 | ;---------------------------------------------------------------
|
---|
71 | ; Coming in:
|
---|
72 | ; FORMAT = BPSF(9002313.92 's format IEN
|
---|
73 | ; NODE = which segment we are processing (i.e. 180 - DUR/PPS)
|
---|
74 | ; .FIELD = array to store the values in
|
---|
75 | ;
|
---|
76 | ; Exitting:
|
---|
77 | ; .FIELD array will look like:
|
---|
78 | ; FIELD(ord)=int^ext
|
---|
79 | ; Where: ext = external field number from BPSF(9002313.91
|
---|
80 | ; int = internal field number from BPSF(9002313.91
|
---|
81 | ; ord = the order of the field - used in creating clm
|
---|
82 | ;---------------------------------------------------------------
|
---|
83 | ;
|
---|
84 | N ORDER,RECMIEN,MDATA,FLDIEN,FLDNUM,DUR
|
---|
85 | ;
|
---|
86 | S ORDER=0
|
---|
87 | ;
|
---|
88 | F D Q:'ORDER
|
---|
89 | . ;
|
---|
90 | . ; let's order through the format file for this node
|
---|
91 | . ;
|
---|
92 | . S ORDER=$O(^BPSF(9002313.92,FORMAT,NODE,"B",ORDER)) Q:'ORDER
|
---|
93 | . S RECMIEN=$O(^BPSF(9002313.92,FORMAT,NODE,"B",ORDER,0))
|
---|
94 | . I 'RECMIEN D IMPOSS^BPSOSUE("DB","TI","NODE="_NODE,"ORDER="_ORDER,2,$T(+0))
|
---|
95 | . S MDATA=^BPSF(9002313.92,FORMAT,NODE,RECMIEN,0)
|
---|
96 | . S FLDIEN=$P(MDATA,U,2)
|
---|
97 | . I 'FLDIEN D IMPOSS^BPSOSUE("DB","TI","NODE="_NODE,"RECMIEN="_RECMIEN,3,$T(+0)) ; corrupt or erroneous format file
|
---|
98 | . I '$D(^BPSF(9002313.91,FLDIEN,0)) D IMPOSS^BPSOSUE("DB,P","TI","FLDIEN="_FLDIEN,,"DURPPS",$T(+0)) ;incomplete field definition
|
---|
99 | . ;
|
---|
100 | . ;lets create a list of fields we need
|
---|
101 | . S FLDNUM=$P($G(^BPSF(9002313.91,FLDIEN,0)),U)
|
---|
102 | . S:FLDNUM'=111 FIELD(ORDER)=FLDIEN_"^"_FLDNUM
|
---|
103 | ;
|
---|
104 | ;
|
---|
105 | Q
|
---|