1 | TIUSRVLO ; SLC/JER - Server fns - lists for CPRS ;9/12/06 14:17
|
---|
2 | ;;1.0;TEXT INTEGRATION UTILITIES;**1,15,19,63,108,122,181,194,211**;Jun 20, 1997;Build 26
|
---|
3 | NOTES(TIUY,DFN,EARLY,LATE,PERSON,SEQUENCE) ; Get notes
|
---|
4 | N TIUPREF,TIUOCC S TIUPREF=$$PERSPRF^TIULE(DUZ)
|
---|
5 | S TIUOCC=$P(TIUPREF,U,10),PERSON=$S(+$G(PERSON):+$G(PERSON),1:+$G(DUZ))
|
---|
6 | S SEQUENCE=$S($G(SEQUENCE)]"":$G(SEQUENCE),1:"D")
|
---|
7 | D CONTEXT(.TIUY,3,1,DFN,$G(EARLY),$G(LATE),PERSON,TIUOCC,SEQUENCE)
|
---|
8 | Q
|
---|
9 | SUMMARY(TIUY,DFN,EARLY,LATE) ; Get Summaries
|
---|
10 | N TIUPREF,TIUOCC S TIUPREF=$$PERSPRF^TIULE(DUZ)
|
---|
11 | S TIUOCC=$P(TIUPREF,U,10),PERSON=$S(+$G(PERSON):+$G(PERSON),1:+$G(DUZ))
|
---|
12 | S SEQUENCE=$S($G(SEQUENCE)]"":$G(SEQUENCE),1:"D")
|
---|
13 | D CONTEXT(.TIUY,244,1,DFN,$G(EARLY),$G(LATE),PERSON,TIUOCC,SEQUENCE)
|
---|
14 | Q
|
---|
15 | CONTEXT(TIUY,CLASS,CONTEXT,DFN,EARLY,LATE,PERSON,OCCLIM,SEQUENCE,SHOWADD,INCUND) ; main
|
---|
16 | ; --- Call with: TIUY - RETURN ARRAY pass by reference
|
---|
17 | ; CLASS - Pointer to TIU DOCUMENT DEFINITION #8925.1
|
---|
18 | ; CONTEXT - 1=All Signed (by PT),
|
---|
19 | ; - 2="Unsigned (by PT&(AUTHOR!TANSCRIBER))
|
---|
20 | ; - 3="Uncosigned (by PT&EXPECTED COSIGNER
|
---|
21 | ; - 4="Signed notes (by PT&selected author)
|
---|
22 | ; - 5="Signed notes (by PT&date range)
|
---|
23 | ; DFN - Pointer to Patient (#2)
|
---|
24 | ; [EARLY] - FM date/time to begin search
|
---|
25 | ; [LATE] - FM date/time to end search
|
---|
26 | ; [PERSON] - Pointer to file 200 (DUZ if not passed)
|
---|
27 | ; [OCCLIM] - Occurrence Limit (optional)
|
---|
28 | ; [SEQUENCE]- "A"=ascending (Regular date/time)
|
---|
29 | ; - "D"=descending (Reverse date/time) (dflt)
|
---|
30 | ; [INCUND] - Boolean: include undictated & untranscribed
|
---|
31 | S TIUY=$NA(^TMP("TIUR",$J))
|
---|
32 | K @TIUY
|
---|
33 | I $G(CONTEXT)'>0 Q
|
---|
34 | I $G(CLASS)'>0 Q
|
---|
35 | I $G(CONTEXT)=1 D STRT1^AWCMCPR1 ; TIU*1.0*181
|
---|
36 | S:+$G(EARLY)'>0!(+$G(CONTEXT)=1) EARLY=0
|
---|
37 | S:+$G(LATE)'>0!(+$G(CONTEXT)=1) LATE=5000000
|
---|
38 | I EARLY>LATE D SWAP(.EARLY,.LATE)
|
---|
39 | I $L(LATE,".")=1 D EXPRANGE(.EARLY,.LATE)
|
---|
40 | S:+$G(PERSON)'>0 PERSON=DUZ
|
---|
41 | S:$G(SEQUENCE)']"" SEQUENCE="D"
|
---|
42 | S:+$G(OCCLIM)'>0 OCCLIM=9999999
|
---|
43 | S DFN=+$G(DFN)
|
---|
44 | S EARLY=9999999-EARLY,LATE=9999999-LATE ; CHANGE TO REVERSE DATES
|
---|
45 | ;
|
---|
46 | I CONTEXT=1!(CONTEXT=5) D G CTXQ
|
---|
47 | . D ACLPT(.TIUY,CLASS,DFN,LATE,EARLY,OCCLIM,SEQUENCE)
|
---|
48 | ;
|
---|
49 | I CONTEXT=2 D G CTXQ
|
---|
50 | . I DFN>0 D Q
|
---|
51 | . . D ACLAU(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE,$G(INCUND))
|
---|
52 | . F S DFN=$O(^TIU(8925,"ACLAU",CLASS,PERSON,DFN)) Q:DFN'>0 D ACLAU(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE,$G(INCUND))
|
---|
53 | ;
|
---|
54 | I CONTEXT=3 D G CTXQ
|
---|
55 | . I DFN>0 D Q
|
---|
56 | . . D ACLEC(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE)
|
---|
57 | . F S DFN=$O(^TIU(8925,"ACLEC",CLASS,PERSON,DFN)) Q:DFN'>0 D ACLEC(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE)
|
---|
58 | ;
|
---|
59 | I CONTEXT=4 D G CTXQ
|
---|
60 | . I DFN>0 D Q
|
---|
61 | . . ;VMP OIFO BAY PINES;ELR;TIU*1.0*194 REMOVED EXECUTION OF ACLSB & ADDED APTCL
|
---|
62 | . . ;D ACLSB(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE)
|
---|
63 | . . D APTCL^TIUSRVLP(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE)
|
---|
64 | . F S DFN=$O(^TIU(8925,"APTCL",DFN)) Q:DFN'>0 D APTCL^TIUSRVLP(.TIUY,CLASS,PERSON,DFN,LATE,EARLY,SEQUENCE)
|
---|
65 | ;
|
---|
66 | CTXQ K @TIUY@("INDX")
|
---|
67 | I $D(AWCSTRT) D END^AWCMCPR1 ; TIU*1.0*181
|
---|
68 | Q
|
---|
69 | ;
|
---|
70 | SWAP(TIUX,TIUY) ; Swap variables
|
---|
71 | N TIUTMP S TIUTMP=TIUX,TIUX=TIUY,TIUY=TIUTMP
|
---|
72 | Q
|
---|
73 | ;
|
---|
74 | EXPRANGE(TIUX,TIUY) ; Expand range when same for early & late
|
---|
75 | I TIUX=DT S TIUY=$$NOW^XLFDT I 1
|
---|
76 | E S TIUY=TIUY_"."_2359
|
---|
77 | Q
|
---|
78 | ;
|
---|
79 | ACLPT(TIUY,CLASS,DFN,TIME1,TIME2,OCCLIM,SEQUENCE) ; Signed, by patient
|
---|
80 | N DATTIM,DA,ROOT,TIUI,TIUJ
|
---|
81 | S ROOT=$NA(^TIU(8925,"ACLPT",CLASS,DFN)),TIUJ=0
|
---|
82 | S DATTIM=TIME1-.0000001
|
---|
83 | F S DATTIM=$O(@ROOT@(DATTIM)) Q:$S(+DATTIM'>0:1,+DATTIM>TIME2:1,+$G(TIUJ)'<OCCLIM:1,1:0) D
|
---|
84 | . S DA=0 F S DA=$O(@ROOT@(DATTIM,DA)) Q:DA'>0 D
|
---|
85 | . . ;Added first condition to following line for interdisciplinary notes - need addenda
|
---|
86 | . . I +$G(SHOWADD)=0,(+$G(^TIU(8925,+DA,0))=81) Q
|
---|
87 | . . I +$G(^TIU(8925,+DA,0))'>0 K @ROOT@(DATTIM,DA) Q
|
---|
88 | . . Q:+$D(@TIUY@("INDX",DA))
|
---|
89 | . . ; Selectively filter DELETED or RETRACTED records
|
---|
90 | . . I +$P($G(^TIU(8925,DA,0)),U,5)>13,'+$$CANDO^TIULP(DA,"VIEW",DUZ) Q
|
---|
91 | . . S TIUI=$S(SEQUENCE="D":+$G(TIUI)+1,1:+$G(TIUI)-1)
|
---|
92 | . . S @TIUY@(TIUI)=DA_U_$$RESOLVE(DA)
|
---|
93 | . . S TIUJ=+$G(TIUJ)+1
|
---|
94 | . . S @TIUY@("INDX",DA,TIUI)=""
|
---|
95 | . . Q:+$G(SHOWADD)=0
|
---|
96 | . . I +$$HASDAD^TIUSRVLI(DA) D SETDAD^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
97 | . . I +$$HASKIDS^TIUSRVLI(DA) D SETKIDS^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
98 | Q
|
---|
99 | ;
|
---|
100 | ACLAU(TIUY,CLASS,AUTHOR,DFN,TIME1,TIME2,SEQUENCE,INCUND) ; Unsigned
|
---|
101 | N DATTIM,DA,ROOT,TIUI
|
---|
102 | S ROOT=$NA(^TIU(8925,"ACLAU",CLASS,AUTHOR,DFN))
|
---|
103 | S DATTIM=TIME1-.0000001
|
---|
104 | F S DATTIM=$O(@ROOT@(DATTIM)) Q:DATTIM'>0!(DATTIM>TIME2) D
|
---|
105 | . S DA=0 F S DA=$O(@ROOT@(DATTIM,DA)) Q:DA'>0 D
|
---|
106 | . . I +$G(^TIU(8925,+DA,0))'>0 K @ROOT@(DATTIM,DA) Q
|
---|
107 | . . I +$P($G(^TIU(8925,DA,0)),U,5)>6 K @ROOT@(DATTIM,DA) Q
|
---|
108 | . . S TIUI=$S(SEQUENCE="D":+$G(TIUI)+1,1:+$G(TIUI)-1)
|
---|
109 | . . Q:+$D(@TIUY@("INDX",DA))
|
---|
110 | . . ; Selectively filter DELETED or RETRACTED records
|
---|
111 | . . I +$P($G(^TIU(8925,DA,0)),U,5)>13,'+$$CANDO^TIULP(DA,"VIEW",DUZ) Q
|
---|
112 | . . S @TIUY@(TIUI)=DA_U_$$RESOLVE(DA)
|
---|
113 | . . S @TIUY@("INDX",DA,TIUI)=""
|
---|
114 | . . Q:+$G(SHOWADD)=0
|
---|
115 | . . I +$$HASDAD^TIUSRVLI(DA) D SETDAD^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
116 | . . I +$$HASKIDS^TIUSRVLI(DA) D SETKIDS^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
117 | I +$G(INCUND) D GETUND^TIUSRVLI(.TIUY,CLASS,DFN,TIME1,TIME2,.TIUI,SEQUENCE)
|
---|
118 | Q
|
---|
119 | ;
|
---|
120 | ACLEC(TIUY,CLASS,EXCOSIGN,DFN,TIME1,TIME2,SEQUENCE) ; Uncosigned
|
---|
121 | N DATTIM,DA,ROOT,TIUI
|
---|
122 | S ROOT=$NA(^TIU(8925,"ACLEC",CLASS,EXCOSIGN,DFN))
|
---|
123 | S DATTIM=TIME1-.0000001
|
---|
124 | F S DATTIM=$O(@ROOT@(DATTIM)) Q:DATTIM'>0!(DATTIM>TIME2) D
|
---|
125 | . S DA=0 F S DA=$O(@ROOT@(DATTIM,DA)) Q:DA'>0 D
|
---|
126 | . . I +$G(^TIU(8925,+DA,0))'>0 K @ROOT@(DATTIM,DA) Q
|
---|
127 | . . S TIUI=$S(SEQUENCE="D":+$G(TIUI)+1,1:+$G(TIUI)-1)
|
---|
128 | . . Q:+$D(@TIUY@("INDX",DA))
|
---|
129 | . . ; Selectively filter DELETED or RETRACTED records
|
---|
130 | . . I +$P($G(^TIU(8925,DA,0)),U,5)>13,'+$$CANDO^TIULP(DA,"VIEW",DUZ) Q
|
---|
131 | . . S @TIUY@(TIUI)=DA_U_$$RESOLVE(DA)
|
---|
132 | . . S @TIUY@("INDX",DA,TIUI)=""
|
---|
133 | . . Q:+$G(SHOWADD)=0
|
---|
134 | . . I +$$HASDAD^TIUSRVLI(DA) D SETDAD^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
135 | . . I +$$HASKIDS^TIUSRVLI(DA) D SETKIDS^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
136 | Q
|
---|
137 | ;
|
---|
138 | ACLSB(TIUY,CLASS,SIGNEDBY,DFN,TIME1,TIME2,SEQUENCE) ; Signed, by author
|
---|
139 | N DATTIM,DA,ROOT,TIUI
|
---|
140 | S ROOT=$NA(^TIU(8925,"ACLSB",CLASS,SIGNEDBY,DFN))
|
---|
141 | S DATTIM=TIME1-.0000001
|
---|
142 | F S DATTIM=$O(@ROOT@(DATTIM)) Q:DATTIM'>0!(DATTIM>TIME2) D
|
---|
143 | . S DA=0 F S DA=$O(@ROOT@(DATTIM,DA)) Q:DA'>0 D
|
---|
144 | . . I +$G(^TIU(8925,+DA,0))'>0 K @ROOT@(DATTIM,DA) Q
|
---|
145 | . . S TIUI=$S(SEQUENCE="D":+$G(TIUI)+1,1:+$G(TIUI)-1)
|
---|
146 | . . Q:+$D(@TIUY@("INDX",DA))
|
---|
147 | . . ; Selectively filter DELETED or RETRACTED records
|
---|
148 | . . I +$P($G(^TIU(8925,DA,0)),U,5)>13,'+$$CANDO^TIULP(DA,"VIEW",DUZ) Q
|
---|
149 | . . S @TIUY@(TIUI)=DA_U_$$RESOLVE(DA)
|
---|
150 | . . S @TIUY@("INDX",DA,TIUI)=""
|
---|
151 | . . Q:+$G(SHOWADD)=0
|
---|
152 | . . I +$$HASDAD^TIUSRVLI(DA) D SETDAD^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
153 | . . I +$$HASKIDS^TIUSRVLI(DA) D SETKIDS^TIUSRVLI(.TIUY,DA,.TIUI)
|
---|
154 | Q
|
---|
155 | ;
|
---|
156 | RESOLVE(DA) ; Resolve to external data
|
---|
157 | N DOC,LOC,PT,AUT,EDT,TIUPT,TIULST4,TIUREC,TIUR0,TIUR12,TIUR13,TIUR14
|
---|
158 | N TIUR17,STATUS,EDTCNT,LOCTYP,TIUADT,TIUDDT,PREFIX,IDPARENT,IDSORT
|
---|
159 | S PREFIX=""
|
---|
160 | S TIUR0=$G(^TIU(8925,+DA,0)),TIUR12=$G(^TIU(8925,+DA,12))
|
---|
161 | S TIUR13=$G(^TIU(8925,+DA,13)),TIUR14=$G(^(14)),TIUR17=$G(^(17))
|
---|
162 | S IDPARENT=+$G(^TIU(8925,+DA,21))
|
---|
163 | S TIUPT=$G(^DPT(+$P(TIUR0,U,2),0))
|
---|
164 | S DOC=$$PNAME^TIULC1(+TIUR0)
|
---|
165 | I +$G(^TIU(8925.1,+DA,15)) D
|
---|
166 | . N TIUD15 S TIUD15=$G(^TIU(8925.1,+DA,15))
|
---|
167 | . S DOC=DOC_";"_$P($G(^TIU(8926.1,+TIUD15,0)),U)
|
---|
168 | I DOC="Addendum" S DOC=DOC_" to "_$$PNAME^TIULC1(+$G(^TIU(8925,+$P(TIUR0,U,6),0)))
|
---|
169 | ; If IDNotes (TIU*1.0*100) installed, use $$PREFIX^TIULA2 to evaluate
|
---|
170 | ; which prefix to use:
|
---|
171 | ; - keep prefix display in earlier CPRS versions and LM
|
---|
172 | ; - omit in newer TreeView versions
|
---|
173 | I $L($T(PREFIX^TIULA2)) D I 1
|
---|
174 | . S PREFIX=$$PREFIX^TIULA2(DA,1) ; 1=include ID Child indicator
|
---|
175 | . I PREFIX["<" S IDSORT=$$IDSORT(DA)
|
---|
176 | . I +$G(SHOWADD)=0 S DOC=PREFIX_DOC
|
---|
177 | ; otherwise, only show addendum indicator (+)
|
---|
178 | ; - keep prefix display in earlier CPRS versions and LM
|
---|
179 | ; - omit in newer TreeView versions
|
---|
180 | E D
|
---|
181 | . I +$$HASADDEN^TIULC1(DA) S PREFIX="+ "
|
---|
182 | . I +$G(SHOWADD)=0,(+$$HASADDEN^TIULC1(DA)) S DOC=PREFIX_DOC
|
---|
183 | I +$$URGENCY^TIURM(+DA)=1 S DOC=$S(DOC["+":"*",1:"* ")_DOC
|
---|
184 | S STATUS=$$LOWER^TIULS($P($G(^TIU(8925.6,+$P(TIUR0,U,5),0)),U))
|
---|
185 | S LOC=$G(^SC(+$P(TIUR12,U,5),0)),LOCTYP=$P(LOC,U,3),LOC=$P(LOC,U)
|
---|
186 | S TIUADT=$S(LOCTYP="W":"Adm: ",1:"Visit: ")_$$DATE^TIULS($P(TIUR0,U,7),"MM/DD/YY")
|
---|
187 | S TIUDDT=$S(+$P(TIUR0,U,8):"Dis: ",1:"")_$$DATE^TIULS($P(TIUR0,U,8),"MM/DD/YY")
|
---|
188 | I +$G(SHOWADD)>0 S TIUADT=TIUADT_";"_$P(TIUR0,U,7),TIUDDT=TIUDDT_";"_$P(TIUR0,U,8)
|
---|
189 | S PT=$$NAME^TIULS($P(TIUPT,U),"LAST, FIRST MI")
|
---|
190 | S TIULST4=$E($P(TIUPT,U,9),6,9)
|
---|
191 | S TIULST4="("_$E(PT)_TIULST4_")"
|
---|
192 | S AUT=+$P(TIUR12,U,2)
|
---|
193 | S AUT=AUT_";"_$$SIGNAME^TIULS(+$P(TIUR12,U,2))_";"_$$GET1^DIQ(200,AUT,.01)
|
---|
194 | S EDT=+TIUR13,EDTCNT=+$G(EDTCNT)+1
|
---|
195 | S TIUREC=DOC_U_EDT_U_PT_" "_TIULST4_U_AUT_U_LOC_U_STATUS_U_TIUADT_U_TIUDDT_U_$P(TIUR14,U,5)_U_$$IMGCNT(DA)_U
|
---|
196 | S TIUREC=TIUREC_$S($L(TIUR17):$E(TIUR17,1,(255-$L(TIUREC)))_U,1:U)
|
---|
197 | S TIUREC=TIUREC_$P(PREFIX," ")_U
|
---|
198 | S TIUREC=TIUREC_$S(+TIUR0=81:+$P(TIUR0,U,6),+IDPARENT:IDPARENT,+$G(CONTEXT):CONTEXT,1:1)_U_$G(IDSORT)
|
---|
199 | Q $G(TIUREC)
|
---|
200 | IMGCNT(TIUDA) ; Get the number of images associated with a document
|
---|
201 | N IMGDA,TIUI S (IMGDA,TIUI)=0
|
---|
202 | F S IMGDA=$O(^TIU(8925.91,"ADI",TIUDA,IMGDA)) Q:+IMGDA'>0 D
|
---|
203 | . S TIUI=TIUI+1
|
---|
204 | Q TIUI
|
---|
205 | IDSORT(TIUDA) ; Get ID Sort indicator when appropriate
|
---|
206 | N TIUDPRM
|
---|
207 | D DOCPRM^TIULC1(+$G(^TIU(8925,+TIUDA,0)),.TIUDPRM)
|
---|
208 | Q +$P(TIUDPRM(0),U,18)
|
---|