| 1 | TIUSRVL ; SLC/JER - Server functions for lists ;7/16/96  17:52
 | 
|---|
| 2 |  ;;1.0;TEXT INTEGRATION UTILITIES;;Jun 20, 1997
 | 
|---|
| 3 | NOTES(TIUY,DFN,STATUS,EARLY,LATE,ROOTFLAG) ; Gets list of Notes
 | 
|---|
| 4 |  N QSTR S QSTR="APT"_U_DFN_U_$P($G(^DPT(+DFN,0)),U)
 | 
|---|
| 5 |  I $S(+$G(DFN)'>0:1,'$D(^DPT(+$G(DFN),0)):1,1:0) Q
 | 
|---|
| 6 |  S STATUS=$S($G(STATUS)]"":$G(STATUS),1:"ALL")
 | 
|---|
| 7 |  D LIST(.TIUY,3,STATUS,QSTR,$G(EARLY),$G(LATE),$G(ROOTFLAG))
 | 
|---|
| 8 |  Q
 | 
|---|
| 9 | SUMMARY(TIUY,DFN,STATUS,EARLY,LATE,ROOTFLAG) ; Gets list of Summaries
 | 
|---|
| 10 |  N QSTR
 | 
|---|
| 11 |  I $S(+$G(DFN)'>0:1,'$D(^DPT(+$G(DFN),0)):1,1:0) Q
 | 
|---|
| 12 |  S QSTR="APT"_U_DFN_U_$P($G(^DPT(+DFN,0)),U)
 | 
|---|
| 13 |  S STATUS=$S($G(STATUS)]"":$G(STATUS),1:"ALL")
 | 
|---|
| 14 |  D LIST(.TIUY,1,STATUS,QSTR,$G(EARLY),$G(LATE),$G(ROOTFLAG))
 | 
|---|
| 15 |  Q
 | 
|---|
| 16 | CONSULT(TIUY,DFN,STATUS,EARLY,LATE,ROOTFLAG) ; Gets list of Consults
 | 
|---|
| 17 |  N QSTR
 | 
|---|
| 18 |  I $S(+$G(DFN)'>0:1,'$D(^DPT(+$G(DFN),0)):1,1:0) Q
 | 
|---|
| 19 |  S QSTR="APT"_U_DFN_U_$P($G(^DPT(+DFN,0)),U)
 | 
|---|
| 20 |  S STATUS=$S($G(STATUS)]"":$G(STATUS),1:"ALL")
 | 
|---|
| 21 |  D LIST(.TIUY,243,STATUS,QSTR,$G(EARLY),$G(LATE),$G(ROOTFLAG))
 | 
|---|
| 22 |  Q
 | 
|---|
| 23 | LIST(TIUY,TYPE,STATUS,SCREEN,EARLY,LATE,ROOTFLAG) ; Build List
 | 
|---|
| 24 |  N TIUCNT,TIUDT,TIUI,TIUJ,TIUK,TIUP,TIUQ,TIUIFN,TIUREC,TIUPRM0,TIUPRM1
 | 
|---|
| 25 |  N TIUPRM3,TIUT,TIUTP,XREF,TIUS,TIUCONT,TIUSTAT,TIUTYPE,TYPES
 | 
|---|
| 26 |  K ^TMP("TIULIST",$J),^TMP("TIUI",$J)
 | 
|---|
| 27 |  I '$D(TIUPRM0) D SETPARM^TIULE
 | 
|---|
| 28 |  D DOCTYPE(.TIUTYPE,TYPE)
 | 
|---|
| 29 |  D CHECKADD(.TIUTYPE)
 | 
|---|
| 30 |  I +$D(TIUTYPE)'>0 S TIUY=0 Q
 | 
|---|
| 31 |  M TYPES=TIUTYPE
 | 
|---|
| 32 |  D STATUS(.TIUSTAT,$$UP^XLFSTR(STATUS))
 | 
|---|
| 33 |  I +$D(TIUSTAT)'>0 S TIUY=0 Q
 | 
|---|
| 34 |  M STATUS=TIUSTAT
 | 
|---|
| 35 |  S EARLY=9999999-+$G(EARLY),LATE=9999999-$S(+$G(LATE):+$G(LATE),1:3333333)
 | 
