| 1 | PSOTEXP1 ;BIR/LE-Tally Missing Expiration Dates ;06/14/06 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**250,268**;DEC 1997;Build 9 | 
|---|
| 3 | ;External references ^DPT supported by DBIA 10035 | 
|---|
| 4 | N NAMSP,PATCH,JOBN,DTOUT,DUOUT,ZTSK,ZTRTN,ZTIO,ZTDTH,ZTDESC,QUIT,Y,ZTQUEUED,ZTREQ,ZTSAVE | 
|---|
| 5 | S NAMSP=$$NAMSP | 
|---|
| 6 | S JOBN="TALLY MISSING EXPIRATION DATES" | 
|---|
| 7 | S PATCH="PSO*7*250" | 
|---|
| 8 | ; | 
|---|
| 9 | L +^XTMP(NAMSP):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I '$T D  Q | 
|---|
| 10 | . D BMES^XPDUTL(JOBN_" job is already running.  Halting...") | 
|---|
| 11 | . D MES^XPDUTL("") | 
|---|
| 12 | . D QUIT | 
|---|
| 13 | ; | 
|---|
| 14 | I '$D(^XTMP(NAMSP)) D INITXTMP(NAMSP,JOBN_", "_PATCH,90)        ;90 day life | 
|---|
| 15 | S QUIT=0 | 
|---|
| 16 | ; | 
|---|
| 17 | I $G(^XTMP(NAMSP,0,"LAST"))["COMPLETED" D  Q | 
|---|
| 18 | . W !!,*7,"This job has been run before to completion on " | 
|---|
| 19 | . W $$FMTE^XLFDT($P($G(^XTMP(NAMSP,0,"LAST")),"^",2)),!! | 
|---|
| 20 | . W "If you want to run it again, the global subscript ^XTMP('PSOTEXP1') must be",! | 
|---|
| 21 | . W "deleted prior to doing so.",!! | 
|---|
| 22 | . D QUIT | 
|---|
| 23 | ; | 
|---|
| 24 | ;ques 2, if running from mumps prompt | 
|---|
| 25 | I '$D(XPDQUES("POS2")) D  I 'ZTDTH D QUIT Q | 
|---|
| 26 | . K DIR | 
|---|
| 27 | . S DIR("A")="  Enter when to Queue the "_JOBN_" job to run in date@time   format " | 
|---|
| 28 | . S DIR("B")="NOW" | 
|---|
| 29 | . S DIR(0)="D^::%DT" | 
|---|
| 30 | . S DIR("?")="Enter when to start the job. The default is Now. You can enter a date and time in the format like this: 021506@3:30p" | 
|---|
| 31 | . D ^DIR I $D(DUOUT) W !,"Halting..." S ZTDTH="" Q | 
|---|
| 32 | . S:$D(DTOUT) Y=$$NOW^XLFDT S ZTDTH=$$FMTH^XLFDT(Y) | 
|---|
| 33 | ; | 
|---|
| 34 | ;ques 2, if running from kids install | 
|---|
| 35 | I $D(XPDQUES("POS2")) S ZTDTH=$$FMTH^XLFDT(XPDQUES("POS2")) | 
|---|
| 36 | ; | 
|---|
| 37 | D BMES^XPDUTL("=============================================================") | 
|---|
| 38 | D MES^XPDUTL("Queuing background job for "_JOBN_"...") | 
|---|
| 39 | D MES^XPDUTL("Start time: "_$$HTE^XLFDT(ZTDTH)) | 
|---|
| 40 | D MES^XPDUTL("==============================================================") | 
|---|
| 41 | I ZTDTH="" D BMES^XPDUTL(JOBN_" NOT QUEUED") D QUIT Q | 
|---|
| 42 | ; | 
|---|
| 43 | S:$D(^XTMP(NAMSP,0,"LAST")) ^XTMP(NAMSP,0,"ZAUDIT",$H)="RE-STARTED ON"_"^"_$$NOW^XLFDT_"^"_$P(^XTMP(NAMSP,0,"LAST"),"^",2,5) | 
|---|
| 44 | ; | 
|---|
| 45 | I $P($G(^XTMP(NAMSP,0,"LAST")),"^")="STOP" D | 
|---|
| 46 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="RUN^"_$$NOW^XLFDT | 
|---|
| 47 | E  D | 
|---|
| 48 | . S ^XTMP(NAMSP,0,"LAST")="RUN^"_$$NOW^XLFDT_"^^^" | 
|---|
| 49 | ; | 
|---|
| 50 | S ZTRTN="EN^PSOTEXP1",ZTIO="" | 
|---|
| 51 | S ZTDESC="Background job for "_JOBN_" on prescriptions updated via "_PATCH | 
|---|
| 52 | S ZTSAVE("JOBN")="" | 
|---|
| 53 | L -^XTMP(NAMSP) | 
|---|
| 54 | D ^%ZTLOAD | 
|---|
| 55 | D:$D(ZTSK) | 
|---|
| 56 | . D MES^XPDUTL("*** Task #"_ZTSK_" Queued! ***") | 
|---|
| 57 | . D BMES^XPDUTL("") | 
|---|
| 58 | D BMES^XPDUTL("") | 
|---|
| 59 | K XPDQUES | 
|---|
| 60 | Q | 
|---|
| 61 | QUIT ; | 
|---|
| 62 | L -^XTMP(NAMSP) | 
|---|
| 63 | Q | 
|---|
| 64 | EN ; | 
|---|
| 65 | N PATCH,NAMSP S NAMSP=$$NAMSP,PATCH="PSO*7*250",JOBN="TALLY MISSING EXPIRATION DATES" | 
|---|
| 66 | ;if can't get Lock, then already running. | 
|---|
| 67 | L +^XTMP(NAMSP):3 I '$T D  Q | 
|---|
| 68 | . S:$D(ZTQUEUED) ZTREQ="@" | 
|---|
| 69 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="LOCKED^"_$$NOW^XLFDT | 
|---|
| 70 | ; | 
|---|
| 71 | N PSOSTART,Y,PSOS1,RXP,PSOV7,PSOARR,PSOISS,PSOEXP,PSOSTA,PSOACT,PSOINST,CC,RXE,DFN,PSODRUG,PSOINACT | 
|---|
| 72 | ; | 
|---|
| 73 | D NOW^%DTC S (Y,PSOS1)=% D DD^%DT S PSOSTART=Y | 
|---|
| 74 | I '$G(DT) S DT=$$DT^XLFDT | 
|---|
| 75 | S RXP=+$P($G(^XTMP(NAMSP,0,"LAST")),"^",4) | 
|---|
| 76 | ;get date that PSO v7 was installed | 
|---|
| 77 | S PSOV7=$S($P($G(^PS(59.7,1,49.99)),"^",7):$P(^PS(59.7,1,49.99),"^",7),1:$P($G(^PS(59.7,1,49.99)),"^",4)) | 
|---|
| 78 | S:PSOV7["." PSOV7=$P(PSOV7,".",1) | 
|---|
| 79 | ; | 
|---|
| 80 | ;^XTMP(NAMSP,INSTITUTION)=tot missing expiration dates on or before v7 install^tot missing expiration dates after v7 install^total missing expiration dates^tot past expiration date minus 1 day | 
|---|
| 81 | ; | 
|---|
| 82 | S PSOINST=$P($G(^DIC(4,+$P($G(^XMB(1,1,"XUS")),"^",17),99)),"^") | 
|---|
| 83 | S:'$G(PSOINST) PSOINST="9999999999" | 
|---|
| 84 | S PSOACT=",0,1,2,3,4,5,10,16,",PSOINACT=",11,12,13,14,15," | 
|---|
| 85 | N STOP K ^XTMP(NAMSP,0,"STOP") S STOP=0 S:RXP="" RXP=0 | 
|---|
| 86 | F CC=1:1 S RXP=$O(^PSRX(RXP)) Q:'RXP!(RXP'?1N.NN)  D  Q:STOP | 
|---|
| 87 | . I $D(^XTMP(NAMSP,0,"STOP")) D  Q | 
|---|
| 88 | . . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="STOP^"_$$NOW^XLFDT,STOP=1 | 
|---|
| 89 | . K PSOARR D GETS^DIQ(52,RXP_",",".01;2;6;1;20;26;100","I","PSOARR") | 
|---|
| 90 | . S DFN=$G(PSOARR(52,RXP_",",2,"I")),PSODRUG=$G(PSOARR(52,RXP_",",6,"I")),PSOSTA=$G(PSOARR(52,RXP_",",100,"I")) | 
|---|
| 91 | . S PSOISS=$G(PSOARR(52,RXP_",",1,"I")) | 
|---|
| 92 | . ;--- eliminate bad Rx's | 
|---|
| 93 | . Q:DFN=""!(PSODRUG="") | 
|---|
| 94 | . Q:'$D(^DPT(DFN))!('$D(^PSDRUG(PSODRUG))) | 
|---|
| 95 | . Q:$G(PSOISS)="" | 
|---|
| 96 | . ;--- | 
|---|
| 97 | . S RXE=$G(PSOARR(52,RXP_",",".01","I")),PSOEXP=$G(PSOARR(52,RXP_",",26,"I")) | 
|---|
| 98 | . ;save last date & fill info | 
|---|
| 99 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",3,5)=$G(PSOISS)_"^"_RXP | 
|---|
| 100 | . D SET | 
|---|
| 101 | G STP:STOP | 
|---|
| 102 | S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="COMPLETED^"_$$NOW^XLFDT | 
|---|
| 103 | D MAIL | 
|---|
| 104 | STP ; | 
|---|
| 105 | L -^XTMP(NAMSP) | 
|---|
| 106 | I $D(^XTMP(NAMSP,0,"STOP")) S ^XTMP(NAMSP,0,"ZAUDIT",$H)="STOPPED ON"_"^"_$P(^XTMP(NAMSP,0,"LAST"),"^",2,5) | 
|---|
| 107 | S:$D(ZTQUEUED) ZTREQ="@" | 
|---|
| 108 | K JOBN | 
|---|
| 109 | ;I '$D(^XTMP(NAMSP,0,"STOP")) K ^XTMP(NAMSP) | 
|---|
| 110 | Q | 
|---|
| 111 | ; | 
|---|
| 112 | SET ;Data collected and stored: | 
|---|
| 113 | ; Piece 1 - Pre-install v7 active Rx's with null expiration date | 
|---|
| 114 | ; Piece 2 - Pre-install v7 inactive Rx's with null expiration date | 
|---|
| 115 | ; Piece 3 - Post-install v7 active Rx's with null expiration | 
|---|
| 116 | ; Piece 4 - Post-install v7 inactive Rx's with null expiration | 
|---|
| 117 | ; Piece 5 - total Rx's with null expiration date | 
|---|
| 118 | ; Piece 6 - total active Rx's with expire date of t-1 day | 
|---|
| 119 | ; | 
|---|
| 120 | I PSOEXP="" D  Q | 
|---|
| 121 | . I PSOISS'>PSOV7 D | 
|---|
| 122 | . . S:PSOACT[(","_PSOSTA_",") $P(^XTMP(NAMSP,PSOINST),"^",1)=$P($G(^XTMP(NAMSP,PSOINST)),"^",1)+1 | 
|---|
| 123 | . . S:PSOINACT[(","_PSOSTA_",") $P(^XTMP(NAMSP,PSOINST),"^",2)=$P($G(^XTMP(NAMSP,PSOINST)),"^",2)+1 | 
|---|
| 124 | . I PSOISS>PSOV7 D | 
|---|
| 125 | . . S:PSOACT[(","_PSOSTA_",") $P(^XTMP(NAMSP,PSOINST),"^",3)=$P($G(^XTMP(NAMSP,PSOINST)),"^",3)+1 | 
|---|
| 126 | . . S:PSOINACT[(","_PSOSTA_",") $P(^XTMP(NAMSP,PSOINST),"^",4)=$P($G(^XTMP(NAMSP,PSOINST)),"^",4)+1 | 
|---|
| 127 | . S $P(^XTMP(NAMSP,PSOINST),"^",5)=$P($G(^XTMP(NAMSP,PSOINST)),"^",5)+1 | 
|---|
| 128 | .;S ^XTMP("PSOTEXP1","MISS",RXP)=PSOINST_"^"_PSOISS_"^"_PSOV7_"^"_PSOEXP_"^"_$S($G(PSOSTA)'="":PSOSTA,1:"*")_"^"_$P($G(^PSRX(RXP,0)),"^") | 
|---|
| 129 | ; normal daily job expires all rx's with yesterday's date, so looking for anything before yesterday. | 
|---|
| 130 | I (PSOEXP<(DT-1))&(PSOACT[(","_PSOSTA_",")) S $P(^XTMP(NAMSP,PSOINST),"^",6)=$P($G(^XTMP(NAMSP,PSOINST)),"^",6)+1 | 
|---|
| 131 | ;.S ^XTMP("PSOTEXP1","PAST",$S($G(PSOSTA)'="":PSOSTA,1:"*"),PSOEXP,RXP)=PSOINST_"^"_PSOISS_"^"_PSOV7_"^"_PSOEXP_"^"_PSOSTA_"^"_$P($G(^PSRX(RXP,0)),"^") | 
|---|
| 132 | Q | 
|---|
| 133 | ; | 
|---|
| 134 | STATUS ;show status of job running | 
|---|
| 135 | I $$ST D | 
|---|
| 136 | . W !,"Currently processing:" | 
|---|
| 137 | . I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D | 
|---|
| 138 | . . W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),! | 
|---|
| 139 | . W !?5,"Date being processed > ",$$FMTE^XLFDT($P(^XTMP($$NAMSP,0,"LAST"),"^",3)) | 
|---|
| 140 | . W !?5,"                RX # > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",4) | 
|---|
| 141 | . ;W !?5,"          TOTAL RX's > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",5),! | 
|---|
| 142 | E  D | 
|---|
| 143 | .I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D | 
|---|
| 144 | .. W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),! | 
|---|
| 145 | Q | 
|---|
| 146 | ; | 
|---|
| 147 | STOP ;stop job command | 
|---|
| 148 | I $$ST S ^XTMP($$NAMSP,0,"STOP")="" D | 
|---|
| 149 | . W !,"TALLY MISSING EXPIRATION DATES Job - set to STOP Soon" | 
|---|
| 150 | . W !!,"Check Status to be sure it has stopped and is not running..." | 
|---|
| 151 | . W !,"     (D STATUS^PSOTEXP1)" | 
|---|
| 152 | Q | 
|---|
| 153 | ST() ;status | 
|---|
| 154 | L +^XTMP($$NAMSP):3 I $T D  Q 0 | 
|---|
| 155 | . L -^XTMP($$NAMSP) | 
|---|
| 156 | . W !,"*** NOT CURRENTLY RUNNING! ***",! | 
|---|
| 157 | Q 1 | 
|---|
| 158 | INITXTMP(NAMSP,TITLE,LIFE) ;create ^Xtmp according to SAC std | 
|---|
| 159 | N BEGDT,PURGDT | 
|---|
| 160 | S BEGDT=$$NOW^XLFDT() | 
|---|
| 161 | S PURGDT=$$FMADD^XLFDT(BEGDT,LIFE) | 
|---|
| 162 | S ^XTMP(NAMSP,0)=PURGDT_"^"_BEGDT_"^"_TITLE | 
|---|
| 163 | Q | 
|---|
| 164 | NAMSP() ; | 
|---|
| 165 | Q $T(+0) | 
|---|
| 166 | ; | 
|---|
| 167 | MAIL ; | 
|---|
| 168 | N PSOEND,PSOEND2,PSOTEXT,XMY,LIN,DATA,J,L,PSOINST,M,LEN | 
|---|
| 169 | S LIN="",$P(LIN," ",80)="",LEN=80 | 
|---|
| 170 | D NOW^%DTC S Y=% D DD^%DT S PSOEND=Y | 
|---|
| 171 | S PSOEND2=$$FMTE^XLFDT(%,"1PS") | 
|---|
| 172 | I $G(DUZ) S XMY(DUZ)="" | 
|---|
| 173 | S XMDUZ=PATCH_" "_JOBN | 
|---|
| 174 | S XMSUB="Outpatient Pharmacy "_PATCH_" "_JOBN | 
|---|
| 175 | S XMY("ELLZEY.LINDA@FORUM.VA.GOV")="" | 
|---|
| 176 | S XMY("WHITE.ELAINE@FORUM.VA.GOV")="" | 
|---|
| 177 | S XMY("WILLIAMSON.ERIC@FORUM.VA.GOV")="" | 
|---|
| 178 | I $O(XMY(""))="" Q  ; no recipients for mail message | 
|---|
| 179 | S PSOTEXT(1)="The "_JOBN_" job for the Outpatient Pharmacy" | 
|---|
| 180 | S PSOTEXT(2)="patch ("_PATCH_") started "_PSOSTART | 
|---|
| 181 | S PSOTEXT(3)="and completed "_PSOEND_"." | 
|---|
| 182 | S PSOTEXT(4)=" " | 
|---|
| 183 | S PSOTEXT(5)="Excel comma delimited data below, five headings, one data line" | 
|---|
| 184 | S PSOTEXT(6)="Note that an institution of 999999999 denotes one was not found during run." | 
|---|
| 185 | S PSOTEXT(7)=",,,,,,Total Active Rx's" | 
|---|
| 186 | S PSOTEXT(8)=",Before v7 Install,Before v7 Install,After v7 Install,After v7 Install,,With" | 
|---|
| 187 | S PSOTEXT(9)=",Tot Active Rx's,Tot Inactive,Tot Active,Tot Inactive,Total Rx's,Expiration" | 
|---|
| 188 | S PSOTEXT(10)=",Missing Expired,Rx's Missing,Rx's Missing,Rx's Missing,Missing,Date of T-1" | 
|---|
| 189 | S PSOTEXT(11)="Institution,Date,Expired Date,Expired Date,Expired Date,Expired Date,Day" | 
|---|
| 190 | S PSOINST=0,L=12 | 
|---|
| 191 | F  S PSOINST=$O(^XTMP(NAMSP,PSOINST)) Q:PSOINST=""!(PSOINST'?1N.NN)  D | 
|---|
| 192 | . S DATA=^XTMP(NAMSP,PSOINST),DATA=$TR(DATA,"^",",") | 
|---|
| 193 | . S PSOTEXT(L)=$E((PSOINST_","_DATA_LIN),1,LEN),L=L+1 | 
|---|
| 194 | S L=L+1,PSOTEXT(L)=" " | 
|---|
| 195 | ; | 
|---|
| 196 | S XMTEXT="PSOTEXT(" N DIFROM D ^XMD K XMDUZ,XMTEXT,XMSUB | 
|---|
| 197 | Q | 
|---|