VistA-FOIAVistA/r/TEXT_INTEGRATION_UTILITIES-.../TIUR3.m

134 lines
5.6 KiB
Mathematica

TIUR3 ; SLC/JER - Integrated Document Review ;11/01/03 [1/12/05 11:42am]
;;1.0;TEXT INTEGRATION UTILITIES;**157**;Jun 20, 1997
;This routine was made from a copy of TIUR and modified to be used
; for option TIU REVIEW UNSIGNED ADDSIG
MAKELIST(TIUCLASS,TIUCHVW) ; Get Search Criteria
N DIRUT,DTOUT,DUOUT,TIUI,SCREEN,STATUS,TIUTYP,TIUSTAT,TIUEDFLT,TIUDCL
N TIUDPRMT,TIUPICT,TIUOUT,STATWORD,STATIFN,NOWFLAG
K DIROUT
D INITRR^TIULRR(0)
; TIURPN used in Order Entry 2.5, OR OE/RR MENU CLIN:
I +$G(ORVP),(+$G(TIUCHVW)'>0) D EN^TIURPN(TIUCLASS,+ORVP) Q
STATUS S STATUS=$$STAT
I +STATUS<0 S VALMQUIT=1 Q
S TIUI=0
F S TIUI=$O(TIUSTAT(TIUI)) Q:'TIUI!(+$G(TIUOUT)) D
. I $P($G(TIUSTAT(TIUI)),U,3)="" S TIUOUT=1 Q
. S STATIFN=$O(^TIU(8925.6,"B",$$UPPER^TIULS($P(TIUSTAT(TIUI),U,3)),0))
. Q:'STATIFN
. S STATUS("IFNS")=$G(STATUS("IFNS"))_STATIFN_";"
I +$G(TIUOUT) S VALMQUIT=1 Q
S TIUI=1,STATWORD=$$UPPER^TIULS($P(TIUSTAT(1),U,3))
I +$G(TIUSTAT(4))'>0 F S TIUI=$O(TIUSTAT(TIUI)) Q:+TIUI'>0 D
. S STATWORD=STATWORD_$S(TIUI=+TIUSTAT(1):" & ",1:", ")_$$UPPER^TIULS($P(TIUSTAT(TIUI),U,3))
I +$G(TIUSTAT(4))>0 S STATWORD=$S($P(TIUSTAT(4),U,4)="ALL":"ALL",1:STATWORD_", OTHER")
S STATUS("WORDS")=STATWORD
DOCTYPE ; Select Document Type(s)
N TIUDCL K TIUPICT
I $S(('$D(TIUQUIK)&'$D(ORVP)):1,($D(ORVP)&+$G(TIUCHVW)):1,1:0) D SELTYP^TIULA(TIUCLASS,.TIUTYP,"A","LAST","DOC",0,.TIUDCL,.TIUPICT)
; SELTYP sets array ^TMP("TIUTYP",$J);
; SELTYP used to set data into TIUTYP array
; Now TIUTYP just ="^TMP("TIUTYP",$J)"
I $S($D(TIUQUIK):1,($D(ORVP)&'+$G(TIUCHVW)):1,1:0) D SELTYP^TIULA(TIUCLASS,.TIUTYP,"F","ALL","DOC",0)
I +$G(DIROUT) S VALMQUIT=1 Q
I +$G(@TIUTYP)'>0,'$D(TIUQUIK) G STATUS
SCREEN ;
N TIUNAME
S TIUNAME=$$GET1^DIQ(200,+DUZ,.01)
I $D(TIUQUIK) D I 1 ; all my unsigned TIUQUIK=1
. I $G(TIUQUIK)=3 S SCREEN(1)="ALL^ANY" Q
. S SCREEN(1)="AAU^"_DUZ_U_TIUNAME
. S:$G(TIUQUIK)=1 SCREEN(2)="ASUP^"_DUZ
. S SCREEN="ALL"
E D SELCAT^TIULA1(.SCREEN,"A","AUTHOR")
I +$G(DIROUT) S VALMQUIT=1 Q
I $D(SCREEN)'>9 K @TIUTYP G DOCTYPE
I $D(@TIUTYP)'>9 W !,$C(7),"You must select one or more TITLES..." G SCREEN
D CHECKADD
ERLY S TIUEDFLT=$S(TIUCLASS=3:"T-2",TIUCLASS=244:"T-30",1:"T-7")
S TIUDPRMT=$S(TIUCLASS=244:"Discharge",1:"Reference")
S TIUEDT=1
I +$G(DIROUT) S VALMQUIT=1 Q
I TIUEDT'>0 G SCREEN
S TIULDT=$S($D(TIUQUIK):9999999,$D(ORVP)&(+$G(TIUCHVW)'>0):+$$NOW^XLFDT,1:$P($$LDATE^TIULA(TIUDPRMT),U))
I +$G(DIROUT) S VALMQUIT=1 Q
I TIULDT'>0 G ERLY
I TIUEDT>TIULDT D SWAP(.TIUEDT,.TIULDT)
I $L(TIULDT,".")=1 D EXPRANGE(.TIUEDT,.TIULDT)
; -- Reset late date to NOW on rebuild:
S NOWFLAG=$S(TIULDT-$$NOW^XLFDT<.0001:1,1:0)
I '$G(TIURBLD) W !,"Searching for the documents."
D BUILD(TIUCLASS,.STATUS,.SCREEN,TIUEDT,TIULDT,NOWFLAG) ;11/30/00 removed param TIUTYP since BUILD uses global now.
; -- If attaching ID note & changed view,
; update video for line to be attached: --
I $G(TIUGLINK) D RESTOREG^TIULM(.TIUGLINK)
;K @TIUTYP ;11/30/00 keep ^TMP("TIUTYP",$J) for rebuild
Q
STAT() ; Determine status
N TIUY
I +$G(TIUQUIK) D G STATX
. S TIUY=$$SELSTAT^TIULA(.TIUSTAT,"F",$S(TIUQUIK=1:"UNSIGNED,UNCOSIGNED",TIUQUIK>1:"UNDICTATED,UNTRANSCRIBED"))
I $D(ORVP),'+$G(TIUCHVW) D G STATX
. S TIUY=$$SELSTAT^TIULA(.TIUSTAT,"F","COMPLETED")
S TIUY=$$SELSTAT^TIULA(.TIUSTAT,"A",$$DFLTSTAT^TIURM(DUZ))
STATX Q TIUY
CHECKADD ; Checks whether Addendum is included in the list of types
N TIUI,HIT,NUMTYPS
S (TIUI,HIT)=0
F S TIUI=$O(^TMP("TIUTYP",$J,TIUI)) Q:+TIUI'>0!+HIT I $$UP^XLFSTR(^TMP("TIUTYP",$J,TIUI))["ADDENDUM" S HIT=1
S NUMTYPS=^TMP("TIUTYP",$J)
I +HIT'>0 S ^TMP("TIUTYP",$J,NUMTYPS+1)=+^TMP("TIUTYP",$J,NUMTYPS)+1_U_"81^Addendum^NOT PICKED",^TMP("TIUTYP",$J)=^TMP("TIUTYP",$J)+1
Q
;
SWAP(TIUX,TIUY) ; Swap variables
N TIUTMP S TIUTMP=TIUX,TIUX=TIUY,TIUY=TIUTMP
Q
EXPRANGE(TIUX,TIUY) ; Expand late date to include time
;P74 If user entered date/time = T, then numerical date time is FIRST ^ PIECE ONLY of TIUX & TIUY.
I $P(TIUY,U)=DT S TIUY=$$NOW^XLFDT I 1
E S TIUY=$P(TIUY,U)_"."_235959 ;P74 Add seconds
Q
BUILD(TIUCLASS,STATUS,SCREEN,EARLY,LATE,NOWFLAG) ; Build List.
;11/30/00 - removed param TYPES. 12/3 added param TIUCLASS
; BUILD (GATHER) uses docmt type info from ^TMP("TIUTYP",$J)
N TIUDT,TIUI,TIUK
N TIUT,TIUTP,XREF,TIUS,TIUPREF
S TIUPREF=$$PERSPRF^TIULE(DUZ),(TIUK,VALMCNT)=0
K ^TMP("TIUR",$J),^TMP("TIURIDX",$J),^TMP("TIUI",$J)
; If user entered NOW at first build, update NOW for rebuild;
; Save data in ^TMP("TIURIDX",$J,0) for rebuild:
I $G(TIURBLD),$G(NOWFLAG) S LATE=$$NOW^XLFDT
S ^TMP("TIURIDX",$J,0)=+EARLY_U_+LATE_U_$G(STATUS("IFNS"))_U_NOWFLAG
S ^TMP("TIUR",$J,"RTN")="TIUR3"
I '$D(TIUPRM0) D SETPARM^TIULE
S EARLY=9999999-+$G(EARLY),LATE=9999999-$S(+$G(LATE):+$G(LATE),1:3333333)
D GATHER^TIUR4(TIUCLASS,TIUPREF)
D PUTLIST^TIUR2(TIUPREF,TIUCLASS,.STATUS,.SCREEN)
K ^TMP("TIUI",$J)
Q
;
CLEAN ; Clean up your mess!
K ^TMP("TIUR",$J),^TMP("TIURIDX",$J) D CLEAN^VALM10,KILLRR^TIULRR
K VALMY
K ^TMP("TIUTYP",$J)
Q
;
RBLD ; Rebuild list after actions 11/30/00
N TIUEXP,TIUR0,TIURIDX0,TIUSCRN,TMP,TIUEDT,TIULDT,TIUSTAT
N TIURBLD,TIUI,TIUCLASS,NOWFLAG
S TIURBLD=1
D FIXLSTNW^TIULM ;restore video for elements added to end of list
I +$O(^TMP("TIUR",$J,"EXPAND",0)) D
. M TIUEXP=^TMP("TIUR",$J,"EXPAND")
S TIUR0=^TMP("TIUR",$J,0),TIURIDX0=^TMP("TIURIDX",$J,0)
S TIUSCRN="ALL",TIUCLASS=^TMP("TIUR",$J,"CLASS")
S STATUS("WORDS")=$P(TIUR0,U,2)
S STATUS("IFNS")=$P(TIURIDX0,U,3)
S TIUEDT=$P(TIURIDX0,U),TIULDT=$P(TIURIDX0,U,2),NOWFLAG=+$P(TIURIDX0,U,4)
K VALMHDR
D BUILD(TIUCLASS,.STATUS,.TIUSCRN,TIUEDT,TIULDT,NOWFLAG)
; Reexpand previously expanded items:
D RELOAD^TIUROR1(.TIUEXP)
D BREATHE^TIUROR1(1)
Q