|---|
| 36 |  F TIUK=1:1:$L(SCREEN,";") D
 | 
|---|
| 37 |  . S XREF=$P($P(SCREEN,";",TIUK),U)
 | 
|---|
| 38 |  . I XREF'="ASUB" S TIUI=$P($P(SCREEN,";",TIUK),U,2) D GATHER(TIUI,.TYPES,.STATUS)
 | 
|---|
| 39 |  . I XREF="ASUB" D
 | 
|---|
| 40 |  . . S TIUI=$O(^TIU(8925,XREF,$P($P(SCREEN,";",TIUK),U,2)),-1)
 | 
|---|
| 41 |  . . F  S TIUI=$O(^TIU(8925,XREF,TIUI)) Q:TIUI=""!(TIUI'[$P($P(SCREEN,";",TIUK),U,2))  D GATHER(TIUI,.TYPES,.STATUS)
 | 
|---|
| 42 |  S TIUY=$NA(^TMP("TIULIST",$J))
 | 
|---|
| 43 |  I +$O(^TMP("TIULIST",$J,0)) S (TIUI,TIUK)=0
 | 
|---|
| 44 |  F  S TIUI=$O(^TMP("TIULIST",$J,TIUI)) Q:+TIUI'>0  D
 | 
|---|
| 45 |  . S TIUJ=0 F  S TIUJ=$O(^TMP("TIULIST",$J,TIUI,TIUJ)) Q:+TIUJ'>0  D
 | 
|---|
| 46 |  . . S TIUK=TIUK+1
 | 
|---|
| 47 |  . . S ^TMP("TIULIST",$J,TIUK)=$G(^TMP("TIULIST",$J,TIUI,TIUJ))
 | 
|---|
| 48 |  . . S ^TMP("TIULIDX",$J,TIUI,TIUJ)=TIUK K ^TMP("TIULIST",$J,TIUI,TIUJ)
 | 
|---|
| 49 |  . . S:+$G(ROOTFLAG) $P(^TMP("TIULIST",$J),U)=TIUK
 | 
|---|
| 50 |  . . S:TIUK=1&+$G(ROOTFLAG) $P(^TMP("TIULIST",$J),U,3)=(9999999-TIUI)
 | 
|---|
| 51 |  . . S:+$G(ROOTFLAG) $P(^TMP("TIULIST",$J),U,2)=(9999999-TIUI)
 | 
|---|
| 52 |  Q
 | 
|---|
| 53 | GATHER(TIUI,TYPES,STATUS) ; Find/sort records for the list
 | 
|---|
| 54 |  N TIUT,TIUTP,TIUS,TIUSTAT
 | 
|---|
| 55 |  S TIUT=0 F  S TIUT=$O(TYPES(TIUT)) Q:+TIUT'>0  D
 | 
|---|
| 56 |  . S TIUTP=+$G(TYPES(TIUT)) Q:TIUTP'>0
 | 
|---|
| 57 |  . S TIUS=0 F  S TIUS=$O(STATUS(TIUS)) Q:+TIUS'>0  D
 | 
|---|
| 58 |  . . S TIUSTAT=+$G(STATUS(TIUS))
 | 
|---|
| 59 |  . . Q:+TIUSTAT'>0
 | 
|---|
| 60 |  . . S TIUJ=LATE F  S TIUJ=$O(^TIU(8925,XREF,TIUI,TIUTP,TIUSTAT,TIUJ)) Q:+TIUJ'>0!(+TIUJ>EARLY)  D
 | 
|---|
| 61 |  . . . S TIUIFN=0
 | 
|---|
| 62 |  . . . F  S TIUIFN=$O(^TIU(8925,XREF,TIUI,TIUTP,TIUSTAT,TIUJ,TIUIFN)) Q:+TIUIFN'>0  D
 | 
|---|
| 63 |  . . . . I TIUTP=81,(+TYPES>1),($P(TYPES(TIUT),U,3)="NOT PICKED"),'+$$DADINTYP(TIUIFN,.TYPES) Q
 | 
|---|
| 64 |  . . . . ;I '$$CANDO^TIULP(TIUIFN,"VIEW") Q
 | 
|---|
| 65 |  . . . . D ADDELMNT(TIUIFN,.TIUCNT)
 | 
|---|
| 66 |  Q
 | 
|---|
| 67 | DADINTYP(TIUDA,TYPES) ; Evaluates whether addendum's parent belongs is among
 | 
|---|
| 68 |  ;                 the selected types
 | 
|---|
| 69 |  N TIUI,TIUDTYP,TIUY S (TIUI,TIUY)=0
 | 
|---|
| 70 |  S TIUDTYP=+$G(^TIU(8925,+$P($G(^TIU(8925,+TIUDA,0)),U,6),0))
 | 
|---|
| 71 |  F  S TIUI=$O(TYPES(TIUI)) Q:+TIUI'>0!+TIUY  D
 | 
|---|
| 72 |  . I +$P(TYPES(TIUI),U)=TIUDTYP S TIUY=1
 | 
|---|
| 73 |  Q TIUY
 | 
|---|
| 74 | ADDELMNT(DA,TIUCNT) ; Add each element to the list
 | 
|---|
| 75 |  N DOC,LOC,PT,AUT,EDT,TIUPT,TIULST4,TIUREC,TIUR0,TIUR12,TIUR13
 | 
|---|
| 76 |  N STATUS,EDTCNT,LOCTYP,TIUADT,TIUDDT
 | 
|---|
| 77 |  S TIUR0=$G(^TIU(8925,+DA,0)),TIUR12=$G(^TIU(8925,+DA,12))
 | 
|---|
| 78 |  S TIUR13=$G(^TIU(8925,+DA,13)),TIUPT=$G(^DPT(+$P(TIUR0,U,2),0))
 | 
|---|
| 79 |  S DOC=$$PNAME^TIULC1(+TIUR0)
 | 
|---|
| 80 |  I DOC="Addendum" S DOC=DOC_" to "_$$PNAME^TIULC1(+$G(^TIU(8925,+$P(TIUR0,U,6),0)))
 | 
|---|
| 81 |  S STATUS=$$LOWER^TIULS($P(^TIU(8925.6,+$P(TIUR0,U,5),0),U))
 | 
|---|
| 82 |  S LOC=$G(^SC(+$P(TIUR12,U,5),0)),LOCTYP=$P(LOC,U,3),LOC=$P(LOC,U)
 | 
|---|
| 83 |  S TIUADT=$S(LOCTYP="W":"Adm: ",1:"Visit: ")_$$DATE^TIULS($P(TIUR0,U,7),"MM/DD/YY")
 | 
|---|
| 84 |  S TIUDDT=$S(+$P(TIUR0,U,8):"Dis: ",1:"")_$$DATE^TIULS($P(TIUR0,U,8),"MM/DD/YY")
 | 
|---|
| 85 |  S PT=$$NAME^TIULS($P(TIUPT,U),"LAST, FIRST MI")
 | 
|---|
| 86 |  S TIULST4=$E($P(TIUPT,U,9),6,9)
 | 
|---|
| 87 |  S TIULST4="("_$E(PT)_TIULST4_")"
 | 
|---|
| 88 |  S AUT=$$SIGNAME^TIULS(+$P(TIUR12,U,2))
 | 
|---|
| 89 |  S EDT=+TIUR13,EDTCNT=+$G(EDTCNT)+1
 | 
|---|
| 90 |  F  Q:+$D(^TMP("TIULIST",$J,9999999-EDT,EDTCNT))'>0  S EDTCNT=EDTCNT+1
 | 
|---|
| 91 |  S TIUCNT=+$G(TIUCNT)+1
 | 
|---|
| 92 |  S TIUREC=DA_U_DOC_U_EDT_U_PT_" "_TIULST4_U_AUT_U_LOC_U_STATUS_U_TIUADT_U_TIUDDT
 | 
|---|
| 93 |  S ^TMP("TIULIST",$J,9999999-EDT,EDTCNT)=TIUREC
 | 
|---|
| 94 |  ;S TIUY(TIUCNT)=TIUREC
 | 
|---|
| 95 |  Q
 | 
|---|
| 96 | DOCTYPE(TIUY,DA,TYPE,TIUK) ; Get all descendent's of a given type
 | 
|---|
| 97 |  N I,J,X,CURTYP,Y
 | 
|---|
| 98 |  ; TIUK is STATIC
 | 
|---|
| 99 |  S TIUK=+$G(TIUK)
 | 
|---|
| 100 |  I $G(TYPE)']"" S TYPE="DOC"
 | 
|---|
| 101 |  S CURTYP=$P(^TIU(8925.1,+DA,0),U,4)
 | 
|---|
| 102 |  S TYPMATCH=$$TYPMATCH^TIULA1(TYPE,CURTYP)
 | 
|---|
| 103 |  I +TYPMATCH S TIUK=+$G(TIUK)+1,TIUY(TIUK)=+DA_U_$$PNAME^TIULC1(+DA),TIUY=+$G(TIUY)+1
 | 
|---|
| 104 |  S I=0 F  S I=$O(^TIU(8925.1,+DA,10,I)) Q:+I'>0  D
 | 
|---|
| 105 |  . N J
 | 
|---|
| 106 |  . S J=+$G(^TIU(8925.1,+DA,10,+I,0)) Q:+J'>0
 | 
|---|
| 107 |  . D DOCTYPE(.TIUY,+J,TYPE,.TIUK)
 | 
|---|
| 108 |  Q
 | 
|---|
| 109 | CHECKADD(TYPES) ; Checks whether Addendum is included in the list of types
 | 
|---|
| 110 |  N TIUI,HIT S (TIUI,HIT)=0
 | 
|---|
| 111 |  F  S TIUI=$O(TYPES(TIUI)) Q:+TIUI'>0!+HIT  I $$UP^XLFSTR(TYPES(TIUI))="ADDENDUM" S HIT=1
 | 
|---|
| 112 |  I +HIT'>0 S TYPES(TYPES+1)="81^Addendum^NOT PICKED",TYPES=TYPES+1
 | 
|---|
| 113 |  Q
 | 
|---|
| 114 | STATUS(TIUY,STATUS,INCLDESC) ; Get statuses
 | 
|---|
| 115 |  N TIUI,TIUS,TIUSTAT S STATUS=$G(STATUS,"ALL")
 | 
|---|
| 116 |  I STATUS'="ALL" D  Q
 | 
|---|
| 117 |  . S TIUS=$O(^TIU(8925.6,"B",STATUS,0)) Q:+TIUS'>0
 | 
|---|
| 118 |  . S TIUSTAT=$P($G(^TIU(8925.6,+TIUS,0)),U)
 | 
|---|
| 119 |  . I $P(^TIU(8925.6,+TIUS,0),U,4)'="DEF" S TIUY(1)=TIUS_U_$$LOWER^TIULS(TIUSTAT)
 | 
|---|
| 120 |  S STATUS=""
 | 
|---|
| 121 |  F  S STATUS=$O(^TIU(8925.6,"B",STATUS)) Q:STATUS']""  D
 | 
|---|
| 122 |  . S TIUS=0
 | 
|---|
| 123 |  . F  S TIUS=$O(^TIU(8925.6,"B",STATUS,TIUS)) Q:+TIUS'>0  D
 | 
|---|
| 124 |  . . S TIUI=+$G(TIUI)+1,TIUSTAT=$P($G(^TIU(8925.6,+TIUS,0)),U)
 | 
|---|
| 125 |  . . I $P(^TIU(8925.6,+TIUS,0),U,4)'="DEF" D
 | 
|---|
| 126 |  . . . S TIUY(TIUI)=TIUS_U_$$LOWER^TIULS(TIUSTAT)
 | 
|---|
| 127 |  . . . I +$G(INCLDESC) D
 | 
|---|
| 128 |  . . . . N TIUJ S TIUJ=0
 | 
|---|
| 129 |  . . . . F  S TIUJ=$O(^TIU(8925.6,+TIUS,1,TIUJ)) Q:+TIUJ'>0  D
 | 
|---|
| 130 |  . . . . . S TIUY(TIUI,1,TIUJ)=$G(^TIU(8925.6,+TIUS,1,+TIUJ,0))
 | 
|---|
| 131 |  Q
 | 
|---|