source: WorldVistAEHR/trunk/r/CLINICAL_REMINDERS-PXRM/PXRMXD.m@ 701

Last change on this file since 701 was 623, checked in by George Lilly, 15 years ago

revised back to 6/30/08 version

File size: 8.9 KB
Line 
1PXRMXD ; SLC/PJH - Reminder Due reports DRIVER ;06/20/2006
2 ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21
3 ;
4START ; Arrays and strings
5 N PXRMIOD,PXRMXST,PXRMOPT,PXRMQUE,PXRMXTMP,PXRMSEL
6 N PXRMFAC,PXRMFACN,PXRMSCAT,PXRMSRT,PXRMTYP
7 N REMINDER,PXRMINP,PXRMFCMB,PXRMLCMB,PXRMTCMB,PXRMTOT
8 ; Addenda
9 N PXRMOTM,PXRMPAT,PXRMPCM,PXRMPRV,PXRMTMP,PXRMRCAT,PXRMREM
10 N PXRMCS,PXRMCSN,PXRMLOCN,PXRMLCHL,PXRMLCSC,PXRMCGRP,PXRMCGRN
11 N PXRMLIS
12 ; Counters
13 N NCAT,NFAC,NLOC,NPAT,NPCM,NOTM,NPRV,NREM,NCS,NHL,NCGRP
14 ; Flags and Dates
15 N PXRMFD,PXRMSDT,PXRMBDT,PXRMEDT,PXRMREP,PXRMPRIM,PXRMFUT,PXRMDLOC
16 N PXRMRT,PXRMSSN,PXRMTABC,PXRMTABS,PXRMTMP,TITLE,VALUE
17 N DBDOWN,DBDUZ,DBERR,PXRMLIST,PXRMLIS1,Y
18 N PLISTPUG
19 N PXRMTPAT,PXRMDPAT
20 ;
21 S PXRMRT="PXRMX",PXRMTYP="X",PXRMFCMB="N",PXRMLCMB="N",PXRMTCMB="N"
22 ;
23 I '$D(PXRMUSER) N PXRMUSER S PXRMUSER=0
24 ;
25 ;Guarantee the timestamp is unique.
26 H 1
27 S PXRMXST=$$NOW^XLFDT
28 S PXRMXTMP=PXRMRT_PXRMXST
29 S ^XTMP(PXRMXTMP,0)=$$FMADD^XLFDT(DT,7)_U_DT_U_"PXRM Reminder Due Report"
30 ;
31 ;Check for existing report templates
32REP ;
33 S PXRMINP=0
34 D:PXRMUSER ^PXRMXTB D:'PXRMUSER ^PXRMXT I $D(DTOUT)!$D(DUOUT) G EXIT
35 ;Run report from template details
36 I PXRMTMP'="" D G:$D(DUOUT)&'$D(DTOUT) REP Q
37 .D START^PXRMXTA("JOB^PXRMXQUE") K DUOUT,DIRUT,DTOUT
38 ;
39 ;Select sample criteria
40SEL ;
41 D SELECT^PXRMXSD(.PXRMSEL) I $D(DTOUT) G EXIT
42 I $D(DUOUT) G:PXRMTMP="" EXIT G REP
43 ;
44FAC ;Get the facility list.
45 I "IRPO"'[PXRMSEL D G:$D(DTOUT) EXIT G:$D(DUOUT) SEL
46 .D FACILITY^PXRMXSU(.PXRMFAC) Q:$D(DTOUT)!$D(DUOUT)
47 ;
48 ;Check if combined facility report is required
49COMB I "IRPO"'[PXRMSEL,NFAC>1 D G:$D(DTOUT) EXIT G:$D(DUOUT) FAC
50 .D COMB^PXRMXSD(.PXRMFCMB,"Facilities","N")
51 ;
52OPT ;Variable prompts
53 ;
54 ;Get Individual Patient list
55 I PXRMSEL="I" K PXRMPAT D PAT^PXRMXSU(.PXRMPAT)
56 ;Get Patient list #810.5
57 I PXRMSEL="R" K PXRMLIST D LIST^PXRMXSU(.PXRMLIST)
58 ;Get OE/RRteam list
59 I PXRMSEL="O" K PXRMOTM D OERR^PXRMXSU(.PXRMOTM)
60 ;Get PCMM team
61 I PXRMSEL="T" K PXRMPCM D PCMM^PXRMXSU(.PXRMPCM)
62 ;Get provider list
63 I PXRMSEL="P" K PXRMPRV D PROV^PXRMXSU(.PXRMPRV)
64 ;Get the location list.
65 I PXRMSEL="L" K PXRMCS,PXRMCSN,PXRMLOCN,PXRMLCHL,PXRMCGRP,PXRMCGRN D
66 .D LOC^PXRMXSU("Determine encounter counts for","HS")
67 I $D(DTOUT) G EXIT
68 I $D(DUOUT) G:"IRPO"[PXRMSEL SEL G:NFAC>1 COMB G FAC
69 ;
70 ;Check if inpatient location report
71 S PXRMINP=$$INP
72 ;
73 ; Primary Provider or All (PCMM Provider only)
74PRIME I PXRMSEL="P" D G:$D(DTOUT) EXIT G:$D(DUOUT) OPT
75 .D PRIME^PXRMXSD(.PXRMPRIM)
76 ;
77DR ; Get the date range.
78 S PXRMFD="P"
79 ; No prompt if individual patients selected
80 ; Single dates only if PCMM teams/providers and OE/RR teams selected
81 ; Choice of previous/future date range if location selected
82 ;
83 ; Prior encounters/future appointments (location only)
84PREV I PXRMSEL="L" D PREV^PXRMXSD(.PXRMFD) G:$D(DTOUT) EXIT G:$D(DUOUT) OPT
85 ; Date range input (location only)
86 I PXRMSEL="L" D G:$D(DTOUT) EXIT G:$D(DUOUT) PREV
87 .I PXRMFD="P" D PDR^PXRMXDUT(.PXRMBDT,.PXRMEDT,"ENCOUNTER")
88 .I PXRMFD="F" D FDR^PXRMXDUT(.PXRMBDT,.PXRMEDT,"APPOINTMENT")
89 .I PXRMFD="A" D PDR^PXRMXDUT(.PXRMBDT,.PXRMEDT,"ADMISSION")
90 .I PXRMFD="C" S PXRMBDT=DT,PXRMEDT=DT
91 ; Due Effective Date
92DUE D SDR^PXRMXDUT(.PXRMSDT) G:$D(DTOUT) EXIT
93 I $D(DUOUT) G:PXRMSEL="L" PREV G OPT
94 ;
95SCAT ;Get the service categories.
96 I PXRMSEL="L",PXRMFD="P" D
97 .D SCAT^PXRMXSC
98 .I $D(DTOUT)!$D(DUOUT) Q
99 I $D(DTOUT) G EXIT
100 I $D(DUOUT) G DUE
101 ;
102TYP ;Determine type of report (detail/summary)
103 S PXRMREP="S"
104 D REP^PXRMXSD(.PXRMREP) I $D(DTOUT) G EXIT
105 I $D(DUOUT) G SCAT
106 ;
107 ;Check if combined location report is required
108LCOMB S NLOC=0
109 I PXRMREP="D",PXRMSEL="L" D G:$D(DTOUT) EXIT G:$D(DUOUT) TYP
110 .N DEFAULT,TEXT
111 .D NLOC
112 .I NLOC>1 D COMB^PXRMXSD(.PXRMLCMB,TEXT,DEFAULT)
113 ;
114 ;Check if combined OE/RR team report is required
115TCOMB I PXRMREP="D",PXRMSEL="O",$G(NOTM)>1 D G:$D(DTOUT) EXIT G:$D(DUOUT) TYP
116 .N DEFAULT,TEXT
117 .S DEFAULT="N",TEXT="OE/RR teams"
118 .D COMB^PXRMXSD(.PXRMTCMB,TEXT,DEFAULT)
119 ;
120FUT ;For detailed report give option to display future appointments
121 S PXRMFUT="N"
122 I PXRMREP="D",'PXRMINP D G:$D(DTOUT) EXIT I $D(DUOUT) G:(PXRMSEL="L")&(NLOC>1) LCOMB G:(PXRMSEL="O")&($G(NOTM)>1) TCOMB G TYP
123 .D FUTURE^PXRMXSD(.PXRMFUT,"Display All Future Appointments: ",5)
124 .I PXRMFUT="Y" D Q:$D(DTOUT)!$D(DUOUT)
125 ..D FUTURE^PXRMXSD(.PXRMDLOC,"Display Appointment Location: ",15)
126 ;
127SRT ;For detailed report give option to sort by appointment date
128 S PXRMSRT="N"
129 I PXRMREP="D",("RI"'[PXRMSEL) D G:$D(DTOUT) EXIT I $D(DUOUT) G:(PXRMSEL="L")&(PXRMINP)&(NLOC>1) LCOMB G:PXRMINP TYP G:(PXRMSEL="O")&($G(NOTM)>1) TCOMB G FUT
130 .;Option to sort by Bed for inpatients
131 .I PXRMSEL="L",PXRMINP D BED^PXRMXSD(.PXRMSRT) Q
132 .;Otherwise option to sort by appt. date
133 .D SRT^PXRMXSD(.PXRMSRT)
134 ;
135 ;Option to print full SSN
136SSN I PXRMREP="D" D G:$D(DTOUT) EXIT I $D(DUOUT) G:"IR"[PXRMSEL FUT G SRT
137 .D SSN^PXRMXSD(.PXRMSSN)
138 ;
139 ;Option to print without totals, with totals or totals only
140TOT I PXRMREP="S" D G:$D(DTOUT) EXIT I $D(DUOUT) G TYP
141 .;Default is normal report
142 .S PXRMTOT="I"
143 .;Ignore patient and patient list reports
144 .I "RI"[PXRMSEL Q
145 .;Only prompt if more than one location, team or provider is selected
146 .I PXRMSEL="P",NPRV<2 Q
147 .I "OT"[PXRMSEL,NOTM<2 Q
148 .;Ignore reports for all locations
149 .I PXRMSEL="L",PXRMLCMB="Y" Q
150 .I PXRMSEL="L" N DEFAULT,TEXT D NLOC Q:NLOC<2
151 .;Prompt for options
152 .N LIT1,LIT2,LIT3
153 .D LIT,TOTALS^PXRMXSD(.PXRMTOT,LIT1,LIT2,LIT3)
154 ;
155 ;Reminder Category/Individual Reminder Selection
156RCAT ;
157 D RCAT^PXRMXSU(.PXRMRCAT,.PXRMREM) I $D(DTOUT) G EXIT
158 I $D(DUOUT) G:PXRMREP="D" SSN G TOT
159 ;
160 ;Create combined reminder list
161 D MERGE^PXRMXS1
162 ;
163SAV ;Option to create a new report template
164 I PXRMTMP="" D ^PXRMXTU G:$D(DTOUT) EXIT I $D(DUOUT) G RCAT
165 ;
166 ;Option to print delimiter separated output
167TABS D G:$D(DTOUT) EXIT I $D(DUOUT) G SAV
168 .D TABS^PXRMXSD(.PXRMTABS)
169 ;Select chracter
170TCHAR I PXRMTABS="Y" D G:$D(DTOUT) EXIT G:$D(DUOUT) TABS
171 .S PXRMTABC=$$DELIMSEL^PXRMXSD
172 ;
173DPAT ;Ask whether to include deceased and test patients.
174 S PXRMDPAT=$$ASKYN^PXRMEUT("N","Include deceased patients on the list")
175 N PXRMIDOD I PXRMDPAT>0 S PXRMIDOD=1
176 Q:$D(DTOUT) G:$D(DUOUT) TABS
177TPAT ;
178 S PXRMTPAT=$$ASKYN^PXRMEUT("N","Include test patients on the list")
179 Q:$D(DTOUT) G:$D(DUOUT) DPAT
180PATLIST ;
181 K PATCREAT
182 N PATLST
183 I PXRMSEL'="I"&(PXRMUSER'="Y") D
184 . D ASK(.PATLST,"Save due patients to a patient list: ",3)
185 . I $G(PATLST)="" Q
186 . I $G(PATLST)="N" S PXRMLIS1="" Q
187 . I $G(PATLST)="Y" D
188 ..S PATCREAT="N"
189 ..D ASK(.PATCREAT,"Secure list?: ",3) I $D(DTOUT)!($D(DUOUT)) Q
190 ..K PLISTPUG
191 ..S PLISTPUG="N" D ASK^PXRMXD(.PLISTPUG,"Purge Patient List after 5 years?: ",5)
192 I $G(PATLST)="" G:$D(DTOUT) EXIT I $D(DUOUT) G TPAT
193 G:$D(DTOUT) EXIT I $D(DUOUT) G PATLIST
194 I $G(PATLST)="Y" S TEXT="Select PATIENT LIST name: " D PLIST^PXRMLCR(.PXRMLIS1,TEXT,"") Q:$D(DUOUT)!$D(DTOUT)
195 ;Determine whether the report should be queued.
196JOB ;
197 D JOB^PXRMXQUE
198 Q
199 ;
200 ;Option PXRM REMINDERS DUE (USER)
201USER N PXRMUSER
202 S PXRMUSER=+$G(DUZ)
203 G START
204 ;
205 ;
206EXIT ;Clean things up.
207 D EXIT^PXRMXGUT
208 Q
209 ;
210 ;Check if inpatient report
211INP() ;Applies to location reports only
212 I PXRMSEL'="L" Q 0
213 ;For all inpatient locations default is automatic
214 I $P(PXRMLCSC,U)="HAI" Q 1
215 ;For selected locations check if all locations are wards
216 I $P(PXRMLCSC,U)="HS" Q $$INP^PXRMXAP(PXRMLCSC,.PXRMLOCN)
217 ;Otherwise
218 Q 0
219 ;
220 ;Prompt text
221LIT N LIT
222 S LIT=$S(PXRMSEL="P":"Provider","OT"[PXRMSEL:"Team",1:"Location")
223 I PXRMFCMB="N" D
224 .S LIT1="Individual "_LIT_"s only"
225 .S LIT2="Individual "_LIT_"s plus Totals by Facility"
226 .S LIT3="Totals by Facility only"
227 I PXRMFCMB="Y" D
228 .S LIT1="Individual "_LIT_"s only"
229 .S LIT2="Individual "_LIT_"s plus Overall Total"
230 .S LIT3="Overall Total only"
231 Q
232 ;
233 ;Check if multiple locations
234NLOC S DEFAULT="N",NLOC=1,TEXT="Locations"
235 I $P(PXRMLCSC,U)["HA" S DEFAULT="Y",NLOC=999
236 I $P(PXRMLCSC,U)="CA" S DEFAULT="Y",NCS=999
237 I $E(PXRMLCSC)="C" S TEXT="Clinic Stops",NLOC=NCS
238 I $E(PXRMLCSC)="G" S TEXT="Clinic Groups",NLOC=NCGRP
239 I $P(PXRMLCSC,U)="HS" S NLOC=NHL S:$$INP TEXT="Inpatient Locations"
240 ;Special coding if more than one facility and location
241 I $P(PXRMLCSC,U)="HS",NFAC>1,NLOC>1 D
242 .N FAC,HLOCIEN,HLNAME,IC,MULT
243 .S IC=0 S:PXRMFCMB="Y" FAC="COMBINED"
244 .;Build list of locations by facility
245 .F S IC=$O(PXRMLCHL(IC)) Q:'IC D
246 ..S HLOCIEN=$P(PXRMLCHL(IC),U,2),FAC=$$FACL^PXRMXAP(HLOCIEN) Q:'FAC
247 ..S HLNAME=$P(PXRMLCHL(IC),U) Q:HLNAME=""
248 ..S MULT(FAC,HLNAME)=""
249 .S MULT=0,FAC=0
250 .;Count locations in each facility
251 .F S FAC=$O(MULT(FAC)) Q:'FAC D Q:MULT
252 ..S IC=0,HLNAME=""
253 ..F S HLNAME=$O(MULT(FAC,HLNAME)) Q:HLNAME="" S IC=IC+1
254 ..I IC>1 S MULT=1
255 .;If only one location per facility suppress combined location option
256 .I 'MULT S NLOC=1
257 Q
258 ;
259ASK(YESNO,PROMPT,NUM) ;
260 N X,Y,TEXT
261 K DIROUT,DIRUT,DTOUT,DUOUT
262 S DIR(0)="YA0"
263 S DIR("A")=PROMPT
264 S DIR("B")="N"
265 S DIR("?")="Enter Y or N. For detailed help type ??"
266 S DIR("??")=U_"D HELP^PXRMLCR("_NUM_")"
267 W !
268 D ^DIR K DIR
269 I $D(DIROUT) S DTOUT=1
270 I $D(DTOUT)!($D(DUOUT)) Q
271 S YESNO=$E(Y(0))
272 Q
273 ;
Note: See TracBrowser for help on using the repository browser.