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