1 | EASMTL1 ;MIN/TCM ALB/SCK/AEG/PHH - AUTOMATED MEANS TEST LETTER - PATIENT SEARCH ; 07/2/01
|
---|
2 | ;;1.0;ENROLLMENT APPLICATION SYSTEM;**3,12,20,54**;MAR 15,2001
|
---|
3 | ; Conversion from class III software
|
---|
4 | ;
|
---|
5 | QUEUE ; Main entry point for tasked (background) letter search
|
---|
6 | N ZTRTN,ZTDESC,ZTDTH,ZTIO,ZTSK,ZDATE
|
---|
7 | ;
|
---|
8 | S ZTRTN="EN^EASMTL1"
|
---|
9 | S ZTDESC="AUTOMATED MT LETTERS GENERATOR"
|
---|
10 | S (ZTDTH,ZDATE)=$$NOW^XLFDT
|
---|
11 | S ZTIO=""
|
---|
12 | D ^%ZTLOAD
|
---|
13 | Q
|
---|
14 | ;
|
---|
15 | SETDT(EASRUN) ;
|
---|
16 | ; Input
|
---|
17 | ; EASRUN - Default start date for processing
|
---|
18 | ;
|
---|
19 | ; Output
|
---|
20 | ; 1 - Ok
|
---|
21 | ; 0 - Quit
|
---|
22 | ; EASRUN - Accepted start date for processing
|
---|
23 | ;
|
---|
24 | N DIR,DIRUT,RSLT
|
---|
25 | ;
|
---|
26 | S DIR("A",1)="The prior processing date is not available. A default date"
|
---|
27 | S DIR("A",2)="of "_$$FMTE^XLFDT(EASRUN)_" will be used."
|
---|
28 | S DIR("A")="Ok to continue? "
|
---|
29 | S DIR(0)="YAO",DIR("B")="YES"
|
---|
30 | D ^DIR K DIR
|
---|
31 | I $D(DIRUT) Q 0
|
---|
32 | Q:Y Y
|
---|
33 | ;
|
---|
34 | S DIR(0)="DAO^:DT:EX",DIR("B")=$$FMTE^XLFDT(EASRUN)
|
---|
35 | S DIR("?")="^D HELP^%DTC"
|
---|
36 | S DIR("A",1)=""
|
---|
37 | S DIR("A")="Select new start date: "
|
---|
38 | D ^DIR K DIR
|
---|
39 | I $D(DIRUT) Q 0
|
---|
40 | S EASRUN=Y
|
---|
41 | Q 1
|
---|
42 | ;
|
---|
43 | EN ; Main entry point for processing
|
---|
44 | N EASLAST,X,EASLST,EASABRT,EASN,EAS6CNT,EAS3CNT,EAS0CNT,EASDT,EASDTFLG,EADT,MSG,EASX
|
---|
45 | ;
|
---|
46 | ; Get last processing date, default to TODAY - 30 if date not available
|
---|
47 | S EASX=$$GET1^DIQ(713,1,2,"I")
|
---|
48 | S EADT=$$DT^XLFDT
|
---|
49 | ; If letter search has already been run for TODAY, quit
|
---|
50 | I EASX=EADT D Q
|
---|
51 | . I '$D(ZTQUEUED) D
|
---|
52 | . . W !!,$CHAR(7),">> The Means Test Letter search has been run for today.",!
|
---|
53 | . . D PAUSE^EASMTUTL
|
---|
54 | ;
|
---|
55 | I EASX S EASLAST=$$FMADD^XLFDT(EASX,1)
|
---|
56 | I '$G(EASX) D Q:$G(EASABRT)
|
---|
57 | . S EASLAST=$$FMADD^XLFDT(DT,-30)
|
---|
58 | . I '$D(ZTQUEUED) S:'$$SETDT(.EASLAST) EASABRT=1
|
---|
59 | ;
|
---|
60 | ; Check lock on parameter file, one process at a time, quit if locked
|
---|
61 | I '$$LOCK^EASMTUTL(1) D Q
|
---|
62 | . I $D(ZTQUEUED) D Q
|
---|
63 | . . D ALERT^EASMTUTL("Auto MT Letters: This process is already running, "_$$FMTE^XLFDT(EADT,"2D"))
|
---|
64 | . W !!,$CHAR(7),"This process is already running, please try again later"
|
---|
65 | . D PAUSE^EASMTUTL
|
---|
66 | ;
|
---|
67 | D BLDLST(EASLAST,EADT) ; Build processing date list
|
---|
68 | D PROCESS ; Process dates
|
---|
69 | S EASX=$$LOCK^EASMTUTL(0)
|
---|
70 | D UPDPARAM(EADT)
|
---|
71 | D STATS(EASLAST,.EAS6CNT,EADT)
|
---|
72 | ;
|
---|
73 | I $D(ZTQUEUED) D
|
---|
74 | . S MSG="Auto-Letters Search completed: "_$$FMTE^XLFDT($$NOW^XLFDT)
|
---|
75 | . D ALERT^EASMTUTL(MSG)
|
---|
76 | Q
|
---|
77 | ;
|
---|
78 | BLDLST(FRDT,TODT) ; Build processing date list
|
---|
79 | ; Input
|
---|
80 | ; FRDT - Beginning date for processing list
|
---|
81 | ; TODT - Ending date for processing list
|
---|
82 | ;
|
---|
83 | N EASN
|
---|
84 | ;
|
---|
85 | S EASN=FRDT,EASLST(FRDT)="",EASLST(TODT)=""
|
---|
86 | F S EASN=$$FMADD^XLFDT(EASN,1) Q:EASN>TODT S EASLST(EASN)=""
|
---|
87 | Q
|
---|
88 | ;
|
---|
89 | PROCESS ; Get anniversary and threshold dates
|
---|
90 | N EASPRCDT
|
---|
91 | ;
|
---|
92 | S (EAS0CNT,EAS3CNT,EAS6CNT)=0
|
---|
93 | ; Calculate Anniverary date and 60/30/0 dates based on the Anniverary date
|
---|
94 | S EASPRCDT=0 ; Begin loop through processing dates
|
---|
95 | F S EASPRCDT=$O(EASLST(EASPRCDT)) Q:EASPRCDT'>0 D Q:$G(ZTSTOP) ; Quit if stop request
|
---|
96 | . K EASDT
|
---|
97 | . I '$D(ZTQUEUED) W !?5,">> Processing date "_$$FMTE^XLFDT(EASPRCDT)_" in progress <<",!
|
---|
98 | . ; Anniversary date is processing date minus one year plus sixty days
|
---|
99 | . ;
|
---|
100 | . S EASDT("ANV")=$$FMADD^XLFDT($$SUBLEAP^EASMTUTL(EASPRCDT),60) ; Anv date: 1 Year - 60 days
|
---|
101 | . S EASDT("60")=$$FMADD^XLFDT(EASDT("ANV"),(365-60)) ; Define 60 day letter print date
|
---|
102 | . S EASDT("30")=$$FMADD^XLFDT(EASDT("ANV"),(365-30)) ; Define 30 day letter print date
|
---|
103 | . S EASDT("0")=$$FMADD^XLFDT(EASDT("ANV"),365) ; Define 0 day letter print date
|
---|
104 | . ;
|
---|
105 | . ; Call the threshold date search
|
---|
106 | . D EN60^EASMTL2
|
---|
107 | . ; Check for stop request if queued
|
---|
108 | . I $D(ZTQUEUED),$$S^%ZTLOAD S ZTSTOP=1
|
---|
109 | Q
|
---|
110 | ;
|
---|
111 | UPDPARAM(EASDT) ; Update the EAS Parameter file, #713
|
---|
112 | ; Input
|
---|
113 | ; EASDT - Today's date
|
---|
114 | ;
|
---|
115 | N DIE,DA,DR
|
---|
116 | ;
|
---|
117 | S DIE="^EAS(713,",DA=1,DR="2////^S X=EASDT"
|
---|
118 | S:'$D(ZTQUEUED) DR=DR_";3////^S X=DUZ;4////^S X=EASDT"
|
---|
119 | D ^DIE K DIE
|
---|
120 | Q
|
---|
121 | ;
|
---|
122 | STATS(EASLAST,EAS6CNT,EASDT) ;Gather and print statistics
|
---|
123 | ; Input
|
---|
124 | ; EASLAST - Last date processed (Beginning date)
|
---|
125 | ; EAS6CNT - Array of 60 day letters
|
---|
126 | ; EASDT - Ending date of processing
|
---|
127 | ;
|
---|
128 | N MSG,EASD,LINE,TOT,XMSUB,XMY,XMTEXT,XMDUZ,ZDCD
|
---|
129 | ;
|
---|
130 | ; EAS*1*12 modification
|
---|
131 | S ZDCD=$S($$VERSION^XPDUTL("IVMC"):0,1:60)
|
---|
132 | ; **
|
---|
133 | ; EAS*1*20 modification
|
---|
134 | I $G(ZDCD)'>0,$G(DT)>3021014 S ZDCD=60
|
---|
135 | ;
|
---|
136 | S MSG(.1)="Automated Means Test Letter Generator Statistics"
|
---|
137 | S MSG(.2)="------------------------------------------------"
|
---|
138 | S MSG(.3)=""
|
---|
139 | S MSG(.4)="Beginning Processing Date: "_$$FMTE^XLFDT(EASLAST)
|
---|
140 | S MSG(.5)="Ending Processing Date: "_$$FMTE^XLFDT(EASDT)
|
---|
141 | S MSG(.6)=""
|
---|
142 | S MSG(11)=" "_ZDCD_"-day Letters: "_EAS6CNT
|
---|
143 | S MSG(16)=""
|
---|
144 | S LINE=18
|
---|
145 | ;
|
---|
146 | S LINE=LINE+1
|
---|
147 | S MSG(LINE)=ZDCD_" Day Letter Totals: "
|
---|
148 | S EASD=0
|
---|
149 | F S EASD=$O(EAS6CNT(EASD)) Q:'EASD D
|
---|
150 | . I +$G(EAS6CNT(EASD)) D
|
---|
151 | . . S LINE=LINE+1
|
---|
152 | . . S MSG(LINE)=" "_$$FMTE^XLFDT(EASD)_" : "_EAS6CNT(EASD)
|
---|
153 | ;
|
---|
154 | S XMSUB="AUTO MT LETTER RESULTS - "_$$FMTE^XLFDT(EASDT)
|
---|
155 | S XMTEXT="MSG("
|
---|
156 | S XMY("G.EAS MTLETTERS")=""
|
---|
157 | S XMDUZ="AUTOMATED MT LETTERS"
|
---|
158 | D ^XMD
|
---|
159 | Q
|
---|