| 1 | PSO160DR ;BIR/BHW-Patch 160 Post Install routine - Driver ;11/24/03 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**160**;DEC 1997 | 
|---|
| 3 | ;External reference to ^SC( supported by DBIA 2675 | 
|---|
| 4 | ;External reference to ^ORD(101, is supp. by DBIA# 872 | 
|---|
| 5 | ; | 
|---|
| 6 | ;Setup TaskManager Task | 
|---|
| 7 | D MGCHK,PRTCL S ZTDTH=@XPDGREF@("PSO160Q"),ZTIO="" | 
|---|
| 8 | S ZTRTN="START^PSO160DR",ZTDESC="Post Install for patch PSO*7*160" | 
|---|
| 9 | D ^%ZTLOAD K ZTDTH,ZTRTN,ZTIO,ZTDESC | 
|---|
| 10 | I $D(ZTSK)&('$D(ZTQUEUED)) D BMES^XPDUTL("Task Queued!") | 
|---|
| 11 | Q | 
|---|
| 12 | ; | 
|---|
| 13 | START ; | 
|---|
| 14 | N PSOTDFN,PSOTDBG,PSOTIBD,TPBCL,PATNAM,PATSSN,VADM,DFN,HLIEN,HLSTOP,SP | 
|---|
| 15 | N PSOTCNT,PATCNT,RXCNT,EMCNT,HLSTOPC,HLCNT,PATSTATC,PATSTAT,X1,X2,X,% | 
|---|
| 16 | N TPBCLP,TPBCLE | 
|---|
| 17 | ; | 
|---|
| 18 | K ^XTMP("PSO160P1",$J),^XTMP("PSO160P2",$J) | 
|---|
| 19 | L +^XTMP("PSO160DR"):0 I '$T W "Already running." S:$D(ZTQUEUED) ZTREQ="@" Q | 
|---|
| 20 | D NOW^%DTC S ^XTMP("PSO160DR",$J,"START")=% | 
|---|
| 21 | I '$G(DT) S DT=$$DT^XLFDT | 
|---|
| 22 | S $P(SP," ",80)="",X1=DT,X2=+90 D C^%DTC | 
|---|
| 23 | S (^XTMP("PSO160P1",0),^XTMP("PSO160P2",0))=$G(X)_"^"_DT | 
|---|
| 24 | ; | 
|---|
| 25 | ;Begin Processing.  Entry point for Task | 
|---|
| 26 | S (PSOTDFN,PATCNT,RXCNT)=0,EMCNT=1 | 
|---|
| 27 | ; | 
|---|
| 28 | ;Find NON-VA entry in RX PATIENT STATUS file (#53) | 
|---|
| 29 | S (PATSTATC,PATSTAT)=0 | 
|---|
| 30 | F  S PATSTAT=$O(^PS(53,"B",PATSTAT)) Q:'$L(PATSTAT)  D | 
|---|
| 31 | . I $$UP^XLFSTR(PATSTAT)="NON-VA" D | 
|---|
| 32 | . . S PATSTATC=$O(^PS(53,"B",PATSTAT,"")) | 
|---|
| 33 | . . Q | 
|---|
| 34 | . Q | 
|---|
| 35 | I 'PATSTATC S PATSTATC="" | 
|---|
| 36 | ; | 
|---|
| 37 | ;Find TPB Clinic (Used in TPB Eligibility Loop) | 
|---|
| 38 | S (HLIEN,HLCNT)=0,(HLSTOP,HLSTOPC,TPBCL,TPBCLE)="" | 
|---|
| 39 | F  S HLIEN=$O(^SC(HLIEN)) Q:'HLIEN  D | 
|---|
| 40 | . S HLSTOP=$$GET1^DIQ(44,HLIEN,8,"I") Q:'HLSTOP | 
|---|
| 41 | . S HLSTOPC=$$GET1^DIQ(40.7,HLSTOP,1) Q:'HLSTOPC | 
|---|
| 42 | . I (HLSTOPC=161) D | 
|---|
| 43 | . . S HLCNT=HLCNT+1,TPBCL=HLSTOP,TPBCLE=$$GET1^DIQ(40.7,HLSTOP,.01) | 
|---|
| 44 | . . Q | 
|---|
| 45 | . Q | 
|---|
| 46 | ;If more than 1 CLINIC found, set to 0 because we can't set it | 
|---|
| 47 | I (HLCNT>1) S TPBCL=0,TPBCLE="" | 
|---|
| 48 | ; | 
|---|
| 49 | ;Start Loop of TPB ELIGIBILITY (#52.91) | 
|---|
| 50 | ; | 
|---|
| 51 | S PSOTDFN=0 | 
|---|
| 52 | F  S PSOTDFN=$O(^PS(52.91,PSOTDFN)) Q:'PSOTDFN  D | 
|---|
| 53 | . ; | 
|---|
| 54 | . S PSOTDBG=$$GET1^DIQ(52.91,PSOTDFN,1,"I")     ;Get DATE PHARMACY BENEFIT BEGAN | 
|---|
| 55 | . S PSOTIBD=$$GET1^DIQ(52.91,PSOTDFN,2,"I")     ;Get INACTIVATION OF BENEFIT DATE | 
|---|
| 56 | . ; | 
|---|
| 57 | . ;Get PATIENT (#2) Specific Information | 
|---|
| 58 | . S DFN=PSOTDFN D DEM^VADPT | 
|---|
| 59 | . S PATNAM=$P(VADM(1),U,1) | 
|---|
| 60 | . I '$L(PATNAM) S PATNAM="Missing Patient" | 
|---|
| 61 | . S PATSSN=$P(VADM(2),U,2) | 
|---|
| 62 | . S PATSSN=$E($P(PATSSN,"-",3),1,5) | 
|---|
| 63 | . ; | 
|---|
| 64 | . ;Marking Rx's as TPB - Part 1 | 
|---|
| 65 | . D EN^PSO160P1 | 
|---|
| 66 | . ; | 
|---|
| 67 | . ;Inactivating Patient TPB's Benefit - Part 2 | 
|---|
| 68 | . D EN^PSO160P2 | 
|---|
| 69 | . Q | 
|---|
| 70 | ; | 
|---|
| 71 | ;Process FINISH date (to be included in the Mailman messages) | 
|---|
| 72 | D NOW^%DTC S ^XTMP("PSO160DR",$J,"FINISH")=% | 
|---|
| 73 | ; | 
|---|
| 74 | ;Mailman Message with Rx's marked as TPB - Part 1 | 
|---|
| 75 | D MAIL^PSO160P1 | 
|---|
| 76 | ; | 
|---|
| 77 | ;Mailman Message with Patients inactivated from TPB - Part 2 | 
|---|
| 78 | D MAIL^PSO160P2 | 
|---|
| 79 | ; | 
|---|
| 80 | L -^XTMP("PSO160DR") K ^XTMP("PSO160DR",$J) | 
|---|
| 81 | Q | 
|---|
| 82 | ; | 
|---|
| 83 | PRTCL ;Adds the Pharmacy PSO TPB SD SUB protocol as a subscriber to the | 
|---|
| 84 | ;Scheduling protocol SDAM APPOINTMENT EVENTS | 
|---|
| 85 | ; | 
|---|
| 86 | N SDPRTCL,PSOPRTCL,X,DIC,DA,DLAYGO,DD,DO,DINUM,Y | 
|---|
| 87 | ; | 
|---|
| 88 | S SDPRTCL=$O(^ORD(101,"B","SDAM APPOINTMENT EVENTS","")) | 
|---|
| 89 | S PSOPRTCL=$O(^ORD(101,"B","PSO TPB SD SUB","")) | 
|---|
| 90 | ; | 
|---|
| 91 | I 'SDPRTCL!'PSOPRTCL Q | 
|---|
| 92 | ; | 
|---|
| 93 | ;Already a subscriber | 
|---|
| 94 | I $D(^ORD(101,SDPRTCL,10,"B",PSOPRTCL)) Q | 
|---|
| 95 | ; | 
|---|
| 96 | S X=PSOPRTCL,DIC="^ORD(101,"_SDPRTCL_",10,",DLAYGO=101.01 | 
|---|
| 97 | S DA(1)=SDPRTCL,DIC(0)="L" D FILE^DICN | 
|---|
| 98 | Q | 
|---|
| 99 | ; | 
|---|
| 100 | ; | 
|---|
| 101 | MGCHK ;If ther user installing the patch is not on the new Mail Group | 
|---|
| 102 | ;PSO TPB GROUP, include him/her as a member | 
|---|
| 103 | ; | 
|---|
| 104 | N MGIEN,USER,X,DIC,DA,DLAYGO,DD,DO,DINUM,Y | 
|---|
| 105 | S USER=+@XPDGREF@("PSOUSER"),MGIEN=$O(^XMB(3.8,"B","PSO TPB GROUP","")) | 
|---|
| 106 | I 'MGIEN Q | 
|---|
| 107 | I $D(^XMB(3.8,MGIEN,1,"B",USER)) Q | 
|---|
| 108 | S X=USER,DIC="^XMB(3.8,"_MGIEN_",1,",DLAYGO=3.81 | 
|---|
| 109 | S DA(1)=MGIEN,DIC(0)="L" D FILE^DICN | 
|---|
| 110 | Q | 
|---|