| 1 | TIUPNFIX ; SLC/MAM - Resolve Upload Filing Errors for Progress Notes ;05/06/02
 | 
|---|
| 2 |  ;;1.0;TEXT INTEGRATION UTILITIES;**131**;Jun 20, 1997
 | 
|---|
| 3 | PNFIX ; Progress Note Filing Error Resolution Code
 | 
|---|
| 4 |  ; Requires: TIUEVNT - 8925.4 Upload Log Event IEN
 | 
|---|
| 5 |  ; Requires: TIUTYPE - IEN of Docmt Def whose Filing Error
 | 
|---|
| 6 |  ;                     Resolution Code is being invoked.
 | 
|---|
| 7 |  ;                     Taken from alert or filing error.
 | 
|---|
| 8 |  ;                     
 | 
|---|
| 9 |  ; NOTE: Module PNFIX is written as Filing Error Resolution Code
 | 
|---|
| 10 |  ;for uploading Progress Notes into TIU, replacing the old Filing
 | 
|---|
| 11 |  ;Error Resolution Code, GETPN^TIUCHLP.
 | 
|---|
| 12 |  ;It has been rewritten to take advantage of new generic upload
 | 
|---|
| 13 |  ;modules such as MAKE^TIUFIX1.  In its use of these new modules,
 | 
|---|
| 14 |  ;it may serve as a model for uploading other types of documents
 | 
|---|
| 15 |  ;such as Consults or Operative Reports into TIU. See also TIUCNFIX.
 | 
|---|
| 16 |  ;All code which is specific to Progress Notes is included
 | 
|---|
| 17 |  ;in module GETCHECK, before MAKE^TIUFIX1 is called.
 | 
|---|
| 18 |  N TIUFLDS,TIUBUF,SUCCESS,OLDTYPE,DFN,TITLDA,TIU
 | 
|---|
| 19 |  S SUCCESS=0
 | 
|---|
| 20 |  I '$D(^TIU(8925.1,+$G(TIUTYPE),0)) S SUCCESS="0^Document type is missing or invalid." G PNFIXX
 | 
|---|
| 21 |  I '$D(^TIU(8925.4,+$G(TIUEVNT),0)) S SUCCESS="0^Upload Log event is missing or invalid." G PNFIXX
 | 
|---|
| 22 |  S TIUBUF=$$BUFFER^TIUFIX2(TIUEVNT) I +TIUBUF'>0 S SUCCESS=TIUBUF G PNFIXX
 | 
|---|
| 23 |  I '$D(TIUPRM0) D SETPARM^TIULE ; Sets TIUPRM0 with hdr signal, etc
 | 
|---|
| 24 |  ; -- Load hdr data from buffer into array TIUFLDS:
 | 
|---|
| 25 |  D LOADHDR^TIUFIX2(.TIUFLDS,TIUBUF,TIUPRM0,TIUTYPE)
 | 
|---|
| 26 |  ; -- Get from user all data needed to create a new document
 | 
|---|
| 27 |  ;    of the given type; Cross-check user data for consistency.
 | 
|---|
| 28 |  S OLDTYPE=TIUTYPE
 | 
|---|
| 29 |  D GETCHECK(.SUCCESS,.TIUTYPE,.TIUFLDS,.DFN,.TITLDA,.TIU)
 | 
|---|
| 30 |  I 'SUCCESS G PNFIXX
 | 
|---|
| 31 |  ; -- Create new document; file all TIUFLDS nodes which have
 | 
|---|
| 32 |  ;    not been killed, execute post-file code, etc.:
 | 
|---|
| 33 |  D MAKE^TIUFIX1(.SUCCESS,TIUEVNT,TIUBUF,.TIUTYPE,.TIUFLDS,.DFN,.TITLDA,.TIU,TIUPRM0)
 | 
|---|
| 34 |  ; -- If docmt filed successfully, set flag to stop - don't go
 | 
|---|
| 35 |  ;    on and try to resolve error by editing buffer and refiling. 
 | 
|---|
| 36 | PNFIXX I +SUCCESS S TIUDONE=1 Q
 | 
|---|
| 37 |  W !!,"Filing error could not be resolved."
 | 
|---|
| 38 |  I $P(SUCCESS,U,2)]"" W !,$P(SUCCESS,U,2)
 | 
