1 | LREPIRS ;DALOI/CKA - EPI-LOCAL REPORT/SPREADSHEET ; 5/14/03
|
---|
2 | ;;5.2;LAB SERVICE;**281**;Sep 27, 1994
|
---|
3 | ; Reference to ^ORD(101 supported by IA #872
|
---|
4 | ;USED TO PRINT REPORT OR SPREADSHEET
|
---|
5 | D NOW^%DTC
|
---|
6 | S LRLRDT=% ;Set LRLRDT- local report date time=now
|
---|
7 | S LRRTYPE=1,LRPROT=0
|
---|
8 | S LRPROT=$O(^ORD(101,"B","LREPI",LRPROT))
|
---|
9 | W @IOF,?(IOM/2-15),"Laboratory Generate Local Report/Spreadsheet option"
|
---|
10 | CRI K LRCYCLE,LREPI S LRMSG="Pathogens" D ALL G:$D(DIRUT) EXIT
|
---|
11 | K DIR,DIRUT,DTOUT,DUOUT,DIROUT
|
---|
12 | I +LRALL D PICKALL G DATE
|
---|
13 | S LRMSG="Local Pathogens" D ALL G:$D(DIRUT) CRI
|
---|
14 | K DIR,DIRUT,DTOUT,DUOUT,DIROUT
|
---|
15 | I +LRALL D LOCALL G DATE
|
---|
16 | I +LRALL'>0 D
|
---|
17 | .W @IOF
|
---|
18 | .F Q:$D(DIRUT) D
|
---|
19 | ..S DIR(0)="PAO^69.5:EMZ",DIR("A")="Select Pathogens: "
|
---|
20 | ..S DIR("S")="D CHKL^LREPIRM I LROK I $P(^(0),U,7)=LRPROT"
|
---|
21 | ..D ^DIR
|
---|
22 | ..Q:$D(DIRUT)
|
---|
23 | ..S LREPI(+Y)=""
|
---|
24 | G:$D(DTOUT)!$D(DUOUT)!$D(DIROUT) CRI
|
---|
25 | I '$D(LREPI) W !,"Sorry No Pathogens Selected" G EXIT
|
---|
26 | DATE ;Select Search Date
|
---|
27 | K DIR,DIRUT
|
---|
28 | S DIR("A")="Select Start Date: "
|
---|
29 | S DIR(0)="DOA^:"_DT D ^DIR
|
---|
30 | G:$D(DIRUT) CRI
|
---|
31 | S LRRPS=Y
|
---|
32 | K DIR,DIRUT
|
---|
33 | S DIR("A")="Select End Date: "
|
---|
34 | S DIR(0)="DOA^:"_DT D ^DIR
|
---|
35 | G:$D(DIRUT) DATE
|
---|
36 | S LRRPE=Y
|
---|
37 | RORS ;REPORT OR SPREADSHEET
|
---|
38 | K DIR,DIRUT
|
---|
39 | S DIR(0)="SO^1:REPORT;2:SPREADSHEET"
|
---|
40 | D ^DIR
|
---|
41 | G:$D(DIRUT) DATE
|
---|
42 | S LRREP=Y
|
---|
43 | W !!
|
---|
44 | I LRREP=1,$D(^XTMP("LREPILOCALREP"_LRLRDT)) D G EXIT
|
---|
45 | .W !,"Data already exists for this date and time. Please try again later."
|
---|
46 | I LRREP=2,$D(^XTMP("LREPILOCALSPSHT"_LRLRDT)) D G EXIT
|
---|
47 | .W !,"Data already exists for this date and time. Please try again later."
|
---|
48 | D SEG G:$D(DIRUT) RORS
|
---|
49 | TITLE K DIR,DIRUT
|
---|
50 | S DIR(0)="F^3:30",DIR("A")="DOCUMENT TITLE"
|
---|
51 | D ^DIR
|
---|
52 | G:$D(DIRUT) RORS
|
---|
53 | S ^XTMP("LREPI"_$S(LRREP=1:"LOCALREP",1:"LOCALSPSHT")_LRLRDT,"TITLE")=Y
|
---|
54 | D TASK,HOME^%ZIS
|
---|
55 | EXIT ;
|
---|
56 | K D0,J,LRALL,LRAUTO,LRBEG,LRCYCLE,LRDT,LREND,LREPI,LRMSG,LROK,LROVR
|
---|
57 | K LRDUZ,LRRNDT,LRRPE,LRREP,LRRPS,LRRTYPE,LRY,ZTSAVE
|
---|
58 | K ZTRTN,ZTIO,ZTDESC,ZTDTH,ZTSK,X,Y,X1,%DT
|
---|
59 | K LRLC,LRHDG,LRPROT,LRLRDT
|
---|
60 | K DIR,DIROUT,DIRUT,DTOUT,DUOUT,I,LRSEG
|
---|
61 | K ^TMP($J)
|
---|
62 | Q
|
---|
63 | ;
|
---|
64 | TASK ;LETS TASK THIS JOB
|
---|
65 | Q:'$D(LREPI)
|
---|
66 | W !!
|
---|
67 | S LRDUZ=DUZ
|
---|
68 | K ZTSAVE
|
---|
69 | S ZTSAVE("LRRTYPE")="" S:LRRTYPE=0 ZTDTH=DT
|
---|
70 | S ZTSAVE("LR*")=""
|
---|
71 | S ZTIO="",ZTRTN="EN^LREPI",ZTDESC="Laboratory EPI local spreadsheet/report-generate"
|
---|
72 | D ^%ZTLOAD
|
---|
73 | I '$D(ZTQUEUED)&($D(ZTSK)) W @IOF,!!,"The Task has been queued",!,"Task # ",$G(ZTSK) H 5
|
---|
74 | Q
|
---|
75 | PICKALL ;SELECT ALL ASSOCIATED PARAMETERS
|
---|
76 | S Y=0 F S Y=$O(^LAB(69.5,Y)) Q:+Y'>0 D CHK S:LROK LREPI(Y)=""
|
---|
77 | Q
|
---|
78 | LOCALL ;SELECT ALL LOCAL PATHOGENS
|
---|
79 | S Y=99 F S Y=$O(^LAB(69.5,Y)) Q:Y'>0 D CHK S:LROK LREPI(Y)=""
|
---|
80 | Q
|
---|
81 | CHK ;CHECK TO SEE IF ITS OK
|
---|
82 | S:'$D(LRCYCLE) LRCYCLE=$P(^LAB(69.5,Y,0),U,5)
|
---|
83 | S LROK=1
|
---|
84 | S:($P(^LAB(69.5,Y,0),U,2)="1") LROK=0 Q
|
---|
85 | S:$P(^LAB(69.5,Y,0),U,7)="" LROK=0 Q
|
---|
86 | S:'$D(^ORD(101,$P(^LAB(69.5,Y,0),U,7),0)) LROK=0 Q
|
---|
87 | S:$P(^LAB(69.5,Y,0),U,5)=LRCYCLE LROK=0 Q
|
---|
88 | Q
|
---|
89 | ALL K DIR,DIRUT
|
---|
90 | S DIR(0)="Y",DIR("B")="NO",DIR("A")="Include All "_LRMSG
|
---|
91 | S DIR("?")="Enter (Y)es or return to individually select pathogens."
|
---|
92 | D ^DIR
|
---|
93 | S LRALL=+Y
|
---|
94 | Q
|
---|
95 | SEG ;CHOOSE SEGMENTS FOR SPREADSHEET
|
---|
96 | W !,"Choose the segments to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
97 | W !,"1-PID"
|
---|
98 | W !,"2-PV1"
|
---|
99 | W !,"3-DG1"
|
---|
100 | W !,"4-NTE"
|
---|
101 | W !,"5-OBR"
|
---|
102 | W !,"6-OBX"
|
---|
103 | K DIR,DIRUT
|
---|
104 | S DIR(0)="L^1:6"
|
---|
105 | D ^DIR
|
---|
106 | Q:$D(DIRUT)
|
---|
107 | S LRY=Y
|
---|
108 | I LRY[1 S LRSEG("PID")=1 D
|
---|
109 | .W !!
|
---|
110 | .W !,"Choose the fields from the PID segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
111 | .W !,"1-Set Id"
|
---|
112 | .W !,"2-SSN"
|
---|
113 | .W !,"3-MPI"
|
---|
114 | .W !,"4-Patient Name"
|
---|
115 | .W !,"5-Date of Birth"
|
---|
116 | .W !,"6-Sex"
|
---|
117 | .W !,"7-Race"
|
---|
118 | .W !,"8-Homeless"
|
---|
119 | .W !,"9-State"
|
---|
120 | .W !,"10-Zip Code"
|
---|
121 | .W !,"11-County"
|
---|
122 | .W !,"12-Ethnicity"
|
---|
123 | .W !,"13-Period of Service"
|
---|
124 | .K DIR,DIRUT
|
---|
125 | .S DIR(0)="L^1:13"
|
---|
126 | .D ^DIR
|
---|
127 | .Q:$D(DIRUT)
|
---|
128 | .F I=1:1:13 I Y[I S LRSEG("PID",I)=""
|
---|
129 | I LRY[2 S LRSEG("PV1")=1 D
|
---|
130 | .W !,"Choose the fields from the PV1 segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
131 | .W !,"1-Set Id"
|
---|
132 | .W !,"2-Patient Class"
|
---|
133 | .W !,"3-Hospital Location"
|
---|
134 | .W !,"4-Discharge Disposition"
|
---|
135 | .W !,"5-Facility"
|
---|
136 | .W !,"6-Admit Date/Time"
|
---|
137 | .W !,"7-Discharge Date/Time"
|
---|
138 | .K DIR,DIRUT
|
---|
139 | .S DIR(0)="L^1:7"
|
---|
140 | .D ^DIR
|
---|
141 | .Q:$D(DIRUT)
|
---|
142 | .F I=1:1:7 I Y[I S LRSEG("PV1",I)=""
|
---|
143 | I LRY[3 S LRSEG("DG1")=1 D
|
---|
144 | .W !,"Choose the fields from the DG1 segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
145 | .W !,"1-Set Id"
|
---|
146 | .W !,"2-Diagnosis Code"
|
---|
147 | .W !,"3-Diagnosis"
|
---|
148 | .W !,"4-Admission Date"
|
---|
149 | .K DIR,DIRUT
|
---|
150 | .S DIR(0)="L^1:4"
|
---|
151 | .D ^DIR
|
---|
152 | .Q:$D(DIRUT)
|
---|
153 | .F I=1:1:4 I Y[I S LRSEG("DG1",I)=""
|
---|
154 | I LRY[4 S LRSEG("NTE")=1 D
|
---|
155 | .W !,"Choose the fields from the NTE segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
156 | .W !,"1-Set Id"
|
---|
157 | .W !,"2-Comment"
|
---|
158 | .K DIR,DIRUT
|
---|
159 | .S DIR(0)="L^1:2"
|
---|
160 | .D ^DIR
|
---|
161 | .Q:$D(DIRUT)
|
---|
162 | .F I=1:1:2 I Y[I S LRSEG("NTE",I)=""
|
---|
163 | I LRY[5 S LRSEG("OBR")=1 D
|
---|
164 | .W !,"Choose the fields from the OBR segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
165 | .W !,"1-Set Id"
|
---|
166 | .W !,"2-Test Name"
|
---|
167 | .W !,"3-Accession Date"
|
---|
168 | .W !,"4-Specimen"
|
---|
169 | .W !,"5-Accession Number"
|
---|
170 | .K DIR,DIRUT
|
---|
171 | .S DIR(0)="L^1:5"
|
---|
172 | .D ^DIR
|
---|
173 | .Q:$D(DIRUT)
|
---|
174 | .F I=1:1:5 I Y[I S LRSEG("OBR",I)=""
|
---|
175 | I LRY[6 S LRSEG("OBX")=1 D
|
---|
176 | .W !,"Choose the fields from the OBX segment to capture for ",$S(LRREP=1:"report.",1:"spreadsheet.")
|
---|
177 | .W !,"1-Set Id"
|
---|
178 | .W !,"2-Value Type"
|
---|
179 | .W !,"3-Test Name"
|
---|
180 | .W !,"4-LOINC Code"
|
---|
181 | .W !,"5-LOINC Name"
|
---|
182 | .W !,"6-Test Result"
|
---|
183 | .W !,"7-Units"
|
---|
184 | .W !,"8-Abnormal Flags"
|
---|
185 | .W !,"9-Verified Date/Time"
|
---|
186 | .K DIR,DIRUT
|
---|
187 | .S DIR(0)="L^1:9"
|
---|
188 | .D ^DIR
|
---|
189 | .Q:$D(DIRUT)
|
---|
190 | .F I=1:1:10 I Y[I S LRSEG("OBX",I)=""
|
---|
191 | Q
|
---|