| [796] | 1 | TMGPUTN0 ;TMG/kst/TIU Document Upload look-up function ;03/25/06; 5/2/10 | 
|---|
|  | 2 | ;;1.0;TMG-LIB;**1**;04/25/04 | 
|---|
|  | 3 |  | 
|---|
|  | 4 | ;"TIU Document Upload look-up function | 
|---|
|  | 5 |  | 
|---|
|  | 6 | ;"Kevin Toppenberg MD | 
|---|
|  | 7 | ;"GNU General Public License (GPL) applies | 
|---|
|  | 8 | ;"4-25-2004 | 
|---|
|  | 9 |  | 
|---|
|  | 10 |  | 
|---|
|  | 11 | LOOKUP(DocTitle,Autosign) ; | 
|---|
|  | 12 | ;"----------------------------------------------------------------------------------- | 
|---|
|  | 13 | ;"Upload look-up function | 
|---|
|  | 14 | ;"by Kevin Toppenberg | 
|---|
|  | 15 | ;"4-25-2004 | 
|---|
|  | 16 | ;" | 
|---|
|  | 17 | ;"PURPOSE: | 
|---|
|  | 18 | ;"This code is used as look-up code by the TIU document upload routines. | 
|---|
|  | 19 | ;"It has a very specific purpose.  It was written for uploading documents | 
|---|
|  | 20 | ;" from a Medic EMR system.  Notes had been dumped out of that system, and | 
|---|
|  | 21 | ;" were to be ported into VistA | 
|---|
|  | 22 | ;"Each note has a header with patient name, dob, ssnum, chart#, provider | 
|---|
|  | 23 | ;"Addendum -- this code will also work with less extensive patient data. | 
|---|
|  | 24 | ;" | 
|---|
|  | 25 | ;"INPUT | 
|---|
|  | 26 | ;"  The variable (with global scope) listed below are expected as input. | 
|---|
|  | 27 | ;"                  Not all will be required every time, however. | 
|---|
|  | 28 | ;"  DocTitle -- this is the type of document type.  i.e. 'OFFICE VISIT' | 
|---|
|  | 29 | ;"                This will be used so that this code can service multiple | 
|---|
|  | 30 | ;"                         types, i.e. NOTE, PRESCRIPTION CALL IN, etc. | 
|---|
|  | 31 | ;"  Autosign -- [OPTIONAL] if value=1 then document will be created as SIGNED | 
|---|
|  | 32 | ;"Results: Document number that uploaded code should be put into is returned in variable Y | 
|---|
|  | 33 | ;" | 
|---|
|  | 34 | ;" | 
|---|
|  | 35 | ;"*How it works*: | 
|---|
|  | 36 | ;"A remote computer connects to the server running VistA.  This remote computer must be | 
|---|
|  | 37 | ;"  able to upload a file using kermit.  The only way I know to do this is to be on a PC | 
|---|
|  | 38 | ;"  using a terminal emulator program that has kermit upload ability. | 
|---|
|  | 39 | ;"From this remote session, get into the TIU menu system and navigate to the option to | 
|---|
|  | 40 | ;"  upload a document.  Note, one's upload parameters must be set up for this to work. | 
|---|
|  | 41 | ;"The remote user will see a #N3, and use this que to acutally upload the file. | 
|---|
|  | 42 | ;"After the file is uploaded, it is then processed.  Each document specifies what 'type' it is | 
|---|
|  | 43 | ;"   for example 'OFFICE VISIT' | 
|---|
|  | 44 | ;"The server then loads up the parameters for OFFICE VISIT and processes each item in the header. | 
|---|
|  | 45 | ;"Here is an example progress note that this file can process | 
|---|
|  | 46 | ;"-------------------------------------- | 
|---|
|  | 47 | ;"[NewDict]:        OFFICE VISIT | 
|---|
|  | 48 | ;"Name:        JONES,BASKETBALL | 
|---|
|  | 49 | ;"Alias:        JONES,BOB | 
|---|
|  | 50 | ;"DOB:                4/13/71 | 
|---|
|  | 51 | ;"Sex:                MALE | 
|---|
|  | 52 | ;"SSNumber:        555 11 9999 | 
|---|
|  | 53 | ;"ChartNumber:        10034 | 
|---|
|  | 54 | ;"Date:        7/22/2002 | 
|---|
|  | 55 | ;"Location:        Peds_Office | 
|---|
|  | 56 | ;"Provider:        KEVIN TOPPENBERG MD | 
|---|
|  | 57 | ;"[TEXT] | 
|---|
|  | 58 | ;" | 
|---|
|  | 59 | ;"        CHIEF COMPLAINT:  Follow up blood clot. | 
|---|
|  | 60 | ;" | 
|---|
|  | 61 | ;"        HPI: | 
|---|
|  | 62 | ;"        1.  BJ was in the emergency room 3 days ago.  He was being | 
|---|
|  | 63 | ;"            evaluated for left lower extremity pain.  He said that they did | 
|---|
|  | 64 | ;"            radiographic studies and told him that he had a blood clot in | 
|---|
|  | 65 | ;"        .... (snip) | 
|---|
|  | 66 | ;" | 
|---|
|  | 67 | ;"[END] | 
|---|
|  | 68 | ;"-------------------------------------- | 
|---|
|  | 69 | ;"[NewDic] tells the system that a document header is starting | 
|---|
|  | 70 | ;"'Name' is a CAPTION, and the value for this caption is 'JONES,BASKETBALL' | 
|---|
|  | 71 | ;"The upload system will put this value into a variable.  In this case, I specified | 
|---|
|  | 72 | ;"  that the variable name TMGNAME to be used. | 
|---|
|  | 73 | ;" | 
|---|
|  | 74 | ;"Here are each caption and its cooresponding Variable: | 
|---|
|  | 75 | ;"Name <--> TMGNAME | 
|---|
|  | 76 | ;"DOB <--> TMGDOB | 
|---|
|  | 77 | ;"Sex <--> TMGSEX | 
|---|
|  | 78 | ;"SSNumber <--> TMGSSNUM | 
|---|
|  | 79 | ;"ChartNumber <--> TMGPTNUM | 
|---|
|  | 80 | ;"Date <--> TIUVDT | 
|---|
|  | 81 | ;"Provider <--> PERSON | 
|---|
|  | 82 | ;"Alias <--> TMGALIAS | 
|---|
|  | 83 | ;"Location: <--> TIULOC | 
|---|
|  | 84 | ;" | 
|---|
|  | 85 | ;"Document Title is passed to function as 'DocTitle' | 
|---|
|  | 86 | ;" | 
|---|
|  | 87 | ;"After the note has been processed and all the above variables have been set, the server | 
|---|
|  | 88 | ;"calls a 'look-up' function.  This function is supposed to return the document number where the | 
|---|
|  | 89 | ;"text is supposed to be put (the number should be put in Y) | 
|---|
|  | 90 | ;" | 
|---|
|  | 91 | ;"This look-up function has an extra twist.  I am using it to register patients on the fly | 
|---|
|  | 92 | ;"  if needed.  I am doing this because I had about 30,000 patients in my database to transfer, | 
|---|
|  | 93 | ;"  and I had difficulty getting a separate file with just demographics etc.  So, if a patient | 
|---|
|  | 94 | ;"  is not already in the database, they are registered here. | 
|---|
|  | 95 | ;" | 
|---|
|  | 96 | ;"Extra note: | 
|---|
|  | 97 | ;"When this function is called, the TIU upload process has already set up some variables. | 
|---|
|  | 98 | ;"DA = the IEN in 8925.2, i.e. ^TIU(8925.2,DA,"TEXT",0) that the uploaded text was temporarily store in. | 
|---|
|  | 99 | ;"     In other words, here DA = the serial index number of the document to be uploaded | 
|---|
|  | 100 | ;"     i.e. 1 for the first, 2 for the second etc. | 
|---|
|  | 101 | ;"TIUI = the line index of the beginning of the report to be processed (i.e. the line | 
|---|
|  | 102 | ;"       that starts with [TEXT] | 
|---|
|  | 103 | ;"DUZ = Current user number. | 
|---|
|  | 104 | ;"TIUHSIG = [NewDict]  .. or whatever it has been set to by user in upload params | 
|---|
|  | 105 | ;"TIUBGN = [TEXT] ... or whatever is has be set to by user in upload params. | 
|---|
|  | 106 |  | 
|---|
|  | 107 | write "+-------------------------------------+",! | 
|---|
|  | 108 | write "| Starting upload code...             |",! | 
|---|
|  | 109 | write "+-------------------------------------+",! | 
|---|
|  | 110 |  | 
|---|
|  | 111 | set BuffNum=$get(DA)    ;"Store which upload buffer we are working on. | 
|---|
|  | 112 | set BuffIdx=$get(TIUI)  ;"Store line number (in upload buffer) we are starting with. | 
|---|
|  | 113 | new cMaxNoteWidth set cMaxNoteWidth=60 | 
|---|
|  | 114 |  | 
|---|
|  | 115 | ;"Field (f) constants | 
|---|
|  | 116 | new fPatient set fPatient=.02        ;"field .02 = PATIENT | 
|---|
|  | 117 | new fVisit set fVisit=.03            ;"field .03 = VISIT | 
|---|
|  | 118 | new fParentDoc set fParentDoc=.04    ;"field .04 = PARENT DOCUMENT TYPE | 
|---|
|  | 119 | new fStatus set fStatus=.05          ;"field .05 = STATUS | 
|---|
|  | 120 | new fParent set fParent=.06          ;"field .06 = PARENT | 
|---|
|  | 121 | new fStartDate set fStartDate=.07    ;"EPISODE BEGIN DATE/TIME (field .07) | 
|---|
|  | 122 | new fEndDate set fEndDate=.08        ;"EPISODE END DATE/TIME (field .08) | 
|---|
|  | 123 | new fEntryDate set fEntryDate=1201   ;"field 1201 = ENTRY DATE/TIME | 
|---|
|  | 124 | new fAuthor set fAuthor=1202         ;"field 1202 = PERSON/DICTATOR | 
|---|
|  | 125 | new fExpSigner set fExpSigner=1204   ;"field 1204 = expected Signer | 
|---|
|  | 126 | new fHospLoc set fHospLoc=1205       ;"field 1205 = HOSPITAL LOCATION | 
|---|
|  | 127 | new fExpCosign set fExpCosign=1208   ;"field 1208 = expected cosigner | 
|---|
|  | 128 | new fAttending set fAttending=1209   ;"field 1209 = ATTENDING | 
|---|
|  | 129 | new fVisitLoc set fVisitLoc=1211     ;"field 1211 = VISIT LOCATION | 
|---|
|  | 130 | new fRefDate set fRefDate=1301       ;"field 1301 = REFERENCE DATE | 
|---|
|  | 131 | new fEnteredBy set fEnteredBy=1302   ;"field 1302 = ENTERED BY (a pointer to file 200) | 
|---|
|  | 132 | new fCapMethod set fCapMethod=1303   ;"field 1303 = CAPTURE METHOD;  U-->'upload' | 
|---|
|  | 133 | new fService set fService=1404       ;"field 1404 = SERVICE | 
|---|
|  | 134 | new fSignedBy set fSignedBy=1502     ;"field 1502 = signed by | 
|---|
|  | 135 | new fNeedCosign set fNeedCosign=1506 ;"field 1506 = cosigniture expected. | 
|---|
|  | 136 | new fCharTrans set fCharTrans=22711  ;"field 22711 = CHAR COUNT -- TRANSCRIPTIONIST | 
|---|
|  | 137 | new fLineCount set fLineCout=.1      ;"field .1 = LINE COUNT | 
|---|
|  | 138 |  | 
|---|
|  | 139 | ;" Piece (p) constants | 
|---|
|  | 140 | new pPatient set pPatient=2      ;"Node 0,piece 2 = PATIENT (field .02) | 
|---|
|  | 141 | new pVisit set pVisit=3          ;"Node 0,piece 3 = VISIT (field .03) | 
|---|
|  | 142 | new pStrtDate set pStrtDate=7    ;"Node 0,piece 7 = EPISODE BEGIN DATE/TIME (field .07) | 
|---|
|  | 143 | new pEndDate set pEndDate=8      ;"Node 0,piece 8 = EPISODE END DATE/TIME (field .08) | 
|---|
|  | 144 | new pExpSigner set pExpSigner=4  ;"Node 12,piece 4 = EXPECTED SIGNER (field 1204) | 
|---|
|  | 145 | new pHospLoc set pHospLoc=5      ;"Node 12,piece 5 = HOSPITAL LOCATION (field 1205) | 
|---|
|  | 146 | new pExpCosign set pExpCosign=8  ;"Node 12,piece 8 = EXPECTED COSIGNER (field 1210) | 
|---|
|  | 147 | new pAttending set pAttending=9  ;"Node 12,piece 9 = ATTENDING PHYSICIAN (field 1209) | 
|---|
|  | 148 | new pService set pService=4      ;"Node 14,piece 4 = SERVICE (field 1404) | 
|---|
|  | 149 |  | 
|---|
|  | 150 | if $data(cAbort)#10=0 new cAbort set cAbort=0 | 
|---|
|  | 151 |  | 
|---|
|  | 152 | new DBIndent,PriorErrorFound | 
|---|
|  | 153 | new Patient | 
|---|
|  | 154 | new DocIEN set DocIEN=-1 | 
|---|
|  | 155 | new Document | 
|---|
|  | 156 | new NewDoc set NewDoc=0 | 
|---|
|  | 157 | new result set result=1  ;"cOKToCont | 
|---|
|  | 158 |  | 
|---|
|  | 159 | do PtArrayCreate(.Patient) ;"Load upload info into Patient array | 
|---|
|  | 160 | set result=$$DocArrayCreate(.Document) ;"Load upload document info into Document array | 
|---|
|  | 161 | if result=cAbort goto LUDone | 
|---|
|  | 162 | set Document("DFN")=$$GetDFN^TMGGDFN(.Patient)  ;"Store DFN of patient. | 
|---|
|  | 163 | if Document("DFN")'>0 set result=cAbort goto LUDone   ;"Abort. | 
|---|
|  | 164 | set Document("AUTO SIGN")=$get(Autosign,1)  ;"default to YES auto-signing | 
|---|
|  | 165 | ;"06-19-05 Changed to disable autosigning.  If document is | 
|---|
|  | 166 | ;"      autosigned here, then no prompt for printing elsewhere. | 
|---|
|  | 167 | ;"9-1-05 Resuming autosigning.  Currently the outside transcriptionists are already | 
|---|
|  | 168 | ;"      printing the notes before giving them to us for upload. | 
|---|
|  | 169 | ;"      Changed default to be YES autosign | 
|---|
|  | 170 | ;"set Document("AUTO SIGN")=0 ;"override setting passed in... | 
|---|
|  | 171 |  | 
|---|
|  | 172 | set Document("CHARACTER COUNT - TRANSCRIPTIONIST'S")=$$BuffCharCount()   ;"Count character prior to any wrapping/merging etc. | 
|---|
|  | 173 | set result=$$PrepUploadBuf()  ;"Do any word-wrapping etc needed in upload buffer | 
|---|
|  | 174 | if result=cAbort goto LUDone | 
|---|
|  | 175 | set DocIEN=$$PrepDoc(.Document,.NewDoc)      ;"Prepair a document to put upload into. Credits transcription | 
|---|
|  | 176 |  | 
|---|
|  | 177 | set Y=DocIEN | 
|---|
|  | 178 | merge TMGDOC=Document  ;"Create a global -- will kill after followup code | 
|---|
|  | 179 | LUDone | 
|---|
|  | 180 | ;"put result into Y.  TIU filing system looks for results in Yi | 
|---|
|  | 181 | if result=cAbort set Y=-1 | 
|---|
|  | 182 |  | 
|---|
|  | 183 | quit | 
|---|
|  | 184 |  | 
|---|
|  | 185 |  | 
|---|
|  | 186 |  | 
|---|
|  | 187 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 188 | ;"==============================================================================================- | 
|---|
|  | 189 | ;" S U B R O U T I N E S | 
|---|
|  | 190 | ;"==============================================================================================- | 
|---|
|  | 191 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 192 | ;"PtArrayCreate(Array) | 
|---|
|  | 193 | ;"DocArrayCreate(Document) | 
|---|
|  | 194 | ;"PrepDoc(Document,NewDoc); | 
|---|
|  | 195 | ;"GetDocTIEN(Title) | 
|---|
|  | 196 | ;"GetLocIEN(Location) | 
|---|
|  | 197 | ;"GetService(IEN) | 
|---|
|  | 198 | ;"GetProvIEN(Provider) | 
|---|
|  | 199 | ;"GetRecord(Document,NewDoc,AskOK,Editable) | 
|---|
|  | 200 | ;"DocExists(Document) | 
|---|
|  | 201 | ;"BuffCharCount() | 
|---|
|  | 202 | ;"PrepUploadBuf() | 
|---|
|  | 203 |  | 
|---|
|  | 204 | ;"NeedsReformat(MaxWidth) | 
|---|
|  | 205 | ;"CutNote(Array) | 
|---|
|  | 206 | ;"PasteNote(Array,NextNoteI) | 
|---|
|  | 207 | ;"CompToBuff(ExistingIEN,UplTIEN,UplDate) | 
|---|
|  | 208 | ;"CreateRec(Document) ; | 
|---|
|  | 209 | ;"StuffRec(Document,PARENT) | 
|---|
|  | 210 | ;"MakeVisit(Document) | 
|---|
|  | 211 | ;"FOLLOWUP(DocIEN) ;Post-filing code for PROGRESS NOTES | 
|---|
|  | 212 |  | 
|---|
|  | 213 |  | 
|---|
|  | 214 | PtArrayCreate(Array) | 
|---|
|  | 215 | ;"SCOPE: Private | 
|---|
|  | 216 | ;"Purpose: To put global scope vars (i.e. TMGNAME,TMGSSNUM etc) into | 
|---|
|  | 217 | ;"        an array for easier portability | 
|---|
|  | 218 | ;"Input: Array, must be passed by reference | 
|---|
|  | 219 | ;"       The global-scope variables setup by the upload system, and are used here: | 
|---|
|  | 220 | ;"                TMGPTNUM,TMGSSNUM,TMGSSNUM,TMGNAME,TMGDOB,TMGSEX | 
|---|
|  | 221 | ;"Output: Array is loaded with info, like this: | 
|---|
|  | 222 | ;"        set Array("SSNUM")="123-45-6789" | 
|---|
|  | 223 | ;"        set Array("NAME")="DOE,JOHN" | 
|---|
|  | 224 | ;"        set Array("DOB")=TMGDOB | 
|---|
|  | 225 | ;"        set Array("PATIENTNUM")="12345677" | 
|---|
|  | 226 | ;"        set Array("SEX")="M" | 
|---|
|  | 227 | ;"        set Array("ALIAS")="DOE,JOHNNY" | 
|---|
|  | 228 | ;"Results: none | 
|---|
|  | 229 |  | 
|---|
|  | 230 | if $data(TMGPTNUM)#10'=0 do | 
|---|
|  | 231 | . set TMGPTNUM=$translate(TMGPTNUM,"PWCI*","")  ;"Clean off alpha characters -- not needed. | 
|---|
|  | 232 | . ;"set TMGPTNUM=$$Trim^TMGSTUTL(TMGPTNUM) | 
|---|
|  | 233 | . set TMGPTNUM=$$FORMAT^DPTNAME(.TMGPTNUM,3,30)  ;"Use same input transform as for .01 field of PATIENT file | 
|---|
|  | 234 | . set Array("PATIENTNUM")=TMGPTNUM | 
|---|
|  | 235 |  | 
|---|
|  | 236 | if $data(TMGSSNUM)#10'=0 do | 
|---|
|  | 237 | . set TMGSSNUM=$translate(TMGSSNUM," /-","")  ;"Clean delimiters | 
|---|
|  | 238 | . if +TMGSSNUM=0 set TMGSSNUM=""  ;was ... "P" | 
|---|
|  | 239 | . if (TMGSSNUM="P")!(+TMGSSNUM>0) set Array("SSNUM")=TMGSSNUM | 
|---|
|  | 240 |  | 
|---|
|  | 241 | set Array("NAME")=$$FormatName^TMGMISC(.TMGNAME) | 
|---|
|  | 242 |  | 
|---|
|  | 243 | if $data(TMGALIAS)#10'=0 do | 
|---|
|  | 244 | . set TMGALIAS=$translate(TMGALIAS,"*","") | 
|---|
|  | 245 | . set TMGALIAS=$$FORMAT^DPTNAME(TMGALIAS,3,30) ;"convert to 'internal' format (strip .'s etc) | 
|---|
|  | 246 | . set Array("ALIAS")=TMGALIAS | 
|---|
|  | 247 |  | 
|---|
|  | 248 | if $data(TMGSEX)#10'=0 do | 
|---|
|  | 249 | . set TMGSEX=$$UP^XLFSTR($get(TMGSEX)) | 
|---|
|  | 250 | . if TMGSEX="M" set TMGSEX="MALE" | 
|---|
|  | 251 | . else  if TMGSEX="F" set TMGSEX="FEMALE" | 
|---|
|  | 252 | . set Array("SEX")=TMGSEX | 
|---|
|  | 253 |  | 
|---|
|  | 254 | if $data(TMGDOB)#10'=0 do | 
|---|
|  | 255 | . if +TMGDOB>0 set Array("DOB")=TMGDOB | 
|---|
|  | 256 | . else  quit | 
|---|
|  | 257 | . new CurDate,CurYr | 
|---|
|  | 258 | . do DT^DILF("E","T",.CurDate) | 
|---|
|  | 259 | . set CurDate=$get(CurDate(0)) | 
|---|
|  | 260 | . if CurDate="" quit | 
|---|
|  | 261 | . set CurYr=$piece(CurDate,", ",2) | 
|---|
|  | 262 | . new DOBYr | 
|---|
|  | 263 | . set DOBYr=$piece(TMGDOB,"/",3) | 
|---|
|  | 264 | . if DOBYr>CurYr do  ;"we have a Y2K problem | 
|---|
|  | 265 | . . set DOBYr=DOBYr-100 | 
|---|
|  | 266 | . . if DOBYr'>0 quit | 
|---|
|  | 267 | . . set TMGDOB=$piece(TMGDOB,"/",1,2)_"/"_DOBYr | 
|---|
|  | 268 | . . set Array("DOB")=TMGDOB | 
|---|
|  | 269 |  | 
|---|
|  | 270 | quit | 
|---|
|  | 271 |  | 
|---|
|  | 272 |  | 
|---|
|  | 273 |  | 
|---|
|  | 274 | DocArrayCreate(Document) | 
|---|
|  | 275 | ;"SCOPE: Private | 
|---|
|  | 276 | ;"Purpose: To put TIUVDT etc. etc into an array for easier portibility | 
|---|
|  | 277 | ;"Input: Document -- OUT parameter, must be passed by reference | 
|---|
|  | 278 | ;"       The global-scope variables setup by the upload system are used: | 
|---|
|  | 279 | ;"                TIUVDT,PERSON,TIULOC, (and also DocTitle) | 
|---|
|  | 280 | ;"Output: Document is loaded with info. | 
|---|
|  | 281 | ;"Results: 1=OKToCont, or cAbort | 
|---|
|  | 282 |  | 
|---|
|  | 283 | new result set result=1 ;"cOKToCont | 
|---|
|  | 284 |  | 
|---|
|  | 285 | set Document("PROVIDER")=$get(PERSON) | 
|---|
|  | 286 | if Document("PROVIDER")="" do  goto DACDone | 
|---|
|  | 287 | . set result=cAbort | 
|---|
|  | 288 | set Document("PROVIDER IEN")=$$GetProvIEN(Document("PROVIDER")) | 
|---|
|  | 289 | set Document("LOCATION")=$get(TIULOC,"Main_Office") | 
|---|
|  | 290 | set Document("DATE")=$get(TIUVDT) | 
|---|
|  | 291 | set Document("TITLE")=$get(DocTitle,"NOTE") | 
|---|
|  | 292 |  | 
|---|
|  | 293 | ;"Decide which transcriptionist is. This will be used for crediting productivity. | 
|---|
|  | 294 | ;"If transcriptionist not specified, current user (DUZ) is assumed. | 
|---|
|  | 295 | if $data(TMGTRANS)#10=0 set TMGTRANS=$piece($get(^VA(200,DUZ,0)),"^",1) | 
|---|
|  | 296 | set Document("TRANSCRIPTIONIST")=$$FormatName^TMGMISC(TMGTRANS) | 
|---|
|  | 297 |  | 
|---|
|  | 298 | if (Document("DATE")="")!(Document("DATE")="00/00/00") do  goto DACDone | 
|---|
|  | 299 | . set result=cAbort | 
|---|
|  | 300 |  | 
|---|
|  | 301 | DACDone | 
|---|
|  | 302 | quit result | 
|---|
|  | 303 |  | 
|---|
|  | 304 |  | 
|---|
|  | 305 |  | 
|---|
|  | 306 | PrepDoc(Document,NewDoc); | 
|---|
|  | 307 | ;"Scope: PRIVATE. | 
|---|
|  | 308 | ;"       Addendum 7/25/07.  Will be called by RPC call BLANKTIU^TMGRPC1 | 
|---|
|  | 309 | ;"                          to return a blank document | 
|---|
|  | 310 | ;"Purpose: Prepair a document to put upload into. | 
|---|
|  | 311 | ;"Input: Document -- an array as follows: | 
|---|
|  | 312 | ;"                Document("DFN")=DFN, the record number of the patient. | 
|---|
|  | 313 | ;"                Document("PROVIDER IEN")= the IEN of the provider | 
|---|
|  | 314 | ;"                Document("LOCATION")= the location of the visit | 
|---|
|  | 315 | ;"                Document("DATE")= the date of the visit. | 
|---|
|  | 316 | ;"                Document("TITLE")= the title of the note | 
|---|
|  | 317 | ;"                Document(cVisitStr)  an OUT PARAMETER | 
|---|
|  | 318 | ;"                Document("TRANSCRIPTIONIST") -- the name of the transcriptionist | 
|---|
|  | 319 | ;"                Document("CHARACTER COUNT - TRANSCRIPTIONIST'S") -- the char count creditable to transcriptionist | 
|---|
|  | 320 | ;"    NewDoc:  OPTIONAL flag, passed back with | 
|---|
|  | 321 | ;"              NewDoc = 1 if returned docmt is new | 
|---|
|  | 322 | ;"              NewDoc = 0 if returned docmt already existed, timeout, etc | 
|---|
|  | 323 | ;"Results: returns record number (IEN) ready to accept upload (or -1 if failure) | 
|---|
|  | 324 | ;"        Also Document("DOC IEN") will have this same IEN | 
|---|
|  | 325 | ;"        NOTE: if result is -1 then errors are passed back in | 
|---|
|  | 326 | ;"              Document("ERROR") node | 
|---|
|  | 327 | ;"              Document("ERROR",n)="ERROR.. Stuffing new document." | 
|---|
|  | 328 | ;"              Document("ERROR","NUM")=n | 
|---|
|  | 329 | ;"              Document("ERROR","FM INFO")=merge with DIERR array | 
|---|
|  | 330 |  | 
|---|
|  | 331 | ;"  PIEN = patient internal entry number | 
|---|
|  | 332 | ;"  Global-Scope variables expected: | 
|---|
|  | 333 | ;"    PERSON, TMGSSNUM etc. defined above | 
|---|
|  | 334 | ;"    TIUVDT expected | 
|---|
|  | 335 | ;"    TIULOC is also expected (i.e. 'LAUGHLIN_OFFICE') | 
|---|
|  | 336 | ;" | 
|---|
|  | 337 | ;"Output: will return document number, or -1 if failure. | 
|---|
|  | 338 | ;"NOTES:  This originated from         ^TIUPUTPN | 
|---|
|  | 339 | ;" | 
|---|
|  | 340 | ;" Look-up code used by router/filer | 
|---|
|  | 341 | ;" Required          variables: TMGSSNUM, TIUVDT | 
|---|
|  | 342 | ;"   i.e., TMGSSNUM (Pt SS-Number) and TIUVDT (visit date) must be set prior to call. | 
|---|
|  | 343 | ;" | 
|---|
|  | 344 |  | 
|---|
|  | 345 | new cStartDate set cStartDate="EDT" | 
|---|
|  | 346 | new cEndDate set cEndDate="LDT" | 
|---|
|  | 347 | new cService set cService="SVC" | 
|---|
|  | 348 | new cDocType set cDocType="TYPE" | 
|---|
|  | 349 | new cDocTIEN set cDocTIEN="TYPE IEN" | 
|---|
|  | 350 | new cHspLocIEN set cHspLocIEN="LOC" | 
|---|
|  | 351 | new cVstLocIEN set cVstLocIEN="VLOC" | 
|---|
|  | 352 | new cVisitStr set cVisitStr="VSTR" | 
|---|
|  | 353 | new cVisitIEN set cVisitIEN="VISIT" | 
|---|
|  | 354 | new cStopCode set cStopCode="STOP" | 
|---|
|  | 355 |  | 
|---|
|  | 356 | new TMG,DFN | 
|---|
|  | 357 | new TIUDAD,TIUEDIT | 
|---|
|  | 358 | new TIULDT,TIUXCRP,DocTIEN | 
|---|
|  | 359 | new LocIEN | 
|---|
|  | 360 | new result set result=-1 | 
|---|
|  | 361 | set NewDoc=0 | 
|---|
|  | 362 |  | 
|---|
|  | 363 | set Document(cStartDate)=$$IDATE^TIULC(Document("DATE")) ;"Convert date into internal format | 
|---|
|  | 364 | set Document(cEndDate)=Document(cStartDate) ;"For office notes, begin and end dates will be the same. | 
|---|
|  | 365 |  | 
|---|
|  | 366 | ;"Setup DocTIEN -- to be used below as [MAS Movement event type] | 
|---|
|  | 367 | ;"Convert Document title into IEN, i.e. OFFICE VISIT --> 128 | 
|---|
|  | 368 | set DocTIEN=$$GetDocTIEN(Document("TITLE")) | 
|---|
|  | 369 | if +DocTIEN'>0 do  goto PrepDocX | 
|---|
|  | 370 | . set Document("ERROR",1)="ERROR: Unable to determine note type from title: "_Document("TITLE") | 
|---|
|  | 371 | . set Document("ERROR","NUM")=1 | 
|---|
|  | 372 |  | 
|---|
|  | 373 | ;"Purpose: setup Document(cDocType)  -- used below as: Title info variable of form: | 
|---|
|  | 374 | ;" Setup string in form of:  1^title IEN^title Name | 
|---|
|  | 375 | ;" e.g.:  1^128^OFFICE VISIT^OFFICE VISIT | 
|---|
|  | 376 | set Document(cDocTIEN)=DocTIEN | 
|---|
|  | 377 | set Document(cDocType)=1_"^"_DocTIEN_"^"_$$PNAME^TIULC1(DocTIEN) | 
|---|
|  | 378 |  | 
|---|
|  | 379 | ;"do MAIN^TIUVSIT(.TIU,.DFN,TMGSSNUM,Document(cStartDate),Document(cEndDate),"LAST",0,Document("LOCATION")) | 
|---|
|  | 380 |  | 
|---|
|  | 381 | ;" setup LocIEN from HOSPITAL LOCATION file (#44) | 
|---|
|  | 382 | ;" This contains entries like 'Laughlin_Office' | 
|---|
|  | 383 | set LocIEN=+$$GetLocIEN(Document("LOCATION")) | 
|---|
|  | 384 | if '$data(^SC(LocIEN,0)) do  goto PrepDocX     ;"^SC(*) is file 44, Hospital Location | 
|---|
|  | 385 | . set Document("ERROR",1)="ERROR: Unable to process location: "_Document("LOCATION") | 
|---|
|  | 386 | . set Document("ERROR","NUM")=1 | 
|---|
|  | 387 |  | 
|---|
|  | 388 | set Document(cService)=$$GetService(Document("PROVIDER IEN"))        ;"i.e. FAMILY PRACTICE | 
|---|
|  | 389 | set Document(cVisitStr)="x;x;"_DocTIEN                        ;"LOC;VDT;VTYP | 
|---|
|  | 390 | set Document(cVisitIEN)=0                                ;"Visit File IFN | 
|---|
|  | 391 | set Document(cHspLocIEN)=LocIEN | 
|---|
|  | 392 | set Document(cVstLocIEN)=LocIEN | 
|---|
|  | 393 | set Document(cStopCode)=0  ;"0=FALSE, don't worry about stop codes. | 
|---|
|  | 394 |  | 
|---|
|  | 395 | set result=$$GetRecord(.Document,.NewDoc,0) | 
|---|
|  | 396 | if result'>0 do  goto PrepDocX | 
|---|
|  | 397 | . new n set n=+$get(Document("ERROR","NUM"))+1 | 
|---|
|  | 398 | . set Document("ERROR",n)="ERROR.. after creating new document." | 
|---|
|  | 399 | . set Document("ERROR","NUM")=n | 
|---|
|  | 400 |  | 
|---|
|  | 401 | ;"At this point, any merging has been done (once implemented) | 
|---|
|  | 402 | ;"So a character count of now will be a total/combined character count | 
|---|
|  | 403 | set Document("CHAR COUNT - TOTAL")=$$BuffCharCount   ;"Count character after any wrapping/merging etc. | 
|---|
|  | 404 | ;"Now, we need the standard CHARARACTERS/LINE value stored in field .03 of TIU PARAMETERS (in ^TIU(8925.99)) | 
|---|
|  | 405 | ;"For my setup, I have only have one record for in this file, so I'll use IEN=1. | 
|---|
|  | 406 | new CharsPerLine set CharsPerLine=$piece($get(^TIU(8925.99,1,0)),"^",3) | 
|---|
|  | 407 | if CharsPerLine'=0 do | 
|---|
|  | 408 | . new IntLC,LC,Delta | 
|---|
|  | 409 | . set LC=Document("CHAR COUNT - TOTAL")\CharsPerLine | 
|---|
|  | 410 | . set IntLC=Document("CHAR COUNT - TOTAL")\CharsPerLine  ;" \ is integer divide | 
|---|
|  | 411 | . set Delta=(LC-IntLC)*10 | 
|---|
|  | 412 | . if Delta>4 set IntLC=IntLC+1  ;"Round to closest integer value. | 
|---|
|  | 413 | . set Document("LINE COUNT")=IntLC | 
|---|
|  | 414 |  | 
|---|
|  | 415 | set result=$$StuffRec(.Document,0)   ;"Will load Document("ERROR","FM INFO") with any FM errors | 
|---|
|  | 416 | if +$get(result)'>0 do  goto PrepDocX | 
|---|
|  | 417 | . new n set n=+$get(Document("ERROR","NUM"))+1 | 
|---|
|  | 418 | . set Document("ERROR",n)="ERROR.. Stuffing new document." | 
|---|
|  | 419 | . set Document("ERROR","NUM")=n | 
|---|
|  | 420 |  | 
|---|
|  | 421 | PrepDocX | 
|---|
|  | 422 | quit result  ;"result is document # | 
|---|
|  | 423 |  | 
|---|
|  | 424 |  | 
|---|
|  | 425 | MakeVisit(Document) | 
|---|
|  | 426 | ;"Purpose -- to create a new entery in the VISIT file, based on info in Document. | 
|---|
|  | 427 | ;"Input -- Document -- array with following info: | 
|---|
|  | 428 | ;"                Document("DFN")=DFN, the record number of the patient. | 
|---|
|  | 429 | ;"                Document("PROVIDER")= the provider of care for the note | 
|---|
|  | 430 | ;"                Document("PROVIDER IEN")= the IEN of the provider | 
|---|
|  | 431 | ;"                Document("LOCATION")= the location of the visit | 
|---|
|  | 432 | ;"                Document("DATE")= the date of the visit. | 
|---|
|  | 433 | ;"Result -- returns IEN of visit entry | 
|---|
|  | 434 |  | 
|---|
|  | 435 | ;"Note -- this function is not now being used... | 
|---|
|  | 436 |  | 
|---|
|  | 437 | new TMGFDA | 
|---|
|  | 438 | ;set TMGFDA(9000010,"?+1,",.01)=        ;".01=VISIT/ADMIT DATE&TIME | 
|---|
|  | 439 | ;set TMGFDA(9000010,"?+1,",.02)=        ;".02=DATE VISIT CREATED | 
|---|
|  | 440 | ;set TMGFDA(9000010,"?+1,",.03)="O"     ;".02=VISIT TYPE  -- O=Other | 
|---|
|  | 441 | ;set TMGFDA(9000010,"?+1,",.05)=        ;".05=PATIENT NAME | 
|---|
|  | 442 | ;set TMGFDA(9000010,"?+1,",15001)="10C1-TEST"  ;"15001=VISIT ID | 
|---|
|  | 443 | ;LOCATION NAME --> Medical Group of Greeneville | 
|---|
|  | 444 | ;SERVICE CATEGORY: A --> AMBULATORY | 
|---|
|  | 445 | ;DSS ID: PRIMARY CARE/MEDICINE | 
|---|
|  | 446 | ;HOSPITAL LOCATION: Laughlin_Office | 
|---|
|  | 447 | ;Created by user: DUZ | 
|---|
|  | 448 | quit | 
|---|
|  | 449 |  | 
|---|
|  | 450 |  | 
|---|
|  | 451 | GetDocTIEN(Title) | 
|---|
|  | 452 | ;"Purpose: To return IEN for document *type defination* / Identify document title | 
|---|
|  | 453 | ;"Input  Title -- the Text Title to look up | 
|---|
|  | 454 | ;"Results: Returns the document definition IFN (i.e. Y) | 
|---|
|  | 455 |  | 
|---|
|  | 456 | new DIC,Y,X | 
|---|
|  | 457 | new TIUFPRIV set TIUFPRIV=1 | 
|---|
|  | 458 |  | 
|---|
|  | 459 | set DIC=8925.1 | 
|---|
|  | 460 | set DIC(0)="M" | 
|---|
|  | 461 | set DIC("S")="IF $PIECE(^TIU(8925.1,+Y,0),""^"",4)=""DOC""" | 
|---|
|  | 462 | set X=Title | 
|---|
|  | 463 | do ^DIC | 
|---|
|  | 464 | kill DIC("S") | 
|---|
|  | 465 | if $find(Y,"^")>0 set Y=$piece(Y,"^",1) | 
|---|
|  | 466 |  | 
|---|
|  | 467 | quit Y | 
|---|
|  | 468 |  | 
|---|
|  | 469 |  | 
|---|
|  | 470 | GetLocIEN(Location) | 
|---|
|  | 471 | ;"Scope: PRIVATE | 
|---|
|  | 472 | ;"Purpose: To return IEN for location | 
|---|
|  | 473 | ;"Input: Location -- the Location to look up. | 
|---|
|  | 474 | ;"Results: returns LocationIEN (i.e. Y) | 
|---|
|  | 475 |  | 
|---|
|  | 476 | new DIC,X,Y | 
|---|
|  | 477 | set DIC=44 ;"file 44 is HOSPITAL LOCATION | 
|---|
|  | 478 | set DIC(0)="M" | 
|---|
|  | 479 | set X=Location | 
|---|
|  | 480 | do ^DIC ;" do a         , value is returned in Y | 
|---|
|  | 481 | if $find(Y,"^")>0 set Y=$piece(Y,"^",1) | 
|---|
|  | 482 |  | 
|---|
|  | 483 | quit Y | 
|---|
|  | 484 |  | 
|---|
|  | 485 |  | 
|---|
|  | 486 | GetService(IEN) | 
|---|
|  | 487 | ;"Scope: PRIVATE | 
|---|
|  | 488 | ;"Purpose: Get the Service for the Provider | 
|---|
|  | 489 | ;"Input: IEN -- the IEN of the Provider to look up. | 
|---|
|  | 490 | ;"Results: returns the Name of the Service for provider, or "" if not found | 
|---|
|  | 491 |  | 
|---|
|  | 492 | new result set result="" | 
|---|
|  | 493 | new node,SvIEN | 
|---|
|  | 494 |  | 
|---|
|  | 495 | if IEN=-1 goto GtSvDone | 
|---|
|  | 496 | set node=$get(^VA(200,IEN,5))  ;"^VA(200, is NEW PERSON file | 
|---|
|  | 497 | set SvIEN=+$piece(node,"^",1) | 
|---|
|  | 498 | if SvIEN=0 goto GtSvDone | 
|---|
|  | 499 | set node=$get(^DIC(49,SvIEN,0)) ;"^DIC(49, is the SERVICE/SECTION file | 
|---|
|  | 500 | set result=$piece(node,"^",1) | 
|---|
|  | 501 |  | 
|---|
|  | 502 | GtSvDone | 
|---|
|  | 503 | quit result | 
|---|
|  | 504 |  | 
|---|
|  | 505 |  | 
|---|
|  | 506 | GetProvIEN(Provider) | 
|---|
|  | 507 | ;"Scope: PRIVATE | 
|---|
|  | 508 | ;"Purpose: To return IEN for Provider | 
|---|
|  | 509 | ;"Input: Provider -- the Provider to look up. | 
|---|
|  | 510 | ;"Results: returns Provider's IEN (i.e. Y), or -1 if not found | 
|---|
|  | 511 |  | 
|---|
|  | 512 | new DIC,X,Y | 
|---|
|  | 513 | set DIC=200 ;"file 200 is NEW PERSON | 
|---|
|  | 514 | set DIC(0)="M" | 
|---|
|  | 515 | set X=Provider | 
|---|
|  | 516 | do ^DIC ;" do a         , value is returned in Y | 
|---|
|  | 517 | if $find(Y,"^")>0 set Y=$piece(Y,"^",1) | 
|---|
|  | 518 |  | 
|---|
|  | 519 | quit Y | 
|---|
|  | 520 |  | 
|---|
|  | 521 |  | 
|---|
|  | 522 | GetRecord(Document,NewDoc,AskOK,Editable) | 
|---|
|  | 523 | ;"Scope: PRIVATE | 
|---|
|  | 524 | ;"PURPOSE: | 
|---|
|  | 525 | ;"  To get a record--either via creating a new one, or returning an existing one | 
|---|
|  | 526 | ;"  Note: If an existing one is returned, it will be emptied first... | 
|---|
|  | 527 | ;" | 
|---|
|  | 528 | ;"  Note: If I want to merge part of what the doctor creates with what the | 
|---|
|  | 529 | ;"        transcriptionist uploads, here what I should do | 
|---|
|  | 530 | ;"        1. Look for an existing document with same date as document being uploaded. | 
|---|
|  | 531 | ;"        2. If found, look in existing document for merge symbols (i.e. {{1}} } | 
|---|
|  | 532 | ;"        3. If found, then take code from existing document and current part | 
|---|
|  | 533 | ;"                of upload buffer, and create a merged document. | 
|---|
|  | 534 | ;"        4. Put this merged document back into the upload buffer. | 
|---|
|  | 535 | ;"        5. Empty the existing document, and return its IEN from this function | 
|---|
|  | 536 | ;" | 
|---|
|  | 537 | ;"INPUT: Document -- array with Document("DFN"), Document(cDocType) are REQUIRED. | 
|---|
|  | 538 | ;" [Document] --> Visit info array -- SHOULD PASS BE REFERENCE. | 
|---|
|  | 539 | ;"              Document("DFN") = patient DFN | 
|---|
|  | 540 | ;"              Document(cVisitStr) = LOC;VDT;VTYP  e.g. 'x;x;OFFICE VISIT' | 
|---|
|  | 541 | ;"              Document(cVisitIEN) = VISIT file IFN  e.g. 0, used for field .03 in file 8925. Pointer to file #9000010 | 
|---|
|  | 542 | ;"              Document(cHspLocIEN)  i.e. Hospital location IEN. Used for field 1205 in 8925.  Pointer to file #44 | 
|---|
|  | 543 | ;"              Document(cVstLocIEN) i.e. visit location IEN. Used for field 1211 in 8925.  Pointer to file #44 | 
|---|
|  | 544 | ;"              Document(cStopCode) = mark to defer workload e.g. 0/FALSE=don't worry about stop codes. | 
|---|
|  | 545 | ;"                 USED FOR: Mark record for deferred crediting of stop code (fld #.11) | 
|---|
|  | 546 | ;"                   This boolean field (.11) indicates whether the stop code associated with a new | 
|---|
|  | 547 | ;"                   visit should be credited when the note is completed. | 
|---|
|  | 548 | ;"                   Note: if Document('STOP')="", then not processed. | 
|---|
|  | 549 | ;"              Document(cDocType)=1^title DA^title Name  i.e.:  1^128^OFFICE VISIT^OFFICE VISIT | 
|---|
|  | 550 | ;"              Document(cDocTIEN)=DocTIEN (a.k.a. title DA) e.g. 128 | 
|---|
|  | 551 | ;"              Document(cService)  e.g.FAMILY PRACTICE | 
|---|
|  | 552 | ;"              Document(cStartDate)   i.e. event begin time | 
|---|
|  | 553 | ;"              Document(cEndDate)  i.e. event end time | 
|---|
|  | 554 | ;" [NewDoc] --> flag, passed back with | 
|---|
|  | 555 | ;"              NewDoc = 1 if returned docmt is new | 
|---|
|  | 556 | ;"              NewDoc = 0 if returned docmt already existed, timeout, etc | 
|---|
|  | 557 | ;" [AskOK] -->  Ask user flag, where | 
|---|
|  | 558 | ;"              AskOK = 1: ask re edit/addend existing docmt | 
|---|
|  | 559 | ;"              (Interactive List Manager options, TRY docmt def) | 
|---|
|  | 560 | ;"              AskOK = 0: don't ask (Upload & GUI options) | 
|---|
|  | 561 | ;" [Editable]-->flag, passed back with Editable = 1 if returned | 
|---|
|  | 562 | ;"              PREEXISTING docmt can be edited by Provider. If | 
|---|
|  | 563 | ;"              preexisting docmt returned and 'Editable, then | 
|---|
|  | 564 | ;"              docmt cannot be edited by Provider. | 
|---|
|  | 565 | ;" | 
|---|
|  | 566 | ;"Results: Returns DocIEN -- IEN of document to use, or -1 if error etc. | 
|---|
|  | 567 | ;"                Also, Document("DOC IEN") is set to DocIEN | 
|---|
|  | 568 | ;"         Errors will be returned in Document("ERROR") | 
|---|
|  | 569 | ;" | 
|---|
|  | 570 | ;"Note:  Code originally from GETRECNM^TIUEDI3 -- KT 5/25/04 | 
|---|
|  | 571 |  | 
|---|
|  | 572 | new MultOK set MultOK=1 | 
|---|
|  | 573 | new DocIEN set DocIEN=-1 | 
|---|
|  | 574 | set NewDoc=0 | 
|---|
|  | 575 |  | 
|---|
|  | 576 | if +$get(BuffNum)'=0 set DocIEN=$$DocExists(.Document) ;"avoid error with RPC calls | 
|---|
|  | 577 | else  set DocIEN=0 | 
|---|
|  | 578 | set Document("DOC IEN")=DocIEN | 
|---|
|  | 579 | if DocIEN>0 do  goto GRDone  ;"DocIEN>0 means that the TEXT of the report is an exact match | 
|---|
|  | 580 | . kill ^TIU(8925,DocIEN,"TEXT")  ;"Kill the TEXT prior report, so we can overwrite it | 
|---|
|  | 581 | else  do | 
|---|
|  | 582 | . set DocIEN=$$CreateRec(.Document) | 
|---|
|  | 583 | . set NewDoc=1 | 
|---|
|  | 584 |  | 
|---|
|  | 585 | GRDone ; | 
|---|
|  | 586 | if NewDoc,DocIEN'>0 set NewDoc=0 | 
|---|
|  | 587 | set Document("DOC IEN")=DocIEN | 
|---|
|  | 588 | quit DocIEN  ;"DocIEN is document number | 
|---|
|  | 589 |  | 
|---|
|  | 590 |  | 
|---|
|  | 591 | DocExists(Document) | 
|---|
|  | 592 | ;"PURPOSE:  To return document IEN, if it  already EXISTS for the | 
|---|
|  | 593 | ;"                given patient, title, and visit. | 
|---|
|  | 594 | ;"INPUT:  Document -- see documentation of format in $$GetRecord | 
|---|
|  | 595 | ;"Results: returns a value for document (i.e. DocIEN), or -1 if no prior doc is found. | 
|---|
|  | 596 | ;" | 
|---|
|  | 597 | ;"Note: The following documents are ignored: | 
|---|
|  | 598 | ;"           - docmts of status deleted or retracted | 
|---|
|  | 599 | ;"         - all docmts if run across a docmt w/ requesting pkg | 
|---|
|  | 600 | ;"         - If REQEDIT, then also ignore docmts PERSON cannot edit. | 
|---|
|  | 601 | ;"Note: If there are more than one, get the smallest DA. | 
|---|
|  | 602 |  | 
|---|
|  | 603 | new DocIEN set DocIEN=-1 | 
|---|
|  | 604 | new index | 
|---|
|  | 605 |  | 
|---|
|  | 606 | if $data(^TIU(8925,"C",Document("DFN")))=0 goto DEDone | 
|---|
|  | 607 | ;"Scan through all documents for patient (DFN) | 
|---|
|  | 608 | set index=$order(^TIU(8925,"C",Document("DFN"),"")) | 
|---|
|  | 609 | if index="" goto DEDone | 
|---|
|  | 610 | for  do  quit:(index="") | 
|---|
|  | 611 | . new DocCompValue | 
|---|
|  | 612 | . set DocCompValue=$$CompToBuff(index,Document(cDocTIEN),Document(cStartDate)) | 
|---|
|  | 613 | . if DocCompValue=2 do  quit  ;"i.e. documents are an exact match | 
|---|
|  | 614 | . . ;"For below, the document is the same as the upload buffer. | 
|---|
|  | 615 | . . ;"We have found our answer. | 
|---|
|  | 616 | . . ;" | 
|---|
|  | 617 | . . ;"Below is code I can use to check to see if I SHOULD be editing. | 
|---|
|  | 618 | . . ;"------------------------------------------------------ | 
|---|
|  | 619 | . . ;"new CANEDIT,CANDel | 
|---|
|  | 620 | . . ;"set CANEDIT=+$$CANDO^TIULP(index,"EDIT RECORD",Document("PROVIDER IEN")) | 
|---|
|  | 621 | . . ;"set CANDel=+$$CANDO^TIULP(index,"DELETE RECORD",Document("PROVIDER IEN")) | 
|---|
|  | 622 | . . ;"if +CANEDIT>0 set DocIEN=index | 
|---|
|  | 623 | . . set DocIEN=index set index="" quit | 
|---|
|  | 624 | . set index=$order(^TIU(8925,"C",Document("DFN"),index)) | 
|---|
|  | 625 |  | 
|---|
|  | 626 | DEDone | 
|---|
|  | 627 | quit DocIEN | 
|---|
|  | 628 |  | 
|---|
|  | 629 |  | 
|---|
|  | 630 | BuffCharCount() | 
|---|
|  | 631 | ;"Purpose: To count the number of characters in the current upload buffer, for the | 
|---|
|  | 632 | ;"        current document.  The upload buffer puts all the documents being uploaded | 
|---|
|  | 633 | ;"        into one big WP array.  This function will count down until the text | 
|---|
|  | 634 | ;"        signal is found to start the next documnent (e.g. '[NewDict]') | 
|---|
|  | 635 | ;"Input: none.  However, several global-scope variables are used. | 
|---|
|  | 636 | ;"        By tracing through the upload code I know that | 
|---|
|  | 637 | ;"      the following variables are set: | 
|---|
|  | 638 | ;"        (I saved DA as BuffNum, and TIUI as BuffIdx) | 
|---|
|  | 639 | ;"        TIUHSIG = [NewDict]  .. or whatever it has been set to by user in upload params | 
|---|
|  | 640 | ;"        TIUBGN = [TEXT] ... or whatever is has be set to by user in upload params. | 
|---|
|  | 641 | ;"        BuffIdx = the line index of the beginning of the report to be processed (i.e. the line | 
|---|
|  | 642 | ;"       that starts with [TEXT] | 
|---|
|  | 643 | ;"        BuffNum = the index in 8925.2, i.e. ^TIU(8925.2,BuffNum,"TEXT",0) | 
|---|
|  | 644 | ;"                     In other words, here BuffNum = the serial index number of the document to | 
|---|
|  | 645 | ;"                be uploaded i.e. 1 for the first, 2 for the second etc. | 
|---|
|  | 646 | ;"Notes | 
|---|
|  | 647 | ;"  8925.2 is file: TIU UPLOAD BUFFER | 
|---|
|  | 648 | ;"  To detect the beginning of the next document, use | 
|---|
|  | 649 | ;"     if MyLine[TIUHSIG then abort | 
|---|
|  | 650 | ;"  I trim of leading and trailing white-space before counting. | 
|---|
|  | 651 | ;"        But, otherwise spaces will be counted | 
|---|
|  | 652 | ;" | 
|---|
|  | 653 | ;"Results: Returns character count, or 0 if none found. | 
|---|
|  | 654 |  | 
|---|
|  | 655 | new index | 
|---|
|  | 656 | new result set result=0 | 
|---|
|  | 657 | if $get(TIUHSIG)="" goto BuffCDone | 
|---|
|  | 658 |  | 
|---|
|  | 659 | set index=$order(^TIU(8925.2,BuffNum,"TEXT",BuffIdx)) | 
|---|
|  | 660 | for  do  quit:(index="") | 
|---|
|  | 661 | . if index="" quit | 
|---|
|  | 662 | . new s set s=$get(^TIU(8925.2,BuffNum,"TEXT",index,0)) | 
|---|
|  | 663 | . if s="" set index="" quit | 
|---|
|  | 664 | . if s[TIUHSIG set index="" quit | 
|---|
|  | 665 | . set s=$$Trim^TMGSTUTL(.s) | 
|---|
|  | 666 | . set result=result+$length(s) | 
|---|
|  | 667 | . set index=$order(^TIU(8925.2,BuffNum,"TEXT",index)) | 
|---|
|  | 668 |  | 
|---|
|  | 669 | BuffCDone | 
|---|
|  | 670 | quit result | 
|---|
|  | 671 |  | 
|---|
|  | 672 |  | 
|---|
|  | 673 |  | 
|---|
|  | 674 | PrepUploadBuf() | 
|---|
|  | 675 | ;"Purpose: Ensure upload buffer is ready for processing | 
|---|
|  | 676 | ;"Background: Transcriptionist will upload a large document containing | 
|---|
|  | 677 | ;"        multiple notes for different patients etc.  This entire large | 
|---|
|  | 678 | ;"        document is stored in the TIU UPLOAD BUFFER file (8925.2) | 
|---|
|  | 679 | ;"        When this filer code is called, the TIU upload process has already | 
|---|
|  | 680 | ;"        set up some variables. | 
|---|
|  | 681 | ;"        DA = the IEN in 8925.2, i.e. ^TIU(8925.2,DA,"TEXT",0) that | 
|---|
|  | 682 | ;"                the uploaded text was temporarily store in. | 
|---|
|  | 683 | ;"        (I save DA as BuffNum) | 
|---|
|  | 684 | ;"        TIUI = the line index of the beginning of the report to | 
|---|
|  | 685 | ;"                be processed (i.e. the line that starts with [TEXT]) | 
|---|
|  | 686 | ;"        (I save TIUI as BuffIdx) | 
|---|
|  | 687 | ;"        TIUHSIG = [NewDict]  .. or whatever it has been set to by user in upload params | 
|---|
|  | 688 | ;"        TIUBGN = [TEXT] ... or whatever is has be set to by user in upload params. | 
|---|
|  | 689 | ;" | 
|---|
|  | 690 | ;"        I found that transcriptionists were using word-processors that automatically | 
|---|
|  | 691 | ;"        wrapped the text to a next line.  Thus paragraphs were being uploaded as | 
|---|
|  | 692 | ;"        one very long line.  Rather than try to reeducate them to consistantly hit | 
|---|
|  | 693 | ;"        enter at the end of every line, I chose to automatically wrap the text to | 
|---|
|  | 694 | ;"        a set width. | 
|---|
|  | 695 | ;" | 
|---|
|  | 696 | ;"        A global-scope var: cMaxNoteWidth is expected to be defined/ | 
|---|
|  | 697 | ;" | 
|---|
|  | 698 | ;"        So, to prepair the upload buffer, I use these steps: | 
|---|
|  | 699 | ;"                1. Scan the part of the upload buffer pertaining to the | 
|---|
|  | 700 | ;"                   current note being processed | 
|---|
|  | 701 | ;"                        - This starts with line BuffIdx, and ends with... | 
|---|
|  | 702 | ;"                        - the line containing TIUHSIG (or end of buffer) | 
|---|
|  | 703 | ;"                   See if any line is longer than cMaxNoteWidth characters. | 
|---|
|  | 704 | ;"                        If so, mark for wrapping. | 
|---|
|  | 705 | ;"                2. If wrapping needed, extract note to a temporary array | 
|---|
|  | 706 | ;"                3. Perform reformatting/wrapping on temp array. | 
|---|
|  | 707 | ;"                4. Put temp array back into Upload buffer | 
|---|
|  | 708 | ;" | 
|---|
|  | 709 | ;"Input: None, but global-scope vars used (see above) | 
|---|
|  | 710 | ;"Output: Upload buffer may be changed | 
|---|
|  | 711 | ;"Result: 1=OKToCont or cAbort | 
|---|
|  | 712 |  | 
|---|
|  | 713 | new result set result=1 | 
|---|
|  | 714 | if $$NeedsReformat(cMaxNoteWidth) do | 
|---|
|  | 715 | . new CurNote | 
|---|
|  | 716 | . new NextNoteI | 
|---|
|  | 717 | . new DoSpecialIndent set DoSpecialIndent=1  ;"I.e. use hanging indents.) | 
|---|
|  | 718 | . set NextNoteI=$$CutNote(.CurNote) | 
|---|
|  | 719 | . do WordWrapArray^TMGSTUTL(.CurNote,cMaxNoteWidth,DoSpecialIndent) | 
|---|
|  | 720 | . set result=$$PasteNote(.CurNote,NextNoteI) | 
|---|
|  | 721 | PULBFDone | 
|---|
|  | 722 | quit result | 
|---|
|  | 723 |  | 
|---|
|  | 724 |  | 
|---|
|  | 725 | NeedsReformat(MaxWidth) | 
|---|
|  | 726 | ;"Purpose: To scan the single note being processed, to see if | 
|---|
|  | 727 | ;"        it is too wide (i.e. any line of length > MaxWidth | 
|---|
|  | 728 | ;"        I had to do this because transcriptionists were using | 
|---|
|  | 729 | ;"        a wordprocessor that wrapped lines.  Then when uploaded | 
|---|
|  | 730 | ;"        each paragraph became one long line. | 
|---|
|  | 731 | ;"        Also, will fix extended ASCII characters | 
|---|
|  | 732 | ;"Input: MaxWidth The max length of any line (i.e. 80 for 80 chars) | 
|---|
|  | 733 | ;"        Also depends on global-scope vars | 
|---|
|  | 734 | ;"Result: 1= A line was found that is > MaxWidth | 
|---|
|  | 735 | ;"          0= no long lines found | 
|---|
|  | 736 |  | 
|---|
|  | 737 | new index | 
|---|
|  | 738 | new result set result=0 | 
|---|
|  | 739 | if $get(TIUHSIG)="" goto NRFMDone | 
|---|
|  | 740 | if $get(MaxWidth)'>0 goto NRFMDone | 
|---|
|  | 741 |  | 
|---|
|  | 742 | set index=$order(^TIU(8925.2,BuffNum,"TEXT",BuffIdx)) | 
|---|
|  | 743 | if index'="" for  do  quit:(index="") | 
|---|
|  | 744 | . new s | 
|---|
|  | 745 | . set s=$get(^TIU(8925.2,BuffNum,"TEXT",index,0)) | 
|---|
|  | 746 | . if s="" set index="" quit | 
|---|
|  | 747 | . ;"9/19/06 Added to remove extended ASCII characters | 
|---|
|  | 748 | . ;"set s=$translate(s,$c(146)_$c(246)_$c(150)_$c(147)_$c(148),"'--""""") | 
|---|
|  | 749 | . if s[TIUHSIG set index="" quit | 
|---|
|  | 750 | . if $length(s)>MaxWidth do  quit | 
|---|
|  | 751 | . . set result=1 | 
|---|
|  | 752 | . . set index="" | 
|---|
|  | 753 | . set index=$order(^TIU(8925.2,BuffNum,"TEXT",index)) | 
|---|
|  | 754 |  | 
|---|
|  | 755 | NRFMDone | 
|---|
|  | 756 | quit result | 
|---|
|  | 757 |  | 
|---|
|  | 758 |  | 
|---|
|  | 759 | CutNote(Array) | 
|---|
|  | 760 | ;"Purpose: To extract the current note out of the entire upload buffer | 
|---|
|  | 761 | ;"Input: Array -- MUST BE PASSED BY REFERENCE.  This is an OUT parameter | 
|---|
|  | 762 | ;"        Array will be loaded with the note, with the first line being | 
|---|
|  | 763 | ;"        put into Array(1) | 
|---|
|  | 764 | ;"        Depends on global-scope vars BuffIdx, BuffNum, TIUHSIG, set up elsewhere. | 
|---|
|  | 765 | ;"Note: This function empties the lines in TIU UPLOAD BUFFER as it cuts out note. | 
|---|
|  | 766 | ;"Result: Returns: | 
|---|
|  | 767 | ;"                #:   index of line containing start of next note. | 
|---|
|  | 768 | ;"                -1:  Error | 
|---|
|  | 769 | ;"                  0:  Note is the last one in the upload buffer, so no next note found | 
|---|
|  | 770 |  | 
|---|
|  | 771 | new index | 
|---|
|  | 772 | new LastI set LastI=0 | 
|---|
|  | 773 | new result set result=-1 | 
|---|
|  | 774 | kill Array | 
|---|
|  | 775 | if $get(TIUHSIG)="" goto ExNDone | 
|---|
|  | 776 | new ArrayI set ArrayI=0 | 
|---|
|  | 777 | new s | 
|---|
|  | 778 | new Done set Done=0 | 
|---|
|  | 779 |  | 
|---|
|  | 780 | set index=$order(^TIU(8925.2,BuffNum,"TEXT",BuffIdx)) | 
|---|
|  | 781 |  | 
|---|
|  | 782 | if index'="" for  do  quit:(index="")!(Done=1) | 
|---|
|  | 783 | . set s=$get(^TIU(8925.2,BuffNum,"TEXT",index,0)) | 
|---|
|  | 784 | . if s[TIUHSIG set Done=1 quit | 
|---|
|  | 785 | . set ArrayI=ArrayI+1 | 
|---|
|  | 786 | . set Array(ArrayI)=s | 
|---|
|  | 787 | . kill ^TIU(8925.2,BuffNum,"TEXT",index) | 
|---|
|  | 788 | . set LastI=index | 
|---|
|  | 789 | . set index=$order(^TIU(8925.2,BuffNum,"TEXT",index)) | 
|---|
|  | 790 |  | 
|---|
|  | 791 | set result=+index | 
|---|
|  | 792 | if result=0 set result=LastI | 
|---|
|  | 793 | ExNDone | 
|---|
|  | 794 | quit result | 
|---|
|  | 795 |  | 
|---|
|  | 796 |  | 
|---|
|  | 797 |  | 
|---|
|  | 798 | PasteNote(Array,NextNoteI) | 
|---|
|  | 799 | ;"Purpose: To put Array back into the upload buffer, at the correct location, | 
|---|
|  | 800 | ;"Input: Array -- Best if PASSED BY REFERENCE. | 
|---|
|  | 801 | ;"        Array is expected to be loaded with the note, with the first line Array(1) | 
|---|
|  | 802 | ;"        NextNoteI: This is the index, in upload buffer, of the start of the next note. | 
|---|
|  | 803 | ;"Depends on global-scope vars BuffIdx, BuffNum, TIUHSIG, set up elsewhere. | 
|---|
|  | 804 | ;"Result: 1=OKToCont if all OK, or cAbort if error | 
|---|
|  | 805 |  | 
|---|
|  | 806 | new EntireBuf | 
|---|
|  | 807 | new IndexInc set IndexInc=0.01  ;"WP^DIE does not require integer indexes. | 
|---|
|  | 808 | new ArrayI,PasteI | 
|---|
|  | 809 | new s | 
|---|
|  | 810 | new Done set Done=0 | 
|---|
|  | 811 | new result set result=cAbort | 
|---|
|  | 812 | merge EntireBuf=^TIU(8925.2,BuffNum,"TEXT") | 
|---|
|  | 813 | kill EntireBuf(0) ;"remove ^^<line count>^<line count>^<fm date>^^ | 
|---|
|  | 814 |  | 
|---|
|  | 815 | set ArrayI=$order(Array("")) | 
|---|
|  | 816 | set PasteI=BuffIdx+1 | 
|---|
|  | 817 | for  do  quit:((Done=1)!(ArrayI="")) | 
|---|
|  | 818 | . if $data(Array(ArrayI))#10=0 set Done=1 quit | 
|---|
|  | 819 | . set s=Array(ArrayI) | 
|---|
|  | 820 | . set EntireBuff(PasteI,0)=s | 
|---|
|  | 821 | . set PasteI=PasteI+IndexInc | 
|---|
|  | 822 | . if PasteI>NextNoteI do  quit | 
|---|
|  | 823 | . . do ShowError^TMGDEBUG(PriorErrorFound,"Insufficient room to put note back into upload buffer.") | 
|---|
|  | 824 | . . set Done=1 | 
|---|
|  | 825 | . set ArrayI=$order(Array(ArrayI)) | 
|---|
|  | 826 |  | 
|---|
|  | 827 | Set result=$$WriteWP^TMGDBAPI(8925.2,BuffNum,1,.EntireBuff) | 
|---|
|  | 828 |  | 
|---|
|  | 829 | quit result | 
|---|
|  | 830 |  | 
|---|
|  | 831 |  | 
|---|
|  | 832 | CompToBuff(ExistingIEN,UplTIEN,UplDate) | 
|---|
|  | 833 | ;"PURPOSE: To compare the document being uploaded (i.e. in the file 8925.2, TIU upload buffer) | 
|---|
|  | 834 | ;"           to documents already existing in database | 
|---|
|  | 835 | ;"Input: ExistingIEN -- the document IEN of a pre-existing document in the database. | 
|---|
|  | 836 | ;"                  i.e. ^TIU(8925,ExistingIEN,*) | 
|---|
|  | 837 | ;"       UplTIEN=The type number of document being uploaded | 
|---|
|  | 838 | ;"         UplDate -- the date of the document being uploaded. | 
|---|
|  | 839 | ;"      NOTE: See also global-scope variables below that are REQUIRED | 
|---|
|  | 840 | ;" | 
|---|
|  | 841 | ;"Output: returns 0 if TEXT or Date different | 
|---|
|  | 842 | ;"                1 if TEXT only is the same (Title is different) | 
|---|
|  | 843 | ;"                2 if TEXT & Title are same | 
|---|
|  | 844 | ;" | 
|---|
|  | 845 | ;"------------------------------------------------------------------------------------ | 
|---|
|  | 846 | ;"Programming Note: By tracing through the upload code I know that | 
|---|
|  | 847 | ;"                  the following variables are set: | 
|---|
|  | 848 | ;"                        (I saved DA as BuffNum, and TIUI as BuffIdx) | 
|---|
|  | 849 | ;"TIUHSIG = [NewDict]  .. or whatever it has been set to by user in upload params | 
|---|
|  | 850 | ;"TIUBGN = [TEXT] ... or whatever is has be set to by user in upload params. | 
|---|
|  | 851 | ;"BuffIdx = the line index of the beginning of the report to be processed (i.e. the line | 
|---|
|  | 852 | ;"       that starts with [TEXT] | 
|---|
|  | 853 | ;"BuffNum = the index in 8925.2, i.e. ^TIU(8925.2,BuffNum,"TEXT",0) | 
|---|
|  | 854 | ;"     In other words, here BuffNum = the serial index number of the document to be uploaded | 
|---|
|  | 855 | ;"     i.e. 1 for the first, 2 for the second etc. | 
|---|
|  | 856 | ;"     Note 8925.2 is file: TIU UPLOAD BUFFER | 
|---|
|  | 857 | ;"Note | 
|---|
|  | 858 | ;"  To detect the beginning of the next document, use | 
|---|
|  | 859 | ;"  if MyLine[TIUHSIG then abort | 
|---|
|  | 860 |  | 
|---|
|  | 861 | new MaxUplLine | 
|---|
|  | 862 | new DocLine,UplLine | 
|---|
|  | 863 | new DocData,UplData | 
|---|
|  | 864 | new result set result=0 | 
|---|
|  | 865 | new MaxDocLine,CompLine | 
|---|
|  | 866 | new DocType,DocName | 
|---|
|  | 867 | new Break set Break=0 | 
|---|
|  | 868 | new DocDate | 
|---|
|  | 869 |  | 
|---|
|  | 870 | ;"First, see if dates are the same.  If not, bail out. | 
|---|
|  | 871 | set DocDate=$piece(^TIU(8925,ExistingIEN,0),"^",7) | 
|---|
|  | 872 | if DocDate'=UplDate goto CompExit  ;"Quit with result=0 | 
|---|
|  | 873 |  | 
|---|
|  | 874 | set MaxUplLine=$piece($get(^TIU(8925.2,BuffNum,"TEXT",0)),"^",3) | 
|---|
|  | 875 | if MaxUplLine="" goto CompExit | 
|---|
|  | 876 | set MaxDocLine=$piece($get(^TIU(8925,ExistingIEN,"TEXT",0)),"^",3) | 
|---|
|  | 877 | if MaxDocLine="" goto CompExit | 
|---|
|  | 878 |  | 
|---|
|  | 879 | set UplLine=BuffIdx | 
|---|
|  | 880 | set DocLine=0 | 
|---|
|  | 881 |  | 
|---|
|  | 882 | ;"Compare the two documents line by line. | 
|---|
|  | 883 | for i=1:1:(MaxUplLine-UplLine) do  if Break goto CompExit | 
|---|
|  | 884 | . set UplData=$get(^TIU(8925.2,BuffNum,"TEXT",UplLine+i,0)) | 
|---|
|  | 885 | . set DocData=$get(^TIU(8925,ExistingIEN,"TEXT",DocLine+i,0),"x") | 
|---|
|  | 886 | . if UplData[TIUHSIG set i=MaxUplLine quit | 
|---|
|  | 887 | . if UplData'=DocData set Break=1 quit | 
|---|
|  | 888 | . quit | 
|---|
|  | 889 |  | 
|---|
|  | 890 | ;"If we have gotten this far, then the text is an identical match. | 
|---|
|  | 891 | set result=1 | 
|---|
|  | 892 |  | 
|---|
|  | 893 | ;"Now check to see if the dictation type is the same. | 
|---|
|  | 894 | set DocType=$piece($get(^TIU(8925,ExistingIEN,0)),"^",1) | 
|---|
|  | 895 | if DocType=UplTIEN set result=2 | 
|---|
|  | 896 |  | 
|---|
|  | 897 | CompExit | 
|---|
|  | 898 | quit result | 
|---|
|  | 899 |  | 
|---|
|  | 900 |  | 
|---|
|  | 901 | ;------------------------------------------------------------------------ | 
|---|
|  | 902 | CreateRec(Document) ; | 
|---|
|  | 903 | ;"Purpose: Create document record - Returns DA | 
|---|
|  | 904 | ;"Input: Document -- an array with document info.  See GetRecord for documentation | 
|---|
|  | 905 | ;"Ouput: DocIEN (internal entry number) of entry created, or -1 if failure | 
|---|
|  | 906 | ;"       Errors (if any) returned in Document("ERROR") | 
|---|
|  | 907 | ;" | 
|---|
|  | 908 | ;"Note: This was originally taken from TIUEDI3 | 
|---|
|  | 909 |  | 
|---|
|  | 910 | ;"new cOKToCont set cOKToCont=1 | 
|---|
|  | 911 | new cAbort set cAbort=0 | 
|---|
|  | 912 | new result set result=1; "cOKToCont | 
|---|
|  | 913 |  | 
|---|
|  | 914 | new DIC,DLAYGO,X,Y,DIE,DR | 
|---|
|  | 915 |  | 
|---|
|  | 916 | new DocIEN set DocIEN=-1 | 
|---|
|  | 917 | new TMGFDA,RecNum,TMGMSG,Flags | 
|---|
|  | 918 | set TMGFDA(8925,"+1,",.01)="`"_Document(cDocTIEN) | 
|---|
|  | 919 | set Flags="E" | 
|---|
|  | 920 |  | 
|---|
|  | 921 | ;"====================================================== | 
|---|
|  | 922 | ;"Call UPDATE^DIE -- add new entries in files or subfiles. | 
|---|
|  | 923 | ;"====================================================== | 
|---|
|  | 924 | do | 
|---|
|  | 925 | . new $etrap set $etrap="do ErrTrp^TMGDBAPI" | 
|---|
|  | 926 | . set ^TMP("TMG",$J,"ErrorTrap")=result | 
|---|
|  | 927 | . set ^TMP("TMG",$J,"Caller")="UPDATE^DIE" | 
|---|
|  | 928 | . do UPDATE^DIE(Flags,"TMGFDA","RecNum","TMGMSG") | 
|---|
|  | 929 | . set result=^TMP("TMG",$J,"ErrorTrap") | 
|---|
|  | 930 | . kill ^TMP("TMG",$J,"ErrorTrap") | 
|---|
|  | 931 | ;"====================================================== | 
|---|
|  | 932 | ;"====================================================== | 
|---|
|  | 933 |  | 
|---|
|  | 934 | if result'=1 goto CRDone  ;"1=cOKToCont | 
|---|
|  | 935 | if $data(TMGMSG("DIERR")) do  goto CRDone | 
|---|
|  | 936 | . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound) | 
|---|
|  | 937 | . set DocIEN=-1 | 
|---|
|  | 938 | . merge Document("ERROR","DIERR")=TMGMSG | 
|---|
|  | 939 | do | 
|---|
|  | 940 | . new index set index=$order(RecNum("")) | 
|---|
|  | 941 | . if index'="" set DocIEN=+$get(RecNum(index)) | 
|---|
|  | 942 | if DocIEN=0 set DocIEN=-1 | 
|---|
|  | 943 |  | 
|---|
|  | 944 | CRDone | 
|---|
|  | 945 | ;"Now check for failure.  DocIEN will equal record number, or -1 if failure | 
|---|
|  | 946 | if DocIEN'>0 do  goto CRDone | 
|---|
|  | 947 | . new n set n=+$get(Document("ERROR","NUM"))+1 | 
|---|
|  | 948 | . set Document("ERROR",n)=$piece(Document(cDocType),"^",3)_" record could not be created." | 
|---|
|  | 949 | set Document("DOC IEN")=DocIEN | 
|---|
|  | 950 |  | 
|---|
|  | 951 | quit DocIEN | 
|---|
|  | 952 |  | 
|---|
|  | 953 |  | 
|---|
|  | 954 |  | 
|---|
|  | 955 | ;------------------------------------------------------------------------ | 
|---|
|  | 956 | StuffRec(Document,PARENT) | 
|---|
|  | 957 | ;"Purpose: Stuff fixed field data | 
|---|
|  | 958 | ;"INPUT: | 
|---|
|  | 959 | ;"  Document = An array containing information to put into document. | 
|---|
|  | 960 | ;"               The array should contain the following: | 
|---|
|  | 961 | ;"                Document("DOC IEN") -- the document IEN | 
|---|
|  | 962 | ;"                Document("PROVIDER IEN") -- the IEN of the provider | 
|---|
|  | 963 | ;"                Document("DFN") -- the patient IEN | 
|---|
|  | 964 | ;"                Document(cVisitIEN) -- a link to a visit entry | 
|---|
|  | 965 | ;"                Document(cStartDate)  -- episode begin date/time | 
|---|
|  | 966 | ;"                Document(cEndDate)  -- episode end date/time | 
|---|
|  | 967 | ;"                Document(cHspLocIEN) -- hospital location (Document(cVstLocIEN) used NULL) | 
|---|
|  | 968 | ;"                Document(cVstLocIEN) -- visit location. | 
|---|
|  | 969 | ;"                Document(cService) -- service (i.e. FAMILY PRACTICE) | 
|---|
|  | 970 | ;"                Document(cVisitStr) | 
|---|
|  | 971 | ;"                Document("TRANSCRIPTIONIST") -- the name of the transcriptionist | 
|---|
|  | 972 | ;"                Document("CHARACTER COUNT - TRANSCRIPTIONIST'S") -- the char count creditable to transcriptionist | 
|---|
|  | 973 | ;"                Document("LINE COUNT") -- Total line count | 
|---|
|  | 974 | ;"  PARENT:  If we are working with an addendum to a document, then | 
|---|
|  | 975 | ;"                parent is the internal entry number of the original parent document | 
|---|
|  | 976 | ;"                Note:DocID can be null if not needed. | 
|---|
|  | 977 | ;"                Note: I don't ever pass a parent, currently | 
|---|
|  | 978 | ;" | 
|---|
|  | 979 | ;"NOTE: The following global-scope variables are also referenced | 
|---|
|  | 980 | ;"        TIUDDT | 
|---|
|  | 981 | ;"Results: Passes back document IEN, or -1 if error. | 
|---|
|  | 982 | ;"         NOTE: if result is -1 then errors are passed back in | 
|---|
|  | 983 | ;"              Document("ERROR") node | 
|---|
|  | 984 | ;"              Document("ERROR",n)="ERROR.. Stuffing new document." | 
|---|
|  | 985 | ;"              Document("ERROR","NUM")=n | 
|---|
|  | 986 | ;"              Document("ERROR","FM INFO")=merge with DIERR array | 
|---|
|  | 987 |  | 
|---|
|  | 988 | new TMGFDA,TMGMSG | 
|---|
|  | 989 | new RefDate | 
|---|
|  | 990 | new DocIEN set DocIEN=$get(Document("DOC IEN"),-1) | 
|---|
|  | 991 | if DocIEN=-1 goto SfRecDone | 
|---|
|  | 992 | new result set result=DocIEN ;"default to success | 
|---|
|  | 993 | new ParentDocType | 
|---|
|  | 994 |  | 
|---|
|  | 995 | ;"Field (f) constants | 
|---|
|  | 996 | new fPatient set fPatient=.02        ;"field .02 = PATIENT | 
|---|
|  | 997 | new fVisit set fVisit=.03            ;"field .03 = VISIT | 
|---|
|  | 998 | new fParentDoc set fParentDoc=.04    ;"field .04 = PARENT DOCUMENT TYPE | 
|---|
|  | 999 | new fStatus set fStatus=.05          ;"field .05 = STATUS | 
|---|
|  | 1000 | new fParent set fParent=.06          ;"field .06 = PARENT | 
|---|
|  | 1001 | new fStartDate set fStartDate=.07    ;"EPISODE BEGIN DATE/TIME (field .07) | 
|---|
|  | 1002 | new fEndDate set fEndDate=.08        ;"EPISODE END DATE/TIME (field .08) | 
|---|
|  | 1003 | new fEntryDate set fEntryDate=1201   ;"field 1201 = ENTRY DATE/TIME | 
|---|
|  | 1004 | new fAuthor set fAuthor=1202         ;"field 1202 = PERSON/DICTATOR | 
|---|
|  | 1005 | new fExpSigner set fExpSigner=1204   ;"field 1204 = expected Signer | 
|---|
|  | 1006 | new fHospLoc set fHospLoc=1205       ;"field 1205 = HOSPITAL LOCATION | 
|---|
|  | 1007 | new fExpCosign set fExpCosign=1208   ;"field 1208 = expected cosigner | 
|---|
|  | 1008 | new fAttending set fAttending=1209   ;"field 1209 = ATTENDING | 
|---|
|  | 1009 | new fVisitLoc set fVisitLoc=1211     ;"field 1211 = VISIT LOCATION | 
|---|
|  | 1010 | new fRefDate set fRefDate=1301       ;"field 1301 = REFERENCE DATE | 
|---|
|  | 1011 | new fEnteredBy set fEnteredBy=1302   ;"field 1302 = ENTERED BY (a pointer to file 200) | 
|---|
|  | 1012 | new fCapMethod set fCapMethod=1303   ;"field 1303 = CAPTURE METHOD;  U-->'upload' | 
|---|
|  | 1013 | new fService set fService=1404       ;"field 1404 = SERVICE | 
|---|
|  | 1014 | new fSignedBy set fSignedBy=1502     ;"field 1502 = signed by | 
|---|
|  | 1015 | new fNeedCosign set fNeedCosign=1506 ;"field 1506 = cosigniture expected. | 
|---|
|  | 1016 | new fCharTrans set fCharTrans=22711  ;"field 22711 = CHAR COUNT -- TRANSCRIPTIONIST | 
|---|
|  | 1017 | new fLineCount set fLineCount=.1      ;"field .1 = LINE COUNT | 
|---|
|  | 1018 |  | 
|---|
|  | 1019 | ;"8925=TIU DOCUMENT, the file we will edit | 
|---|
|  | 1020 | ;"do Set8925Value(.TMGFDA,Document("DFN"),fPatient,1)  ;"Will file separatedly below. | 
|---|
|  | 1021 | do Set8925Value(.TMGFDA,Document(cVisitIEN),fVisit,1) | 
|---|
|  | 1022 | do Set8925Value(.TMGFDA,Document("PROVIDER IEN"),fAuthor,1) | 
|---|
|  | 1023 | do Set8925Value(.TMGFDA,Document("PROVIDER IEN"),fExpSigner,1) | 
|---|
|  | 1024 | do Set8925Value(.TMGFDA,Document("PROVIDER IEN"),fAttending,1) | 
|---|
|  | 1025 | do Set8925Value(.TMGFDA,Document(cHspLocIEN),fHospLoc,1) | 
|---|
|  | 1026 | do Set8925Value(.TMGFDA,Document(cVstLocIEN),fVisitLoc,1) | 
|---|
|  | 1027 | do Set8925Value(.TMGFDA,Document("TRANSCRIPTIONIST"),fEnteredBy,0)   ;"VA transcriptionist field | 
|---|
|  | 1028 | do Set8925Value(.TMGFDA,Document("CHARACTER COUNT - TRANSCRIPTIONIST'S"),fCharTrans,0) | 
|---|
|  | 1029 |  | 
|---|
|  | 1030 | if $data(Document("LINE COUNT")) do | 
|---|
|  | 1031 | . do Set8925Value(.TMGFDA,Document("LINE COUNT"),fLineCount,0) | 
|---|
|  | 1032 |  | 
|---|
|  | 1033 | set ParentDocType=$$DOCCLASS^TIULC1(+$piece(DocIEN,"^",2)) | 
|---|
|  | 1034 | if +ParentDocType>0 do Set8925Value(.TMGFDA,ParentDocType,fParentDoc,1) | 
|---|
|  | 1035 |  | 
|---|
|  | 1036 | if $get(Document("AUTO SIGN"))=1 do | 
|---|
|  | 1037 | . do Set8925Value(.TMGFDA,"COMPLETED",fStatus,0) | 
|---|
|  | 1038 | . do Set8925Value(.TMGFDA,Document("PROVIDER IEN"),fSignedBy,1) | 
|---|
|  | 1039 | else  do | 
|---|
|  | 1040 | . do Set8925Value(.TMGFDA,"UNSIGNED",fStatus,0) | 
|---|
|  | 1041 |  | 
|---|
|  | 1042 | if +$get(PARENT)'>0 do | 
|---|
|  | 1043 | . ;"do Set8925Value(.TMGFDA,Document("DFN"),fPatient,1) | 
|---|
|  | 1044 | . do Set8925Value(.TMGFDA,Document(cVisitIEN),fVisit,1) | 
|---|
|  | 1045 | . do Set8925Value(.TMGFDA,Document(cStartDate),fStartDate,0) | 
|---|
|  | 1046 | . do Set8925Value(.TMGFDA,Document(cEndDate),fEndDate,0) | 
|---|
|  | 1047 | . do Set8925Value(.TMGFDA,Document(cService),fService,0) | 
|---|
|  | 1048 | if +$get(PARENT)>0 do | 
|---|
|  | 1049 | . new NodeZero set NodeZero=$get(^TIU(8925,+PARENT,0)) | 
|---|
|  | 1050 | . new Node12 set Node12=$get(^TIU(8925,+PARENT,12)) | 
|---|
|  | 1051 | . new Node14 set Node14=$get(^TIU(8925,+PARENT,14)) | 
|---|
|  | 1052 | . ;" | 
|---|
|  | 1053 | . do Set8925Value(.TMGFDA,PARENT,fParent,1) | 
|---|
|  | 1054 | . do Set8925Value(.TMGFDA,$piece(NodeZero,"^",pPatient),fPatient,1) | 
|---|
|  | 1055 | . do Set8925Value(.TMGFDA,$piece(NodeZero,"^",pVisit),fVisit,1) | 
|---|
|  | 1056 | . do Set8925Value(.TMGFDA,$piece(NodeZero,"^",pStrtDate),fStartDate,0) | 
|---|
|  | 1057 | . do Set8925Value(.TMGFDA,$piece(NodeZero,"^",pEndDate),fEndDate,0) | 
|---|
|  | 1058 | . do Set8925Value(.TMGFDA,$piece(Node12,"^",pHospLoc),fHospLoc,1) | 
|---|
|  | 1059 | . do Set8925Value(.TMGFDA,$piece(Node14,"^",pService),fService,0) | 
|---|
|  | 1060 |  | 
|---|
|  | 1061 | do Set8925Value(.TMGFDA,$$NOW^TIULC,fEntryDate,0) | 
|---|
|  | 1062 | do Set8925Value(.TMGFDA,Document(cHspLocIEN),fHospLoc,1) | 
|---|
|  | 1063 | do Set8925Value(.TMGFDA,Document(cVstLocIEN),fVisitLoc,1) | 
|---|
|  | 1064 | do Set8925Value(.TMGFDA,Document(cStartDate),fRefDate,0) | 
|---|
|  | 1065 | do Set8925Value(.TMGFDA,"U",fCapMethod,0)   ;"  U-->'upload' | 
|---|
|  | 1066 | ;"do Set8925Value(.TMGFDA,3,fStatus,0) | 
|---|
|  | 1067 |  | 
|---|
|  | 1068 | kill ^TMG("TMP","EDDIE") | 
|---|
|  | 1069 | ;"merge ^TMG("TMP","EDDIE","INSIDE DOCUMENT")=Document  ;"TEMP!! | 
|---|
|  | 1070 | merge ^TMG("TMP","EDDIE","FDA")=TMGFDA  ;"TEMP!! | 
|---|
|  | 1071 |  | 
|---|
|  | 1072 | do FILE^DIE("EK","TMGFDA","TMGMSG") | 
|---|
|  | 1073 | if $data(TMGMSG("DIERR")) do  goto SfRecDone | 
|---|
|  | 1074 | . set result=-1 | 
|---|
|  | 1075 | . merge Document("ERROR","FM INFO")=TMGMSG("DIERR") | 
|---|
|  | 1076 |  | 
|---|
|  | 1077 | ;" -- [Mark record for deferred crediting of stop code (fld #.11)]: -- | 
|---|
|  | 1078 | if +$get(Document("STOP")) do | 
|---|
|  | 1079 | . do DEFER^TIUVSIT(DocIEN,+$get(Document("STOP"))) | 
|---|
|  | 1080 |  | 
|---|
|  | 1081 | ;"Try storing .02 field separately to avoid weird filing error | 
|---|
|  | 1082 | kill TMGFDA | 
|---|
|  | 1083 | kill ^TMG("TMP","EDDIE") | 
|---|
|  | 1084 | new PtDFN set PtDFN=Document("DFN") | 
|---|
|  | 1085 | if (+PtDFN'=PtDFN),(PtDFN["`") set PtDFN=$piece(PtDFN,"`",2) | 
|---|
|  | 1086 | if +PtDFN>0 do | 
|---|
|  | 1087 | . set TMGFDA(8925,DocIEN_",",.02)=PtDFN | 
|---|
|  | 1088 | . merge ^TMG("TMP","EDDIE","FDA")=TMGFDA  ;"TEMP!! | 
|---|
|  | 1089 | . do FILE^DIE("K","TMGFDA","TMGMSG") | 
|---|
|  | 1090 | . if $data(TMGMSG("DIERR")) do | 
|---|
|  | 1091 | . . set result=-1 | 
|---|
|  | 1092 | . . merge Document("ERROR","FM INFO")=TMGMSG("DIERR") | 
|---|
|  | 1093 |  | 
|---|
|  | 1094 | SfRecDone | 
|---|
|  | 1095 | quit result | 
|---|
|  | 1096 |  | 
|---|
|  | 1097 |  | 
|---|
|  | 1098 | Set8925Value(TMGFDA,Value,Field,IsIEN) | 
|---|
|  | 1099 | ;"Purpose: To provide a clean means of loading values into fields, into TMGFDA(8925,DOCIEN) | 
|---|
|  | 1100 | ;"Input: TMGFDA -- The array to fill | 
|---|
|  | 1101 | ;"       Value -- the value to load | 
|---|
|  | 1102 | ;"       Field -- the field | 
|---|
|  | 1103 | ;"       IsIEN = 1 if value is an IEN | 
|---|
|  | 1104 | ;"Note: DEPENDS ON GLOBAL-SCOPE VARIABLES:  DocIEN,Document | 
|---|
|  | 1105 |  | 
|---|
|  | 1106 | if ($get(Value)'="")&($data(Field)>0) do | 
|---|
|  | 1107 | . if $get(IsIEN)>0,$extract(Value,1)'="`" set Value="`"_+Value | 
|---|
|  | 1108 | . if Value'="`0" set TMGFDA(8925,DocIEN_",",Field)=Value | 
|---|
|  | 1109 | quit | 
|---|
|  | 1110 |  | 
|---|
|  | 1111 |  | 
|---|
|  | 1112 |  | 
|---|
|  | 1113 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 1114 | ;"==============================================================================================- | 
|---|
|  | 1115 | ;" F O L L O W - U P   C O D E | 
|---|
|  | 1116 | ;"==============================================================================================- | 
|---|
|  | 1117 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 1118 |  | 
|---|
|  | 1119 | FOLLOWUP(DocIEN) ;" Post-filing code for PROGRESS NOTES | 
|---|
|  | 1120 | ;"PURPOSE: | 
|---|
|  | 1121 | ;"  This function is called by the TIU upload document facilities. | 
|---|
|  | 1122 | ;"  it is called after the text has been put into the document | 
|---|
|  | 1123 | ;" | 
|---|
|  | 1124 | ;"INPUT: | 
|---|
|  | 1125 | ;" DocIEN  -- is passed a value held in TIUREC("#"), i.e. | 
|---|
|  | 1126 | ;"                   do FOLLOWUP^TIUPUTN1(TIUREC("#")). | 
|---|
|  | 1127 |  | 
|---|
|  | 1128 | write ! | 
|---|
|  | 1129 | write "+-------------------------------------+",! | 
|---|
|  | 1130 | write "| Starting Follow-up code...          |",! | 
|---|
|  | 1131 | write "+-------------------------------------+",! | 
|---|
|  | 1132 |  | 
|---|
|  | 1133 | if $data(cOKToCont)#10=0 new cOKToCont set cOKToCont=1 | 
|---|
|  | 1134 | if $data(cAbort)#10=0 new cAbort set cAbort=0 | 
|---|
|  | 1135 |  | 
|---|
|  | 1136 | new DBIndent,PriorErrorFound | 
|---|
|  | 1137 | new result set result=1 ;" 1=cOKToCont | 
|---|
|  | 1138 |  | 
|---|
|  | 1139 | new Document merge Document=TMGDOC | 
|---|
|  | 1140 |  | 
|---|
|  | 1141 | new cStartDate set cStartDate="EDT" | 
|---|
|  | 1142 | new cEndDate set cEndDate="LDT" | 
|---|
|  | 1143 | new cService set cService="SVC" | 
|---|
|  | 1144 | new cDocType set cDocType="TYPE" | 
|---|
|  | 1145 | new cDocTIEN set cDocTIEN="TYPE IEN" | 
|---|
|  | 1146 | ;"new cDocIEN set cDocIEN="DOC IEN" | 
|---|
|  | 1147 | ;"new cPatIEN set cPatIEN="DFN"   ;"DFN = Patient IEN | 
|---|
|  | 1148 | new cHspLocIEN set cHspLocIEN="LOC" | 
|---|
|  | 1149 | new cVstLocIEN set cVstLocIEN="VLOC" | 
|---|
|  | 1150 | new cVisitStr set cVisitStr="VSTR" | 
|---|
|  | 1151 | new cVisitIEN set cVisitIEN="VISIT" | 
|---|
|  | 1152 | new cStopCode set cStopCode="STOP" | 
|---|
|  | 1153 |  | 
|---|
|  | 1154 | ;" 'p constants | 
|---|
|  | 1155 | new pPatient set pPatient=2      ;"Node 0,piece 2 = PATIENT (field .02) | 
|---|
|  | 1156 | new pVisit set pVisit=3          ;"Node 0,piece 3 = VISIT (field .03) | 
|---|
|  | 1157 | new pStrtDate set pStrtDate=7    ;"Node 0,piece 7 = EPISODE BEGIN DATE/TIME (field .07) | 
|---|
|  | 1158 | new pEndDate set pEndDate=8      ;"Node 0,piece 8 = EPISODE END DATE/TIME (field .08) | 
|---|
|  | 1159 |  | 
|---|
|  | 1160 | new pAuthor set pAuthor=2        ;"Node 12,piece 2 = AUTHOR/DICTATOR (field 1202) | 
|---|
|  | 1161 | new pExpSigner set pExpSigner=4  ;"Node 12,piece 4 = EXPECTED SIGNER (field 1204) | 
|---|
|  | 1162 | new pHospLoc set pHospLoc=5      ;"Node 12,piece 5 = field 1205 = HOSPITAL LOCATION | 
|---|
|  | 1163 | new pAttending set pAttending=9  ;"Node 12,piece 9 = ATTENDING PHYSICIAN (field 1209) | 
|---|
|  | 1164 | new pExpCosign set pExpCosign=8  ;"Node 12,piece 8 = EXPECTED COSIGNER (field 1210) | 
|---|
|  | 1165 | new pVstLoc set pVstLoc=11       ;"Node 12,piece 11 = field 1211 = VISIT LOCATION | 
|---|
|  | 1166 |  | 
|---|
|  | 1167 | ;"Field (f) constants | 
|---|
|  | 1168 | new fPatient set fPatient=.02        ;"field .02 = PATIENT | 
|---|
|  | 1169 | new fVisit set fVisit=.03            ;"field .03 = VISIT | 
|---|
|  | 1170 | new fParentDoc set fParentDoc=.04    ;"field .04 = PARENT DOCUMENT TYPE | 
|---|
|  | 1171 | new fStatus set fStatus=.05          ;"field .05 = STATUS | 
|---|
|  | 1172 | new fParent set fParent=.06          ;"field .06 = PARENT | 
|---|
|  | 1173 | new fStartDate set fStartDate=.07    ;"EPISODE BEGIN DATE/TIME (field .07) | 
|---|
|  | 1174 | new fEndDate set fEndDate=.08        ;"EPISODE END DATE/TIME (field .08) | 
|---|
|  | 1175 | new fEntryDate set fEntryDate=1201   ;"field 1201 = ENTRY DATE/TIME | 
|---|
|  | 1176 | new fAuthor set fAuthor=1202         ;"field 1202 = AUTHOR/DICTATOR | 
|---|
|  | 1177 | new fExpSigner set fExpSigner=1204   ;"field 1204 = expected Signer | 
|---|
|  | 1178 | new fHospLoc set fHospLoc=1205       ;"field 1205 = HOSPITAL LOCATION | 
|---|
|  | 1179 | new fExpCosign set fExpCosign=1208   ;"field 1208 = expected cosigner | 
|---|
|  | 1180 | new fVisitLoc set fVisitLoc=1211     ;"field 1211 = VISIT LOCATION | 
|---|
|  | 1181 | new fRefDate set fRefDate=1301       ;"field 1301 = REFERENCE DATE | 
|---|
|  | 1182 | new fCapMethod set fCapMethod=1303   ;"field 1303 = CAPTURE METHOD;  U-->'upload' | 
|---|
|  | 1183 | new fService set fService=1404       ;"field 1404 = SERVICE | 
|---|
|  | 1184 | new fNeedCosign set fNeedCosign=1506 ;"field 1506 = cosigniture expected. | 
|---|
|  | 1185 | new fSignedBy set fSignedBy=1502     ;"field 1502 = signed by | 
|---|
|  | 1186 |  | 
|---|
|  | 1187 | new TMGFDA,TMGMSG | 
|---|
|  | 1188 | new DFN | 
|---|
|  | 1189 | new Attending,ExpSigner,ExpCosign,Author | 
|---|
|  | 1190 | new BailOut set BailOut=0 | 
|---|
|  | 1191 | new Node12 set Node12=$get(^TIU(8925,DocIEN,12)) | 
|---|
|  | 1192 | new NodeZero set NodeZero=$get(^TIU(8925,DocIEN,0)) | 
|---|
|  | 1193 | if $data(Document)=0 new Document | 
|---|
|  | 1194 |  | 
|---|
|  | 1195 | set Author=+$piece(Node12,"^",pAuthor) | 
|---|
|  | 1196 | set Attending=+$piece(Node12,"^",pAttending) | 
|---|
|  | 1197 | set ExpCosign=+$piece(Node12,"^",pExpCosign) | 
|---|
|  | 1198 | set ExpSigner=+$piece(Node12,"^",pExpSigner) | 
|---|
|  | 1199 |  | 
|---|
|  | 1200 | do | 
|---|
|  | 1201 | . new Signer set Signer=$$WHOSIGNS^TIULC1(DocIEN) | 
|---|
|  | 1202 | . do Set8925Value(.TMGFDA,$$WHOSIGNS^TIULC1(DocIEN),fExpSigner,1) | 
|---|
|  | 1203 |  | 
|---|
|  | 1204 | if (Attending>0)&(ExpCosign=0) do | 
|---|
|  | 1205 | . do Set8925Value(.TMGFDA,$$WHOCOSIG^TIULC1(DocIEN),fExpCosign,1) | 
|---|
|  | 1206 |  | 
|---|
|  | 1207 | if (ExpCosign>0)&(ExpSigner'=ExpCosign) do | 
|---|
|  | 1208 | . do Set8925Value(.TMGFDA,1,fNeedCosign,0) | 
|---|
|  | 1209 |  | 
|---|
|  | 1210 | set result=$$dbWrite^TMGDBAPI(.TMGFDA,1) | 
|---|
|  | 1211 | if result=-1 goto FUDone | 
|---|
|  | 1212 |  | 
|---|
|  | 1213 | do RELEASE^TIUT(DocIEN,1)  ;"Call function to 'Release Document from transcription' | 
|---|
|  | 1214 | do AUDIT^TIUEDI1(DocIEN,0,$$CHKSUM^TIULC("^TIU(8925,"_+DocIEN_",""TEXT"")"))  ;"Update audit trail | 
|---|
|  | 1215 |  | 
|---|
|  | 1216 | if '$data(Document) do  if (BailOut=1) goto FUDone | 
|---|
|  | 1217 | . new VstLocIEN,HspLocIEN,StartDate,EndDate | 
|---|
|  | 1218 | . if $data(NodeZero)#10=0 do  quit | 
|---|
|  | 1219 | . . set BailOut=1 | 
|---|
|  | 1220 | . set DFN=+$piece(NodeZero,"^",pPatient) | 
|---|
|  | 1221 | . set StartDate=+$piece(NodeZero,"^",pStrtDate) | 
|---|
|  | 1222 | . set EndDate=$$FMADD^XLFDT(StartDate,1) | 
|---|
|  | 1223 | . set Document(cHspLocIEN)=+$piece(Node12,"^",pHospLoc) | 
|---|
|  | 1224 | . set Document(cVstLocIEN)=+$piece(Node12,"^",pVstLoc) | 
|---|
|  | 1225 | . set VstLocIEN=Document(cVstLocIEN) | 
|---|
|  | 1226 | . if VstLocIEN'>0 set VstLocIEN=Document(cHspLocIEN) | 
|---|
|  | 1227 | . if (DFN>0)&(StartDate>0)&(EndDate>0)&(VstLocIEN>0) do | 
|---|
|  | 1228 | . . ;"This is an interactive visit         .... | 
|---|
|  | 1229 | . . do MAIN^TIUVSIT(.Document,DFN,"",StartDate,EndDate,"LAST",0,VstLocIEN) | 
|---|
|  | 1230 |  | 
|---|
|  | 1231 | if $data(Document)=0 goto FUDone | 
|---|
|  | 1232 | if $data(Document(cVisitStr))#10=0 goto FUDone | 
|---|
|  | 1233 | if $data(DFN)=0 set DFN=$get(Document("DFN")) if DFN="" goto FUDone | 
|---|
|  | 1234 |  | 
|---|
|  | 1235 | ;"Note: reviewing the code for ENQ^TIUPXAP1, it appears the following is expected: | 
|---|
|  | 1236 | ;"        .TIU array | 
|---|
|  | 1237 | ;"        DFN -- the patient IEN | 
|---|
|  | 1238 | ;"        DA -- the IEN of the document to work on. | 
|---|
|  | 1239 | ;"        TIUDA -- the doc IEN that was passed to this function. | 
|---|
|  | 1240 | ;"                Note, I'm not sure how DA and TIUDA are used differently. | 
|---|
|  | 1241 | ;"                In fact, if $data(TIUDA)=0, then function uses DA. | 
|---|
|  | 1242 | ;"                Unless I kill TIUDA (which might cause other problems), I don't | 
|---|
|  | 1243 | ;"                know if TIUDA will hold an abherent value.  So I'll set to DA | 
|---|
|  | 1244 | do | 
|---|
|  | 1245 | . new TIUDA set TIUDA=DocIEN | 
|---|
|  | 1246 | . new DA set DA=DocIEN | 
|---|
|  | 1247 | . new TIU merge TIU=Document | 
|---|
|  | 1248 | . do ENQ^TIUPXAP1 ;" Get/file VISIT | 
|---|
|  | 1249 |  | 
|---|
|  | 1250 | FUDone  ; | 
|---|
|  | 1251 | kill TMGDOC | 
|---|
|  | 1252 | quit | 
|---|
|  | 1253 |  | 
|---|
|  | 1254 |  | 
|---|
|  | 1255 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 1256 | ;"==============================================================================================- | 
|---|
|  | 1257 | ;" R E - F I L I N G   C O D E | 
|---|
|  | 1258 | ;"==============================================================================================- | 
|---|
|  | 1259 | ;"----------------------------------------------------------------------------------------------- | 
|---|
|  | 1260 |  | 
|---|
|  | 1261 | REFILE | 
|---|
|  | 1262 | ;"Purpose: Somtimes the upload process fails because of an error in the | 
|---|
|  | 1263 | ;"        upload filing code.  Rather than require a re-upload of the file, | 
|---|
|  | 1264 | ;"        this function will trigger a retry of filing the TIU UPLOAD BUFFER | 
|---|
|  | 1265 | ;"        (file 8925.2) | 
|---|
|  | 1266 | ;"This function is called by menu option TMG REFILE UPLOAD | 
|---|
|  | 1267 |  | 
|---|
|  | 1268 | new TIUDA set TIUDA="" | 
|---|
|  | 1269 | new job | 
|---|
|  | 1270 | new DoRetry set DoRetry="" | 
|---|
|  | 1271 | new Abort set Abort=0 | 
|---|
|  | 1272 | new Found set Found=0 | 
|---|
|  | 1273 |  | 
|---|
|  | 1274 | write !,! | 
|---|
|  | 1275 | write "------------------------------------------------",! | 
|---|
|  | 1276 | write " Refiler for failed uploads (i.e. a second try.)",! | 
|---|
|  | 1277 | write "------------------------------------------------",!,! | 
|---|
|  | 1278 |  | 
|---|
|  | 1279 | write "Here are all the failed uploads:",!,! | 
|---|
|  | 1280 | set job=$order(^TIU(8925.2,"B","")) | 
|---|
|  | 1281 | for  do  quit:(job="") | 
|---|
|  | 1282 | . new Buff,NextBuff | 
|---|
|  | 1283 | . if job="" quit | 
|---|
|  | 1284 | . set Buff=$order(^TIU(8925.2,"B",job,"")) | 
|---|
|  | 1285 | . for  do  quit:(Buff="") | 
|---|
|  | 1286 | . . if Buff="" quit | 
|---|
|  | 1287 | . . write "Buffer #"_Buff_" (created by process #"_job_")",! | 
|---|
|  | 1288 | . . set Found=1 | 
|---|
|  | 1289 | . . set Buff=$order(^TIU(8925.2,"B",job,Buff)) | 
|---|
|  | 1290 | . set job=$order(^TIU(8925.2,"B",job)) | 
|---|
|  | 1291 |  | 
|---|
|  | 1292 | if Found=0 write "(There are no failed uploads to process... Great!)",! | 
|---|
|  | 1293 | else  write "------------------------------------------------",! | 
|---|
|  | 1294 |  | 
|---|
|  | 1295 | set job=$order(^TIU(8925.2,"B","")) | 
|---|
|  | 1296 | for  do  quit:(job="")!(Abort=1) | 
|---|
|  | 1297 | . new Buff,NextBuff | 
|---|
|  | 1298 | . if job="" quit | 
|---|
|  | 1299 | . set Buff=$order(^TIU(8925.2,"B",job,"")) | 
|---|
|  | 1300 | . for  do  quit:(Buff="")!(Abort=1) | 
|---|
|  | 1301 | . . if Buff="" quit | 
|---|
|  | 1302 | . . if DoRetry'="all" do | 
|---|
|  | 1303 | . . . write !,"Refile upload buffer #"_Buff_" (created by process #"_job_")? (y/n/all/^) " | 
|---|
|  | 1304 | . . . read DoRetry:$get(DTIME,300),! | 
|---|
|  | 1305 | . . else  do | 
|---|
|  | 1306 | . . . new GetKey | 
|---|
|  | 1307 | . . . read *GetKey:0 | 
|---|
|  | 1308 | . . . if $get(GetKey)=27 set DoRetry="n" | 
|---|
|  | 1309 | . . . else  write !,!,"Processing upload buffer #",Buff,! | 
|---|
|  | 1310 | . . if DoRetry="^" set Abort=1 quit | 
|---|
|  | 1311 | . . if (DoRetry["y")!(DoRetry["Y")!(DoRetry="all") do | 
|---|
|  | 1312 | . . . set TIUDA=Buff | 
|---|
|  | 1313 | . . . ;"These is an edited form of MAIN^TIUUPLD | 
|---|
|  | 1314 | . . . N EOM,TIUERR,TIUHDR,TIULN,TIUSRC,X | 
|---|
|  | 1315 | . . . I '$D(TIUPRM0)!'$D(TIUPRM1) D SETPARM^TIULE | 
|---|
|  | 1316 | . . . S TIUSRC=$P($G(TIUPRM0),U,9),EOM=$P($G(TIUPRM0),U,11) | 
|---|
|  | 1317 | . . . I EOM']"",($P(TIUPRM0,U,17)'="k") do  quit | 
|---|
|  | 1318 | . . . . W !,$C(7),$C(7),$C(7),"No End of Message Signal Defined - Contact IRM.",! | 
|---|
|  | 1319 | . . . S:TIUSRC']"" TIUSRC="R" | 
|---|
|  | 1320 | . . . S TIUHDR=$P(TIUPRM0,U,10) | 
|---|
|  | 1321 | . . . I TIUHDR']"" do  quit | 
|---|
|  | 1322 | . . . . W $C(7),$C(7),$C(7),"No Record Header Signal Defined - Contact IRM.",! | 
|---|
|  | 1323 | . . . new temp set temp=$order(^TIU(8925.2,TIUDA,"TEXT",0)) | 
|---|
|  | 1324 | . . . write "First line of TEXT=",temp,! | 
|---|
|  | 1325 | . . . I +$O(^TIU(8925.2,TIUDA,"TEXT",0))>0 do | 
|---|
|  | 1326 | . . . . write "Calling FILE^TIUUPLD("_TIUDA_")",! | 
|---|
|  | 1327 | . . . . D FILE^TIUUPLD(TIUDA) | 
|---|
|  | 1328 | . . . I +$O(^TIU(8925.2,TIUDA,"TEXT",0))'>0 D BUFPURGE^TIUPUTC(TIUDA) | 
|---|
|  | 1329 | . . set Buff=$order(^TIU(8925.2,"B",job,Buff)) | 
|---|
|  | 1330 | . set job=$order(^TIU(8925.2,"B",job)) | 
|---|
|  | 1331 |  | 
|---|
|  | 1332 | write !,"------------------------------------------------",! | 
|---|
|  | 1333 | write " All done with Refiler",! | 
|---|
|  | 1334 | write "------------------------------------------------",!,! | 
|---|
|  | 1335 |  | 
|---|
|  | 1336 | RFDone | 
|---|
|  | 1337 | Q | 
|---|
|  | 1338 |  | 
|---|
|  | 1339 |  | 
|---|
|  | 1340 |  | 
|---|
|  | 1341 |  | 
|---|