1 | BPSRPT3 ;BHAM ISC/BEE - ECME REPORTS ;14-FEB-05
|
---|
2 | ;;1.0;E CLAIMS MGMT ENGINE;**1,3,5**;JUN 2004;Build 45
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | Q
|
---|
6 | ;
|
---|
7 | ; Select the ECME Pharmacy or Pharmacies
|
---|
8 | ;
|
---|
9 | ; Input Variable -> none
|
---|
10 | ; Return Value -> "" = Valid Entry or Entries Selected
|
---|
11 | ; ^ = Exit
|
---|
12 | ;
|
---|
13 | ; Output Variable -> BPPHARM = 1 One or More Pharmacies Selected
|
---|
14 | ; = 0 User Entered 'ALL'
|
---|
15 | ;
|
---|
16 | ; If BPPHARM = 1 then the BPPHARM array will be defined where:
|
---|
17 | ; BPPHARM(ptr) = ptr ^ BPS PHARMACY NAME and
|
---|
18 | ; ptr = Internal Pointer to BPS PHARMACIES file (#9002313.56)
|
---|
19 | ;
|
---|
20 | SELPHARM() N DIC,DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
21 | ;
|
---|
22 | ;Reset BPPHARM array
|
---|
23 | K BPPHARM
|
---|
24 | ;
|
---|
25 | ;First see if they want to enter individual divisions or ALL
|
---|
26 | S DIR(0)="S^D:DIVISION;A:ALL"
|
---|
27 | S DIR("A")="Select Certain Pharmacy (D)ivisions or (A)LL"
|
---|
28 | S DIR("L",1)="Select one of the following:"
|
---|
29 | S DIR("L",2)=""
|
---|
30 | S DIR("L",3)=" D DIVISION"
|
---|
31 | S DIR("L",4)=" A ALL"
|
---|
32 | D ^DIR K DIR
|
---|
33 | ;
|
---|
34 | ;Check for "^" or timeout, otherwise define BPPHARM
|
---|
35 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
36 | E S BPPHARM=$S(Y="A":0,1:1)
|
---|
37 | ;
|
---|
38 | ;If division selected, ask prompt
|
---|
39 | I $G(BPPHARM)=1 F D Q:Y="^"!(Y="")
|
---|
40 | .;
|
---|
41 | .;Prompt for entry
|
---|
42 | .K X S DIC(0)="QEAM",DIC=9002313.56,DIC("A")="Select ECME Pharmacy Division(s): "
|
---|
43 | .W ! D ^DIC
|
---|
44 | .;
|
---|
45 | .;Check for "^" or timeout
|
---|
46 | .I ($G(DUOUT)=1)!($G(DTOUT)=1) K BPPHARM S Y="^" Q
|
---|
47 | .;
|
---|
48 | .;Check for blank entry, quit if no previous selections
|
---|
49 | .I $G(X)="" S Y=$S($D(BPPHARM)>9:"",1:"^") K:Y="^" BPPHARM Q
|
---|
50 | .;
|
---|
51 | .;Handle Deletes
|
---|
52 | .I $D(BPPHARM(+Y)) D Q:Y="^" I 1
|
---|
53 | ..N P
|
---|
54 | ..S P=Y ;Save Original Value
|
---|
55 | ..S DIR(0)="S^Y:YES;N:NO",DIR("A")="Delete "_$P(P,U,2)_" from your list?"
|
---|
56 | ..S DIR("B")="NO" D ^DIR
|
---|
57 | ..I ($G(DUOUT)=1)!($G(DTOUT)=1) K BPPHARM S Y="^" Q
|
---|
58 | ..I Y="Y" K BPPHARM(+P),BPPHARM("B",$P(P,U,2),+P)
|
---|
59 | ..S Y=P ;Restore Original Value
|
---|
60 | ..K P
|
---|
61 | .E D
|
---|
62 | ..;Define new entries in BPPHARM array
|
---|
63 | ..S BPPHARM(+Y)=Y
|
---|
64 | ..S BPPHARM("B",$P(Y,U,2),+Y)=""
|
---|
65 | .;
|
---|
66 | .;Display a list of selected divisions
|
---|
67 | .I $D(BPPHARM)>9 D
|
---|
68 | ..N X
|
---|
69 | ..W !,?2,"Selected:"
|
---|
70 | ..S X="" F S X=$O(BPPHARM("B",X)) Q:X="" W !,?10,X
|
---|
71 | ..K X
|
---|
72 | .Q
|
---|
73 | ;
|
---|
74 | K BPPHARM("B")
|
---|
75 | Q Y
|
---|
76 | ;
|
---|
77 | ; Display (S)ummary or (D)etail Format
|
---|
78 | ;
|
---|
79 | ; Input Variable -> DFLT = 1 Summary
|
---|
80 | ; 2 Detail
|
---|
81 | ;
|
---|
82 | ; Return Value -> 1 = Summary
|
---|
83 | ; 0 = Detail
|
---|
84 | ; ^ = Exit
|
---|
85 | ;
|
---|
86 | SELSMDET(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
87 | S DFLT=$S($G(DFLT)=1:"Summary",$G(DFLT)=0:"Detail",1:"Detail")
|
---|
88 | S DIR(0)="S^S:Summary;D:Detail",DIR("A")="Display (S)ummary or (D)etail Format",DIR("B")=DFLT
|
---|
89 | D ^DIR
|
---|
90 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
91 | S Y=$S(Y="S":1,Y="D":0,1:Y)
|
---|
92 | Q Y
|
---|
93 | ;
|
---|
94 | ; Select to Display Single (I)nsurance Company or (A)ll
|
---|
95 | ;
|
---|
96 | ; Input Variable -> DFLT = 1 Single Insurance
|
---|
97 | ; 0 All Insurance
|
---|
98 | ;
|
---|
99 | ; Return Value -> ptr to #36^Insurance Company Name
|
---|
100 | ; 0 = All Insurances
|
---|
101 | ; ^ = Exit
|
---|
102 | ;
|
---|
103 | SELINSIN(DFLT) N DIC,DIR,DIRUT,DUOUT,INS,X,Y
|
---|
104 | ;
|
---|
105 | S DFLT=$S($G(DFLT)=1:"Single Insurance",1:"ALL")
|
---|
106 | S DIR(0)="S^I:Single Insurance;A:ALL"
|
---|
107 | S DIR("A")="Display Single (I)nsurance Company or (A)LL",DIR("B")=DFLT
|
---|
108 | D ^DIR
|
---|
109 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
110 | S INS=$S(Y="I":1,Y="A":0,1:Y)
|
---|
111 | ;
|
---|
112 | ;Check for "^" or timeout, otherwise define INS
|
---|
113 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S (INS,Y)="^"
|
---|
114 | ;
|
---|
115 | ;If single insurance selected, ask prompt
|
---|
116 | I $G(INS)=1 D
|
---|
117 | .;
|
---|
118 | .;Prompt for entry
|
---|
119 | .W ! S Y=$$SELINS^BPSRPT6()
|
---|
120 | .;
|
---|
121 | .;Check for "^", timeout, or blank entry
|
---|
122 | .I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S (INS,Y)="^" Q
|
---|
123 | .;
|
---|
124 | .;If valid entry, setup INS
|
---|
125 | .I Y'="^" S INS=Y
|
---|
126 | ;
|
---|
127 | Q INS
|
---|
128 | ;
|
---|
129 | ; Display (C)MOP or (M)ail or (W)indow or (A)ll
|
---|
130 | ;
|
---|
131 | ; Input Variable -> DFLT = C CMOP
|
---|
132 | ; W Window
|
---|
133 | ; M Mail
|
---|
134 | ; A All
|
---|
135 | ;
|
---|
136 | ; Return Value -> C = CMOP
|
---|
137 | ; W = Window
|
---|
138 | ; M = Mail
|
---|
139 | ; A = All
|
---|
140 | ; ^ = Exit
|
---|
141 | ;
|
---|
142 | SELMWC(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
143 | S DFLT=$S($G(DFLT)="C":"CMOP",$G(DFLT)="W":"Window",$G(DFLT)="M":"Mail",1:"ALL")
|
---|
144 | S DIR(0)="S^C:CMOP;M:Mail;W:Window;A:ALL"
|
---|
145 | S DIR("A")="Display (C)MOP or (M)ail or (W)indow or (A)LL",DIR("B")=DFLT
|
---|
146 | D ^DIR
|
---|
147 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
148 | Q Y
|
---|
149 | ;
|
---|
150 | ; Display (R)ealTime Fills or (B)ackbills or (A)LL
|
---|
151 | ;
|
---|
152 | ; Input Variable -> DFLT = 3 Backbill
|
---|
153 | ; 2 Real Time Fills
|
---|
154 | ; 1 ALL
|
---|
155 | ;
|
---|
156 | ; Return Value -> 3 = Backbill (manually)
|
---|
157 | ; 2 = Real Time Fills (automatically during FINISH)
|
---|
158 | ; 1 = ALL
|
---|
159 | ; ^ = Exit
|
---|
160 | ;
|
---|
161 | SELRTBCK(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
162 | S DFLT=$S($G(DFLT)=2:"Real Time",$G(DFLT)=3:"Backbill",1:"ALL")
|
---|
163 | S DIR(0)="S^R:Real Time Fills;B:Backbill;A:ALL"
|
---|
164 | S DIR("A")="Display (R)ealTime Fills or (B)ackbills or (A)LL",DIR("B")=DFLT
|
---|
165 | D ^DIR
|
---|
166 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
167 | S Y=$S(Y="A":1,Y="R":2,Y="B":3,1:Y)
|
---|
168 | Q Y
|
---|
169 | ;
|
---|
170 | ; Display Specific (D)rug or Drug (C)lass
|
---|
171 | ;
|
---|
172 | ; Input Variable -> DFLT = 3 Drug Class
|
---|
173 | ; 2 Drug
|
---|
174 | ; 1 ALL
|
---|
175 | ;
|
---|
176 | ; Return Value -> 3 = Drug Class
|
---|
177 | ; 2 = Drug
|
---|
178 | ; 1 = ALL
|
---|
179 | ; ^ = Exit
|
---|
180 | ;
|
---|
181 | SELDRGAL(DFLT) N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
182 | S DFLT=$S($G(DFLT)=2:"Drug",$G(DFLT)=3:"Drug Class",1:"ALL")
|
---|
183 | S DIR(0)="S^D:Drug;C:Drug Class;A:ALL"
|
---|
184 | S DIR("A")="Display Specific (D)rug or Drug (C)lass or (A)LL",DIR("B")=DFLT
|
---|
185 | D ^DIR
|
---|
186 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
187 | S Y=$S(Y="A":1,Y="D":2,Y="C":3,1:Y)
|
---|
188 | Q Y
|
---|
189 | ;
|
---|
190 | ; Select Drug
|
---|
191 | ;
|
---|
192 | ; Input Variable -> none
|
---|
193 | ;
|
---|
194 | ; Return Value -> ptr = pointer to DRUG file (#50)
|
---|
195 | ; ^ = Exit
|
---|
196 | ;
|
---|
197 | SELDRG() N DIC,DIRUT,DUOUT,X,Y
|
---|
198 | ;
|
---|
199 | ;Prompt for entry
|
---|
200 | W ! D SELDRG^BPSRPT6
|
---|
201 | ;
|
---|
202 | ;Check for "^", timeout, or blank entry
|
---|
203 | I ($G(DUOUT)=1)!($G(DTOUT)=1) S Y="^"
|
---|
204 | ;
|
---|
205 | ;Check for Valid Entry
|
---|
206 | I +Y>0 S Y=+Y
|
---|
207 | ;
|
---|
208 | Q Y
|
---|
209 | ;
|
---|
210 | ; Select Drug Class
|
---|
211 | ;
|
---|
212 | ; Input Variable -> none
|
---|
213 | ;
|
---|
214 | ; Return Value -> ptr = pointer to VA DRUG CLASS file (#50.605)
|
---|
215 | ; ^ = Exit
|
---|
216 | ;
|
---|
217 | SELDRGCL() N DIC,DIRUT,DUOUT,Y
|
---|
218 | ;
|
---|
219 | ;Prompt for entry
|
---|
220 | W ! D SELDRGC^BPSRPT6
|
---|
221 | ;
|
---|
222 | ;Check for "^", timeout, or blank entry
|
---|
223 | I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(Y)="") S Y="^"
|
---|
224 | ;
|
---|
225 | Q Y
|
---|
226 | ;
|
---|
227 | ; Enter Date Range
|
---|
228 | ;
|
---|
229 | ; Input Variable -> TYPE = 7 CLOSE REPORT
|
---|
230 | ; 1-6 OTHER REPORTS
|
---|
231 | ;
|
---|
232 | ; Return Value -> P1^P2
|
---|
233 | ;
|
---|
234 | ; where P1 = From Date
|
---|
235 | ; = ^ Exit
|
---|
236 | ; P2 = To Date
|
---|
237 | ; = blank for Exit
|
---|
238 | ;
|
---|
239 | SELDATE(TYPE) N BPSIBDT,DIR,DIRUT,DTOUT,DUOUT,VAL,X,Y
|
---|
240 | S TYPE=$S($G(TYPE)=7:"CLOSE",1:"TRANSACTION")
|
---|
241 | SELDATE1 S VAL="",DIR(0)="DA^:DT:EX",DIR("A")="START WITH "_TYPE_" DATE: ",DIR("B")="T-1"
|
---|
242 | W ! D ^DIR
|
---|
243 | ;
|
---|
244 | ;Check for "^", timeout, or blank entry
|
---|
245 | I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S VAL="^"
|
---|
246 | ;
|
---|
247 | I VAL="" D
|
---|
248 | .S $P(VAL,U)=Y
|
---|
249 | .S DIR(0)="DA^"_VAL_":DT:EX",DIR("A")=" GO TO "_TYPE_" DATE: ",DIR("B")="T"
|
---|
250 | .D ^DIR
|
---|
251 | .;
|
---|
252 | .;Check for "^", timeout, or blank entry
|
---|
253 | .I ($G(DUOUT)=1)!($G(DTOUT)=1)!($G(X)="") S VAL="^" Q
|
---|
254 | .;
|
---|
255 | .;Define Entry
|
---|
256 | .S $P(VAL,U,2)=Y
|
---|
257 | ;
|
---|
258 | Q VAL
|
---|