1 | OREVNTX1 ; SLC/JLI - Event delayed orders RPC's ;9/19/02 13:35
|
---|
2 | ;;3.0;ORDER ENTRY/RESULTS REPORTING;**141,165,149**;Dec 17, 1997
|
---|
3 | ;
|
---|
4 | PUTEVNT(ORY,DFN,EVT,ORIFN) ; Save new patient delayed events to file 100.2
|
---|
5 | S ORY=$$NEW^OREVNT(DFN,EVT,ORIFN)
|
---|
6 | Q
|
---|
7 | ;
|
---|
8 | GTEVT(ORY,PTEVT) ; Return Event infomation based on PTEVT ptr #100.2
|
---|
9 | ;EVTID ptr #100.5
|
---|
10 | Q:'+PTEVT
|
---|
11 | N EVTID,EVTTYPE,EVTNAME,EVTDISP,EVTDLG,PRTEVT
|
---|
12 | S (EVTTYPE,EVTNAME,EVTDISP,PRTEVT)=""
|
---|
13 | S EVTDLG=0
|
---|
14 | I '$P(^ORE(100.2,+$G(PTEVT),0),U,2) Q
|
---|
15 | S EVTID=$$EVT^OREVNTX(PTEVT)
|
---|
16 | S PRTEVT=$P(^ORD(100.5,EVTID,0),U,12)
|
---|
17 | I PRTEVT S EVTTYPE=$P(^ORD(100.5,PRTEVT,0),U,2)
|
---|
18 | E S EVTTYPE=$P(^ORD(100.5,EVTID,0),U,2)
|
---|
19 | I $D(^ORD(100.5,EVTID,0)) D
|
---|
20 | . S EVTNAME=$P(^ORD(100.5,EVTID,0),U,1)
|
---|
21 | . S EVTDISP=$P(^ORD(100.5,EVTID,0),U,8)
|
---|
22 | . S EVTDLG=$P(^ORD(100.5,EVTID,0),U,4)
|
---|
23 | S ORY=EVTTYPE_U_EVTID_U_EVTNAME_U_EVTDISP_U_EVTDLG
|
---|
24 | Q
|
---|
25 | GTEVT1(ORY,EVT) ; Return Event information based on EVT ptr #100.5
|
---|
26 | ;EVT ptr #100.5
|
---|
27 | Q:'+EVT
|
---|
28 | N EVTTYPE,EVTNAME,EVTDISP,EVTDLG,PRTEVT
|
---|
29 | S (EVTDLG,PRTEVT)=0
|
---|
30 | S PRTEVT=$P(^ORD(100.5,+EVT,0),U,12)
|
---|
31 | I PRTEVT>0 S EVTTYPE=$P(^ORD(100.5,PRTEVT,0),U,2)
|
---|
32 | E S EVTTYPE=$P(^ORD(100.5,+EVT,0),U,2)
|
---|
33 | S EVTNAME=$P($G(^ORD(100.5,+EVT,0)),U,1)
|
---|
34 | S EVTDISP=$P($G(^ORD(100.5,+EVT,0)),U,8)
|
---|
35 | S EVTDLG=$P($G(^ORD(100.5,+EVT,0)),U,4)
|
---|
36 | S ORY=EVTTYPE_U_EVT_U_EVTNAME_U_EVTDISP_U_EVTDLG
|
---|
37 | Q
|
---|
38 | ;
|
---|
39 | EVT(ORY,PTEVT) ; Return Event ptr #100.5, given PTEVT ptr #100.2
|
---|
40 | Q:'+PTEVT
|
---|
41 | S ORY=$$EVT^OREVNTX(PTEVT)
|
---|
42 | Q
|
---|
43 | ;
|
---|
44 | EXISTS(ORY,DFN,EVT) ;Returns PtEvtID ptr #100.2 if patient already has delayed orders
|
---|
45 | I '+EVT S ORY=0 Q
|
---|
46 | N PTEVT S (PTEVT,ORY)=0
|
---|
47 | S PTEVT=$O(^ORE(100.2,"AE",+DFN,+EVT,PTEVT))
|
---|
48 | I PTEVT>0 S ORY=PTEVT
|
---|
49 | Q
|
---|
50 | ;
|
---|
51 | TYPEXT(ORY,DFN,EVT) ; does EVT has delayed orders?
|
---|
52 | ; 1 if Patient DFN has delayed orders for EVT
|
---|
53 | ; 2 if Parent/Sibling event has delayed orders
|
---|
54 | ; 0 if No delayed orders for EVT
|
---|
55 | Q:'+EVT
|
---|
56 | S ORY=$$EXISTS^OREVNTX(DFN,EVT)
|
---|
57 | Q
|
---|
58 | ;
|
---|
59 | MATCH(ORY,DFN,EVT) ;If Pt's current data match selected event
|
---|
60 | ;DFN: patient DFN
|
---|
61 | ;EVT: ptr to #100.5
|
---|
62 | S ORY=0
|
---|
63 | Q:('+DFN)!('+EVT)
|
---|
64 | S ORY=$$MATCH^OREVNT(DFN,EVT)
|
---|
65 | N TS,TSNM
|
---|
66 | S TS=$S($G(ORTS):+ORTS,1:+$G(^DPT(DFN,.103)))
|
---|
67 | S TSNM=$P($G(^DIC(45.7,TS,0)),U)
|
---|
68 | S:ORY ORY=ORY_U_TSNM
|
---|
69 | Q
|
---|
70 | ;
|
---|
71 | NAME(ORY,PTEVT) ; Return Event name from #100.5, given PTEVT ptr #100.2
|
---|
72 | I PTEVT'>0 S ORY="" Q
|
---|
73 | S ORY=$$NAME^OREVNTX(PTEVT)
|
---|
74 | Q
|
---|
75 | ;
|
---|
76 | DIV(ORY,PTEVT) ; Return division for PTEVT ptr #100.2
|
---|
77 | Q:'+PTEVT
|
---|
78 | S ORY=$$DIV^OREVNTX(PTEVT)
|
---|
79 | Q
|
---|
80 | ;
|
---|
81 | DIV1(ORY,EVT) ; Return division for EVT ptr #100.5
|
---|
82 | Q:'+EVT
|
---|
83 | S ORY=+$P($G(^ORD(100.5,+EVT,0)),U,3) S:ORY<1 ORY=+$G(DUZ(2))
|
---|
84 | Q
|
---|
85 | ;
|
---|
86 | LOC(ORY,PTEVT) ; Return default hospital location ^SC( for PTEVT ptr #100.2
|
---|
87 | Q:'+PTEVT
|
---|
88 | S ORY=$$LOC^OREVNTX(PTEVT)
|
---|
89 | S ORY=+ORY
|
---|
90 | Q
|
---|
91 | ;
|
---|
92 | LOC1(ORY,EVT) ; Return default hospital location ^SC( for EVT ptr #100.5
|
---|
93 | Q:'+EVT
|
---|
94 | S ORY=+$P($G(^ORD(100.5,+EVT,0)),U,9) S:ORY<1 ORY=+$G(ORL)
|
---|
95 | Q
|
---|
96 | ;
|
---|
97 | CHGEVT(ORY,NEWEVT,ORIDS) ; Change order's event
|
---|
98 | N ORI
|
---|
99 | S ORI=0
|
---|
100 | F S ORI=$O(ORIDS(ORI)) Q:'+ORI D
|
---|
101 | . D CHGEVT^OREVNTX(+$G(ORIDS(ORI)),NEWEVT)
|
---|
102 | Q
|
---|
103 | ;
|
---|
104 | EMPTY(ORY,PTEVT) ; Return 1 if PTEVT doesn't have any orders
|
---|
105 | Q:'+PTEVT
|
---|
106 | S ORY=$$EMPTY^OREVNTX(PTEVT)
|
---|
107 | Q
|
---|
108 | ;
|
---|
109 | DELPTEVT(ORY,PTEVT) ; Delete Patient Event in #100.2
|
---|
110 | Q:'+PTEVT
|
---|
111 | D CANCEL^OREVNTX(PTEVT)
|
---|
112 | Q
|
---|
113 | ;
|
---|
114 | UPDTOR(ORY,PTIFN,ORIFN,PTEVT) ; If delayed order was DCed, then update the EVENT and "AEVNT"
|
---|
115 | Q ;Don't ever need to do this!
|
---|
116 | CURSPE(ORY,PTIFN) ; Return current treating specialty
|
---|
117 | Q:'PTIFN
|
---|
118 | N SPCID
|
---|
119 | I $D(^DPT(PTIFN,.103)) D
|
---|
120 | . S SPCID=$G(^DPT(PTIFN,.103))
|
---|
121 | . S:SPCID ORY=$P($G(^DIC(45.7,SPCID,0)),U)_U_SPCID
|
---|
122 | Q
|
---|
123 | DFLTEVT(ORY,PVIFN) ; Return default release event based on provider IFN
|
---|
124 | N CMEVTLST,IDX
|
---|
125 | S CMEVTLST="",IDX=0
|
---|
126 | D GETLST^OREV3(.CMEVTLST)
|
---|
127 | F S IDX=$O(CMEVTLST(IDX)) Q:'IDX D
|
---|
128 | . I $P($G(CMEVTLST(IDX)),U,2) S ORY=$P($G(CMEVTLST(IDX)),U) Q
|
---|
129 | Q
|
---|
130 | CMEVTS(ORY,CLOC) ;Return common event list
|
---|
131 | N IDX,X0,X,LOC
|
---|
132 | S:CLOC>0 LOC=CLOC
|
---|
133 | S IDX=0,ORY=""
|
---|
134 | D GETLST^OREV3(.ORY)
|
---|
135 | F S IDX=$O(ORY(IDX)) Q:'IDX D
|
---|
136 | . S X0=""
|
---|
137 | . S:$L($G(^ORD(100.5,+ORY(IDX),0))) X0=$G(^(0))
|
---|
138 | . I '$L($P(X0,U,2)) D
|
---|
139 | .. S X=$P(X0,U,12) S:X $P(X0,U,2)=$P($G(^ORD(100.5,+X,0)),U,2)
|
---|
140 | . S:$L(X0) ORY(IDX)=+ORY(IDX)_U_X0
|
---|
141 | Q
|
---|
142 | ;
|
---|
143 | DELDFLT(ORY,PVIFN) ; Delete default release event
|
---|
144 | Q:'PVIFN
|
---|
145 | N ORERR
|
---|
146 | S ORERR=""
|
---|
147 | D DEL^XPAR(PVIFN_";VA(200,","OREVNT DEFAULT",1,.ORERR)
|
---|
148 | Q
|
---|
149 | WRLSTED(LST,LOC,EVTID) ; Return list of dialogs for writing event delayed orders
|
---|
150 | ; .Y(n): DlgName^ListBox Text
|
---|
151 | WRLST1 N ANENT
|
---|
152 | S LOC=+$G(LOC)_";SC(" I 'LOC S LOC=""
|
---|
153 | S ANENT="ALL^USR.`"_DUZ_"^"_LOC_$S($G(^VA(200,DUZ,5)):"^SRV.`"_+$G(^(5)),1:"")
|
---|
154 | N MNU,SEQ,IEN,ITM,TXT,FID,DGRP,X,TYP
|
---|
155 | S MNU=$$GET^XPAR(ANENT,"ORWDX WRITE ORDERS EVENT LIST",EVTID,"I") Q:'MNU
|
---|
156 | S SEQ=0 F S SEQ=$O(^ORD(101.41,MNU,10,"B",SEQ)) Q:'SEQ D
|
---|
157 | . S IEN=0 F S IEN=$O(^ORD(101.41,MNU,10,"B",SEQ,IEN)) Q:'IEN D
|
---|
158 | . . S X=$G(^ORD(101.41,MNU,10,IEN,0)),ITM=+$P(X,U,2),TXT=$P(X,U,4)
|
---|
159 | . . S X=$G(^ORD(101.41,ITM,5)),FID=+$P(X,U,5)
|
---|
160 | . . S X=$G(^ORD(101.41,ITM,0)),TYP=$P(X,U,4),DGRP=+$P(X,U,5)
|
---|
161 | . . S:'$L(TXT) TXT=$P(X,U,2)
|
---|
162 | . . I TYP="M" S:'FID FID=1001
|
---|
163 | . . S LST(SEQ)=ITM_";"_FID_";"_DGRP_";"_TYP_U_TXT
|
---|
164 | Q
|
---|
165 | ;
|
---|
166 | GETDLG(LST,DLGID) ; Return dialog infomation based on the DLGID
|
---|
167 | N DIEN,DFID,DTXT,DTYP,DGRP,X0,X5
|
---|
168 | S DLGID=+DLGID
|
---|
169 | Q:'DLGID
|
---|
170 | S X0=^ORD(101.41,DLGID,0),X5=$G(^(5))
|
---|
171 | S DGRP=+$P(X0,U,5),DFID=+$P(X5,U,5),DTXT=$P(X5,U,4),DTYP=$P(X0,U,4)
|
---|
172 | S:'$L(DTXT) DTXT=$P(X0,U,2)
|
---|
173 | I $P(X0,U,4)="M" S:'DFID DFID=1001
|
---|
174 | S LST=DLGID_";"_DFID_";"_DGRP_";"_DTYP_U_DTXT
|
---|
175 | Q
|
---|
176 | DONE(LST,PTEVT) ; Terminate PTEvt
|
---|
177 | Q:'PTEVT
|
---|
178 | D DONE^OREVNTX(PTEVT)
|
---|
179 | D ACTLOG^OREVNTX(PTEVT,"MN")
|
---|
180 | Q
|
---|
181 | SETDFLT(ORY,EVT) ;Set personal default event
|
---|
182 | N ERR,VAL S ERR=""
|
---|
183 | Q:'$D(^ORD(100.5,EVT,0))
|
---|
184 | S VAL=$P(^ORD(100.5,EVT,0),U)
|
---|
185 | D EN^XPAR(DUZ_";VA(200,","OREVNT DEFAULT",1,VAL,ERR)
|
---|
186 | S ORY=ERR
|
---|
187 | Q
|
---|
188 | CPACT(ORY,EVT) ; Return True/False to display active orders for copy
|
---|
189 | ; EVT ptr to #100.5
|
---|
190 | Q:'EVT
|
---|
191 | S ORY=0
|
---|
192 | Q:'$D(^ORD(100.5,EVT,0))
|
---|
193 | S ORY=$P(^ORD(100.5,EVT,0),U,11)
|
---|
194 | Q
|
---|
195 | PRMPTID(ORY,PRTNM) ;Return event prompt IEN for OR GTX EVENT
|
---|
196 | S:$D(^ORD(101.41,"B","OR GTX EVENT")) ORY=$O(^("OR GTX EVENT",0))
|
---|
197 | Q
|
---|
198 | ISDCOD(ORY,ORIFN) ;True: the order need to be filtered out
|
---|
199 | N PAS,X3,X0,ORGRPLST,THEGRP,IDX,ODGRP
|
---|
200 | S (ORY,IDX)=0
|
---|
201 | Q:'$D(^OR(100,+ORIFN,0))
|
---|
202 | S X0=$G(^OR(100,+ORIFN,0))
|
---|
203 | S ODGRP=$P(X0,U,11)
|
---|
204 | D GETLST^XPAR(.ORGRPLST,"ALL","OREVNT EXCLUDE DGRP")
|
---|
205 | F S IDX=$O(ORGRPLST(IDX)) Q:'IDX!ORY D
|
---|
206 | . S THEGRP=$P($G(ORGRPLST(IDX)),U,2)
|
---|
207 | . I $$GRPCHK(THEGRP,ODGRP) S ORY=1
|
---|
208 | I ORY Q
|
---|
209 | S PAS=";1;"
|
---|
210 | S:$D(^OR(100,+ORIFN,3)) X3=^OR(100,+ORIFN,3)
|
---|
211 | S:(PAS'[(";"_$P(X3,U,3)_";")) ORY=0
|
---|
212 | Q
|
---|
213 | DEFLTS(ORY,EVTID) ;Return default specialty for EVTID(#100.5)
|
---|
214 | Q:'+EVTID
|
---|
215 | N PRTEVT
|
---|
216 | S PRTEVT=0
|
---|
217 | S PRTEVT=$P(^ORD(100.5,+EVTID,0),U,12)
|
---|
218 | I PRTEVT>0 S EVTID=PRTEVT
|
---|
219 | S ORY=$$DEFTS^ORCDADT(EVTID)
|
---|
220 | Q
|
---|
221 | ;
|
---|
222 | MULTS(ORY,EVTID) ;Return specialty list for the EVTID(#100.5)
|
---|
223 | Q:'+EVTID
|
---|
224 | N I,CNT,X,Y S (I,CNT)=0
|
---|
225 | N PRTEVT
|
---|
226 | S PRTEVT=0
|
---|
227 | S PRTEVT=$P(^ORD(100.5,+EVTID,0),U,12)
|
---|
228 | I PRTEVT>0 S EVTID=PRTEVT
|
---|
229 | F S I=$O(^ORD(100.5,+$G(EVTID),"TS",I)) Q:I<1 S X=+$G(^(I,0)) D
|
---|
230 | . S Y=$$GET1^DIQ(45.7,X_",",.01)
|
---|
231 | . S CNT=CNT+1,ORY(CNT)=X_U_Y
|
---|
232 | Q
|
---|
233 | ;
|
---|
234 | PRTIDS(ORY,IDS) ;Return some prompt ids from #101.41
|
---|
235 | ; treating specialty Id^attending provider id
|
---|
236 | N IDX,ORTS,ORATT
|
---|
237 | S (ORY,ORTS,ORATT)=""
|
---|
238 | S IDX=$O(^ORD(101.41,"B","OR GTX TREATING SPECIALTY",0))
|
---|
239 | S:$D(^ORD(101.41,IDX,1)) ORTS=$P($G(^ORD(101.41,IDX,1)),U,2,3)
|
---|
240 | S IDX=$O(^ORD(101.41,"B","OR GTX PROVIDER",0))
|
---|
241 | S:$D(^ORD(101.41,IDX,1)) ORATT=$P($G(^ORD(101.41,IDX,1)),U,2,3)
|
---|
242 | S ORY=ORTS_"~"_ORATT
|
---|
243 | Q
|
---|
244 | ;
|
---|
245 | DFLTDLG(ORY,EVTID) ;Return event default dialog IEN
|
---|
246 | S ORY=0
|
---|
247 | Q:'$D(^ORD(100.5,+EVTID,0))
|
---|
248 | S ORY=$P(^ORD(100.5,+EVTID,0),U,4)
|
---|
249 | Q
|
---|
250 | AUTHMREL(ORY,USER) ;1: user can manual release delayed orders 0: can't
|
---|
251 | S ORY=$$CANREL^OREV3
|
---|
252 | Q
|
---|
253 | HAVEPRT(ORY,PTEVT) ;return parent patient event from #100.2
|
---|
254 | Q:'+PTEVT
|
---|
255 | S ORY=""
|
---|
256 | S:$L($G(^ORE(100.2,PTEVT,1))) ORY=$P(^(1),U,5)
|
---|
257 | Q
|
---|
258 | GRPCHK(DG,AGRP) ;If an order's group belong to DG group
|
---|
259 | N RST
|
---|
260 | S RST=0
|
---|
261 | N ORGRP
|
---|
262 | D GRP^ORQ1(DG)
|
---|
263 | S RST=$S($D(ORGRP(AGRP)):1,1:0)
|
---|
264 | Q RST
|
---|
265 | ODPTEVID(ORY,ORID) ;Return PtEvtID based on the ORID
|
---|
266 | Q:'$D(^OR(100,+ORID,0))
|
---|
267 | S ORY=$P($G(^OR(100,+ORID,0)),U,17)
|
---|
268 | Q
|
---|
269 | COMP(ORY,PTEVT) ;Return 1 or 0 if PTEVT completed or not
|
---|
270 | Q:'+PTEVT
|
---|
271 | S ORY=$$COMP^OREVNTX(+PTEVT)
|
---|
272 | Q
|
---|
273 | ISHDORD(ORY,ORID) ;Return 1 if it's on-hold med order
|
---|
274 | Q:'+ORID
|
---|
275 | Q:'$D(^OR(100,+ORID,0))
|
---|
276 | N STS,HDSTS,ODGP,INPT,OUPT,MEDS,IVMD
|
---|
277 | S HDSTS=$O(^ORD(100.01,"B","HOLD",0))
|
---|
278 | S STS=$P($G(^OR(100,+ORID,3)),U,3)
|
---|
279 | S INPT=$O(^ORD(100.98,"B","UD RX",0))
|
---|
280 | S OUPT=$O(^ORD(100.98,"B","O RX",0))
|
---|
281 | S MEDS=$O(^ORD(100.98,"B","RX",0))
|
---|
282 | S IVMD=$O(^ORD(100.98,"B","IV RX",0))
|
---|
283 | S ODGP=$P(^OR(100,+ORID,0),U,11)
|
---|
284 | I (U_INPT_U_OUPT_U_MEDS_U_IVMD_U[U_ODGP_U),(HDSTS=STS) S ORY=1
|
---|
285 | Q
|
---|
286 | ISPASS(ORY,PTEVTID,EVTTYPE) ;Return 1 if it's a pass event
|
---|
287 | S ORY=$$EVT^OREVNTX(PTEVTID)
|
---|
288 | S ORY=$P($G(^ORD(100.5,+ORY,0)),U,7)
|
---|
289 | I EVTTYPE="T",ORY,ORY<4 S ORY=1
|
---|
290 | E S ORY=0
|
---|
291 | Q
|
---|
292 | ISPASS1(ORY,EVTID,EVTTYPE) ;Return 1 if it's a pass event
|
---|
293 | S ORY=$P($G(^ORD(100.5,+EVTID,0)),U,7)
|
---|
294 | I EVTTYPE="T",ORY,ORY<4 S ORY=1
|
---|
295 | E S ORY=0
|
---|
296 | Q
|
---|
297 | DLGIEN(ORY,DLGNAME) ;Return Order Dialog IEN based on name
|
---|
298 | Q:'$D(^ORD(101.41,"B",DLGNAME))
|
---|
299 | S ORY=$O(^ORD(101.41,"B",DLGNAME,0))
|
---|
300 | Q
|
---|
301 | GETSTS(ORY,ORDID) ;Return Order status
|
---|
302 | Q:'+ORDID
|
---|
303 | Q:'$D(^OR(100,+ORDID,0))
|
---|
304 | S ORY=$P($G(^OR(100,+ORDID,3)),U,3)
|
---|
305 | Q
|
---|