source: FOIAVistA/trunk/r/TEXT_INTEGRATION_UTILITIES-GMRP-TIU/TIUSRVL.m@ 1765

Last change on this file since 1765 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 5.8 KB
Line 
1TIUSRVL ; SLC/JER - Server functions for lists ;7/16/96 17:52
2 ;;1.0;TEXT INTEGRATION UTILITIES;;Jun 20, 1997
3NOTES(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
9SUMMARY(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
16CONSULT(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
23LIST(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
53GATHER(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
67DADINTYP(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
74ADDELMNT(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
96DOCTYPE(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
109CHECKADD(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
114STATUS(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
Note: See TracBrowser for help on using the repository browser.