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