| 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 | 
|---|