source: FOIAVistA/trunk/r/INTEGRATED_BILLING-IB-PRQ--IBD--IBQ--PRQS/IBCNERP1.m@ 1068

Last change on this file since 1068 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 8.8 KB
Line 
1IBCNERP1 ;DAOU/BHS - IBCNE USER IF IIV RESPONSE REPORT ;03-JUN-2002
2 ;;2.0;INTEGRATED BILLING;**184,271**;21-MAR-94
3 ;;Per VHA Directive 10-93-142, this routine should not be modified.
4 ;
5 ; IIV - Insurance Identification and Verification Interface
6 ;
7 ; Input parameters: N/A
8 ; Other relevant variables ZTSAVED for queueing:
9 ; IBCNERTN = "IBCNERP1" (current routine name for queueing the
10 ; COMPILE process)
11 ; IBCNESPC("BEGDT")=start dt for rpt
12 ; IBCNESPC("ENDDT")=end dt for rpt
13 ; IBCNESPC("PYR")=payer ien (365.12) or "" for all payers
14 ; IBCNESPC("SORT")=1 (Payer name) OR 2 (Patient name)
15 ; IBCNESPC("PAT")=patient ien (2) or "" for all patients
16 ; IBCNESPC("TYPE")=A (All Responses) for date range OR M (Most Recent
17 ; Responses) for date range (by unique Payer/Pat pair)
18 ; IBCNESPC("TRCN")=Trace #^IEN, if non-null all other params are null
19 ; IBCNESPC("RFLAG")=Report Flag used to indicate which report is being
20 ; run. Response Report (0), Inactive Report (1), or Ambiguous
21 ; Report (2).
22 ; IBCNESPC("DTEXP")=Expiration date used in the inactive policy report
23 ;
24 ; Only call this routine at a tag
25 Q
26EN(IPRF) ; Main entry pt
27 ; Init vars
28 N STOP,IBCNERTN,POP,IBCNESPC
29 S IBCNESPC("RFLAG")=$G(IPRF)
30 ;
31 S STOP=0
32 S IBCNERTN="IBCNERP1"
33 W @IOF
34 W !,"IIV ",$S(IPRF=1:"Inactive Policy",IPRF=2:"Ambiguous Policy",1:"Response")," Report",!
35 I $G(IPRF) D
36 . W !,"Please select a date range to view ",$S(IPRF=1:"inactive",1:"ambiguous")," policy information that the IIV"
37 . W !,"process turned up while attempting to discover previously unknown"
38 . W !,"insurance policies. (Date range selection is based on the date that"
39 . W !,"IIV receives the response from the payer.)"
40 ;
41 I '$G(IPRF) D
42 . W !,"Insurance verification and identification responses are received daily."
43 . W !,"Please select a date range in which responses were received to view the"
44 . W !,"associated response detail. Otherwise, select a Trace # to view specific"
45 . W !,"response detail."
46 ;
47 ; Rpt by Date Range or Trace #
48R05 I '$G(IPRF) D RTYPE I STOP G:$$STOP EXIT G R05
49 ; If rpt by Trace # - no other criteria is necessary
50 I $G(IBCNESPC("TRCN")) G R100
51 ; Date Range params
52R10 D DTRANGE I STOP G:$$STOP EXIT G R05
53 ; Payer Selection param
54R20 D PYRSEL I STOP G:$$STOP EXIT G R10
55 ; Patient Selection param
56R30 D PTSEL I STOP G:$$STOP EXIT G R20
57 ; Type of data to return param
58R40 D TYPE I STOP G:$$STOP EXIT G R30
59 ; How far back do you want the expiration date
60R45 I $G(IPRF)=1 D DTEXP I STOP G:$$STOP EXIT G R40
61 ; Sort by param - Payer or Patient
62R50 D SORT I STOP G:$$STOP EXIT G R45
63 ; Select output device
64R100 D DEVICE(IBCNERTN,.IBCNESPC) I STOP G:$$STOP EXIT G:$G(IBCNESPC("TRCN"))'="" R05 G R50
65 G EXIT
66 ;
67EXIT ; Exit pt
68 Q
69 ;
70 ;
71COMPILE(IBCNERTN,IBCNESPC) ;
72 ; Entry point called from EN^XUTMDEVQ in either direct or queued mode.
73 ; Input params:
74 ; IBCNERTN = Routine name for ^TMP($J,...
75 ; IBCNESPC = Array passed by ref of the report params
76 ;
77 ; Init scratch globals
78 K ^TMP($J,IBCNERTN),^TMP($J,IBCNERTN_"X")
79 ; Compile
80 I IBCNERTN="IBCNERP1" D EN^IBCNERP2(IBCNERTN,.IBCNESPC)
81 I IBCNERTN="IBCNERP4" D EN^IBCNERP5(IBCNERTN,.IBCNESPC)
82 I IBCNERTN="IBCNERP7" D EN^IBCNERP8(IBCNERTN,.IBCNESPC)
83 ; Print
84 I '$G(ZTSTOP) D
85 . I IBCNERTN="IBCNERP1" D EN3^IBCNERPA(IBCNERTN,.IBCNESPC)
86 . I IBCNERTN="IBCNERP4" D EN6^IBCNERPA(IBCNERTN,.IBCNESPC)
87 . I IBCNERTN="IBCNERP7" D EN^IBCNERP9(IBCNERTN,.IBCNESPC)
88 ; Close device
89 D ^%ZISC
90 ; Kill scratch globals
91 K ^TMP($J,IBCNERTN),^TMP($J,IBCNERTN_"X")
92 ; Purge task record
93 I $D(ZTQUEUED) S ZTREQ="@"
94 ;
95COMPILX ; COMPILE exit pt
96 Q
97 ;
98STOP() ; Determine if user wants to exit out of the whole option
99 ; Init vars
100 N DIR,X,Y,DIRUT
101 ;
102 W !
103 S DIR(0)="Y"
104 S DIR("A")="Do you want to exit out of this option entirely"
105 S DIR("B")="YES"
106 S DIR("?",1)=" Enter YES to immediately exit out of this option."
107 S DIR("?")=" Enter NO to return to the previous question."
108 D ^DIR K DIR
109 I $D(DIRUT) S (STOP,Y)=1 G STOPX
110 I 'Y S STOP=0
111 ;
112STOPX ; STOP exit pt
113 Q Y
114 ;
115DTRANGE ; Determine start and end dates for date range param
116 ; Init vars
117 N X,Y,DIRUT
118 ;
119 W !
120 ;
121 S DIR(0)="D^:-NOW:EX"
122 S DIR("A")="Start DATE"
123 S DIR("?",1)=" Please enter a valid date for which an IIV Response"
124 S DIR("?")=" would have been received. Future dates are not allowed."
125 D ^DIR K DIR
126 I $D(DIRUT) S STOP=1 G DTRANGX
127 S IBCNESPC("BEGDT")=Y
128 ; End date
129DTRANG1 S DIR(0)="DA^"_Y_":-NOW:EX"
130 S DIR("A")=" End DATE: "
131 S DIR("?",1)=" Please enter a valid date for which an IIV Response"
132 S DIR("?",2)=" would have been received. This date must not precede"
133 S DIR("?")=" the Start Date. Future dates are not allowed."
134 D ^DIR K DIR
135 I $D(DIRUT) S STOP=1 G DTRANGX
136 S IBCNESPC("ENDDT")=Y
137 ;
138DTRANGX ; DTRANGE exit pt
139 Q
140 ;
141PYRSEL ; Select one payer or ALL - File #365.12
142 ; Init vars
143 NEW DIC,DTOUT,DUOUT,X,Y
144 ;
145 W !
146 S DIC(0)="ABEQ"
147 S DIC("A")=$$FO^IBCNEUT1("Payer or <Return> for All Payers: ",40,"R")
148 ; Do not allow selection of '~NO PAYER' and non-IIV payers
149 S DIC("S")="I ($P(^(0),U,1)'=""~NO PAYER""),$$PYRAPP^IBCNEUT5(""IIV"",$G(Y))'="""""
150 S DIC="^IBE(365.12,"
151 D ^DIC
152 I $D(DUOUT)!$D(DTOUT) S STOP=1 G PYRSELX
153 ; If nothing was selected (Y=-1), select ALL payers
154 S IBCNESPC("PYR")=$S(Y=-1:"",1:$P(Y,U,1))
155 ;
156PYRSELX ; PYRSEL exit pt
157 Q
158 ;
159PTSEL ; Select one patient or ALL - File #2
160 ; Init vars
161 NEW DIC,DTOUT,DUOUT,X,Y
162 ; Patient lookup
163 W !
164 S DIC(0)="AEQM"
165 S DIC("A")=$$FO^IBCNEUT1("Patient or <Return> for All Patients: ",40,"R")
166 S DIC="^DPT("
167 D ^DIC
168 I $D(DUOUT)!$D(DTOUT) S STOP=1 G PTSELX
169 ; If nothing was selected (Y=-1), select ALL patients
170 S IBCNESPC("PAT")=$S(Y=-1:"",1:$P(Y,U,1))
171 ;
172PTSELX ; PTSEL exit pt
173 Q
174 ;
175TYPE ; Prompt to select to display All or Most Recent Responses for
176 ; Patient/Payer combos
177 ; Init vars
178 N DIR,X,Y,DIRUT
179 ;
180 S DIR(0)="S^A:All Responses;M:Most Recent Responses"
181 S DIR("A")="Select the type of responses to display"
182 S DIR("B")="A"
183 S DIR("?",1)=" A - All responses from the payer during the date range will be"
184 S DIR("?",2)=" displayed for each unique payer/patient combination."
185 S DIR("?",3)=" (Default)"
186 S DIR("?",4)=" M - Only the most recently received response from the payer"
187 S DIR("?",5)=" during the date range will be displayed for each unique"
188 S DIR("?")=" payer/patient combination."
189 D ^DIR K DIR
190 I $D(DIRUT) S STOP=1 G TYPEX
191 S IBCNESPC("TYPE")=Y
192 ;
193TYPEX ; TYPE exit pt
194 Q
195 ;
196DTEXP ; Prompt for oldest expiration date to pull for.
197 ; Init Vars
198 N Y,DIRUT,TODAY
199 ;
200 W !
201 ;
202 S DIR(0)="D^:-NOW:EX"
203 S DIR("A")="Earliest Policy Expiration Date to Select From"
204 S DIR("B")="T-365"
205 S DIR("?",1)=" Please enter a valid date in the past. Any policy with a reported"
206 S DIR("?")=" expiration date prior to this date will not be selected."
207 D ^DIR K DIR
208 I $D(DIRUT) S STOP=1 G DTEXPX
209 S IBCNESPC("DTEXP")=Y
210 ;
211DTEXPX ; DTEXP Exit
212 Q
213 ;
214SORT ; Prompt to allow users to sort the report by Payer(default) or
215 ; Patient
216 ; Init vars
217 N DIR,X,Y,DIRUT
218 ;
219 S DIR(0)="S^1:Payer Name;2:Patient Name"
220 S DIR("A")="Select the primary sort field"
221 S DIR("B")=1
222 S DIR("?",1)=" 1 - Payer Name is the primary sort, Patient Name is secondary."
223 S DIR("?",2)=" (Default)"
224 S DIR("?")=" 2 - Patient Name is the primary sort, Payer Name is secondary."
225 D ^DIR K DIR
226 I $D(DIRUT) S STOP=1 G SORTX
227 S IBCNESPC("SORT")=Y
228 ;
229SORTX ; SORT exit pt
230 Q
231 ;
232RTYPE ; Prompt to allow users to report by date range or Trace #
233 ; Init vars
234 N D,DIC,DIR,X,Y,DIRUT,DTOUT,DUOUT
235 ;
236 S DIR(0)="S^1:Report by Date Range;2:Report by Trace #"
237 S DIR("A")="Select the type of report to generate"
238 S DIR("B")=1
239 S DIR("?",1)=" 1 - Generate report by date range, payer range, patient range"
240 S DIR("?",2)=" and All or Most Recent responses for payer/patient."
241 S DIR("?",3)=" (Default)"
242 S DIR("?",4)=" 2 - Generate report for a specific Trace # which corresponds"
243 S DIR("?")=" to an unique response."
244 D ^DIR K DIR
245 I $D(DIRUT) S STOP=1 G RTYPEX
246 I Y=1 S IBCNESPC("TRCN")="" G RTYPEX
247 ;
248 ; Allow user to select Trace # from x-ref "C"
249 W !
250 S DIC(0)="AEVZSQ"
251 S DIC="^IBCN(365,",D="C",DIC("A")="Enter Trace # for report: "
252 S DIC("W")="N IBX S IBX=$P($G(^(0)),U,2,3) W:$P(IBX,U,1) $P($G(^DPT($P(IBX,U,1),0)),U,1) W:$P(IBX,U,2) "" ""_$P($G(^IBE(365.12,$P(IBX,U,2),0)),U,1)"
253 D IX^DIC K DIC
254 I $D(DTOUT)!$D(DUOUT) S STOP=1 G RTYPEX
255 I 'Y!(Y<0) S STOP=1 G RTYPEX
256 S IBCNESPC("TRCN")=$P(Y(0),U,9)_"^"_$P(Y,U,1)
257 ;
258RTYPEX ; RTYPE exit pt
259 Q
260 ;
261DEVICE(IBCNERTN,IBCNESPC) ; Device Handler and possible TaskManager calls
262 ;
263 ; Input params:
264 ; IBCNERTN = Routine name for ^TMP($J,...
265 ; IBCNESPC = Array passed by ref of the report params
266 ;
267 ; Init vars
268 N ZTRTN,ZTDESC,ZTSAVE,POP
269 ;
270 I IBCNERTN="IBCNERP4" W !!!,"*** This report is 132 characters wide ***",!
271 S ZTRTN="COMPILE^IBCNERP1("""_IBCNERTN_""",.IBCNESPC)"
272 S ZTDESC="IBCNE IIV "_$S(IBCNERTN="IBCNERP1":"Response",1:"Payer")_" Report"
273 S ZTSAVE("IBCNESPC(")=""
274 S ZTSAVE("IBCNERTN")=""
275 D EN^XUTMDEVQ(ZTRTN,ZTDESC,.ZTSAVE)
276 I POP S STOP=1
277 ;
278DEVICEX ; DEVICE exit pt
279 Q
280 ;
Note: See TracBrowser for help on using the repository browser.