1 | SCDXMSG1 ;ALB/JRP - AMB CARE MESSAGE BUILDER UTILS;08-MAY-1996 ; 6/21/05 2:08pm
|
---|
2 | ;;5.3;Scheduling;**44,55,70,77,85,66,143,142,162,172,180,239,245,254,293,325,387,459,472**;AUG 13, 1993
|
---|
3 | ;
|
---|
4 | ;-- Line tags for building HL7 segment
|
---|
5 | BLDEVN S VAFEVN=$$EN^VAFHLEVN(EVNTHL7,ENCNDT,VAFSTR,HL("Q"),HL("FS"))
|
---|
6 | ;SD*5.3*387 replaced EVNTDATE with ENCNDT
|
---|
7 | Q
|
---|
8 | BLDPID S VAFPID=$$EN^VAFHLPID(DFN,VAFSTR)
|
---|
9 | D SETMAR^SCMSVUT0(.VAFPID,HL("Q"),HL("FS"))
|
---|
10 | Q
|
---|
11 | BLDZPD S VAFZPD=$$EN1^VAFHLZPD(DFN,VAFSTR)
|
---|
12 | D SETPOW^SCMSVUT0(DFN,.VAFZPD,HL("Q"),HL("FS"))
|
---|
13 | Q
|
---|
14 | BLDPV1 D SETID^SCMSVUT0(ENCPTR,DELPTR)
|
---|
15 | S VAFPV1=$$EN^VAFHLPV1(ENCPTR,DELPTR,VAFSTR,1,HL("Q"),HL("FS"))
|
---|
16 | Q
|
---|
17 | BLDDG1 K @VAFARRY
|
---|
18 | D EN^VAFHLDG1(ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
---|
19 | Q
|
---|
20 | BLDPR1 K @VAFARRY
|
---|
21 | D SETPRTY^SCMSVUT0(ENCPTR)
|
---|
22 | D EN^VAFHLPR1(ENCPTR,VAFSTR,HL("Q"),HL("FS"),HL("ECH"),VAFARRY)
|
---|
23 | Q
|
---|
24 | BLDZEL N ELCOD,ELIGENC,I,VAFMSTDT
|
---|
25 | S VAFMSTDT=ENCDT
|
---|
26 | D EN1^VAFHLZEL(DFN,VAFSTR,1,.VAFZEL)
|
---|
27 | S ELCOD=$P($G(^SCE(ENCPTR,0)),"^",13),ELIGENC=$P($G(^DIC(8,+ELCOD,0)),"^",9)
|
---|
28 | S $P(VAFZEL(1),HL("FS"),3)=ELIGENC
|
---|
29 | Q
|
---|
30 | BLDZIR K DGREL,DGINC,DGINR,DGDEP
|
---|
31 | D ALL^DGMTU21(DFN,"V",ENCDT,"R")
|
---|
32 | S VAFZIR=$$EN^VAFHLZIR(+$G(DGINR("V")),VAFSTR,1,ENCPTR)
|
---|
33 | K DGREL,DGINC,DGINR,DGDEP
|
---|
34 | Q
|
---|
35 | BLDZCL K @VAFARRY
|
---|
36 | D EN^VAFHLZCL(DFN,ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
---|
37 | Q
|
---|
38 | BLDZSC K @VAFARRY
|
---|
39 | D EN^VAFHLZSC(ENCPTR,VAFSTR,HL("Q"),HL("FS"),VAFARRY)
|
---|
40 | Q
|
---|
41 | BLDZSP S VAFZSP=$$EN^VAFHLZSP(DFN,1,1)
|
---|
42 | S VAFZSP=$$SETVSI^SCMSVUT0(DFN,$G(VAFZSP),HL("Q"),HL("FS"))
|
---|
43 | Q
|
---|
44 | BLDROL K @VAFARRY
|
---|
45 | N SCDXPRV,SCDXPAR,SCDXROL,PTRPRV,NODE,PRVNUM,TMP
|
---|
46 | D GETPRV^SDOE(ENCPTR,"SCDXPRV")
|
---|
47 | S PTRPRV=0
|
---|
48 | F PRVNUM=1:1 S PTRPRV=+$O(SCDXPRV(PTRPRV)) Q:('PTRPRV) D
|
---|
49 | .K SCDXPAR,SCDXROL
|
---|
50 | .S NODE=SCDXPRV(PTRPRV)
|
---|
51 | .S SCDXPAR("PTR200")=+NODE
|
---|
52 | .S SCDXPAR("INSTID")=$$VID4XMIT^SCDXFU11(XMITPTR)_"-"_(+NODE)_"*"_PRVNUM
|
---|
53 | .S SCDXPAR("ACTION")="CO"
|
---|
54 | .S SCDXPAR("ALTROLE")=($TR($P(NODE,"^",4),"PS","10"))_$E(HL("ECH"),1)_HL("Q")_$E(HL("ECH"),1)_"VA01"
|
---|
55 | .S SCDXPAR("CODEONLY")=0
|
---|
56 | .S SCDXPAR("RDATE")=ENCDT
|
---|
57 | .D OUTPAT^VAFHLROL("SCDXPAR","SCDXROL",VAFSTR,HL("FS"),HL("ECH"),HL("Q"),240)
|
---|
58 | .K SCDXROL("ERROR"),SCDXROL("WARNING")
|
---|
59 | .M @VAFARRY@(PRVNUM)=SCDXROL
|
---|
60 | Q
|
---|
61 | BLDPD1 S VAFPD1=$$EN^VAFHLPD1(DFN,VAFSTR)
|
---|
62 | Q
|
---|
63 | BLDZEN S VAFZEN=$$EN^VAFHLZEN(DFN,VAFSTR,1,HL("Q"),HL("FS"))
|
---|
64 | Q
|
---|
65 | ;
|
---|
66 | ;-- Line tags for validating HL7 segments
|
---|
67 | VLDEVN S ERROR=$$EN^SCMSVEVN(VAFEVN,HL("Q"),HL("FS"),VALERR)
|
---|
68 | S:(ERROR>0) ERROR=0
|
---|
69 | Q
|
---|
70 | VLDPID S ERROR=$$EN^SCMSVPID(.VAFPID,HL("Q"),HL("FS"),HL("ECH"),VALERR,ENCDT,EVNTHL7)
|
---|
71 | S:(ERROR>0) ERROR=0
|
---|
72 | Q
|
---|
73 | VLDZPD S ERROR=$$EN^SCMSVZPD(.VAFZPD,HL("Q"),HL("FS"),VALERR,ENCDT,NODE)
|
---|
74 | S:(ERROR>0) ERROR=0
|
---|
75 | Q
|
---|
76 | VLDPV1 S ERROR=$$EN^SCMSVPV1(VAFPV1,HL("Q"),HL("FS"),VALERR,NODE,EVNTHL7,ENCNDT)
|
---|
77 | S:(ERROR>0) ERROR=0
|
---|
78 | Q
|
---|
79 | VLDDG1 S ERROR=$$EN^SCMSVDG1(VAFARRY,HL("Q"),HL("FS"),ENCPTR,VALERR,ENCDT)
|
---|
80 | S:(ERROR>0) ERROR=0
|
---|
81 | Q
|
---|
82 | VLDPR1 S ERROR=$$EN^SCMSVPR1(VAFARRY,HL("Q"),HL("FS"),HL("ECH"),VALERR,ENCDT)
|
---|
83 | S:(ERROR>0) ERROR=0
|
---|
84 | Q
|
---|
85 | VLDZEL S ERROR=$$EN^SCMSVZEL(.VAFZEL,HL("Q"),HL("FS"),VALERR,DFN)
|
---|
86 | S:(ERROR>0) ERROR=0
|
---|
87 | Q
|
---|
88 | VLDZIR S ERROR=$$EN^SCMSVZIR(VAFZIR,HL("Q"),HL("FS"),VALERR)
|
---|
89 | S:(ERROR>0) ERROR=0
|
---|
90 | Q
|
---|
91 | VLDZCL S ERROR=$$EN^SCMSVZCL(VAFARRY,HL("Q"),HL("FS"),VALERR,DFN)
|
---|
92 | S:(ERROR>0) ERROR=0
|
---|
93 | Q
|
---|
94 | VLDZSC S ERROR=$$EN^SCMSVZSC(VAFARRY,HL("Q"),HL("FS"),VALERR,ENCPTR)
|
---|
95 | S:(ERROR>0) ERROR=0
|
---|
96 | Q
|
---|
97 | VLDZSP S ERROR=$$EN^SCMSVZSP(VAFZSP,HL("Q"),HL("FS"),VALERR,DFN)
|
---|
98 | S:(ERROR>0) ERROR=0
|
---|
99 | Q
|
---|
100 | VLDROL S ERROR=$$EN^SCMSVROL(VAFARRY,HL("Q"),HL("FS"),HL("ECH"),VALERR)
|
---|
101 | S:(ERROR>0) ERROR=0
|
---|
102 | Q
|
---|
103 | VLDPD1 S ERROR=0
|
---|
104 | Q
|
---|
105 | VLDZEN S ERROR=0
|
---|
106 | Q
|
---|
107 | ;
|
---|
108 | ;-- Line tags for copying HL7 segments into HL7 message
|
---|
109 | CPYEVN N I
|
---|
110 | S @XMITARRY@(CURLINE)=VAFEVN
|
---|
111 | S LINESADD=LINESADD+1
|
---|
112 | S I=""
|
---|
113 | F S I=+$O(VAFEVN(I)) Q:('I) D
|
---|
114 | .S @XMITARRY@(CURLINE,I)=VAFEVN(I)
|
---|
115 | .S LINESADD=LINESADD+1
|
---|
116 | Q
|
---|
117 | CPYPID N I
|
---|
118 | S @XMITARRY@(CURLINE)=VAFPID
|
---|
119 | S LINESADD=LINESADD+1
|
---|
120 | S I=""
|
---|
121 | F S I=+$O(VAFPID(I)) Q:('I) D
|
---|
122 | .S @XMITARRY@(CURLINE,I)=VAFPID(I)
|
---|
123 | .S LINESADD=LINESADD+1
|
---|
124 | Q
|
---|
125 | CPYZPD N I
|
---|
126 | S @XMITARRY@(CURLINE)=VAFZPD
|
---|
127 | S LINESADD=LINESADD+1
|
---|
128 | S I=""
|
---|
129 | F S I=+$O(VAFZPD(I)) Q:('I) D
|
---|
130 | .S @XMITARRY@(CURLINE,I)=VAFZPD(I)
|
---|
131 | .S LINESADD=LINESADD+1
|
---|
132 | Q
|
---|
133 | CPYPV1 N I
|
---|
134 | S @XMITARRY@(CURLINE)=VAFPV1
|
---|
135 | S LINESADD=LINESADD+1
|
---|
136 | S I=""
|
---|
137 | F S I=+$O(VAFPV1(I)) Q:('I) D
|
---|
138 | .S @XMITARRY@(CURLINE,I)=VAFPV1(I)
|
---|
139 | .S LINESADD=LINESADD+1
|
---|
140 | Q
|
---|
141 | CPYDG1 N I,J,K
|
---|
142 | S I=""
|
---|
143 | F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
---|
144 | .S J=""
|
---|
145 | .F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
---|
146 | ..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
---|
147 | ..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
---|
148 | ..S LINESADD=LINESADD+1
|
---|
149 | S CURLINE=CURLINE+K-1
|
---|
150 | Q
|
---|
151 | CPYPR1 N I,J,K
|
---|
152 | S I=""
|
---|
153 | F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
---|
154 | .S J=""
|
---|
155 | .F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
---|
156 | ..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
---|
157 | ..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
---|
158 | ..S LINESADD=LINESADD+1
|
---|
159 | S CURLINE=CURLINE+K-1
|
---|
160 | Q
|
---|
161 | CPYZEL N I
|
---|
162 | S @XMITARRY@(CURLINE)=VAFZEL(1)
|
---|
163 | S LINESADD=LINESADD+1
|
---|
164 | S I=""
|
---|
165 | F S I=+$O(VAFZEL(1,I)) Q:('I) D
|
---|
166 | .S @XMITARRY@(CURLINE,I)=VAFZEL(1,I)
|
---|
167 | .S LINESADD=LINESADD+1
|
---|
168 | Q
|
---|
169 | CPYZIR N I
|
---|
170 | S @XMITARRY@(CURLINE)=VAFZIR
|
---|
171 | S LINESADD=LINESADD+1
|
---|
172 | N I
|
---|
173 | S I=""
|
---|
174 | F S I=+$O(VAFZIR(I)) Q:('I) D
|
---|
175 | .S @XMITARRY@(CURLINE,I)=VAFZIR(I)
|
---|
176 | .S LINESADD=LINESADD+1
|
---|
177 | Q
|
---|
178 | CPYZCL N I,J,K
|
---|
179 | S I=""
|
---|
180 | F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
---|
181 | .S J=""
|
---|
182 | .F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
---|
183 | ..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
---|
184 | ..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
---|
185 | ..S LINESADD=LINESADD+1
|
---|
186 | S CURLINE=CURLINE+K-1
|
---|
187 | Q
|
---|
188 | CPYZSC N I,J,K
|
---|
189 | S I=""
|
---|
190 | F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
---|
191 | .S J=""
|
---|
192 | .F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
---|
193 | ..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
---|
194 | ..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
---|
195 | ..S LINESADD=LINESADD+1
|
---|
196 | S CURLINE=CURLINE+K-1
|
---|
197 | Q
|
---|
198 | CPYZSP N I
|
---|
199 | S @XMITARRY@(CURLINE)=VAFZSP
|
---|
200 | S LINESADD=LINESADD+1
|
---|
201 | S I=""
|
---|
202 | F S I=+$O(VAFZSP(I)) Q:('I) D
|
---|
203 | .S @XMITARRY@(CURLINE,I)=VAFZSP(I)
|
---|
204 | .S LINESADD=LINESADD+1
|
---|
205 | Q
|
---|
206 | CPYROL N I,J,K
|
---|
207 | S I=""
|
---|
208 | F K=0:1 S I=+$O(@VAFARRY@(I)) Q:('I) D
|
---|
209 | .S J=""
|
---|
210 | .F S J=$O(@VAFARRY@(I,J)) Q:(J="") D
|
---|
211 | ..S:('J) @XMITARRY@(CURLINE+K)=@VAFARRY@(I,J)
|
---|
212 | ..S:(J) @XMITARRY@(CURLINE+K,J)=@VAFARRY@(I,J)
|
---|
213 | ..S LINESADD=LINESADD+1
|
---|
214 | S CURLINE=CURLINE+K-1
|
---|
215 | Q
|
---|
216 | CPYPD1 N I
|
---|
217 | S @XMITARRY@(CURLINE)=VAFPD1
|
---|
218 | S LINESADD=LINESADD+1
|
---|
219 | S I=""
|
---|
220 | F S I=+$O(VAFPD1(I)) Q:('I) D
|
---|
221 | .S @XMITARRY@(CURLINE,I)=VAFPD1(I)
|
---|
222 | .S LINESADD=LINESADD+1
|
---|
223 | Q
|
---|
224 | CPYZEN N I
|
---|
225 | S @XMITARRY@(CURLINE)=VAFZEN
|
---|
226 | S LINESADD=LINESADD+1
|
---|
227 | S I=""
|
---|
228 | F S I=+$O(VAFZEN(I)) Q:('I) D
|
---|
229 | .S @XMITARRY@(CURLINE,I)=VAFZEN(I)
|
---|
230 | .S LINESADD=LINESADD+1
|
---|
231 | Q
|
---|
232 | ;
|
---|
233 | ;-- Line tags for deleting HL7 segments
|
---|
234 | DELEVN K VAFEVN
|
---|
235 | Q
|
---|
236 | DELPID K VAFPID
|
---|
237 | Q
|
---|
238 | DELZPD K VAFZPD
|
---|
239 | Q
|
---|
240 | DELPV1 K VAFPV1
|
---|
241 | Q
|
---|
242 | DELDG1 K @VAFARRY
|
---|
243 | Q
|
---|
244 | DELPR1 K @VAFARRY
|
---|
245 | Q
|
---|
246 | DELZEL K VAFZEL
|
---|
247 | Q
|
---|
248 | DELZIR K VAFZIR
|
---|
249 | Q
|
---|
250 | DELZCL K @VAFARRY
|
---|
251 | Q
|
---|
252 | DELZSC K @VAFARRY
|
---|
253 | Q
|
---|
254 | DELZSP K VAFZSP
|
---|
255 | Q
|
---|
256 | DELROL K @VAFARRY
|
---|
257 | Q
|
---|
258 | DELPD1 K VAFPD1
|
---|
259 | Q
|
---|
260 | DELZEN K VAFZEN
|
---|
261 | Q
|
---|
262 | ;
|
---|
263 | ;
|
---|
264 | SEGMENTS(EVNTTYPE,SEGARRY) ;Build list of HL7 segments for a given
|
---|
265 | ; event type
|
---|
266 | ;
|
---|
267 | ;Input : EVNTTYPE - Event type to build list for
|
---|
268 | ; A08 & A23 are the only types currently supported
|
---|
269 | ; (Defaults to A08)
|
---|
270 | ; SEGARRY - Array to place output in (full global reference)
|
---|
271 | ; (Defaults to ^TMP("SCDX SEGMENTS",$J))
|
---|
272 | ;Output : None
|
---|
273 | ; SEGARRY(Seq,Name) = Fields
|
---|
274 | ; Seq - Sequencing number to order the segments as
|
---|
275 | ; they should be placed in the HL7 message
|
---|
276 | ; Name - Name of HL7 segment
|
---|
277 | ; Fields - List of fields used by Ambulatory Care
|
---|
278 | ; VAFSTR would be set to this value
|
---|
279 | ; : MSH segment is not included
|
---|
280 | ;
|
---|
281 | ;Check input
|
---|
282 | S EVNTTYPE=$G(EVNTTYPE)
|
---|
283 | S:(EVNTTYPE'="A23") EVNTTYPE="A08"
|
---|
284 | S SEGARRY=$G(SEGARRY)
|
---|
285 | S:(SEGARRY="") SEGARRY="^TMP(""SCDX SEGMENTS"","_$J_")"
|
---|
286 | ;Segments used by A08 & A23
|
---|
287 | S @SEGARRY@(1,"EVN")="1,2"
|
---|
288 | S @SEGARRY@(2,"PID")="1,2,3,4,5,6,7,8,10N,11PC,13,14,16,17,19,22N"
|
---|
289 | S @SEGARRY@(3,"PD1")="3,4"
|
---|
290 | S @SEGARRY@(4,"PV1")="1,2,4,14,19,39,44,50"
|
---|
291 | ;Building list for A23 - add ZPD segment and quit
|
---|
292 | I (EVNTTYPE="A23") D Q
|
---|
293 | .S @SEGARRY@(5,"ZPD")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,40"
|
---|
294 | S @SEGARRY@(5,"DG1")="1,2,3,4,5,15"
|
---|
295 | S @SEGARRY@(6,"PR1")="1,3,16"
|
---|
296 | S @SEGARRY@(7,"ROL")="1,2,3,4"
|
---|
297 | S @SEGARRY@(8,"ZPD")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,40"
|
---|
298 | S @SEGARRY@(9,"ZEL")="1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,29,37,38"
|
---|
299 | S @SEGARRY@(10,"ZIR")="1,2,3,4,5,6,7,8,9,10,11,12,13"
|
---|
300 | S @SEGARRY@(11,"ZCL")="1,2,3"
|
---|
301 | S @SEGARRY@(12,"ZSC")="1,2,3"
|
---|
302 | S @SEGARRY@(13,"ZSP")="1,2,3,4"
|
---|
303 | S @SEGARRY@(14,"ZEN")="1,2,3,4,5,6,7,8,9,10"
|
---|
304 | Q
|
---|
305 | ;
|
---|
306 | UNWIND(XMITARRY,INSRTPNT) ;Remove all data that was put into HL7 message
|
---|
307 | ;
|
---|
308 | ;Input : XMITARRY - Array containing HL7 message (full global ref)
|
---|
309 | ; (Defaults to ^TMP("HLS",$J))
|
---|
310 | ; INSRTPNT - Where to begin deletion from (Defaults to 1)
|
---|
311 | ;Output : None
|
---|
312 | ;
|
---|
313 | ;Check input
|
---|
314 | S XMITARRY=$G(XMITARRY)
|
---|
315 | S:(XMITARRY="") XMITARRY="^TMP(""HLS"","_$J_")"
|
---|
316 | S INSRTPNT=$G(INSRTPNT)
|
---|
317 | S:(INSRTPNT="") INSRTPNT=1
|
---|
318 | ;Remove insertion point from array
|
---|
319 | K @XMITARRY@(INSRTPNT)
|
---|
320 | ;Remove everything from insertion point to end of array
|
---|
321 | F S INSRTPNT=$O(@XMITARRY@(INSRTPNT)) Q:(INSRTPNT="") K @XMITARRY@(INSRTPNT)
|
---|
322 | ;Done
|
---|
323 | Q
|
---|