1 | PXRMXT ; SLC/PJH - Reminder Reports Template Load ;11/21/2005
|
---|
2 | ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21
|
---|
3 | ;
|
---|
4 | ; Called from PXRMYD,PXRMXD
|
---|
5 | ;
|
---|
6 | ;Select Template
|
---|
7 | ;---------------
|
---|
8 | START N X,Y,CNT,FOUND,PXRMFLD,DIC,MSG
|
---|
9 | K DIROUT,DIRUT,DTOUT,DUOUT
|
---|
10 | S PXRMTMP="",FOUND=0
|
---|
11 | ;
|
---|
12 | ;Check if any templates exist for this report type
|
---|
13 | Q:'$$FIND(PXRMTYP)
|
---|
14 | ;
|
---|
15 | ;Select template required
|
---|
16 | W !
|
---|
17 | S CNT=0,DIC=810.1,DIC(0)="AEQMZ"
|
---|
18 | S DIC("A")="Select an existing REPORT TEMPLATE or return to continue: "
|
---|
19 | S DIC("S")="I $P(^PXRMPT(810.1,+Y,0),U,3)=PXRMTYP"
|
---|
20 | D ^DIC
|
---|
21 | I X=(U_U) S DTOUT=1
|
---|
22 | I '$D(DTOUT),('$D(DUOUT)) D
|
---|
23 | .I +Y'=-1 D Q
|
---|
24 | ..S CNT=CNT+1,ARRAY(CNT)=Y_U_Y(0,0)_U_$P(Y(0),U,3)
|
---|
25 | K DIC
|
---|
26 | ;
|
---|
27 | ;Load template into local array
|
---|
28 | I (+Y'=-1)&('$D(DTOUT))&('$D(DUOUT)) D
|
---|
29 | .L +^PXRMPT(810.1,$P(Y,U)):0
|
---|
30 | .E W !!?5,"Another user is editing this entry." S DUOUT=1 Q
|
---|
31 | .;Load template into an array
|
---|
32 | .S PXRMTMP=Y_U_$P(Y(0),U,2) D LOAD
|
---|
33 | .L -^PXRMPT(810.1,$P(PXRMTMP,U))
|
---|
34 | .;Exit if problem loading template
|
---|
35 | .I $D(MSG) S DTOUT=1 Q
|
---|
36 | .;Display Template information
|
---|
37 | .D:'$D(MSG) ^PXRMXTD
|
---|
38 | ;
|
---|
39 | EXIT Q
|
---|
40 | ;
|
---|
41 | ;Check if any templates exist for this report type
|
---|
42 | ;-------------------------------------------------
|
---|
43 | FIND(TYP) ;
|
---|
44 | N SUB,FOUND
|
---|
45 | S SUB=0,FOUND=0
|
---|
46 | F S SUB=$O(^PXRMPT(810.1,SUB)) Q:'SUB D Q:FOUND
|
---|
47 | .I $P($G(^PXRMPT(810.1,SUB,0)),U,3)=TYP S FOUND=1
|
---|
48 | Q FOUND
|
---|
49 | ;
|
---|
50 | ;
|
---|
51 | ;Load variables from report template (both INT and EXT)
|
---|
52 | ;------------------------------------------------------
|
---|
53 | LOAD N ARRAY
|
---|
54 | D GETS^DIQ(810.1,$P(PXRMTMP,U),"**","IE","ARRAY","MSG")
|
---|
55 | I $D(MSG) D Q
|
---|
56 | .W !!,"File read failed, GETS^DIQ returned the following error message:"
|
---|
57 | .N IC S IC="MSG"
|
---|
58 | .F S IC=$Q(@IC) Q:IC="" W !,IC,"=",@IC
|
---|
59 | .W !,"Examine the above error message for the reason.",!
|
---|
60 | .H 2
|
---|
61 | ;
|
---|
62 | N MREF,ORDER,ORDERC,SUB,SUB1,XREF
|
---|
63 | ;
|
---|
64 | S SUB1=$O(ARRAY(810.1,""))
|
---|
65 | D XREF^PXRMXTB
|
---|
66 | S SUB="" F S SUB=$O(XREF(SUB)) Q:SUB="" D
|
---|
67 | .S @SUB=$G(ARRAY(810.1,SUB1,XREF(SUB),"I"))
|
---|
68 | ;
|
---|
69 | S PXRMFLD=$G(ARRAY(810.1,SUB1,XREF("PXRMSEL"),"E"))
|
---|
70 | S RUN=$G(ARRAY(810.1,SUB1,XREF("RUN"),"E"))
|
---|
71 | ;Update name if template has been renamed
|
---|
72 | S $P(PXRMTMP,U,2)=$G(ARRAY(810.1,SUB1,XREF("NAME"),"E"))
|
---|
73 | S TITLE=$G(ARRAY(810.1,SUB1,XREF("TITLE"),"E")),$P(PXRMTMP,U,3)=TITLE
|
---|
74 | ;
|
---|
75 | MULT ;Clear multiple field arrays
|
---|
76 | K PXRMREM,PXRMPAT,PXRMPRV,PXRMOTM,PXRMFAC,PXRMLCHL,PXRMCS,PXRMCGRP
|
---|
77 | K PXRMFACN,PXRMCSN,PXRMCGRN,PXRMRCAT,REMINDER
|
---|
78 | ;
|
---|
79 | ;Load Multiple fields
|
---|
80 | D SUB(.PXRMREM,810.12,"REMINDER",1)
|
---|
81 | ;Load Patients
|
---|
82 | D SUB(.PXRMPAT,810.16,"PATIENT",1)
|
---|
83 | ;Load Providers
|
---|
84 | D SUB(.PXRMPRV,810.14,"PROVIDER",1)
|
---|
85 | ;Load OE/RR Teams
|
---|
86 | D SUB(.PXRMOTM,810.17,"OERR TEAM",1)
|
---|
87 | ;Load PCMM Teams
|
---|
88 | D SUB(.PXRMPCM,810.18,"PCMM TEAM",1)
|
---|
89 | ;Load Facility codes
|
---|
90 | D SUB(.PXRMFAC,810.13,"FACILITY",1)
|
---|
91 | ;Load Hospital Location codes
|
---|
92 | D SUB(.PXRMLCHL,810.11,"LOCATION",2)
|
---|
93 | ;Load Clinic Stop codes
|
---|
94 | D SUB(.PXRMCS,810.111,"STOP CODE",2)
|
---|
95 | ;Load Clinic Groups
|
---|
96 | D SUB(.PXRMCGRP,810.112,"CLINIC GROUP",1)
|
---|
97 | ;Load Reminder Categories
|
---|
98 | D SUB(.PXRMRCAT,810.113,"REMINDER CATEGORY",1)
|
---|
99 | ;Load Patient lists
|
---|
100 | D SUB(.PXRMLIST,810.114,"PXRMLIST",1)
|
---|
101 | ;
|
---|
102 | ;Build PXRMFACN/PXRMLOCN array IEN's and counters NHL/NFAC
|
---|
103 | D NUM
|
---|
104 | ;
|
---|
105 | ;Build Service Category array
|
---|
106 | I $L(PXRMSCAT)>0 F IC=1:1:$L(PXRMSCAT,",") S PXRMSCAT($P(PXRMSCAT,",",IC))=""
|
---|
107 | ;
|
---|
108 | ;Add Descriptions for Reminders
|
---|
109 | D DES(.PXRMREM,"^PXD(811.9",4)
|
---|
110 | ;Add Descriptions for Reminder Categories
|
---|
111 | D DES(.PXRMRCAT,"^PXRMD(811.7",4)
|
---|
112 | ;Add Descriptions for Teams
|
---|
113 | D DES(.PXRMOTM,"^OR(100.21",3)
|
---|
114 | ;Add Display Codes for Stops
|
---|
115 | D CODE(.PXRMCS,"^DIC(40.7",3)
|
---|
116 | ;
|
---|
117 | ;Sort Reminders into display order
|
---|
118 | D SORT(.PXRMREM,.ORDER)
|
---|
119 | ;Sort Reminders categories into display order
|
---|
120 | D SORT(.PXRMRCAT,.ORDERC)
|
---|
121 | ;
|
---|
122 | ;Combine individual reminders and category reminders
|
---|
123 | D MERGE^PXRMXS1
|
---|
124 | Q
|
---|
125 | ;
|
---|
126 | ;
|
---|
127 | ;Extract INTernal and EXTernal format from ARRAY
|
---|
128 | ;-----------------------------------------------
|
---|
129 | SUB(OUTPUT,SUB,VAR,ORD) ;
|
---|
130 | K OUTPUT
|
---|
131 | N IC,INT,EXT,SUB1,DISP
|
---|
132 | S SUB1="",IC=0
|
---|
133 | F S SUB1=$O(ARRAY(SUB,SUB1)) Q:SUB1="" D
|
---|
134 | .S INT=$P($G(ARRAY(SUB,SUB1,MREF(VAR),"I")),";")
|
---|
135 | .S EXT=$G(ARRAY(SUB,SUB1,MREF(VAR),"E"))
|
---|
136 | .S IC=IC+1
|
---|
137 | .I ORD=1 S OUTPUT(IC)=INT_U_EXT
|
---|
138 | .I ORD'=1 S OUTPUT(IC)=EXT_U_INT
|
---|
139 | .I (VAR'="REMINDER")&(VAR'="REMINDER CATEGORY") Q
|
---|
140 | .;Get display order
|
---|
141 | .S DISP=$G(ARRAY(SUB,SUB1,MREF("DISPLAY ORDER"),"I"))
|
---|
142 | .;Store in PXRMREM for display
|
---|
143 | .S OUTPUT(IC)=OUTPUT(IC)_U_DISP
|
---|
144 | .;Put reminders with no sequence number last
|
---|
145 | .I DISP="" S DISP=99
|
---|
146 | .;Create order array for sorting entries later
|
---|
147 | .I VAR="REMINDER" S ORDER(DISP,IC)=""
|
---|
148 | .I VAR="REMINDER CATEGORY" S ORDERC(DISP,IC)=""
|
---|
149 | Q
|
---|
150 | ;
|
---|
151 | ;Build array PXRMFACN and NFAC
|
---|
152 | ;-----------------------------
|
---|
153 | NUM N IC,FACN,FACNAM
|
---|
154 | K PXRMLOCN,PXRMCSN,PXRMCGRN,PXRMFACN
|
---|
155 | S IC=""
|
---|
156 | F S IC=$O(PXRMFAC(IC)) Q:IC="" D
|
---|
157 | .S FACN=$P(PXRMFAC(IC),U),FACNAM=$P(PXRMFAC(IC),U,2)
|
---|
158 | .S PXRMFACN(FACN)=FACNAM_U_FACN,NFAC=IC
|
---|
159 | ; Build Array PXRMLOCN and NHL
|
---|
160 | N LOCN
|
---|
161 | F S IC=$O(PXRMLCHL(IC)) Q:IC="" D
|
---|
162 | .S LOCN=$P(PXRMLCHL(IC),U,2)
|
---|
163 | .S PXRMLOCN(LOCN)=IC,NHL=IC
|
---|
164 | ; Build Array PXRMCSN and NCS
|
---|
165 | N CSN
|
---|
166 | F S IC=$O(PXRMCS(IC)) Q:IC="" D
|
---|
167 | .S CSN=$P(PXRMCS(IC),U,2)
|
---|
168 | .S PXRMCSN(CSN)=IC,NCS=IC
|
---|
169 | ; Build Array PXRMCGRN and NCGRP
|
---|
170 | N GRPN
|
---|
171 | F S IC=$O(PXRMCGRP(IC)) Q:IC="" D
|
---|
172 | .S GRPN=$P(PXRMCGRP(IC),U,1)
|
---|
173 | .S PXRMCGRN(GRPN)=IC,NCGRP=IC
|
---|
174 | Q
|
---|
175 | ;
|
---|
176 | ;Add print name to OUTPUT array
|
---|
177 | ;-------------------------------
|
---|
178 | DES(OUTPUT,GLOB,POSN) ;
|
---|
179 | N IC,IEN,DES
|
---|
180 | S IC=""
|
---|
181 | F S IC=$O(OUTPUT(IC)) Q:IC="" D
|
---|
182 | .S IEN=$P(OUTPUT(IC),U,1)
|
---|
183 | .X "S DES=$P($G("_GLOB_",IEN,0)),U,3)"
|
---|
184 | .S $P(OUTPUT(IC),U,POSN)=DES
|
---|
185 | Q
|
---|
186 | ;
|
---|
187 | ;Add stop code to OUTPUT array
|
---|
188 | ;-------------------------------
|
---|
189 | CODE(OUTPUT,GLOB,POSN) ;
|
---|
190 | N IC,IEN,CODE
|
---|
191 | S IC=""
|
---|
192 | F S IC=$O(OUTPUT(IC)) Q:IC="" D
|
---|
193 | .S IEN=$P(OUTPUT(IC),U,2)
|
---|
194 | .X "S CODE=$P($G("_GLOB_",IEN,0)),U,2)"
|
---|
195 | .S $P(OUTPUT(IC),U,POSN)=CODE
|
---|
196 | Q
|
---|
197 | ;
|
---|
198 | ;Sort reminders into display order (allow for duplicates)
|
---|
199 | ;--------------------------------------------------------
|
---|
200 | SORT(INPUT,ORDER) ;
|
---|
201 | N IC,DISP,OUTPUT,IC1
|
---|
202 | S DISP="",IC1=0
|
---|
203 | F S DISP=$O(ORDER(DISP)) Q:DISP="" D
|
---|
204 | .S IC=""
|
---|
205 | .F S IC=$O(ORDER(DISP,IC)) Q:IC="" D
|
---|
206 | ..S IC1=IC1+1,OUTPUT(IC1)=INPUT(IC)
|
---|
207 | ; Move results back
|
---|
208 | K INPUT M INPUT=OUTPUT
|
---|
209 | Q
|
---|