|---|
| 39 |  W !,"If you wish to try a different approach, edit the buffered data directly",!,"and refile it, or simply exit and try again later.",!
 | 
|---|
| 40 |  Q
 | 
|---|
| 41 |  ;
 | 
|---|
| 42 | GETCHECK(SUCCESS,TIUTYPE,TIUFLDS,DFN,TITLDA,TIU) ; Get and
 | 
|---|
| 43 |  ;check data
 | 
|---|
| 44 |  ;
 | 
|---|
| 45 |  ;This is written for Progress Notes (PN), but may also serve
 | 
|---|
| 46 |  ;as a model for the use of new generic modules such as
 | 
|---|
| 47 |  ;MAKE^TIUFIX1 in uploading other types of documents such
 | 
|---|
| 48 |  ;as Consults or Operative Reports. See also TIUCNFIX.
 | 
|---|
| 49 |  ;The new generic modules accommodate only documents which
 | 
|---|
| 50 |  ;are uploaded into the TIU DOCUMENT file.
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 |  ;Since a filing error occurred when filer could not locate
 | 
|---|
| 53 |  ;or create a TIU document using data from buffer, we ask the
 | 
|---|
| 54 |  ;user for all data needed to locate/create a document, and
 | 
|---|
| 55 |  ;use that data, instead of the buffer data, to locate/create
 | 
|---|
| 56 |  ;the document.
 | 
|---|
| 57 |  ;Data are acquired from the user is such a way as to guarantee
 | 
|---|
| 58 |  ;that all data necessary to go ahead and create a Progress Note
 | 
|---|
| 59 |  ;are complete and consistent
 | 
|---|
| 60 |  ;
 | 
|---|
| 61 |  ; SUCCESS = 1 - Data are complete and consistent or
 | 
|---|
| 62 |  ;         = 0^Explanatory msg
 | 
|---|
| 63 |  ; TIUTYPE = Docmt Def whose methods are being invoked.
 | 
|---|
| 64 |  ; TIUFLDS     - array of fields to be filed later in FILE^TIUFIX1.
 | 
|---|
| 65 |  ;               See warning in MAKE^TIUFIX1 concerning possible
 | 
|---|
| 66 |  ;               need to kill nodes of TIUFLDS before calling MAKE.
 | 
|---|
| 67 |  ; DFN, TITLDA, TIU - Patient, Document title, Demographics
 | 
|---|
| 68 |  ;                    /visit array.
 | 
|---|
| 69 |  ;                    Must be gotten from user and passed back.
 | 
|---|
| 70 |  ;                    Used in GETRECNW to create docmt, in MERGTEXT
 | 
|---|
| 71 |  ;                    to create components.
 | 
|---|
| 72 |  N DEFAULT,BADTYPES,ASK
 | 
|---|
| 73 |  ; -- Initialize SUCCESS to 0^Error msg:
 | 
|---|
| 74 |  S SUCCESS="0^Patient, visit, and title are required."
 | 
|---|
| 75 |  ; -- Get patient and visit, and title:
 | 
|---|
| 76 |  S DFN=+$$PATIENT^TIULA Q:DFN'>0
 | 
|---|
| 77 |  D ENPN^TIUVSIT(.TIU,+DFN,1)
 | 
|---|
| 78 |  I '$D(TIU) Q
 | 
|---|
| 79 |  ; -- TIU*1*131 - cf GETPN^TIUCHLP: Before 131, if user
 | 
|---|
| 80 |  ;    up-arrowed at OK?, code continued.
 | 
|---|
| 81 |  I '$$CHEKPN^TIUCHLP(.TIU) K TIU Q
 | 
|---|
| 82 |  ; -- Screen out consult titles; don't ask about changing type:
 | 
|---|
| 83 |  S BADTYPES=+$$CLASS^TIUCNSLT,ASK=0
 | 
|---|
| 84 |  D GETTITLE^TIUFIX(.SUCCESS,TIUTYPE,.TIUFLDS,.TITLDA,BADTYPES,ASK)
 | 
|---|
| 85 |  Q:TITLDA'>0
 | 
|---|
| 86 |  ; -- If consistent and complete, set SUCCESS=1: 
 | 
|---|
| 87 |  S SUCCESS=1
 | 
|---|
| 88 | GETX ;
 | 
|---|
| 89 |  Q
 | 
|---|