1 | ORB3 ; slc/CLA - Main routine for OE/RR 3 notifications ;6/6/01 10:46 [8/16/05 5:33am]
|
---|
2 | ;;3.0;ORDER ENTRY/RESULTS REPORTING;**31,74,91,105,139,190,220,253,265**;Dec 17, 1997;Build 17
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | EN(ORN,ORBDFN,ORNUM,ORBADUZ,ORBPMSG,ORBPDATA) ;
|
---|
5 | ;
|
---|
6 | N ORBENT
|
---|
7 | S ORBENT=$$ENTITY^ORB31(ORNUM)
|
---|
8 | ;
|
---|
9 | Q:$$GET^XPAR(ORBENT,"ORB SYSTEM ENABLE/DISABLE",1,"I")="D"
|
---|
10 | Q:'$L($G(^ORD(100.9,ORN,0)))
|
---|
11 | Q:+$$ONOFF^ORB3FN(ORN)=0
|
---|
12 | ;
|
---|
13 | S ORBPMSG=$E($G(ORBPMSG),1,51)
|
---|
14 | ;
|
---|
15 | ;if msg from notif file or oc notif (#54), quit if dup w/in past 1 min:
|
---|
16 | N ORBDUP,ORBN
|
---|
17 | S ORBN=^ORD(100.9,ORN,0)
|
---|
18 | I ($P(ORBN,"^",4)="NOT")!(ORN=54) D
|
---|
19 | .S ORBDUP=$$DUP^ORB31(ORN,ORBDFN,ORBPMSG,ORNUM)
|
---|
20 | Q:+$G(ORBDUP)=1
|
---|
21 | ;
|
---|
22 | N ORBDESC
|
---|
23 | S ORBDESC=" Send Alert Notification ("_(+ORN)_") "_$P($G(^ORD(100.9,+ORN,0)),U,1)_" "
|
---|
24 | ;
|
---|
25 | D QUEUE^ORB31(ORN,ORBDFN,$G(ORNUM),.ORBADUZ,$G(ORBPMSG),$G(ORBPDATA),$H,ORBDESC,$G(DGPMA))
|
---|
26 | Q
|
---|
27 | ZTSK ;
|
---|
28 | D START
|
---|
29 | S ZTREQ="@"
|
---|
30 | Q
|
---|
31 | UTL(ORBU,ORN,ORBDFN,ORNUM,ORBADUZ,ORBPMSG,ORBPDATA) ;
|
---|
32 | Q:$G(ORBU)'=1
|
---|
33 | START Q:$G(ORN)=""!($G(ORBDFN)="")
|
---|
34 | Q:'$L($G(^ORD(100.9,ORN,0)))
|
---|
35 | N ORBNOW,ORBID,ORBLOCK,ORBDESC
|
---|
36 | S ORBNOW=$$NOW^XLFDT
|
---|
37 | S ORBLOCK=0
|
---|
38 | ;
|
---|
39 | ;lock to prevent concurrent processing by other resource slots:
|
---|
40 | I '$D(ORBU) D
|
---|
41 | .S ^XTMP("ORBLOCK",0)=$$FMADD^XLFDT(ORBNOW,1,"","","")_"^"_ORBNOW
|
---|
42 | .S ORBID=$P($P($G(ORBPDATA),"|",2),"@") ;get unique data id
|
---|
43 | .I $L(ORBID) D
|
---|
44 | ..LOCK +^XTMP("ORBLOCK",ORBDFN,ORN,ORBID):60 E D Q
|
---|
45 | ...S ORBDESC=" Requeue Alert Notification ("_(+ORN)_") "_$P($G(^ORD(100.9,+ORN,0)),U,1)_" "
|
---|
46 | ...D QUEUE^ORB31(ORN,ORBDFN,$G(ORNUM),.ORBADUZ,$G(ORBPMSG),$G(ORBPDATA),$$HADD^XLFDT($H,"","",5,""),ORBDESC,$G(DGPMA)) ;requeue in 5 min.
|
---|
47 | ...S ORBLOCK=1
|
---|
48 | .;
|
---|
49 | .I '$L(ORBID) D
|
---|
50 | ..LOCK +^XTMP("ORBLOCK",ORBDFN,ORN):60 E D Q
|
---|
51 | ...S ORBDESC=" Requeue Alert Notification ("_(+ORN)_") "_$P($G(^ORD(100.9,+ORN,0)),U,1)_" "
|
---|
52 | ...D QUEUE^ORB31(ORN,ORBDFN,$G(ORNUM),.ORBADUZ,$G(ORBPMSG),$G(ORBPDATA),$$HADD^XLFDT($H,"","",5,""),ORBDESC,$G(DGPMA)) ;requeue in 5 min.
|
---|
53 | ...S ORBLOCK=1
|
---|
54 | .;
|
---|
55 | I ORBLOCK=1 D QUIT Q
|
---|
56 | ;
|
---|
57 | DOALERT ; Entry point for alert logic outside of TaskMan
|
---|
58 | N ORBDUZ,ORBN,ORBXQAID,ORPTNAM,ORBPRIM,ORBATTD,ORBDEV,ORBENT
|
---|
59 | N ORBUI,ORBASPEC,ORBSMSG,ORBADT,ORBSDEV,ORBDEL,ORBDI,ORBTDEV,ORY
|
---|
60 | S ORBUI=1,ORBADT=0
|
---|
61 | S:'$L($G(ORBPMSG)) ORBPMSG=""
|
---|
62 | I '$L(ORBPDATA),(+$G(ORNUM)>0) S ORBPDATA=+$G(ORNUM)_"@"
|
---|
63 | S ORBN=^ORD(100.9,ORN,0)
|
---|
64 | ;
|
---|
65 | S ORBENT=$$ENTITY^ORB31(ORNUM)
|
---|
66 | ;
|
---|
67 | N DFN S DFN=ORBDFN,VA200="" D OERR^VADPT
|
---|
68 | I ('$L($G(VA("BID"))))!('$L($G(VADM(1)))) D QUIT Q
|
---|
69 | I (ORN=18)!(ORN=20)!(ORN=35) S ORBADT=1 ;A/D/T notif
|
---|
70 | ;if not an A/D/T notif, get primary & attending from OERR^VADPT:
|
---|
71 | I ORBADT=0 S ORBPRIM=+$P(VAIN(2),U),ORBATTD=+$P(VAIN(11),U)
|
---|
72 | I ORBADT=1 D ADT^ORB31(ORN,ORBDFN,.ORBPRIM,.ORBATTD,$G(ORDGPMA)) ;A/D/T notif
|
---|
73 | I $D(ORBU) D ;create debug msg
|
---|
74 | .S ORBU(ORBUI)="Processing notification: "_$P(ORBN,U),ORBUI=ORBUI+1
|
---|
75 | .S ORBU(ORBUI)=" for patient: "_VADM(1),ORBUI=ORBUI+1
|
---|
76 | .I $G(ORNUM)>0 S ORBU(ORBUI)=" for order: "_ORNUM,ORBUI=ORBUI+1
|
---|
77 | D REGULAR^ORB3REG(ORN,.XQA,.ORBU,.ORBUI,.ORBDEV,ORBDFN)
|
---|
78 | D SPECIAL^ORB3SPEC(ORN,.ORBASPEC,.ORBU,.ORBUI,$G(ORNUM),ORBDFN,$G(ORBPDATA),.ORBSMSG,$G(ORBPMSG),.ORBSDEV,$G(ORBPRIM),$G(ORBATTD))
|
---|
79 | I $L($G(ORBSMSG)) S ORBPMSG=$E(ORBSMSG,1,51)
|
---|
80 | I $D(ORBASPEC)>1 D SPECDUZS ;special recips
|
---|
81 | I $D(ORBADUZ)>1 D PKGDUZS ;pkg-supplied recips
|
---|
82 | D TITLE ;provider recips
|
---|
83 | S ORBXQAID=$P(ORBN,"^",2)_","_ORBDFN_","_ORN
|
---|
84 | ;
|
---|
85 | I ($D(XQA)>1)!($D(ORBDEV)>1)!($D(ORBSDEV)>1) D ;recips found
|
---|
86 | .S XQAFLG=$P(ORBN,"^",5)
|
---|
87 | .S XQADFN=ORBDFN
|
---|
88 | .I XQAFLG="R" S XQAROU=$P(ORBN,"^",6)_"^"_$P(ORBN,"^",7)
|
---|
89 | .I $G(ORBPDATA)'="" S XQADATA=ORBPDATA
|
---|
90 | .S ORPTNAM=$E(VADM(1)_" ",1,9)
|
---|
91 | .S XQAMSG=ORPTNAM_" "_"("_$E(ORPTNAM)_$E(VA("BID"),1,4)_")"_": "
|
---|
92 | .S XQAMSG=XQAMSG_$S(ORBPMSG'="":ORBPMSG,1:$P(ORBN,"^",3))
|
---|
93 | .S XQAARCH=$$GET^XPAR(ORBENT,"ORB ARCHIVE PERIOD",ORN,"I")
|
---|
94 | .S XQASUPV=$$GET^XPAR(ORBENT,"ORB FORWARD SUPERVISOR",ORN,"I")
|
---|
95 | .S XQASURO=$$GET^XPAR(ORBENT,"ORB FORWARD SURROGATES",ORN,"I")
|
---|
96 | .S XQAREVUE=$$GET^XPAR(ORBENT,"ORB FORWARD BACKUP REVIEWER",ORN,"I")
|
---|
97 | .S XQACNDEL=$$GET^XPAR(ORBENT,"ORB REMOVE",ORN,"I")
|
---|
98 | .S XQACNDEL=$S(XQACNDEL=1:1,1:"")
|
---|
99 | .I $D(ORBDEV)>1 D REGDEV^ORB31(.ORBDEV)
|
---|
100 | .I $D(ORBSDEV)>1 D REGDEV^ORB31(.ORBSDEV)
|
---|
101 | .I $D(ORBTDEV)>1 D REGDEV^ORB31(.ORBTDEV)
|
---|
102 | .S XQAID=ORBXQAID
|
---|
103 | .I $D(XQA) D SETUP^XQALERT ;if no [new] recips don't send alert
|
---|
104 | QUIT ;
|
---|
105 | K VA,VA200,VADM,VAERR,VAIN,XQA,XQADATA,XQAID,XQAFLG,XQAMSG,XQAROU,XQAARCH,XQASUPV,XQASURO,XQADFN
|
---|
106 | K ^XTMP("ORBUSER",$J)
|
---|
107 | I '$D(ORBU),$D(ORBLOCK) D
|
---|
108 | .I $G(ORBID)]"" LOCK -^XTMP("ORBLOCK",ORBDFN,ORN,ORBID)
|
---|
109 | .E LOCK -^XTMP("ORBLOCK",ORBDFN,ORN)
|
---|
110 | Q
|
---|
111 | PKGDUZS ;get DUZs from pkg-passed ORBADUZ() array
|
---|
112 | N ORBPDUZ
|
---|
113 | I $D(ORBU) D
|
---|
114 | .S ORBU(ORBUI)=" ",ORBUI=ORBUI+1
|
---|
115 | .I ORN=68 S ORBU(ORBUI)="Recipients with Lab Threshold Exceeded:",ORBUI=ORBUI+1
|
---|
116 | .E S ORBU(ORBUI)="Recipients defined when notif was triggered:",ORBUI=ORBUI+1
|
---|
117 | S ORBPDUZ=""
|
---|
118 | F S ORBPDUZ=$O(ORBADUZ(ORBPDUZ)) Q:ORBPDUZ="" S ORBDUZ=ORBPDUZ D USER
|
---|
119 | Q
|
---|
120 | SPECDUZS ;get DUZs rtn by SPECIAL^ORB3SPEC
|
---|
121 | N ORBSDUZ
|
---|
122 | I $D(ORBU) D
|
---|
123 | .S ORBU(ORBUI)=" ",ORBUI=ORBUI+1
|
---|
124 | .S ORBU(ORBUI)="Special recipients associated with the notification:",ORBUI=ORBUI+1
|
---|
125 | S ORBSDUZ=""
|
---|
126 | F S ORBSDUZ=$O(ORBASPEC(ORBSDUZ)) Q:ORBSDUZ="" S ORBDUZ=ORBSDUZ D USER
|
---|
127 | Q
|
---|
128 | TITLE ;get provider recips
|
---|
129 | N TITLES
|
---|
130 | I $D(ORBU) D
|
---|
131 | .S ORBU(ORBUI)=" ",ORBUI=ORBUI+1
|
---|
132 | .S ORBU(ORBUI)="Recipients determined by Provider Recipient parameter:",ORBUI=ORBUI+1
|
---|
133 | ;
|
---|
134 | S TITLES=$$GET^XPAR(ORBENT,"ORB PROVIDER RECIPIENTS",ORN,"I")
|
---|
135 | I TITLES["P" D PRIMARY
|
---|
136 | I TITLES["A" D ATTEND
|
---|
137 | I TITLES["T" D TEAMS
|
---|
138 | I TITLES["O" D ORDERER
|
---|
139 | I TITLES["E" D ENTERBY
|
---|
140 | I TITLES["R" D PCMMPRIM
|
---|
141 | I TITLES["S" D PCMMASSC
|
---|
142 | I TITLES["M" D PCMMTEAM
|
---|
143 | Q
|
---|
144 | PRIMARY ;
|
---|
145 | I $D(ORBU),ORBADT=0 S ORBU(ORBUI)=" Inpt primary provider:",ORBUI=ORBUI+1
|
---|
146 | I $D(ORBU),ORBADT=1 S ORBU(ORBUI)=" Inpt primary provider: option cannot determine without A/D/T event data.",ORBUI=ORBUI+1
|
---|
147 | I +$G(ORBPRIM)>0 S ORBDUZ=ORBPRIM D USER
|
---|
148 | Q
|
---|
149 | ATTEND ;
|
---|
150 | I $D(ORBU),ORBADT=0 S ORBU(ORBUI)=" Attending physician:",ORBUI=ORBUI+1
|
---|
151 | I $D(ORBU),ORBADT=1 S ORBU(ORBUI)=" Attending physician: option cannot determine without A/D/T event data.",ORBUI=ORBUI+1
|
---|
152 | I +$G(ORBATTD)>0 S ORBDUZ=ORBATTD D USER
|
---|
153 | Q
|
---|
154 | TEAMS ;
|
---|
155 | I $D(ORBU) S ORBU(ORBUI)=" Teams/Personal Lists related to patient:",ORBUI=ORBUI+1
|
---|
156 | N ORBLST,ORBI,ORBJ,ORBTM,ORBTNAME,ORBTTYPE,ORBTD
|
---|
157 | D TMSPT^ORQPTQ1(.ORBLST,ORBDFN)
|
---|
158 | Q:+$G(ORBLST(1))<1
|
---|
159 | S ORBI="" F S ORBI=$O(ORBLST(ORBI)) Q:ORBI="" D
|
---|
160 | .S ORBTM=$P(ORBLST(ORBI),U),ORBTNAME=$P(ORBLST(ORBI),U,2)
|
---|
161 | .S ORBTTYPE=$P(ORBLST(ORBI),U,3)
|
---|
162 | .I $D(ORBU) D
|
---|
163 | ..S ORBU(ORBUI)=" Patient list "_ORBTNAME_" ["_ORBTTYPE_"]:",ORBUI=ORBUI+1
|
---|
164 | .N ORBLST2 D TEAMPROV^ORQPTQ1(.ORBLST2,ORBTM)
|
---|
165 | .Q:+$G(ORBLST2(1))<1
|
---|
166 | .S ORBJ="" F S ORBJ=$O(ORBLST2(ORBJ)) Q:ORBJ="" D
|
---|
167 | ..S ORBDUZ=$P(ORBLST2(ORBJ),U)_U_ORBTM I +$G(ORBDUZ)>0 D USER
|
---|
168 | .;
|
---|
169 | .S ORBTD=$P($$TMDEV^ORB31(ORBTM),U,2) ;Team's device
|
---|
170 | .I $L(ORBTD) D
|
---|
171 | ..S ORBTDEV(ORBTD)=""
|
---|
172 | ..I $D(ORBU) D
|
---|
173 | ...S ORBU(ORBUI)=" Team's Device "_ORBTD_" is a recipient",ORBUI=ORBUI+1
|
---|
174 | Q
|
---|
175 | ORDERER ;
|
---|
176 | Q:+$G(ORNUM)<1
|
---|
177 | I $D(ORBU) S ORBU(ORBUI)=" Ordering provider:",ORBUI=ORBUI+1
|
---|
178 | N ORBLST,ORBI,ORBTM,ORBJ,ORBTNAME,ORBPLST,ORBPI,ORBPTM,ORBTTYPE
|
---|
179 | S ORBDUZ=$S(ORN=12:+$$UNSIGNOR^ORQOR2(ORNUM),1:$$ORDERER^ORQOR2(ORNUM))
|
---|
180 | I +$G(ORBDUZ)>0 D
|
---|
181 | .D USER
|
---|
182 | .;if notif = Order Req E/S (#12) or Order Req Co-sign (#37) and
|
---|
183 | .;user doesn't have ES authority, send to fellow team members w/ES:
|
---|
184 | .I ((ORN=12)!(ORN=37)),('$D(^XUSEC("ORES",ORBDUZ))) D
|
---|
185 | ..I $D(ORBU) S ORBU(ORBUI)=" Orderer can't elec sign, getting teams orderer belongs to:",ORBUI=ORBUI+1
|
---|
186 | ..D TEAMPR^ORQPTQ1(.ORBLST,ORBDUZ) ;get orderer's tms
|
---|
187 | ..Q:+$G(ORBLST(1))<1
|
---|
188 | ..D TMSPT^ORQPTQ1(.ORBPLST,ORBDFN) ;get pt's tms
|
---|
189 | ..Q:+$G(ORBPLST(1))<1
|
---|
190 | ..S ORBI="" F S ORBI=$O(ORBLST(ORBI)) Q:ORBI="" D
|
---|
191 | ...S ORBPI="" F S ORBPI=$O(ORBPLST(ORBPI)) Q:ORBPI="" D
|
---|
192 | ....S ORBTM=$P(ORBLST(ORBI),U),ORBPTM=$P(ORBPLST(ORBPI),U)
|
---|
193 | ....I ORBTM=ORBPTM D ;if pt is on provider's team
|
---|
194 | .....I +$G(ORBPTM)>0 D
|
---|
195 | ......S ORBTNAME=$P(ORBPLST(ORBPI),U,2)
|
---|
196 | ......S ORBTTYPE=$P(ORBPLST(ORBPI),U,3)
|
---|
197 | ......I $D(ORBU) S ORBU(ORBUI)=" Orderer's pt list "_ORBTNAME_" ["_ORBTTYPE_"] recipients: ",ORBUI=ORBUI+1
|
---|
198 | ......N ORBLST2 D TEAMPROV^ORQPTQ1(.ORBLST2,ORBPTM)
|
---|
199 | ......Q:+$G(ORBLST2(1))<1
|
---|
200 | ......S ORBJ="" F S ORBJ=$O(ORBLST2(ORBJ)) Q:ORBJ="" D
|
---|
201 | .......S ORBDUZ=$P(ORBLST2(ORBJ),U)_U_ORBPTM I +$G(ORBDUZ)>0,($D(^XUSEC("ORES",+ORBDUZ))) D USER
|
---|
202 | Q
|
---|
203 | ENTERBY ;
|
---|
204 | I $D(ORBU) S ORBU(ORBUI)=" User entering order's most recent activity:",ORBUI=ORBUI+1
|
---|
205 | Q:+$G(ORNUM)<1
|
---|
206 | I $D(^OR(100,ORNUM,8,0)) D
|
---|
207 | .S ORBDUZ=$P(^OR(100,ORNUM,8,$P(^OR(100,ORNUM,8,0),U,3),0),U,13)
|
---|
208 | I +$G(ORBDUZ)>0 D USER
|
---|
209 | Q
|
---|
210 | PCMMPRIM ;
|
---|
211 | I $D(ORBU) S ORBU(ORBUI)=" PCMM Primary Care Practitioner:",ORBUI=ORBUI+1
|
---|
212 | S ORBDUZ=+$$OUTPTPR^SDUTL3(ORBDFN,$$NOW^XLFDT,1) ;DBIA #1252
|
---|
213 | I +$G(ORBDUZ)>0 D USER
|
---|
214 | Q
|
---|
215 | PCMMASSC ;
|
---|
216 | I $D(ORBU) S ORBU(ORBUI)=" PCMM Associate Provider:",ORBUI=ORBUI+1
|
---|
217 | S ORBDUZ=+$$OUTPTAP^SDUTL3(ORBDFN,$$NOW^XLFDT) ;DBIA #1252
|
---|
218 | I +$G(ORBDUZ)>0 D USER
|
---|
219 | Q
|
---|
220 | PCMMTEAM ;
|
---|
221 | N ORPCMM,ORPCMMDZ
|
---|
222 | I $D(ORBU) S ORBU(ORBUI)=" PCMM Team Position Assignments:",ORBUI=ORBUI+1
|
---|
223 | S ORPCMM=$$PRPT^SCAPMC(ORBDFN,,,,,,"^TMP(""ORPCMM"",$J)",) ;DBIA #1916
|
---|
224 | S ORPCMMDZ=0
|
---|
225 | F S ORPCMMDZ=$O(^TMP("ORPCMM",$J,"SCPR",ORPCMMDZ)) Q:'ORPCMMDZ D
|
---|
226 | .S ORBDUZ=ORPCMMDZ D USER
|
---|
227 | K ^TMP("ORPCMM",$J)
|
---|
228 | Q
|
---|
229 | USER ;should USER (ORBDUZ) be a recip
|
---|
230 | D USER^ORB3USER(.XQA,ORBDUZ,ORN,.ORBU,.ORBUI,ORBDFN,+$G(ORNUM))
|
---|
231 | Q
|
---|