1 | LREPIRM ;DALOI/SED - EMERGING PATHOGENS SEARCH ; 7/16/96
|
---|
2 | ;;5.2;LAB SERVICE;**175,281**;Sep 27, 1994
|
---|
3 | ; Reference to ^ORD(101 supported by IA #972
|
---|
4 | ;
|
---|
5 | ;Search Parameters - LREPI(#)
|
---|
6 | ;Search Date -Start LRRPS
|
---|
7 | ; Stop LRRPE
|
---|
8 | ;
|
---|
9 | MAN ;USED TO RERUN THE OPTION FOR ANY PRIOR MONTHS
|
---|
10 | S LRRTYPE=1
|
---|
11 | W @IOF,?(IOM/2-15),"Laboratory Search rerun option"
|
---|
12 | PROT ;SELECT PROTOCOL
|
---|
13 | K DIC,LRPROT,X,Y
|
---|
14 | S DIC="69.4",DIC("A")="Select Protocol: "
|
---|
15 | S DIC(0)="AEMNQ"
|
---|
16 | S DIC("W")="W ?40,$P(^(0),U,5)"
|
---|
17 | D ^DIC
|
---|
18 | G:+Y'>0 EXIT
|
---|
19 | S LRPROT=+Y
|
---|
20 | OVR K DIR,DIRUT
|
---|
21 | S DIR(0)="Y",DIR("B")="NO",DIR("A")="Override Any Inactive indicators: "
|
---|
22 | S DIR("?")="Enter (Y)es if the overriding of any Inactive indicator is desired. "
|
---|
23 | D ^DIR
|
---|
24 | G:$D(DIRUT) PROT
|
---|
25 | S LROVR=+Y
|
---|
26 | CRI K LRCYCLE,LREPI S LRMSG="Search Parameters" D ALL G:$D(DIRUT) OVR
|
---|
27 | K DIR,DIRUT,DTOUT,DUOUT,DIROUT
|
---|
28 | I +LRALL D PICKALL
|
---|
29 | I +LRALL'>0 D
|
---|
30 | .W @IOF
|
---|
31 | .F Q:$D(DIRUT) D
|
---|
32 | ..S DIR(0)="PAO^69.5:EMZ",DIR("A")="Select Search Parameters: "
|
---|
33 | ..S DIR("?")="Select the Search Parameters. "
|
---|
34 | ..S DIR("S")="D CHK^LREPIRM I LROK"
|
---|
35 | ..D ^DIR
|
---|
36 | ..Q:$D(DIRUT)
|
---|
37 | ..S LREPI(+Y)=""
|
---|
38 | G:$D(DTOUT)!$D(DUOUT)!$D(DIROUT) CRI
|
---|
39 | I '$D(LREPI) W !,"Sorry No Search Parameters Selected" G CRI
|
---|
40 | DATE ;Select Search Date
|
---|
41 | K DIR,DIRUT
|
---|
42 | S DIR("A")="Select Search Date: "
|
---|
43 | S DIR(0)="DOA^:"_DT_":E" D ^DIR
|
---|
44 | G:$D(DIRUT) CRI
|
---|
45 | K DIR,DIRUT,LRCYCLE
|
---|
46 | S LRTYPE=$O(LREPI(0))
|
---|
47 | S LRCYCLE=$P(^LAB(69.5,LRTYPE,0),U,5)
|
---|
48 | S X=Y I LRCYCLE="M" D
|
---|
49 | .D DAYS
|
---|
50 | .S LRRPE=$E(Y,1,5)_X,LRRPS=$E(Y,1,5)_"01"
|
---|
51 | I LRCYCLE="D" S (LRRPE,LRRPS)=Y
|
---|
52 | K X,Y,X1,LRCYCLE,LRTYPE
|
---|
53 | D TASK ;;*Cincinnati - Toggle Task On/Off*
|
---|
54 | ;D EN^LREPI ;;Cincinnati - Toggle Console Execution On/Off*
|
---|
55 | EXIT ;
|
---|
56 | K D0,LRAUTO,LRBEG,LRDT,LREND,LRRNDT,LREPI,LRRPE,LRRPS,LRPREV,ZTSAVE
|
---|
57 | K LRRSD,LRLAG,ZTREQ,ZTRTN,ZTIO,ZTDESC,ZTDTH,ZTSK,X,Y,X1,%DT
|
---|
58 | Q
|
---|
59 | ;
|
---|
60 | TASK ;LETS TASK THIS JOB
|
---|
61 | Q:'$D(LREPI)
|
---|
62 | K ZTSAVE
|
---|
63 | S (ZTSAVE("LREPI("),ZTSAVE("LRRPS"),ZTSAVE("LRRPE"))=""
|
---|
64 | S ZTSAVE("LRRTYPE")="",ZTSAVE("LRPREV")="" S:LRRTYPE=0 ZTDTH=DT
|
---|
65 | S ZTIO="",ZTRTN="EN^LREPI",ZTDESC="Laboratory EPI",ZTREQ="@"
|
---|
66 | D ^%ZTLOAD
|
---|
67 | I '$D(ZTQUEUED)&($D(ZTSK)) W @IOF,!!,"The Task has been queued",!,"Task # ",$G(ZTSK) H 5
|
---|
68 | Q
|
---|
69 | PICKALL ;SELECT ALL ASSOCIATED PARAMETERS
|
---|
70 | S Y=0 F S Y=$O(^LAB(69.5,Y)) Q:+Y'>0!(Y>99) D CHK S:LROK LREPI(Y)=""
|
---|
71 | Q
|
---|
72 | CHK ;CHECK TO SEE IF ITS OK
|
---|
73 | I Y>99 S LROK=0 Q
|
---|
74 | CHKL ;CHECK FOR LOCAL PATHOGENS
|
---|
75 | S:'$D(LRCYCLE) LRCYCLE=$P(^LAB(69.5,Y,0),U,5)
|
---|
76 | S LROK=1
|
---|
77 | S:$P(^LAB(69.5,Y,0),U,7)'=LRPROT LROK=0 Q
|
---|
78 | S:'LROVR&($P(^LAB(69.5,Y,0),U,2)="1") LROK=0 Q
|
---|
79 | S:$P(^LAB(69.5,Y,0),U,7)="" LROK=0 Q
|
---|
80 | S:'$D(^ORD(101,$P(^LAB(69.5,Y,0),U,7),0)) LROK=0 Q
|
---|
81 | S:$P(^LAB(69.5,Y,0),U,5)=LRCYCLE LROK=0 Q
|
---|
82 | Q
|
---|
83 | ALL K DIR,DIRUT
|
---|
84 | S DIR(0)="Y",DIR("B")="YES",DIR("A")="Include All "_LRMSG
|
---|
85 | S DIR("?")="Enter (Y)es or return for all entries to be Selected"
|
---|
86 | D ^DIR
|
---|
87 | S LRALL=+Y
|
---|
88 | Q
|
---|
89 | AUTO ; CHECKS TO SEE IF IT IS TIME TO RUN A SEARCH
|
---|
90 | K %DT,X,Y,LREPI,^TMP($J)
|
---|
91 | S D0=0
|
---|
92 | F S D0=$O(^LAB(69.5,D0)) Q:+D0'>0!(+D0>99) D
|
---|
93 | .Q:$P(^LAB(69.5,D0,0),U,2)="1"
|
---|
94 | .Q:$P(^LAB(69.5,D0,0),U,7)=""
|
---|
95 | .Q:'$D(^ORD(101,$P(^LAB(69.5,D0,0),U,7),0))
|
---|
96 | .S LRCYC=$P(^LAB(69.5,D0,0),U,5)
|
---|
97 | .Q:LRCYC=""
|
---|
98 | .S LRRNDT=$P(^LAB(69.5,D0,0),U,4)
|
---|
99 | .S LRLAG=$P(^LAB(69.5,D0,0),U,3)
|
---|
100 | .S:+$G(LRLAG)'>0 LRLAG="1"
|
---|
101 | .S X="T-"_+(LRLAG-1) D ^%DT Q:+Y'>0
|
---|
102 | .S LRRSD=+Y
|
---|
103 | .;Look at the monthly runs
|
---|
104 | .I LRCYC="M" D
|
---|
105 | ..S X=$S($E(LRRSD,4,5)="01":($E(LRRSD,1,3)-1),1:$E(LRRSD,1,3))
|
---|
106 | ..S X1=$S($E(LRRSD,4,5)="01":"12",1:($E(LRRSD,4,5)-1))
|
---|
107 | ..S:X1<10 X1="0"_X1
|
---|
108 | ..S X=X_X1
|
---|
109 | ..K X1,Y D DAYS
|
---|
110 | ..S LRRPS=$E(X1,1,5)_"01",LRRPE=$E(X1,1,5)_X
|
---|
111 | ..S:LRLAG<10 LRLAG="0"_LRLAG
|
---|
112 | ..S LRDT=$E(DT,1,5)_LRLAG
|
---|
113 | ..I LRRNDT="" S ^TMP($J,"CYC",LRCYC,LRRPS,D0)=LRRPE Q
|
---|
114 | ..Q:DT<LRDT
|
---|
115 | ..Q:DT>LRDT
|
---|
116 | ..S ^TMP($J,"CYC",LRCYC,LRRPS,D0)=LRRPE Q
|
---|
117 | .;LOOK FOR DAILY RUNS
|
---|
118 | .I LRCYC="D" D
|
---|
119 | ..S (LRRPS,LRRPE)=LRRSD
|
---|
120 | ..I LRRNDT="" S ^TMP($J,"CYC",LRCYC,LRRPS,D0)=LRRPE Q
|
---|
121 | ..;Q:LRRNDT>LRRPS
|
---|
122 | ..S ^TMP($J,"CYC",LRCYC,LRRPS,D0)=LRRPE Q
|
---|
123 | ;Lets Task the Jobs
|
---|
124 | K LRRPE,LRRPS,LRCYC,D0
|
---|
125 | F LRCYC="M","D" I $D(^TMP($J,"CYC",LRCYC)) D
|
---|
126 | .S LRRPS=0
|
---|
127 | .F S LRRPS=$O(^TMP($J,"CYC",LRCYC,LRRPS)) Q:+LRRPS'>0 D
|
---|
128 | ..K LREPI
|
---|
129 | ..S D0=0 F S D0=$O(^TMP($J,"CYC",LRCYC,LRRPS,D0)) Q:+D0'>0!(D0>99) D
|
---|
130 | ...S LRRPE=$P(^TMP($J,"CYC",LRCYC,LRRPS,D0),U,1),LREPI(D0)=LRRPS_U_LRRPE
|
---|
131 | ..S LRRTYPE=0
|
---|
132 | ..D TASK
|
---|
133 | K LREPI
|
---|
134 | F LRCYC="M","D" I $D(^TMP($J,"CYC",LRCYC)) D
|
---|
135 | .S LRRPS=0
|
---|
136 | .F S LRRPS=$O(^TMP($J,"CYC",LRCYC,LRRPS)) Q:+LRRPS'>0 D
|
---|
137 | ..K LREPI
|
---|
138 | ..S D0=0 F S D0=$O(^TMP($J,"CYC",LRCYC,LRRPS,D0)) Q:+D0'>0!(D0>99) D
|
---|
139 | ...Q:'$P(^LAB(69.5,D0,0),U,13)
|
---|
140 | ...S LRRPE=$P(^TMP($J,"CYC",LRCYC,LRRPS,D0),U,1),LREPI(D0)=LRRPS_U_LRRPE
|
---|
141 | ..S LRRTYPE=0
|
---|
142 | I $D(LREPI) D
|
---|
143 | .S LRPREV=1
|
---|
144 | .S D0=0 F S D0=$O(LREPI(D0)) Q:D0'>0 S LRRPS=$P(LREPI(D0),U),LRRPE=$P(LREPI(D0),U,2) D PREV,TASK
|
---|
145 | G EXIT
|
---|
146 | DAYS ;GET DAYS OF THE MONTH
|
---|
147 | S X1=X,X=+$E(X,4,5),X=$S("^1^3^5^7^8^10^12^"[(U_X_U):31,X'=2:30,$E(X1,1,3)#4:28,1:29)
|
---|
148 | Q
|
---|
149 | ;
|
---|
150 | PREV S LRPRECYC=$P(^LAB(69.5,D0,0),U,13),LRRPS=$P(LREPI(D0),U),LRRPE=$P(LREPI(D0),U,2) D
|
---|
151 | .I $P(^LAB(69.5,D0,0),U,5)="D" D
|
---|
152 | ..S X1=$P(LRRPS,"."),X2=LRPRECYC D C^%DTC S (LRRPS,LRRPE)=X
|
---|
153 | .I $P(^LAB(69.5,D0,0),U,5)="M" D
|
---|
154 | ..S X1=$P(LRRPS,"."),X2=$E(X1,4,5),X3=X2-LRPRECYC
|
---|
155 | ..I X3>0 S LRRPS=$E(X1,1,3)_$S($L(X3)=1:"0"_X3,1:X3)_"01"
|
---|
156 | ..I X3'>0 S X3=12+X3,LRRPS=$E(X1,1,3)_$S($L(X3)=1:"0"_X3,1:X3)_"01"
|
---|
157 | ..S X1=$P(LRRPE,"."),X2=$E(X1,4,5),X3=X2-LRPRECYC
|
---|
158 | ..I X3'>0 S X3=12+X3
|
---|
159 | ..S DAYS=$S("^1^3^5^7^8^10^12^"[(U_+X3_U):31,+X3'=2:30,$E(X1,1,3)#4:28,1:29)
|
---|
160 | ..S LRRPE=$E(X1,1,3)_$S($L(X3)=1:"0"_X3,1:X3)_DAYS
|
---|
161 | ..K X,X1,X2,X3,DAYS
|
---|
162 | Q
|
---|
163 | ;
|
---|