| 1 | PSUCP2 ;BIR/TJH - CHECK COMPLETION OF MONTHLY PBM REPORT ;25 AUG 1998 | 
|---|
| 2 | ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005 | 
|---|
| 3 | ; | 
|---|
| 4 | ;DBIAs | 
|---|
| 5 | ; Reference to File #4    supported by DBIA 10090 | 
|---|
| 6 | ; Reference to File #4.3  supported by DBIA 10091 | 
|---|
| 7 | ; Reference to File #40.8 supported by DBIA 2438 | 
|---|
| 8 | ; Reference to File #59.7 supported by DBIA 2854 | 
|---|
| 9 | ; | 
|---|
| 10 | MANUAL ; Entry point if tasked by PSU PBM MANUAL option | 
|---|
| 11 | S PSUWAY="Manual" | 
|---|
| 12 | AUTO ; Entry point if tasked by PSU PBM AUTO option | 
|---|
| 13 | I '$D(PSUWAY) S PSUWAY="Automatic" | 
|---|
| 14 | D NOW^%DTC | 
|---|
| 15 | S PSUNOW=% K %,%H,%I,X | 
|---|
| 16 | S PSULRD=$$VALI^PSUTL(59.7,1,90) ; last run date | 
|---|
| 17 | D | 
|---|
| 18 | .I PSULRD="" S PSUOK=0 Q  ; it's 24 hours later and finish time is not set, may be a problem. | 
|---|
| 19 | .S X1=PSUNOW,X2=PSULRD D ^%DTC | 
|---|
| 20 | .I X>6 S PSUOK=0 Q  ; the last run date must be left over from a previous run, it's a problem. | 
|---|
| 21 | .S PSUOK=1 | 
|---|
| 22 | G:PSUOK EXIT ; no message sent if OK. | 
|---|
| 23 | D XMY^PSUTL1 | 
|---|
| 24 | M XMY=PSUXMYS1 | 
|---|
| 25 | I $G(PSUMASF) M XMY=PSUXMYH | 
|---|
| 26 | S X=$$VALI^PSUTL(4.3,1,217),PSUDIV=+$$VAL^PSUTL(4,X,99) | 
|---|
| 27 | S X=PSUDIV,DIC=40.8,DIC(0)="XM" D ^DIC | 
|---|
| 28 | S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01) | 
|---|
| 29 | S XMSUB="PBM "_PSUWAY_" Statistics Job "_PSUDIV_" "_PSUDIVNM | 
|---|
| 30 | S X(1)="The PBM "_PSUWAY_" Statistics background job did not run to completion." | 
|---|
| 31 | S X(2)="Please correct the problem and retransmit the data to the National PBM" | 
|---|
| 32 | S X(3)="section at Hines." | 
|---|
| 33 | S XMTEXT="X(" | 
|---|
| 34 | S XMCHAN=1 | 
|---|
| 35 | D ^XMD | 
|---|
| 36 | EXIT ; normal exit point from PSUCP2 | 
|---|
| 37 | K PSUWAY,PSUNOW,PSULRD,PSUOK,PSUDIV,PSUDIVNM | 
|---|
| 38 | Q | 
|---|
| 39 | MMNOMAP ; Generate MM regarding locations not mapped | 
|---|
| 40 | Q:$D(^XTMP("PSU_"_PSUJOB,"PSUFLAG3"))  ;Quit if user does not want a | 
|---|
| 41 | ;copy sent to self | 
|---|
| 42 | ; | 
|---|
| 43 | N TXT1,TXT2 | 
|---|
| 44 | ; | 
|---|
| 45 | D PULL^PSUCP | 
|---|
| 46 | F I=1:1:$L(PSUOPTS,",") S PSUMOD($P(PSUOPTS,",",I))="" | 
|---|
| 47 | S X=$$VALI^PSUTL(4.3,1,217),PSUSNDR=+$$VAL^PSUTL(4,X,99),PSUNAME=$$VAL^PSUTL(4,X,.01) | 
|---|
| 48 | K TXT | 
|---|
| 49 | S TXT(1)="The locations listed below have not been mapped to a Medical Center" | 
|---|
| 50 | S TXT(2)="Division or Outpatient Site. All data extracted from these locations have" | 
|---|
| 51 | S TXT(3)="been attributed to "_PSUSNDR_" "_PSUNAME | 
|---|
| 52 | S TXT(4)=" " | 
|---|
| 53 | S TLC=4 | 
|---|
| 54 | ; | 
|---|
| 55 | I $D(PSUARSUB) D | 
|---|
| 56 | .I $D(^XTMP(PSUARSUB,"AOU")),$D(PSUMOD(3)) D | 
|---|
| 57 | ..K AOUNMAP,MAP  ;Array to hold unmapped AOU data | 
|---|
| 58 | ..N LOC,LOC1 | 
|---|
| 59 | ..M MAP=^XTMP(PSUARSUB,"AOU") | 
|---|
| 60 | ..F TXT=" ","AOUs:" D TXT | 
|---|
| 61 | ..S IEN=0 F  S IEN=$O(MAP(IEN)) Q:IEN=""  D | 
|---|
| 62 | ...S LOC=MAP(IEN,.01) | 
|---|
| 63 | ...M AOUNMAP(LOC)=MAP(IEN) | 
|---|
| 64 | ..S LOC1=0 | 
|---|
| 65 | ..F  S LOC1=$O(AOUNMAP(LOC1)) Q:LOC1=""  D | 
|---|
| 66 | ...S TXT1=AOUNMAP(LOC1,.01) | 
|---|
| 67 | ...S TXT2=$G(AOUNMAP(LOC1,3)) I TXT2'="" S TXT2="   **INACTIVE**" | 
|---|
| 68 | ...S TXT=TXT1_TXT2 D TXT | 
|---|
| 69 | .; | 
|---|
| 70 | .I '$D(^XTMP(PSUARSUB,"AOU")),$D(PSUMOD(3)) D | 
|---|
| 71 | ..F TXT=" ","AOUs:" D TXT | 
|---|
| 72 | ..S TXT="There are no unmapped AOU's for the dates of this extract" D TXT | 
|---|
| 73 | ; | 
|---|
| 74 | I $D(PSUARSUB) D | 
|---|
| 75 | .I $D(^XTMP(PSUARSUB,"NAOU")),$D(PSUMOD(6)) D | 
|---|
| 76 | ..K NAOUMAP,MAP | 
|---|
| 77 | ..N LOC,LOC1 | 
|---|
| 78 | ..M MAP=^XTMP(PSUARSUB,"NAOU") | 
|---|
| 79 | ..F TXT="","NAOUs:" D TXT | 
|---|
| 80 | ..S IEN=0 F  S IEN=$O(MAP(IEN)) Q:IEN'>0  D | 
|---|
| 81 | ...S LOC=MAP(IEN,.01) | 
|---|
| 82 | ...M NAOUMAP(LOC)=MAP(IEN) | 
|---|
| 83 | ..S LOC1=0 | 
|---|
| 84 | ..F  S LOC1=$O(NAOUMAP(LOC1)) Q:LOC1=""  D | 
|---|
| 85 | ...S TXT1=NAOUMAP(LOC1,.01) | 
|---|
| 86 | ...S TXT2=$G(NAOUMAP(LOC1,4)) I TXT2'="" S TXT2="   **INACTIVE**" | 
|---|
| 87 | ...S TXT=TXT1_TXT2 D TXT | 
|---|
| 88 | .; | 
|---|
| 89 | .I '$D(^XTMP(PSUARSUB,"NAOU")),$D(PSUMOD(6)) D | 
|---|
| 90 | .. F TXT=" ","NAOUs:" D TXT | 
|---|
| 91 | ..S TXT="There are no unmapped NAOU's for the dates of this extract" D TXT | 
|---|
| 92 | ; | 
|---|
| 93 | I $D(PSUARSUB) D | 
|---|
| 94 | .I $D(^XTMP(PSUARSUB,"DAPH")),$D(PSUMOD(5)) D | 
|---|
| 95 | ..K DAPH,MAP | 
|---|
| 96 | ..N LOC,LOC1 | 
|---|
| 97 | ..M MAP=^XTMP(PSUARSUB,"DAPH") | 
|---|
| 98 | ..F TXT="","DA Pharmacy Locations:" D TXT | 
|---|
| 99 | ..S IEN=0 F  S IEN=$O(MAP(IEN)) Q:IEN'>0  D | 
|---|
| 100 | ...S LOC=MAP(IEN,.01) | 
|---|
| 101 | ...M DAPH(LOC)=MAP(IEN) | 
|---|
| 102 | ..S LOC1=0 | 
|---|
| 103 | ..F  S LOC1=$O(DAPH(LOC1)) Q:LOC1=""  D | 
|---|
| 104 | ...S TXT1=DAPH(LOC1,.01) | 
|---|
| 105 | ...S TXT2=$G(DAPH(LOC1,4)) I TXT2'="" S TXT2="   **INACTIVE**" | 
|---|
| 106 | ...S TXT=TXT1_TXT2 D TXT | 
|---|
| 107 | .; | 
|---|
| 108 | .I '$D(^XTMP(PSUARSUB,"DAPH")),$D(PSUMOD(5)) D | 
|---|
| 109 | .. F TXT=" ","DA Pharmacy Locations:" D TXT | 
|---|
| 110 | ..S TXT="There are no unmapped DA Pharmacy Locations for the dates of this extract" D TXT | 
|---|
| 111 | ; | 
|---|
| 112 | MSGNOMAP ; send MM | 
|---|
| 113 | ; | 
|---|
| 114 | S Y=PSUSDT\1 X ^DD("DD") S PSUDTS=Y | 
|---|
| 115 | S Y=PSUEDT\1 X ^DD("DD") S PSUDTE=Y | 
|---|
| 116 | S XMSUB="PBM Unmapped Locations for "_PSUDTS_" to "_PSUDTE_" from "_PSUSNDR_" "_PSUNAME | 
|---|
| 117 | S XMTEXT="TXT(" | 
|---|
| 118 | S XMY("G.PSU PBM")="" | 
|---|
| 119 | S XMY(DUZ)="" | 
|---|
| 120 | I $D(PSUARSUB) D ^XMD | 
|---|
| 121 | Q | 
|---|
| 122 | ; | 
|---|
| 123 | TXT S TLC=TLC+1,TXT(TLC)=TXT | 
|---|
| 124 | Q | 
|---|