1 | ORWRP16 ; ALB/MJK Report Calls - 16bit ;5/22/97 19:13
|
---|
2 | ;;3.0;ORDER ENTRY/RESULTS REPORTING;;Dec 17, 1997
|
---|
3 | ;
|
---|
4 | LIST(ROOT) ; -- return lists for list boxes
|
---|
5 | ; RPC: ORWRP REPORT LIST
|
---|
6 | ; See RPC definition for details on input and output parameters
|
---|
7 | ;
|
---|
8 | N EOF
|
---|
9 | S EOF="$$END",ROOT=$NA(^TMP($J,"ORPTLIST"))
|
---|
10 | K @ROOT
|
---|
11 | ;
|
---|
12 | ; -- get list of reports
|
---|
13 | D GETRPTS(.ROOT,.EOF)
|
---|
14 | ; -- get list of health summary types
|
---|
15 | D GETHS(.ROOT,.EOF)
|
---|
16 | ; -- get list of date ranges
|
---|
17 | D GETDT(.ROOT,.EOF)
|
---|
18 | ;
|
---|
19 | Q
|
---|
20 | ;
|
---|
21 | GETRPTS(ROOT,EOF) ; -- get list of reports
|
---|
22 | N I,X
|
---|
23 | D SETITEM(.ROOT,"[REPORT LIST]")
|
---|
24 | F I=2:1 S X=$P($T(RPTLIST+I),";",3) D SETITEM(.ROOT,X) Q:X=EOF
|
---|
25 | Q
|
---|
26 | ;
|
---|
27 | RPTLIST ; -- list of reports
|
---|
28 | ;<ID> ^ <report name> ^ <ask date range> ^ <ask health summary type> ^ <right margin>
|
---|
29 | ;;1^Health Summary^N^Y^80
|
---|
30 | ;;2^Blood Bank Report^N^N^80
|
---|
31 | ;;3^Anatomic Path Report^N^N^80
|
---|
32 | ;;4^Dietetics Profile^N^N^80
|
---|
33 | ;;5^Vitals Cumulative^Y^N^132
|
---|
34 | ;;6^Vitals SF511^Y^N^132
|
---|
35 | ;;$$END
|
---|
36 | ;
|
---|
37 | GETHS(ROOT,EOF) ; --get list of health summary types
|
---|
38 | N I,HSPARM
|
---|
39 | D GETLST^XPAR(.HSPARM,"SYS","ORWRP HEALTH SUMMARY TYPE LIST","N")
|
---|
40 | ;
|
---|
41 | D SETITEM(.ROOT,"[HEALTH SUMMARY TYPES]")
|
---|
42 | S I=0 F S I=$O(HSPARM(I)) Q:'I D SETITEM(.ROOT,HSPARM(I))
|
---|
43 | D SETITEM(.ROOT,EOF)
|
---|
44 | Q
|
---|
45 | ;
|
---|
46 | GETDT(ROOT,EOF) ; -- get date range choices
|
---|
47 | N I,X
|
---|
48 | D SETITEM(.ROOT,"[DATE RANGES]")
|
---|
49 | F I=2:1 S X=$P($T(DTLIST+I),";",3) D SETITEM(.ROOT,X) Q:X=EOF
|
---|
50 | Q
|
---|
51 | ;
|
---|
52 | DTLIST ; -- list of date ranges
|
---|
53 | ;<number of days>^ <display text>
|
---|
54 | ;;0^Today
|
---|
55 | ;;7^One Week Back
|
---|
56 | ;;14^Two Weeks Back
|
---|
57 | ;;30^One Month Back
|
---|
58 | ;;180^Six Months Back
|
---|
59 | ;;365^One Year Back
|
---|
60 | ;;$$END
|
---|
61 | ;
|
---|
62 | SETITEM(ROOT,X) ; -- set item in list
|
---|
63 | S @ROOT@($O(@ROOT@(9999),-1)+1)=X
|
---|
64 | Q
|
---|
65 | ;
|
---|
66 | RPT(ROOT,DFN,RPTID,HSTYPE,DTRANGE,SECTION) ; -- return report text
|
---|
67 | ; RPC: ORWRP REPORT TEXT
|
---|
68 | ; See RPC definition for details on input and output parameters
|
---|
69 | ;
|
---|
70 | IF $G(SECTION),$D(^TMP("ORDATA",$J,SECTION)) D G RPTQ
|
---|
71 | . S ROOT=$NA(^TMP("ORDATA",$J,SECTION))
|
---|
72 | ;
|
---|
73 | ; -- init output global for close logic of WORKSTATION device
|
---|
74 | K ^TMP("ORDATA",$J)
|
---|
75 | S ROOT=$NA(^TMP("ORDATA",$J,1))
|
---|
76 | ;
|
---|
77 | ; -- get report text
|
---|
78 | IF RPTID=1 D HS(DFN,HSTYPE) G RPTQ
|
---|
79 | IF RPTID=2 D BL(DFN) G RPTQ
|
---|
80 | IF RPTID=3 D PATH(DFN) G RPTQ
|
---|
81 | IF RPTID=4 D DIET(.ROOT,DFN) G RPTQ
|
---|
82 | IF RPTID=5 D VITALS(DFN,DTRANGE,"VITCUM") G RPTQ
|
---|
83 | IF RPTID=6 D VITALS(DFN,DTRANGE,"VIT511") G RPTQ
|
---|
84 | ;
|
---|
85 | ; -- basic report if id not found above
|
---|
86 | D NOTYET(.ROOT)
|
---|
87 | RPTQ Q
|
---|
88 | ;
|
---|
89 | HS(ORDFN,ORHS) ; - get health summary report
|
---|
90 | N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
|
---|
91 | S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
|
---|
92 | D OPEN(.ORRM,.ORHFS,"W",.ORIO)
|
---|
93 | ;
|
---|
94 | D HSB(.ORDFN,.ORHS)
|
---|
95 | ;
|
---|
96 | D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
|
---|
97 | Q
|
---|
98 | ;
|
---|
99 | HSB(ORDFN,ORHS) ; - build health summary report
|
---|
100 | N ORVP,GMTYP,Y
|
---|
101 | S ORVP=ORDFN_";DPT("
|
---|
102 | S Y=$P($G(^GMT(142,+ORHS,0)),U)
|
---|
103 | S GMTYP(0)=1,GMTYP(1)=+ORHS_U_Y_U_Y_U_Y
|
---|
104 | D PQ^ORPRS13
|
---|
105 | Q
|
---|
106 | ;
|
---|
107 | BL(ORDFN) ; -- get blood bank report
|
---|
108 | N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
|
---|
109 | S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
|
---|
110 | D OPEN(.ORRM,.ORHFS,"W",.ORIO)
|
---|
111 | ;
|
---|
112 | D BLB(.ORDFN)
|
---|
113 | ;
|
---|
114 | D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
|
---|
115 | Q
|
---|
116 | ;
|
---|
117 | BLB(ORDFN) ; -- build blood bank report
|
---|
118 | N DFN
|
---|
119 | ;
|
---|
120 | D SET^LRBLPD1
|
---|
121 | IF $G(OREND)'=1 D
|
---|
122 | . S DFN=ORDFN
|
---|
123 | . D OERR^LRBLPD1
|
---|
124 | . D CLEAN^LRBLPD1
|
---|
125 | Q
|
---|
126 | ;
|
---|
127 | PATH(ORDFN) ; -- get anatomic path report
|
---|
128 | N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
|
---|
129 | S ORRM=80,ORHFS=$$HFS(),ORSUB="ORDATA"
|
---|
130 | D OPEN(.ORRM,.ORHFS,"W",.ORIO)
|
---|
131 | ;
|
---|
132 | D PATHB(.ORDFN)
|
---|
133 | ;
|
---|
134 | D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
|
---|
135 | Q
|
---|
136 | ;
|
---|
137 | PATHB(ORDFN) ; -- build anatomic path report
|
---|
138 | N DFN
|
---|
139 | ;
|
---|
140 | D SET^LRAPS3
|
---|
141 | IF $G(OREND)'=1 D
|
---|
142 | . S DFN=ORDFN
|
---|
143 | . D OERR^LRAPS3
|
---|
144 | . D CLEAN^LRAPS3
|
---|
145 | Q
|
---|
146 | ;
|
---|
147 | DIET(ROOT,DFN) ; -- get dietetics profile
|
---|
148 | D NOTYET(.ROOT)
|
---|
149 | Q
|
---|
150 | ;
|
---|
151 | DIETB(DFN) ; -- get dietetics profile
|
---|
152 | W !!,"Dietetics Profile not yet available."
|
---|
153 | Q
|
---|
154 | ;
|
---|
155 | VITALS(DFN,DTRANGE,ORTAG) ; -- get vitals report
|
---|
156 | N ZTQUEUED,ORRM,ORHFS,ORSUB,ORIO
|
---|
157 | S ORRM=132,ORHFS=$$HFS(),ORSUB="ORDATA"
|
---|
158 | D OPEN(.ORRM,.ORHFS,"W",.ORIO)
|
---|
159 | ;
|
---|
160 | D VITALSB(.DFN,.DTRANGE,.ORTAG)
|
---|
161 | ;
|
---|
162 | D CLOSE(.ORRM,.ORHFS,.ORSUB,.ORIO)
|
---|
163 | Q
|
---|
164 | ;
|
---|
165 | VITALSB(DFN,DTRANGE,ORTAG) ; -- build vitals report
|
---|
166 | N ORVP,XQORNOD,ORSSTRT,ORSSTOP
|
---|
167 | ;
|
---|
168 | S ORVP=DFN_";DPT(",XQORNOD=1
|
---|
169 | S X1=DT
|
---|
170 | ; -- if TODAY then do not substract 1
|
---|
171 | S X2=-$S(DTRANGE:DTRANGE-1,1:0)
|
---|
172 | D C^%DTC
|
---|
173 | S ORSSTRT(XQORNOD)=X-.7641,ORSSTOP(XQORNOD)=DT+.2359
|
---|
174 | D @ORTAG^ORPRS14
|
---|
175 | Q
|
---|
176 | ;
|
---|
177 | NOTYET(ROOT) ; -- standard not available display text
|
---|
178 | D SETITEM(.ROOT,"Report not available at this time.")
|
---|
179 | S @ROOT@(.1)="1^1"
|
---|
180 | Q
|
---|
181 | ;
|
---|
182 | HFS() ; -- get hfs file name
|
---|
183 | ; -- need to define better unique algorithm
|
---|
184 | Q "ORU_"_$J_".DAT"
|
---|
185 | ;
|
---|
186 | OPEN(ORRM,ORHFS,ORMODE,ORIO) ; -- open WORKSTATION device
|
---|
187 | ; ORRM: right margin
|
---|
188 | ; ORHFS: host file name
|
---|
189 | ; ORMODE: open file in 'R'ead or 'W'rite mode
|
---|
190 | S ZTQUEUED="" K IOPAR
|
---|
191 | S IOP="WORKSTATION;"_$G(ORRM,80)
|
---|
192 | S %ZIS("HFSMODE")=ORMODE,%ZIS("HFSNAME")=ORHFS
|
---|
193 | D ^%ZIS K IOP,%ZIS
|
---|
194 | U IO S ORIO=IO
|
---|
195 | Q
|
---|
196 | ;
|
---|
197 | CLOSE(ORRM,ORHFS,ORSUB,ORIO) ; -- close WORKSTATION device
|
---|
198 | ; ORSUB: unique subscript name for output
|
---|
199 | IF IO=ORIO D ^%ZISC
|
---|
200 | U IO
|
---|
201 | D USEHFS
|
---|
202 | U IO
|
---|
203 | Q
|
---|
204 | USEHFS ; -- use host file to build global array
|
---|
205 | N IO,OROK
|
---|
206 | ; D OPEN^%ZISH(ORSUB,"",ORHFS,"R") I POP Q
|
---|
207 | K ^TMP($J,"ORTMPLST")
|
---|
208 | S OROK=$$FTG^%ZISH(,ORHFS,$NA(^TMP($J,"ORTMPLST",1)),3)
|
---|
209 | D BUILD
|
---|
210 | K ^TMP($J,"ORTMPLST")
|
---|
211 | ; D CLOSE^%ZISH(ORSUB)
|
---|
212 | N ORARR S ORARR(ORHFS)=""
|
---|
213 | S OROK=$$DEL^%ZISH("",$NA(ORARR))
|
---|
214 | Q
|
---|
215 | ;
|
---|
216 | BUILD ; -- build tmp global for report
|
---|
217 | N INC,CNT,MAX,SECTION,ROOT,STRIP,LN
|
---|
218 | S SECTION=0,MAX=20000,STRIP=$C(7,12)
|
---|
219 | D INIT
|
---|
220 | ; -- strip out ff's and quit on error
|
---|
221 | S LN=0 F S LN=$O(^TMP($J,"ORTMPLST",LN)) Q:'LN S X=^(LN) D
|
---|
222 | . ;F U IO R X:5 D Q:$$STATUS^%ZISH
|
---|
223 | . I (CNT+250)>MAX D INIT
|
---|
224 | . S X=$TR(X,STRIP,"")
|
---|
225 | . S INC=INC+1,@ROOT@(INC)=X
|
---|
226 | . S CNT=CNT+$L(X)
|
---|
227 | D FINAL
|
---|
228 | Q
|
---|
229 | ;
|
---|
230 | INIT ; -- initialize counts and global section
|
---|
231 | S (INC,CNT)=0,SECTION=SECTION+1
|
---|
232 | S ROOT=$NA(^TMP(ORSUB,$J,SECTION))
|
---|
233 | K @ROOT
|
---|
234 | Q
|
---|
235 | ;
|
---|
236 | FINAL ; -- set 'x of y' for each section
|
---|
237 | N I
|
---|
238 | F I=1:1:SECTION S ^TMP(ORSUB,$J,I,.1)=I_U_SECTION
|
---|
239 | Q
|
---|
240 | ;
|
---|