1 | HLCSRPT4 ;OIFO-O/LJA - Error Listing code ;3/18/02 10:19
|
---|
2 | ;;1.6;HEALTH LEVEL SEVEN;**85**;Oct 13, 1995
|
---|
3 | ;
|
---|
4 | ; Patch HL*1.6*85 created a significant amount of code; enough
|
---|
5 | ; that this routine had to be created to hold it.
|
---|
6 | ;
|
---|
7 | LOADERR ; Find latest NUMERR statuses in ERRDTB->ERRDTE date range. ;HL*1.6*85
|
---|
8 | ;ERRDTB,ERRDTE,HLCSER,HLCSTER1,NUMERR -- req
|
---|
9 | ;
|
---|
10 | N CT,ERR,ERR4,IEN,TIME
|
---|
11 | ;
|
---|
12 | KILL ^TMP("HLERR",$J),^TMP("ERRLST",$J)
|
---|
13 | ;
|
---|
14 | S HLERR=3.9,CT=0
|
---|
15 | F S HLERR=$O(^HLMA("AG",HLERR)) QUIT:HLERR'>0!(HLERR>7) D
|
---|
16 | . S IEN773=0
|
---|
17 | . F S IEN773=$O(^HLMA("AG",HLERR,IEN773)) Q:IEN773'>0 D
|
---|
18 | . . S ERR4=$P($G(^HLMA(+IEN773,"P")),U,4) QUIT:ERR4'>0 ;->
|
---|
19 | . . D CHKERR(ERR4,IEN773,ERRDTB,ERRDTE)
|
---|
20 | . . S CT=CT+1 W:'(CT#1000) "."
|
---|
21 | ;
|
---|
22 | S ERR=0
|
---|
23 | F S ERR=$O(^TMP("HLERR",$J,ERR)) Q:ERR'>0 D
|
---|
24 | . S TIME=0
|
---|
25 | . F S TIME=$O(^TMP("HLERR",$J,ERR,TIME)) Q:TIME'>0 D
|
---|
26 | . . S IEN=0
|
---|
27 | . . F S IEN=$O(^TMP("HLERR",$J,ERR,TIME,IEN)) Q:IEN'>0 D
|
---|
28 | . . . S ^TMP("ERRLST",$J,+ERR,+IEN)=""
|
---|
29 | ;
|
---|
30 | KILL ^TMP("HLERR",$J)
|
---|
31 | ;
|
---|
32 | QUIT
|
---|
33 | ;
|
---|
34 | CHKERR(ERR4,IEN773,DTB,DTE) ; Should this entry be included? ;HL*1.6*85
|
---|
35 | ;NUMERR -- req
|
---|
36 | ;
|
---|
37 | N ERRNO,OLD773,OLDPDT,PROCDT
|
---|
38 | ;
|
---|
39 | ; Processing date/time check...
|
---|
40 | S PROCDT=$$PROCDT(IEN773) QUIT:PROCDT'>0 ;->
|
---|
41 | I PROCDT<DTB!(PROCDT>DTE) QUIT ;->
|
---|
42 | ; OK. Date check passes. But, is it among NUMERR latest?
|
---|
43 | ;
|
---|
44 | ; How many errors recorded for error status?
|
---|
45 | S ERRNO=$G(^TMP("HLERR",$J,ERR4))
|
---|
46 | ;
|
---|
47 | ; Number of errors recorded less than # maximum per status...
|
---|
48 | I ERRNO<NUMERR D RECERR(ERR4,IEN773) QUIT ;->
|
---|
49 | ;
|
---|
50 | ; Find oldest entry's process date/time & last 773 IEN...
|
---|
51 | S OLDPDT=$O(^TMP("HLERR",$J,ERR4,0)) QUIT:OLDPDT'>0 ;->
|
---|
52 | S OLD773=$O(^TMP("HLERR",$J,ERR4,+OLDPDT,0)) QUIT:OLD773'>0 ;->
|
---|
53 | ;
|
---|
54 | ; Now see if "this" error is newer...
|
---|
55 | QUIT:PROCDT<OLDPDT ;->
|
---|
56 | I PROCDT=OLDPDT,IEN773<OLD773 QUIT ;->
|
---|
57 | ;
|
---|
58 | ; Max number errors reached, but this error is newer than newest...
|
---|
59 | ;
|
---|
60 | ; Zilch oldest entry, then record "this" error...
|
---|
61 | D KILLERR(ERR4,OLDPDT,OLD773)
|
---|
62 | D RECERR(ERR4,IEN773)
|
---|
63 | ;
|
---|
64 | QUIT
|
---|
65 | ;
|
---|
66 | KILLERR(ERR4,OLDPDT,OLD773) ; Remove entry and adjust counts... ;HL*1.6*85
|
---|
67 | N NUM
|
---|
68 | ;
|
---|
69 | KILL ^TMP("HLERR",$J,ERR4,OLDPDT,OLD773)
|
---|
70 | ;
|
---|
71 | I $O(^TMP("HLERR",$J,ERR4,OLDPDT,0))'>0 D
|
---|
72 | . KILL ^TMP("HLERR",$J,ERR4,OLDPDT)
|
---|
73 | I $O(^TMP("HLERR",$J,ERR4,OLDPDT,0))>0 D
|
---|
74 | . S NUM=$G(^TMP("HLERR",$J,ERR4,OLDPDT))-1,NUM=$S(NUM'<0:+NUM,1:0)
|
---|
75 | . S ^TMP("HLERR",$J,ERR4,OLDPDT)=NUM
|
---|
76 | ;
|
---|
77 | I $O(^TMP("HLERR",$J,ERR4,0))'>0 D
|
---|
78 | . KILL ^TMP("HLERR",$J,ERR4)
|
---|
79 | I $O(^TMP("HLERR",$J,ERR4,0))>0 D
|
---|
80 | . S NUM=$G(^TMP("HLERR",$J,ERR4))-1,NUM=$S(NUM'<0:+NUM,1:0)
|
---|
81 | . S ^TMP("HLERR",$J,ERR4)=NUM
|
---|
82 | ;
|
---|
83 | I $O(^TMP("HLERR",$J,0))'>0 D
|
---|
84 | . KILL ^TMP("HLERR",$J)
|
---|
85 | I $O(^TMP("HLERR",$J,0))>0 D
|
---|
86 | . S NUM=$G(^TMP("HLERR",$J))-1,NUM=$S(NUM'<0:+NUM,1:0)
|
---|
87 | . S ^TMP("HLERR",$J)=NUM
|
---|
88 | ;
|
---|
89 | QUIT
|
---|
90 | ;
|
---|
91 | RECERR(ERR4,IEN773) ; Store error in ^TMP("HLERR",$J,STATUS,IEN773) ;HL*1.6*85
|
---|
92 | S ^TMP("HLERR",$J,ERR4)=$G(^TMP("HLERR",$J,ERR4))+1
|
---|
93 | S ^TMP("HLERR",$J,ERR4,PROCDT)=$G(^TMP("HLERR",$J,ERR4,PROCDT))+1
|
---|
94 | S ^TMP("HLERR",$J,ERR4,PROCDT,IEN773)=""
|
---|
95 | QUIT
|
---|
96 | ;
|
---|
97 | SETUP() ; Setup "limit" variables... ;HL*1.6*85
|
---|
98 | S TYPEINFO=$$TYPEINFO QUIT:TYPEINFO']"" "" ;->
|
---|
99 | ;
|
---|
100 | S (ERRDTB,ERRDTE,NUMERR)=""
|
---|
101 | W !!," If you answer NO below, you will be allowed to specify the number of"
|
---|
102 | W !," errors to be included in the report."
|
---|
103 | W !
|
---|
104 | S NUMERR=$$YN("Print all errors","No") QUIT:NUMERR']"" "" ;->
|
---|
105 | S NUMERR=$S(NUMERR=1:9999999,1:$$NUMERR) QUIT:NUMERR'>0 "" ;->
|
---|
106 | I NUMERR=9999999 D
|
---|
107 | . W !!," All errors in the date range you specify next will be included"
|
---|
108 | . W !," in the report."
|
---|
109 | I NUMERR'=9999999 D
|
---|
110 | . W !!," The newest ",NUMERR," errors, for every error status, in the date range you"
|
---|
111 | . W !," specify next will be included in the report."
|
---|
112 | W !!,"The first entry at your site is from ",$$FMTE^XLFDT($O(^HL(772,"B",2840000))),"."
|
---|
113 | W !
|
---|
114 | S1 S ERRDTB=$$DATE("Enter START DATE/TIME",,$$FMADD^XLFDT($$DT^XLFDT,-90)) QUIT:ERRDTB'>0 "" ;->
|
---|
115 | W !
|
---|
116 | S ERRDTE=$$DATE("Enter END DATE/TIME",ERRDTB,"NOW") QUIT:ERRDTE'>0 "" ;->
|
---|
117 | I ERRDTB=ERRDTE D G S1 ;->
|
---|
118 | . W !!,"You cannot enter the same values for the beginning and ending times!"
|
---|
119 | . W !
|
---|
120 | QUIT 1
|
---|
121 | ;
|
---|
122 | NUMERR() ; How many errors, maximum, does user want to see ;HL*1.6*85
|
---|
123 | ; HLCSER -- req
|
---|
124 | N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
125 | W !!,"Enter the maximum number errors to report for every error status."
|
---|
126 | W !
|
---|
127 | S DIR(0)="N",DIR("A")="Enter maximum number errors/status"
|
---|
128 | S DIR("B")=999
|
---|
129 | S DIR("?",1)="If you enter '1000' for the maximum number errors/status..."
|
---|
130 | S DIR("?",2)=""
|
---|
131 | I HLCSER="ALL" D
|
---|
132 | . S DIR("?",3)="... The most recent 1000 errors for every error type will be included in the"
|
---|
133 | . S DIR("?",4)="... report. If two different error types exist, and each error type has"
|
---|
134 | . S DIR("?",5)="... more than 1000 entries, then 2000 errors will be reported."
|
---|
135 | . S DIR("?")="... (I.e., 1000 errors per error type.)"
|
---|
136 | I HLCSER'="ALL" D
|
---|
137 | . S DIR("?",3)="... The most recent 1000 errors for the error type you just selected"
|
---|
138 | . S DIR("?")="... will be included in the report."
|
---|
139 | D ^DIR
|
---|
140 | QUIT $S(Y>0:+Y,1:"")
|
---|
141 | ;
|
---|
142 | DATE(PMT,BDT,PDT) ; Entry of date for looping ;HL*1.6*85
|
---|
143 | N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
144 | S BDT=$S($G(BDT)?7N.E:BDT,1:"")
|
---|
145 | S DIR(0)="DA^"_$G(BDT)_"::ET"
|
---|
146 | I $G(BDT)>0 D
|
---|
147 | . N TXT
|
---|
148 | . S TXT="Enter a date/time after "_$$FMTE^XLFDT(BDT)_"..."
|
---|
149 | . S DIR("?")=TXT
|
---|
150 | S DIR("A")=PMT_": "
|
---|
151 | I $G(PDT)?7N.E S DIR("B")=$P($$FMTE^XLFDT(PDT),":",1,2)
|
---|
152 | I $G(PDT)="NOW" S DIR("B")="NOW"
|
---|
153 | D ^DIR
|
---|
154 | I Y?7N.E,$G(PMT)="NOW",$G(PDT)="NOW" QUIT 9999999.24 ;->
|
---|
155 | QUIT $S(Y>0:+Y,1:"")
|
---|
156 | ;
|
---|
157 | YN(PMT,DEF,FF) ; Generic YES/NO DIR call... ;HL*1.6*85
|
---|
158 | N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
159 | F X=1:1:$G(FF) W !
|
---|
160 | S DIR(0)="Y",DIR("A")=PMT
|
---|
161 | S:$G(DEF)]"" DIR("B")=DEF
|
---|
162 | D ^DIR
|
---|
163 | QUIT:$D(DIRUT)!($D(DTOUT))!($D(DUOUT)) "" ;->
|
---|
164 | QUIT $S(Y=1:1,1:0)
|
---|
165 | ;
|
---|
166 | TMPLOG ; Reset ^TMP("TMPLOG") data created in ERRRPT to ^TMP("TLOG") format
|
---|
167 | ; expected by the browser. (See DISPLAY^HLCSRPT)
|
---|
168 | ; [This subroutine created by HL*1.6*85.]
|
---|
169 | N HLCSLN,PROCDT,IEN773
|
---|
170 | S HLCSLN=0,PROCDT="zzzzz"
|
---|
171 | F S PROCDT=$O(^TMP("TMPLOG",$J,PROCDT),-1) Q:PROCDT']"" D
|
---|
172 | . S IEN773=":"
|
---|
173 | . F S IEN773=$O(^TMP("TMPLOG",$J,PROCDT,IEN773),-1) Q:IEN773'>0 D
|
---|
174 | . . S HLCSLN=HLCSLN+1
|
---|
175 | . . S ^TMP("TLOG",$J,+HLCSLN)=$G(^TMP("TMPLOG",$J,PROCDT,IEN773))
|
---|
176 | KILL ^TMP("TMPLOG",$J)
|
---|
177 | QUIT
|
---|
178 | ;
|
---|
179 | OKDATE(IEN773,DTBEG,DTEND) ; Does 773 processing time fall in date range? ;HL*1.6*85
|
---|
180 | N PROCDT
|
---|
181 | ;
|
---|
182 | ; Check what's passed in...
|
---|
183 | QUIT:'$D(^HLMA(+IEN773,0)) "" ;->
|
---|
184 | QUIT:$G(DTBEG)'?7N.E "" ;->
|
---|
185 | QUIT:$G(DTEND)'?7N.E "" ;->
|
---|
186 | ;
|
---|
187 | ; Get processing date/time...
|
---|
188 | S PROCDT=$$PROCDT(IEN773) QUIT:PROCDT'?7N.E "" ;->
|
---|
189 | ;
|
---|
190 | ; Compare dates...
|
---|
191 | I PROCDT=DTBEG!(PROCDT=DTEND) QUIT 1 ;->
|
---|
192 | QUIT:PROCDT<DTBEG "" ;->
|
---|
193 | QUIT:PROCDT>DTEND "" ;->
|
---|
194 | ;
|
---|
195 | QUIT 1
|
---|
196 | ;
|
---|
197 | PROCDT(IEN773) ; Return 773'S processing date (1st), or if not available
|
---|
198 | ; return the 772 creation date/time. ;HL*1.6*85
|
---|
199 | N PROCDT
|
---|
200 | S PROCDT=$P($G(^HLMA(+IEN773,"S")),U) QUIT:PROCDT?7N.E PROCDT ;->
|
---|
201 | QUIT $P($G(^HL(772,+$G(^HLMA(+IEN773,0)),0)),U)
|
---|
202 | ;
|
---|
203 | DTORTM(DTB,DTE,PDT) ; Show date or time?
|
---|
204 | QUIT $S($E(DTB,1,7)=$E(DTE,1,7):$$TM(PDT),1:$$DT(PDT))
|
---|
205 | ;
|
---|
206 | TM(PDT) ; Show the 5 character hh:mm time
|
---|
207 | QUIT $E($P($$FMTE^XLFDT(+PDT),"@",2),1,5)
|
---|
208 | ;
|
---|
209 | DT(PDT) ; Show the 8 character mm/dd/yy date
|
---|
210 | QUIT $E(PDT,4,5)_"/"_$E(PDT,6,7)_"/"_$E(PDT,2,3)
|
---|
211 | ;
|
---|
212 | TYPEINFO() ; Display error type or application information?
|
---|
213 | N DIR,DIRUT,DTOUT,DUOUT,X,Y
|
---|
214 | W !!,"Select the report view now. There are two report views. Both list the "
|
---|
215 | W !,"internal entry number from the HL7 Message Administration file (#773) entry,"
|
---|
216 | W !,"message ID, processing date or time, and logical link. The two report views"
|
---|
217 | W !,"differ in the remainder of the information displayed on the report. "
|
---|
218 | S DIR(0)="S^1:Display message, event, & application data;2:Display error type"
|
---|
219 | S DIR("A")="Select data to display",DIR("B")=1
|
---|
220 | S DIR("?",1)="Select the data to be displayed in the last few columns of the report after"
|
---|
221 | S DIR("?")="the IEN, message ID, processing date or time, and logical link."
|
---|
222 | D ^DIR
|
---|
223 | QUIT $S(Y>0:+Y,1:"")
|
---|
224 | ;
|
---|
225 | EOR ;HLCSRPT4 - Error Listing code ;3/18/02 10:19
|
---|