1 | TMGNDF2F ;TMG/kst/FDA Import: Fix drugs with missing ingredients ;03/25/06
|
---|
2 | ;;1.0;TMG-LIB;**1**;11/21/06
|
---|
3 |
|
---|
4 | ;" FDA - NATIONAL DRUG FILES COMPILING FUNCTIONS
|
---|
5 | ;" Further processing, after functions in TMGNDF2E
|
---|
6 | ;" Fixing drugs with missing ingredients (i.e. not provided by FDA database)
|
---|
7 | ;"Kevin Toppenberg MD
|
---|
8 | ;"GNU General Public License (GPL) applies
|
---|
9 | ;"11-21-2006
|
---|
10 |
|
---|
11 | ;"=======================================================================
|
---|
12 | ;" API -- Public Functions.
|
---|
13 | ;"=======================================================================
|
---|
14 | ;" //no Menu -- will launch FixMissing from Menu^TMGNDF2E
|
---|
15 | ;"=======================================================================
|
---|
16 | ;"FixMissing -- Fix entries in file 22706.9 that don't have any ingredients,
|
---|
17 | ;" either by finding similar drugs already present, and using
|
---|
18 | ;" their ingredients, or asking user.
|
---|
19 |
|
---|
20 | ;"=======================================================================
|
---|
21 | ;" Private Functions.
|
---|
22 | ;"=======================================================================
|
---|
23 | ;"GetMissing(List) -- Gather list of drugs that have no ingredients
|
---|
24 | ;"GetSuggestions(List) -- expand list such that it contains suggested ingredients
|
---|
25 | ;"Suggest1(IEN,Array) -- find a suggested answer for one record
|
---|
26 | ;"SgstFromVAP(IEN,vapIEN,Array) -- Return list of ingredient IENs based on IEN from VA PRODUCT
|
---|
27 | ;"SgstByName(IEN,Array) -- find suggested ingredients of one drug, based on IEN from 22706.9
|
---|
28 | ;"ShowList(Array,Answers,ShowBoth,ByGeneric,ShowIngred,CompactMode) -- display the list generated by GetSuggestions
|
---|
29 | ;"HandleList(Array) -- allow user to manipulate and fix problems found
|
---|
30 | ;"XMenuOption(Prompt,FnStr,HlpFn,EntryList,EntryS) -- carry out the various menu functions
|
---|
31 | ;"SetSkip(Array,Answers,EntryList) -- remove entries from consideration for adding to 50.68
|
---|
32 | ;"ShowInfo(Array,Answers,EntryList) -- allow user to explore existing entries in 22706.9 file
|
---|
33 | ;"Lookup(Array,Answers,EntryList) -- allow user to explore existing entries in 50.68 file
|
---|
34 | ;"FixItems(Array,Answers,EntryList) -- Fix one item
|
---|
35 | ;"AskFix1Item(Array,IEN) -- fix one entry, with user input
|
---|
36 | ;"Show1(Array,IEN,Answers,ShowIgd) -- display the list generated by GetSuggestions
|
---|
37 | ;"Look2Fix(IEN,Array) -- allow user to find a match to use for fixing.
|
---|
38 | ;"KillMatch(IEN,Array,Answers,EntryList) -- remove VA PRODUCT matches from consideration
|
---|
39 | ;"ArrayKill(IEN,Array) -- remove entry IEN from the Array of drugs to be fixed
|
---|
40 | ;"Fix1From(IEN,vapIEN,Array,NoVerify) -- use rec in VA PRODUCT file to fix rec in TMG FDA IMPORT COMPILED
|
---|
41 | ;"VerifySource(vapIEN) -- show the drug name, and the drug's ingredients, and ask user to verify choice
|
---|
42 | ;"Copy1(vapIEN,IEN) -- fill in missing answers in the record in 22706.9, from record in 50.68
|
---|
43 | ;"ManIngredients(Array,Answers,EntryList) -- Manually Add ingredients to a list of records
|
---|
44 | ;"AskManIngred(IEN,IngredArray) -- ask user for a list of ingredients, then add to record in 22706.9
|
---|
45 | ;"ShowIngreds(IngredArray) -- Show list of ingredients in array
|
---|
46 | ;"Add1Ingredients(IEN,IngredArray) -- put a list of ingredients into one (1) record in 22706.9
|
---|
47 |
|
---|
48 | ;"=======================================================================
|
---|
49 | ;"=======================================================================
|
---|
50 |
|
---|
51 | ;"Note: The FDA database lists some drugs that do not have ingredients specified.
|
---|
52 | ;" Some such drugs may not be wanted, and some others might have easily
|
---|
53 | ;" identifiable ingredients (i.e. Lasix -->can figure out ingredient of furosemide)
|
---|
54 | ;" So the purpose of this module is to handle those drugs that don't have
|
---|
55 | ;" enough information for addition into the VistA system.
|
---|
56 |
|
---|
57 | FixMissing
|
---|
58 | ;"Purpose: Fix entries in file 22706.9 that don't have any ingredients,
|
---|
59 | ;" either by finding similar drugs already present, and using
|
---|
60 | ;" their ingredients, or asking user.
|
---|
61 |
|
---|
62 | new List,Answers
|
---|
63 | write "Scanning TMG FDA IMPORT COMPILED file for drugs with missing information.",!
|
---|
64 | do GetMissing(.List)
|
---|
65 | write !
|
---|
66 | write "Searching for potential fixes for each drug with missing information",!
|
---|
67 | do GetSuggestions(.List)
|
---|
68 | write !
|
---|
69 | do HandleList(.List)
|
---|
70 |
|
---|
71 | ;"do ShowList(.List,.Answers,1,0)
|
---|
72 |
|
---|
73 | quit
|
---|
74 |
|
---|
75 |
|
---|
76 | GetMissing(List)
|
---|
77 | ;"Purpose: Gather list of drugs that have no ingredients
|
---|
78 | ;"Input: List -- PASS BY REFERENCE, an OUT PARAMETER
|
---|
79 | ;" format:
|
---|
80 | ;" List(IEN)=TMGTradeName^TMGGeneric
|
---|
81 | ;" List(IEN)=TMGTradeName^TMGGeneric
|
---|
82 | ;" List("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
83 | ;" List("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
84 | ;"results: none
|
---|
85 |
|
---|
86 | new Itr,IEN
|
---|
87 | set IEN=$$ItrInit^TMGITR(22706.9,.Itr)
|
---|
88 | do PrepProgress^TMGITR(.Itr,2)
|
---|
89 | if IEN'="" for do quit:($$ItrNext^TMGITR(.Itr,.IEN)'>0)
|
---|
90 | . if $piece($get(^TMG(22706.9,IEN,1)),"^",4)=1 quit ;" 1;4=SKIP THIS RECORD
|
---|
91 | . if +$piece($get(@Itr@(IEN,4,0)),"^",4)=0 do ;"4;0 -> header of INGREDIENTS subfile, part 4=rec count
|
---|
92 | . . new TMGTradeName set TMGTradeName=$$GET1^DIQ(22706.9,IEN,.05)
|
---|
93 | . . set TMGTradeName=$translate(TMGTradeName,"""","'")
|
---|
94 | . . if TMGTradeName="" set TMGTradeName="?"
|
---|
95 | . . new TMGGeneric set TMGGeneric=$$GET1^DIQ(22706.9,IEN,.07)
|
---|
96 | . . set TMGGeneric=$translate(TMGGeneric,"""","'")
|
---|
97 | . . if TMGGeneric="" set TMGGeneric="?"
|
---|
98 | . . set List(IEN)=TMGTradeName_"^"_TMGGeneric
|
---|
99 | . . if TMGGeneric'="?" set List("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
100 | . . set List("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
101 |
|
---|
102 | quit
|
---|
103 |
|
---|
104 |
|
---|
105 | GetSuggestions(List)
|
---|
106 | ;"Purpose: expand list such that it contains suggested ingredients
|
---|
107 | ;"Input: List -- PASS BY REFERENCE,
|
---|
108 | ;" List(IEN)=TMGTradeName^VAGeneric
|
---|
109 | ;" List(IEN)=TMGTradeName^VAGeneric
|
---|
110 | ;" List("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
111 | ;" List("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
112 | ;"Output: List is filled in, as follows:
|
---|
113 | ;" List(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
114 | ;" List(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
115 | ;" List(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
116 | ;" List(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
117 | ;" List(IEN)=TMGTradeName^VAGeneric
|
---|
118 | ;" List(IEN)=TMGTradeName^VAGeneric
|
---|
119 | ;" List("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
120 | ;" List("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
121 |
|
---|
122 | new IEN,Itr
|
---|
123 | set IEN=$$ItrAInit^TMGITR("List",.Itr)
|
---|
124 | do PrepProgress^TMGITR(.Itr,10)
|
---|
125 | if IEN'="" for do quit:($$ItrANext^TMGITR(.Itr,.IEN)'>0)
|
---|
126 | . do Suggest1(IEN,.List)
|
---|
127 |
|
---|
128 | quit
|
---|
129 |
|
---|
130 |
|
---|
131 | Suggest1(IEN,Array)
|
---|
132 | ;"Purpose: To find a suggested answer for one record
|
---|
133 | ;"Input: IEN -- the IEN in file 22706.9 to find answer for
|
---|
134 | ;" Array -- PASS BY REFERENCE, an OUT PARAMETER. FORMAT:
|
---|
135 | ;" Array(IEN)=TMGTradeName^VAGeneric
|
---|
136 | ;" Array(IEN)=TMGTradeName^VAGeneric
|
---|
137 | ;"Output: Array is returned
|
---|
138 | ;" Note: RxIEN is IEN in file 50.416
|
---|
139 | ;" Array(IEN)=TMGTradeName^VAGeneric
|
---|
140 | ;" Array(IEN)=TMGTradeName^VAGeneric
|
---|
141 | ;" List(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
142 | ;" List(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
143 | ;" List(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
144 | ;" List(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
145 | ;"Results: none
|
---|
146 |
|
---|
147 | new Itr,RxIEN,vapIEN
|
---|
148 | set vapIEN=$$ItrFInit^TMGITR(22706.914,.Itr,.RxIEN,.01,IEN,"I")
|
---|
149 | if vapIEN'="" for do quit:($$ItrFNext^TMGITR(.Itr,.RxIEN,.vapIEN)'>0)
|
---|
150 | . do SgstFromVAP(IEN,vapIEN,.Array)
|
---|
151 |
|
---|
152 | kill Itr
|
---|
153 | set RxIEN=$$ItrFInit^TMGITR(22706.915,.Itr,.RxIEN,.01,IEN,"I")
|
---|
154 | if RxIEN'="" for do quit:($$ItrFNext^TMGITR(.Itr,.RxIEN,.vapIEN)'>0)
|
---|
155 | . do SgstFromVAP(IEN,RxIEN,.Array)
|
---|
156 |
|
---|
157 | do SgstByName(IEN,.Array)
|
---|
158 |
|
---|
159 | quit
|
---|
160 |
|
---|
161 |
|
---|
162 | SgstFromVAP(IEN,vapIEN,Array)
|
---|
163 | ;"Purpose: Return list of ingredient IENs based on IEN from VA PRODUCT
|
---|
164 | ;"Input: IEN -- the IEN in file 22706.9
|
---|
165 | ;" vapIEN -- an IEN to file 50.68 (VA PRODUCT)
|
---|
166 | ;" Array -- PASS BY REFERENCE, an OUT PARAMETER. format:
|
---|
167 | ;" Note: RxIEN is IEN in file 50.416
|
---|
168 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
169 | ;"Output: Array is filled with data, if found
|
---|
170 | ;" Note: RxIEN is IEN in file 50.416
|
---|
171 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
172 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
173 | ;" Array(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
174 | ;" Array(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
175 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
176 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
177 | ;"Results: none.
|
---|
178 |
|
---|
179 | new Itr,igdIEN,IEN2
|
---|
180 | set igdIEN=$$ItrFInit^TMGITR(50.6814,.Itr,.IEN2,.01,vapIEN,"I")
|
---|
181 | if igdIEN'="" for do quit:($$ItrFNext^TMGITR(.Itr,.IEN2,.igdIEN)'>0)
|
---|
182 | . if igdIEN'=0 do
|
---|
183 | . . new IENS set IENS=igdIEN_","_IEN_","
|
---|
184 | . . new IngredName set IngredName=$$GET1^DIQ(50.416,IENS,.01)
|
---|
185 | . . set Array(IEN,"POSS IGD MATCH",igdIEN)=IngredName
|
---|
186 |
|
---|
187 | quit
|
---|
188 |
|
---|
189 |
|
---|
190 | SgstByName(IEN,Array)
|
---|
191 | ;"Purpose: to find suggested ingredients of one drug, based on IEN from 22706.9
|
---|
192 | ;"Input: IEN -- IEN from 22706.9
|
---|
193 | ;" Array -- PASS BY REFERENCE, an OUT PARAMETER. format:
|
---|
194 | ;" Note: RxIEN is IEN in file 50.416
|
---|
195 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
196 | ;"Output: Array is filled with data, if found
|
---|
197 | ;" Note: RxIEN is IEN in file 50.416
|
---|
198 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
199 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
200 | ;" Array(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
201 | ;" Array(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
202 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
203 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
204 | ;"Results: none.
|
---|
205 |
|
---|
206 | new TMGTradeName,TMGFDA,TMGMSG,PriorErrorFound
|
---|
207 | set TMGTradeName=$piece($get(Array(IEN)),"^",1)
|
---|
208 | if (TMGTradeName="")!(TMGTradeName="?") goto SBNDone
|
---|
209 | new Value set Value=$piece(TMGTradeName," ",1)
|
---|
210 | do FIND^DIC(50.68,,.01,"M",Value,"*",,,,"TMGFDA","TMGMSG")
|
---|
211 | if $data(TMGMSG("DIERR"))'=0 do goto SBNDone
|
---|
212 | . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
213 |
|
---|
214 | ;"Now gather ingredient list from results found
|
---|
215 | new i,vapIEN
|
---|
216 | for i=1:1:$piece($get(TMGFDA("DILIST",0)),"^",1) do
|
---|
217 | . set vapIEN=+$get(TMGFDA("DILIST",2,i))
|
---|
218 | . new vapName set vapName=$$GET1^DIQ(50.68,vapIEN,.01)
|
---|
219 | . set Array(IEN,"POSS RX MATCH",vapIEN)=vapName
|
---|
220 | . do SgstFromVAP(IEN,vapIEN,.Array)
|
---|
221 |
|
---|
222 | SBNDone
|
---|
223 | quit
|
---|
224 |
|
---|
225 | ;"=======================================================================
|
---|
226 |
|
---|
227 | ShowList(Array,Answers,ShowBoth,ByGeneric,ShowIngred,CompactMode)
|
---|
228 | ;"Purpose: To display the list generated by GetSuggestions
|
---|
229 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format:
|
---|
230 | ;" note IEN is from 22706.9
|
---|
231 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
232 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
233 | ;" Array("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
234 | ;" Array("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
235 | ;" Array(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
236 | ;" Array(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
237 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
238 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
239 | ;" Answers -- PASS BY REFERENCE, and OUT PARAMETER
|
---|
240 | ;" An array that will link display numbers with IENs
|
---|
241 | ;" Answer(count)=IEN^TMGTradeName^TMGGeneric
|
---|
242 | ;" Answer(count)=IEN^TMGTradeName^TMGGeneric
|
---|
243 | ;" ShowBoth -- OPTIONAL, if value=1, thenTMGGeneric & TMGTrade names will both be shown. Default=0
|
---|
244 | ;" ByGeneric -- OPTIONAL, if value=1, then list is shown sorted by Generic Name. Default=0
|
---|
245 | ;" ShowIngred -- OPTIONAL, if value=1 then all possible ingredients are shown. Default=0
|
---|
246 | ;" CompactMode -- OPTIONAL, if value=1 then only 20 entries are shown.
|
---|
247 | ;"Output: List is shown, and the Answers array is established and passed back.
|
---|
248 | ;"Results: none.
|
---|
249 |
|
---|
250 | new someShown set someShown=0
|
---|
251 | new count
|
---|
252 | set count=1
|
---|
253 | kill Answers
|
---|
254 | set ShowBoth=$get(ShowBoth,0)
|
---|
255 | set ByGeneric=$get(ByGeneric,0)
|
---|
256 | set ShowIngred=$get(ShowIngred,0)
|
---|
257 | set CompactMode=$get(CompactMode,0)
|
---|
258 | new NodeName set NodeName="BY TRADE"
|
---|
259 | if ByGeneric=1 set NodeName="BY GENERIC"
|
---|
260 | new ShortLen set ShortLen=25
|
---|
261 |
|
---|
262 | write NodeName,!
|
---|
263 |
|
---|
264 | new done set done=0
|
---|
265 | new Itr,RxName,OtherName,IEN
|
---|
266 | set RxName=$$ItrAInit^TMGITR("Array("""_NodeName_""")",.Itr)
|
---|
267 | if RxName'="" for do quit:($$ItrANext^TMGITR(.Itr,.RxName)="")!(done=1)
|
---|
268 | . new Itr2
|
---|
269 | . set IEN=$$ItrAInit^TMGITR("Array("""_NodeName_""","""_RxName_""")",.Itr2)
|
---|
270 | . if IEN'="" for do quit:($$ItrANext^TMGITR(.Itr2,.IEN)'>0)!(done=1)
|
---|
271 | . . set OtherName=$get(Array(NodeName,RxName,IEN))
|
---|
272 | . . set Answers(count)=IEN
|
---|
273 | . . if (CompactMode=0)!(count'>ShortLen) do
|
---|
274 | . . . new NumMatches set NumMatches=$$ListCt^TMGMISC("Array("""_IEN_""",""POSS RX MATCH"")")
|
---|
275 | . . . write count,". ",RxName
|
---|
276 | . . . if (ShowBoth)&(OtherName'="?") write " (",OtherName,")"
|
---|
277 | . . . write " (",NumMatches," possible matches)",!
|
---|
278 | . . set someShown=1
|
---|
279 | . . set count=count+1
|
---|
280 | . . if (CompactMode=1)&(count>ShortLen) quit
|
---|
281 | . . new Itr3,IngredIEN set IngredIEN=""
|
---|
282 | . . if ShowIngred=0 quit
|
---|
283 | . . set IngredIEN=$$ItrAInit^TMGITR("Array("""_IEN_""",""POSS IGD MATCH"")",.Itr3)
|
---|
284 | . . if IngredIEN'="" for do quit:($$ItrANext^TMGITR(.Itr3,.IngredIEN)="")
|
---|
285 | . . . new IngredName set IngredName=$get(Array(IEN,"POSS IGD MATCH",IngredIEN))
|
---|
286 | . . . if IngredName'="" write " -- ",IngredName,!
|
---|
287 | if (CompactMode=1)&(count>ShortLen) do
|
---|
288 | . write "... ",(count-ShortLen-1)," other items truncated.",!
|
---|
289 |
|
---|
290 | SL2 if 'someShown write " --- (List is Empty) ---",!
|
---|
291 |
|
---|
292 | SLDone quit
|
---|
293 |
|
---|
294 |
|
---|
295 | HandleList(Array)
|
---|
296 | ;"Purpose: to allow user to manipulate and fix problems found
|
---|
297 | ;"Input: Array -- PASS BY REFERENCE. The list as created by GetSuggestions()
|
---|
298 | ;" note IEN is from 22706.9
|
---|
299 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
300 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
301 | ;" Array("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
302 | ;" Array("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
303 | ;" Array(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
304 | ;" Array(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
305 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
306 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
307 |
|
---|
308 | new done set done=0
|
---|
309 | new input set input="R"
|
---|
310 | new Answers
|
---|
311 | new CompactMode set CompactMode=1 ;" (list display mode: 1=compact, 0=verbose)
|
---|
312 | new ShowBoth set ShowBoth=0
|
---|
313 | new ShowIngred set ShowIngred=0
|
---|
314 | new ByGeneric set ByGeneric=0
|
---|
315 | new EntryList,EntryS,Fn,Cancelled
|
---|
316 | new CompactMode set CompactMode=1
|
---|
317 | set Cancelled=0
|
---|
318 |
|
---|
319 | for do quit:(done=1)
|
---|
320 | . if input="R" do
|
---|
321 | . . write !!
|
---|
322 | . . write "--------------------------------------------------",!
|
---|
323 | . . write "Specify which drugs to FIX",!
|
---|
324 | . . write "--------------------------------------------------",!
|
---|
325 | . . do ShowList(.Array,.Answers,ShowBoth,ByGeneric,ShowIngred,CompactMode)
|
---|
326 | . . write "--------------------------------------------------",!
|
---|
327 | . . write "Specify which drugs to FIX",!
|
---|
328 | . . write "--------------------------------------------------",!
|
---|
329 | . . write " R to refresh, L lookup X remove from list, N iNfo",!
|
---|
330 | . . write " M to Manually add Ingredients",!
|
---|
331 | . . write " C turn Compact display ",$select((CompactMode=1):"OFF",1:"ON")
|
---|
332 | . . write " I turn Show Ingredients display ",$select((ShowIngred=1):"OFF",1:"ON"),!
|
---|
333 | . . if $get(EntryS)'="" write " Current SET #'s: ",EntryS,", D to delete SET",!
|
---|
334 | . . write " # or #-# or #,#-#,# etc., ^ done, ",!
|
---|
335 | . write "Enter number(s) to Fix (or codes listed above): ^//"
|
---|
336 | . read input:$get(DTIME,3600),!
|
---|
337 | . if input="" set input="^"
|
---|
338 | . set input=$$UP^XLFSTR(input)
|
---|
339 | . if input="^" set done=1 quit
|
---|
340 | . if input="R" quit
|
---|
341 | . else if input="I" do quit
|
---|
342 | . . set ShowIngred='ShowIngred
|
---|
343 | . . set input="R"
|
---|
344 | . else if input="C" do quit
|
---|
345 | . . set CompactMode='CompactMode
|
---|
346 | . . set input="R"
|
---|
347 | . else if input="M" do quit;"<----- Manual add Ingredients
|
---|
348 | . . set Fn="do ManIngredients(.Array,.Answers,.EntryList)"
|
---|
349 | . . do XMenuOption("MANUALLY add INGREDIENTS to",Fn,"",.EntryList,.EntryS)
|
---|
350 | . . set input="R"
|
---|
351 | . else if input="D" do quit;"---- delete set
|
---|
352 | . . kill EntryList,EntryS
|
---|
353 | . . set input="R"
|
---|
354 | . else if input="L" do quit;"<----- Do Lookup
|
---|
355 | . . set input=1 ;"a dummy entry, not needed.
|
---|
356 | . . set Fn="do Lookup(.Array,.Answers,.EntryList)"
|
---|
357 | . . do XMenuOption("",Fn,"",.EntryList,.EntryS)
|
---|
358 | . else if input="N" do quit;"<----- Show Info
|
---|
359 | . . set Fn="do ShowInfo(.Array,.Answers,.EntryList)"
|
---|
360 | . . do XMenuOption("show INFO about",Fn,"",.EntryList,.EntryS)
|
---|
361 | . else if input="X" do quit;"<----- Set Skip
|
---|
362 | . . set Fn="do SetSkip(.Array,.Answers,.EntryList)"
|
---|
363 | . . do XMenuOption("specify NOT to ADD",Fn,"",.EntryList,.EntryS)
|
---|
364 | . . set input="R"
|
---|
365 | . else do ;"default is ACCEPT
|
---|
366 | . . set Cancelled=0
|
---|
367 | . . set Fn="do FixItems(.Array,.Answers,.EntryList)"
|
---|
368 | . . do XMenuOption("",Fn,"",.EntryList,.EntryS)
|
---|
369 | . . set input="R"
|
---|
370 |
|
---|
371 | quit
|
---|
372 |
|
---|
373 |
|
---|
374 | XMenuOption(Prompt,FnStr,HlpFn,EntryList,EntryS)
|
---|
375 | ;"Purpose: To carry out the various menu functions
|
---|
376 | ;"Input: Prompt: the message to use to prompt user to enter numbers etc.
|
---|
377 | ;" "Enter the Number(s) to" will be automatically provided
|
---|
378 | ;" and ": (? help) ^// " will be added at end
|
---|
379 | ;" FnStr: -- code to execute, e.g. "do DoLookup(.Array,.Answers,.Classes,.EntryList)"
|
---|
380 | ;" HlpFn: e.g. FindHelp, SimHelp, LookupHelp, etc Don't add () to name
|
---|
381 | ;" EntryList -- PASS BY REFERENCE
|
---|
382 | ;" EntryS -- PASS BY REFERENCE. a string showing current set as a string
|
---|
383 | ;"Note: makes use of global scope of 'input', and 'CompactMode', 'Cancelled'
|
---|
384 | ;"Result: none.
|
---|
385 |
|
---|
386 | if $get(EntryS)="" do quit:(valid=0)
|
---|
387 | . if Prompt'="" do
|
---|
388 | XMO1 . . write "Enter the Number(s) to ",Prompt,": (? help) ^// "
|
---|
389 | . . read input,!
|
---|
390 | . . if (input="?") do goto XMO1
|
---|
391 | . . . if Hlpfn="" write "(Sorry, no help available)",! quit
|
---|
392 | . . . new Code set Code="do "_HlpFn_"()"
|
---|
393 | . . . Xecute code
|
---|
394 | . set valid=$$MkMultList^TMGMISC(input,.EntryList)
|
---|
395 | . if valid set EntryS=input
|
---|
396 | Xecute FnStr
|
---|
397 | if $get(CompactMode)=1 set input="R"
|
---|
398 | if $get(Cancelled)=0 kill EntryList,EntryS
|
---|
399 |
|
---|
400 | quit
|
---|
401 |
|
---|
402 |
|
---|
403 | SetSkip(Array,Answers,EntryList)
|
---|
404 | ;"Purpose: To remove entries from consideration for adding to 50.68
|
---|
405 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
406 | ;" Answers -- PASS BY REFERENCE
|
---|
407 | ;" An array that will link display numbers with IENs
|
---|
408 | ;" Answers(count)=IEN^TMGTradeName^TMGGeneric
|
---|
409 | ;" Answers(count)=IEN^TMGTradeName^TMGGeneric
|
---|
410 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
411 | ;" Format as follows.
|
---|
412 | ;" EntryList(Entry number)="" (same as count above)
|
---|
413 | ;" EntryList(Entry number)=""
|
---|
414 | ;"Results: none
|
---|
415 |
|
---|
416 | new Itr,Count,IEN
|
---|
417 | set Count=$$ItrAInit^TMGITR("EntryList",.Itr)
|
---|
418 | if Count>0 for do quit:($$ItrANext^TMGITR(.Itr,.Count)'>0)
|
---|
419 | . set IEN=$piece($get(Answers(Count)),"^",1)
|
---|
420 | . if IEN="" quit
|
---|
421 | . new TMGTradeName,TMGGeneric
|
---|
422 | . set TMGTradeName=$piece($get(Array(IEN)),"^",1)
|
---|
423 | . set TMGGeneric=$piece($get(Array(IEN)),"^",2)
|
---|
424 | . ;"I could put in some undo code here...
|
---|
425 | . set $piece(^TMG(22706.9,IEN,1),"^",4)=1 ;"set skipflag to true
|
---|
426 | . ;"Now delete data from display data
|
---|
427 | . kill Array(IEN)
|
---|
428 | . if (TMGGeneric'="") kill Array("BY GENERIC",TMGGeneric,IEN)
|
---|
429 | . if (TMGTradeName'="") kill Array("BY TRADE",TMGTradeName,IEN)
|
---|
430 |
|
---|
431 | quit
|
---|
432 |
|
---|
433 |
|
---|
434 | ShowInfo(Array,Answers,EntryList)
|
---|
435 | ;"Purpose: To allow user to explore existing entries in 22706.9 file
|
---|
436 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
437 | ;" Answers -- PASS BY REFERENCE,
|
---|
438 | ;" An array that will link display numbers with IENs
|
---|
439 | ;" Answer(count)=IEN
|
---|
440 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
441 | ;" Format as follows.
|
---|
442 | ;" EntryList(Entry number)="" (same as count above)
|
---|
443 |
|
---|
444 | new Itr,Count,IEN
|
---|
445 | set Count=$$ItrAInit^TMGITR("EntryList",.Itr)
|
---|
446 | if Count>0 for do quit:($$ItrANext^TMGITR(.Itr,.Count)'>0)
|
---|
447 | . set IEN=$piece($get(Answers(Count)),"^",1)
|
---|
448 | . do DumpRec2^TMGDEBUG(22706.9,IEN,0)
|
---|
449 | . do PressToCont^TMGUSRIF
|
---|
450 |
|
---|
451 | quit
|
---|
452 |
|
---|
453 |
|
---|
454 | Lookup(Array,Answers,EntryList)
|
---|
455 | ;"Purpose: To allow user to explore existing entries in 50.68 file
|
---|
456 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
457 | ;" Answers -- PASS BY REFERENCE,
|
---|
458 | ;" An array that will link display numbers with IENs
|
---|
459 | ;" Answer(count)=IEN
|
---|
460 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
461 | ;" Format as follows.
|
---|
462 | ;" EntryList(Entry number)="" (same as count above)
|
---|
463 |
|
---|
464 | new DIC,Y
|
---|
465 | set DIC=50.68
|
---|
466 | set DIC(0)="MAEQ"
|
---|
467 | do ^DIC write !
|
---|
468 | if +Y>0 do
|
---|
469 | . do DumpRec2^TMGDEBUG(50.68,+Y,0)
|
---|
470 | . do PressToCont^TMGUSRIF
|
---|
471 |
|
---|
472 | quit
|
---|
473 |
|
---|
474 | FixItems(Array,Answers,EntryList)
|
---|
475 | ;"Purpose: To Fix one item
|
---|
476 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
477 | ;" Answers -- PASS BY REFERENCE
|
---|
478 | ;" An array that will link display numbers with IENs
|
---|
479 | ;" Answers(count)=IEN^TMGTradeName^TMGGeneric
|
---|
480 | ;" Answers(count)=IEN^TMGTradeName^TMGGeneric
|
---|
481 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
482 | ;" Format as follows.
|
---|
483 | ;" EntryList(Entry number)="" (same as count above)
|
---|
484 | ;" EntryList(Entry number)=""
|
---|
485 | ;"Results: none
|
---|
486 |
|
---|
487 | new Itr,Count,IEN
|
---|
488 | new done set done=0
|
---|
489 | new vapIEN set vapIEN=0 ;"for first cycle, no ready answer available.
|
---|
490 |
|
---|
491 | set Count=$$ItrAInit^TMGITR("EntryList",.Itr)
|
---|
492 | if Count>0 for do quit:($$ItrANext^TMGITR(.Itr,.Count)'>0)!(done=1)
|
---|
493 | . set IEN=$piece($get(Answers(Count)),"^",1)
|
---|
494 | . if vapIEN'=0 do ;"If we've already fixed on, use same answer for rest of list
|
---|
495 | . . if $$Fix1From(IEN,vapIEN,.Array,1)=0 set done=1
|
---|
496 | . else do
|
---|
497 | . . set vapIEN=$$AskFix1Item(.Array,IEN)
|
---|
498 | . . if vapIEN=0 set done=1
|
---|
499 | . if done=1 quit
|
---|
500 | . do ArrayKill(IEN,.Array) ;"delete data from display data
|
---|
501 |
|
---|
502 | quit
|
---|
503 |
|
---|
504 |
|
---|
505 | AskFix1Item(Array,IEN)
|
---|
506 | ;"Purpose: to fix one entry, with user input
|
---|
507 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
508 | ;" IEN -- the Record to fix.
|
---|
509 | ;"Results: 1 if item Fixed, 0 if not
|
---|
510 |
|
---|
511 | ;"First, ask if the drug is similar enough that a copy of that other drug
|
---|
512 | ;" is allowed
|
---|
513 | ;"Next, (if above fails), ask for matching of possible ingredients
|
---|
514 | ;"If no ingredient found, even consider adding a new ingredient to INGREDIENT file
|
---|
515 |
|
---|
516 | new done set done=0
|
---|
517 | new input set input="R"
|
---|
518 | new Answers,Fn
|
---|
519 | new CompactMode set CompactMode=1 ;" (list display mode: 1=compact, 0=verbose)
|
---|
520 | new ShowBoth set ShowBoth=0
|
---|
521 | new ShowIngred set ShowIngred=0
|
---|
522 | new ByGeneric set ByGeneric=0
|
---|
523 | new EntryList,EntryS,Fn,Cancelled
|
---|
524 | new FixedWithIEN set FixedWithIEN=0
|
---|
525 |
|
---|
526 | for do quit:(done=1)
|
---|
527 | . if input="R" do
|
---|
528 | . . write !!
|
---|
529 | . . write "--------------------------------------------------",!
|
---|
530 | . . write "Specify CLOSEST MATCH (IGNORE DOSE & FORM)",!
|
---|
531 | . . do Show1(.Array,IEN,.Answers,0)
|
---|
532 | . . if $$ListCt^TMGMISC("Answers")>20 do
|
---|
533 | . . . write "--------------------------------------------------",!
|
---|
534 | . . . write "Specify CLOSEST MATCH (IGNORE DOSE & FORM)",!
|
---|
535 | . . write "--------------------------------------------------",!
|
---|
536 | . . write " R to refresh, F to find Match",!
|
---|
537 | . . write " X to remove from list",!
|
---|
538 | . . if $get(EntryS)'="" write " Current SET #'s: ",EntryS,", D to delete SET",!
|
---|
539 | . . write " ^ if done, ",!
|
---|
540 | . write "Enter number to ACCEPT (or codes listed above): ^//"
|
---|
541 | . read input:$get(DTIME,3600),!
|
---|
542 | . if input="" set input="^"
|
---|
543 | . set input=$$UP^XLFSTR(input)
|
---|
544 | . if input="^" set done=1 quit
|
---|
545 | . if input="R" quit
|
---|
546 | . else if input="D" do quit;"---- delete set
|
---|
547 | . . kill EntryList,EntryS
|
---|
548 | . . set input="R"
|
---|
549 | . else if input="F" do quit;"<----- Look for answer
|
---|
550 | . . set FixedWithIEN=$$Look2Fix(IEN,.Array)
|
---|
551 | . . if FixedWithIEN'=0 set done=1
|
---|
552 | . . else set input="R"
|
---|
553 | . else if input="X" do quit;"<----- Set Skip
|
---|
554 | . . set Fn="do KillMatch(IEN,.Array,.Answers,.EntryList)"
|
---|
555 | . . do XMenuOption("specify match NOT to USE",Fn,"",.EntryList,.EntryS)
|
---|
556 | . else do ;"default is ACCEPT
|
---|
557 | . . if (input["-")!(input[",") write "ENTER ONLY *ONE* ENTRY NUMBER",! quit
|
---|
558 | . . new vapIEN set vapIEN=+$get(Answers(+input))
|
---|
559 | . . if vapIEN>0 set FixedWithIEN=$$Fix1From(IEN,vapIEN,.Array)
|
---|
560 | . . if FixedWithIEN'=0 set done=1
|
---|
561 | . . else set input="R"
|
---|
562 |
|
---|
563 | quit FixedWithIEN
|
---|
564 |
|
---|
565 |
|
---|
566 | Show1(Array,IEN,Answers,ShowIgd)
|
---|
567 | ;"Purpose: To display the list generated by GetSuggestions
|
---|
568 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
569 | ;" IEN -- the One entry to display
|
---|
570 | ;" Answers -- PASS BY REFERENCE, and OUT PARAMETER
|
---|
571 | ;" An array that will link display numbers with IENs
|
---|
572 | ;" Answer(count)=IEN
|
---|
573 | ;" Answer(count)=IEN
|
---|
574 | ;" ShowIgd -- OPTIONAL, if value=1 then ingredients will be shown, otherwise
|
---|
575 | ;" matches in VA PRODUCT FILE are shown.
|
---|
576 | ;"Output: List is shown, and the Answers array is established and passed back.
|
---|
577 | ;"Results: none.
|
---|
578 |
|
---|
579 | new someShown set someShown=0
|
---|
580 | new count set count=1
|
---|
581 | kill Answers
|
---|
582 | new NodeName set NodeName="POSS RX MATCH"
|
---|
583 | if $get(ShowIgd)=1 set NodeName="POSS IGD MATCH"
|
---|
584 |
|
---|
585 | new Itr,subIEN
|
---|
586 | new TMGTradeName,TMGGeneric
|
---|
587 |
|
---|
588 | set TMGTradeName=$piece($get(Array(IEN)),"^",1)
|
---|
589 | set TMGGeneric=$piece($get(Array(IEN)),"^",2)
|
---|
590 | write " For: ",TMGTradeName
|
---|
591 | if (TMGGeneric'="?")&(TMGGeneric'="") write " (",TMGGeneric,")"
|
---|
592 | write !
|
---|
593 | write "--------------------------------------------------",!
|
---|
594 |
|
---|
595 | if $get(IEN)="" goto S1Done
|
---|
596 |
|
---|
597 | set subIEN=$$ItrAInit^TMGITR("Array("_IEN_","""_NodeName_""")",.Itr)
|
---|
598 | if subIEN'="" for do quit:($$ItrANext^TMGITR(.Itr,.subIEN)="")
|
---|
599 | . set Answers(count)=subIEN
|
---|
600 | . new Name set Name=$get(Array(IEN,NodeName,subIEN))
|
---|
601 | . write count,". ",Name,!
|
---|
602 | . set count=count+1
|
---|
603 | . set someShown=1
|
---|
604 |
|
---|
605 | S1Done
|
---|
606 | if 'someShown write " --- (List is Empty) ---",!
|
---|
607 | quit
|
---|
608 |
|
---|
609 |
|
---|
610 | Look2Fix(IEN,Array)
|
---|
611 | ;"Purpose: To allow user to find a match to use for fixing.
|
---|
612 | ;"Input: IEN -- the IEN to fix
|
---|
613 | ;" Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
614 | ;"Result: 0 if no fix, or vapIEN (IEN in 50.68) otherwise
|
---|
615 |
|
---|
616 | new result set result=0 ;"default to failure
|
---|
617 |
|
---|
618 | write "SEARCH for a drug that can be used to fix incomplete entry.",!
|
---|
619 | new DIC,Y
|
---|
620 | set DIC=50.68
|
---|
621 | set DIC(0)="MAEQ"
|
---|
622 | do ^DIC write !
|
---|
623 | if +Y>0 do
|
---|
624 | . if $$Fix1From(IEN,+Y,.Array)=1 set result=+Y
|
---|
625 |
|
---|
626 | quit result
|
---|
627 |
|
---|
628 |
|
---|
629 | KillMatch(IEN,Array,Answers,EntryList)
|
---|
630 | ;"Purpose: To remove VA PRODUCT matches from consideration
|
---|
631 | ;"Input: IEN -- the IEN in 22706.9,
|
---|
632 | ;" Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
633 | ;" Answers -- PASS BY REFERENCE,
|
---|
634 | ;" An array that will link display numbers with IENs
|
---|
635 | ;" Answer(count)=IEN
|
---|
636 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
637 | ;" Format as follows.
|
---|
638 | ;" EntryList(Entry number)="" (same as count above)
|
---|
639 |
|
---|
640 | new Itr,Count,subIEN
|
---|
641 | set Count=$$ItrAInit^TMGITR("EntryList",.Itr)
|
---|
642 | if Count>0 for do quit:($$ItrANext^TMGITR(.Itr,.Count)'>0)
|
---|
643 | . set subIEN=$piece($get(Answers(Count)),"^",1)
|
---|
644 | . new TMGTradeName,TMGGeneric
|
---|
645 | . set TMGTradeName=$piece($get(Array(IEN)),"^",1)
|
---|
646 | . set TMGGeneric=$piece($get(Array(IEN)),"^",2)
|
---|
647 | . ;"I could put in some undo code here...
|
---|
648 | . ;"Now delete data from display data
|
---|
649 | . ;"kill Array(IEN,"POSS RX MATCH",subIEN)
|
---|
650 | . do ArrayKill(IEN,.Array)
|
---|
651 | quit
|
---|
652 |
|
---|
653 |
|
---|
654 | ArrayKill(IEN,Array)
|
---|
655 | ;"Purpose: to remove entry IEN from the Array of drugs to be fixed
|
---|
656 | ;"Input: IEN -- the IEN to remove
|
---|
657 | ;" Array -- the array with the drug info. Format as follows:
|
---|
658 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
659 | ;" Array(IEN)=TMGTradeName^TMGGeneric
|
---|
660 | ;" Array("BY GENERIC",TMGGeneric,IEN)=TMGTradeName
|
---|
661 | ;" Array("BY TRADE",TMGTradeName,IEN)=TMGGeneric
|
---|
662 | ;" Array(IEN,"POSS IGD MATCH",igdIEN)=IngredientName
|
---|
663 | ;" Array(IEN,"POSS IGD MATCH"igdIEN)=IngredientName
|
---|
664 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
665 | ;" Array(IEN,"POSS RX MATCH",RxIEN)=vapEntryName
|
---|
666 |
|
---|
667 | new TMGTradeName,TMGGeneric
|
---|
668 | set TMGTradeName=$piece($get(Array(IEN)),"^",1)
|
---|
669 | set TMGGeneric=$piece($get(Array(IEN)),"^",2)
|
---|
670 | if TMGTradeName="" set TMGTradeName="?"
|
---|
671 | if TMGGeneric="" set TMGGeneric="?"
|
---|
672 | kill Array(IEN)
|
---|
673 | kill Array("BY TRADE",TMGTradeName,IEN)
|
---|
674 | kill Array("BY GENERIC",TMGGeneric,IEN)
|
---|
675 |
|
---|
676 | quit
|
---|
677 |
|
---|
678 |
|
---|
679 | Fix1From(IEN,vapIEN,Array,NoVerify)
|
---|
680 | ;"Purpose: To take a record in VA PRODUCT file (50.68) and use this to fix record in
|
---|
681 | ;" TMG FDA IMPORT COMPILED (22706.9)
|
---|
682 | ;"Input: IEN -- the IEN in 22706.9,
|
---|
683 | ;" vapIEN -- the IEN in 50.68 to fix from
|
---|
684 | ;" Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
685 | ;" NoVerify -- OPTIONAL, if value=1 no user verification asked. Default=0
|
---|
686 | ;"result: 1 if OK to continue, 0 if user abort
|
---|
687 |
|
---|
688 | new result set result=0 ;"default to failure
|
---|
689 |
|
---|
690 | if $get(NoVerify,0)=0,$$VerifySource(vapIEN)=0 goto F1FDone
|
---|
691 | ;"I could put in some undo code here... BUT undoing changes from Copy1 would be HARD
|
---|
692 | if $$Copy1(vapIEN,IEN)=0 goto F1FDone
|
---|
693 | do ArrayKill(IEN,.Array)
|
---|
694 | set result=1 ;"success
|
---|
695 |
|
---|
696 | F1FDone
|
---|
697 | quit result
|
---|
698 |
|
---|
699 |
|
---|
700 | VerifySource(vapIEN)
|
---|
701 | ;"Purpose: to show the drug name, and the drug's ingredients, and ask user to verify choice
|
---|
702 | ;"Input: vapIEN -- IEN in file 50.68
|
---|
703 | ;"Result: 1 if OK to use this drug. 0 if don't use
|
---|
704 |
|
---|
705 | new PriorErrorFound
|
---|
706 | new result set result=0
|
---|
707 | write "-------------------------------------------------",!
|
---|
708 | write "Drug Information:",!
|
---|
709 | write "-------------------------------------------------",!
|
---|
710 | ;"write "NAME: ",$$GET1^DIQ(50.68,vapIEN,.01),!
|
---|
711 | write "GENERIC NAME: ",$$GET1^DIQ(50.68,vapIEN,.05),!
|
---|
712 | write "INGREDIENTS:",!
|
---|
713 | new TMGMSG,TMGFDA
|
---|
714 | do LIST^DIC(50.6814,","_vapIEN_",",".01;1","","*",,,,,,"TMGFDA","TMGMSG")
|
---|
715 | if $data(TMGMSG("DIERR"))'=0 do goto VSDone
|
---|
716 | . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
717 | new i
|
---|
718 | for i=1:1:+$get(TMGFDA("DILIST",0)) do
|
---|
719 | . write " ",$get(TMGFDA("DILIST",1,i)),!
|
---|
720 | write "-------------------------------------------------",!
|
---|
721 | write "Use this drug to fix entry in FDA database"
|
---|
722 | new % set %=1
|
---|
723 | do YN^DICN write !
|
---|
724 | if %=1 set result=1
|
---|
725 |
|
---|
726 | VSDone
|
---|
727 | quit result
|
---|
728 |
|
---|
729 |
|
---|
730 | Copy1(vapIEN,IEN)
|
---|
731 | ;"Purpose: to fill in missing answers in the record in 22706.9, from record in 50.68
|
---|
732 | ;"Input: vapIEN -- IEN in 50.68
|
---|
733 | ;" IEN -- IEN in 22706.9
|
---|
734 | ;"Result: 1 if OK to continue, 0 if error
|
---|
735 |
|
---|
736 | new result set result=0 ;"default to failure
|
---|
737 | new error set error=0
|
---|
738 | new PriorErrorFound
|
---|
739 |
|
---|
740 | new CompFields set CompFields=".08;.05^.09;15"
|
---|
741 | new TMGFDA,TMGMSG
|
---|
742 | new i,TMGField,vapField
|
---|
743 | for i=1:1:$length(CompFields,"^") do
|
---|
744 | . new field1,field2,comp
|
---|
745 | . new Value1,Value2
|
---|
746 | . set comp=$piece(CompFields,"^",i)
|
---|
747 | . set field1=$piece(comp,";",1)
|
---|
748 | . set field2=$piece(comp,";",2)
|
---|
749 | . set Value1=$$GET1^DIQ(22706.9,IEN,field1)
|
---|
750 | . set Value2=$$GET1^DIQ(50.68,vapIEN,field2)
|
---|
751 | . if (Value1="")&(Value2'="") do
|
---|
752 | . . set TMGFDA(22706.9,IEN_",",field1)=Value2
|
---|
753 |
|
---|
754 | if $data(TMGFDA) do goto:(error=1) C1Done
|
---|
755 | . do FILE^DIE("EK","TMGFDA","TMGMSG")
|
---|
756 | . if $data(TMGMSG("DIERR"))'=0 do
|
---|
757 | . . set error=1
|
---|
758 | . . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
759 |
|
---|
760 | ;"Now prep to copy over ingredients...
|
---|
761 | X1 new Itr,subIEN,IngredArray,tempIEN
|
---|
762 | set subIEN=$$ItrInit^TMGITR(50.6814,.Itr,vapIEN)
|
---|
763 | if subIEN>0 for do quit:($$ItrNext^TMGITR(.Itr,.subIEN)'>0)!(error=1)
|
---|
764 | . set tempIEN=+$piece($get(^PSNDF(50.68,vapIEN,2,subIEN,0)),"^",1)
|
---|
765 | . if tempIEN'>0 quit
|
---|
766 | . kill TMGFDA
|
---|
767 | . do FIND^DIC(22706.916,","_IEN_",",".01","AQ",tempIEN,"*",,,,"TMGFDA","TMGMSG")
|
---|
768 | . if $data(TMGMSG("DIERR"))'=0 do quit
|
---|
769 | . . set error=1
|
---|
770 | . . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
771 | . if $get(TMGFDA("DILIST",0))>0 quit
|
---|
772 | . set IngredArray(tempIEN)="" ;"store ingredients. Next I'll see if they are new
|
---|
773 |
|
---|
774 | set result=$$Add1Ingredients(IEN,.IngredArray)
|
---|
775 |
|
---|
776 | C1Done
|
---|
777 | quit result
|
---|
778 |
|
---|
779 |
|
---|
780 | ManIngredients(Array,Answers,EntryList)
|
---|
781 | ;"Purpose: to Manually Add ingredients to a list of records
|
---|
782 | ;"Input: Array -- PASS BY REFERENCE. Array with data. Format same as for HandleList
|
---|
783 | ;" Answers -- PASS BY REFERENCE,
|
---|
784 | ;" An array that will link display numbers with IENs
|
---|
785 | ;" Answer(count)=IEN
|
---|
786 | ;" EntryList -- PASS BY REFERENCE -- an array of entries (user input values) to process.
|
---|
787 | ;" Format as follows.
|
---|
788 | ;" EntryList(Entry number)="" (same as count above)
|
---|
789 | ;"Result: None
|
---|
790 |
|
---|
791 | new Itr,Count,IEN
|
---|
792 | new IngredArray
|
---|
793 | new result set result=1
|
---|
794 |
|
---|
795 | set Count=$$ItrAInit^TMGITR("EntryList",.Itr)
|
---|
796 | if Count>0 for do quit:($$ItrANext^TMGITR(.Itr,.Count)'>0)
|
---|
797 | . set IEN=$piece($get(Answers(Count)),"^",1)
|
---|
798 | . if $data(IngredArray)=0 do
|
---|
799 | . . set result=$$AskManIngred(IEN,.IngredArray)
|
---|
800 | . else do
|
---|
801 | . . set result=$$Add1Ingredients(IEN,.IngredArray)
|
---|
802 | . ;"I could put in some undo code here...
|
---|
803 | . if result=0 kill IngredArray quit
|
---|
804 | . do ArrayKill(IEN,.Array)
|
---|
805 |
|
---|
806 | quit
|
---|
807 |
|
---|
808 |
|
---|
809 | AskManIngred(IEN,IngredArray)
|
---|
810 | ;"Purpose: To ask user for a list of ingredients, then add to record in 22706.9
|
---|
811 | ;"Input: IEN -- the IEN in 22706.9 to have ingredients added to
|
---|
812 | ;" IngredArray -- OPTIONAL. PASS BY REFERENCE, an OUT PARAMETER
|
---|
813 | ;" Ised to pass back out list of ingredients, so they can be used for other enteries
|
---|
814 | ;" Any former entries in list will be killed
|
---|
815 | ;"Result: 1 = OK To Continue, 0 if abort
|
---|
816 |
|
---|
817 | new result set result=0
|
---|
818 | kill IngredArray
|
---|
819 |
|
---|
820 | new DIC,Y
|
---|
821 | set DIC=50.416,DIC(0)="AEQML"
|
---|
822 | set DIC("A")="Enter a drug INGREDIENT to add (^ when done): "
|
---|
823 |
|
---|
824 | for do quit:(+Y'>0)
|
---|
825 | . do ^DIC
|
---|
826 | . if +Y>0 set IngredArray(+Y)=""
|
---|
827 | . else write ! quit
|
---|
828 | . write " ... OK, added.",!
|
---|
829 |
|
---|
830 | if $data(IngredArray)=0 goto AMIDone
|
---|
831 |
|
---|
832 | write "Done adding new ingredients.",!!
|
---|
833 | new % set %=1
|
---|
834 | write "Ingredient List:",!
|
---|
835 | write "------------------------------",!
|
---|
836 | do ShowIngreds(.IngredArray)
|
---|
837 | write "Add INGREDIENT(S) to selected drugs:"
|
---|
838 | do YN^DICN write !
|
---|
839 | if %'=1 goto AMIDone
|
---|
840 |
|
---|
841 | set result=$$Add1Ingredients(IEN,.IngredArray)
|
---|
842 |
|
---|
843 | AMIDone
|
---|
844 | quit result
|
---|
845 |
|
---|
846 |
|
---|
847 | ShowIngreds(IngredArray)
|
---|
848 | ;"Purpose: to Show list of ingredients in array
|
---|
849 |
|
---|
850 | new IEN,Itr
|
---|
851 | set IEN=$$ItrAInit^TMGITR("IngredArray",.Itr)
|
---|
852 | if IEN>0 for do quit:($$ItrANext^TMGITR(.Itr,.IEN)'>0)
|
---|
853 | . write " ",$$GET1^DIQ(50.416,IEN,.01),!
|
---|
854 |
|
---|
855 | quit
|
---|
856 |
|
---|
857 |
|
---|
858 | Add1Ingredients(IEN,IngredArray)
|
---|
859 | ;"Purpose: To put a list of ingredients into one (1) record in 22706.9
|
---|
860 | ;"Input: IEN -- the IEN in 22706.9 to load ingredients into
|
---|
861 | ;" IngredArray -- array with list of ingredients. Format as follows:
|
---|
862 | ;" IngredArray(ingredIEN)=""
|
---|
863 | ;" IngredArray(ingredIEN)=""
|
---|
864 | ;"Output: Ingredients will be added to 22706.9. Note: If ingredients are already present, they
|
---|
865 | ;" will be added a second time.
|
---|
866 | ;" Also, FillGenericName will be called to fill in TMGGeneric Name
|
---|
867 | ;"Results: 1 if OK to continue, 0 if error
|
---|
868 |
|
---|
869 | new Itr,TMGFDA,TMGMSG,tempIEN
|
---|
870 | new result set result=0 ;"default to failure
|
---|
871 | new error set error=0
|
---|
872 |
|
---|
873 | ;"Cycle through IngredArray, and set up FDA for adding to 22706.9
|
---|
874 | kill Itr,TMGFDA
|
---|
875 | set tempIEN=$$ItrAInit^TMGITR("IngredArray",.Itr)
|
---|
876 | if tempIEN'="" for do quit:(+$$ItrANext^TMGITR(.Itr,.tempIEN)'>0)
|
---|
877 | . new IENS set IENS="+"_tempIEN_","_IEN_"," ;" +# format with # as arbitrary unique number
|
---|
878 | . set TMGFDA(22706.916,IENS,.01)=tempIEN ;"an arbitrary index number
|
---|
879 | . set TMGFDA(22706.916,IENS,2)=tempIEN ;"a pointer to the ingredent
|
---|
880 |
|
---|
881 | ;"Call UPDATE^DIE with FDA
|
---|
882 | if $data(TMGFDA) do goto:(error=1) ADIDone
|
---|
883 | . new TMGIEN
|
---|
884 | . do UPDATE^DIE("","TMGFDA","TMGIEN","TMGMSG")
|
---|
885 | . if $data(TMGMSG("DIERR"))'=0 do
|
---|
886 | . . set error=1
|
---|
887 | . . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
888 |
|
---|
889 | ;"Create a generic name from ingredients
|
---|
890 | do FillGenericName^TMGNDF1C(IEN)
|
---|
891 |
|
---|
892 | set result=1 ;"success
|
---|
893 | ADIDone
|
---|
894 | quit result
|
---|