[613] | 1 | PSUOPMD ;BIR/CFL,DAM - PSU PBM Multidose Outpatient Pharmacy create mailman messages ;17 NOV 2004
|
---|
| 2 | ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
|
---|
| 3 | ;
|
---|
| 4 | ;DBIA(s)
|
---|
| 5 | ; Reference to file #4.3 supported by DBIA 2496
|
---|
| 6 | ; Reference to file #59 supported by DBIA 2510
|
---|
| 7 | ; Reference to file #4 supported by DBIA 10090
|
---|
| 8 | ;
|
---|
| 9 | EN ;
|
---|
| 10 | ;
|
---|
| 11 | S $P(PSUDASH,"-",100)=""
|
---|
| 12 | S $P(PSUFILL," ",100)=""
|
---|
| 13 | ;Organize index of ^XTMP("DATAMD") global
|
---|
| 14 | S (PSUDV,PSUTMP)=""
|
---|
| 15 | F S PSUDV=$O(^XTMP(PSUOPSUB,"DATAMD",PSUDV)) Q:PSUDV="" D
|
---|
| 16 | .S PSULCT=0
|
---|
| 17 | .S PSURXIEN=""
|
---|
| 18 | .F S PSURXIEN=$O(^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN)) Q:PSURXIEN="" D
|
---|
| 19 | ..S PSURCT=0
|
---|
| 20 | ..F S PSURCT=$O(^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT)) Q:PSURCT="" D
|
---|
| 21 | ...S PSULCT=PSULCT+1
|
---|
| 22 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,1)
|
---|
| 23 | ...S PSULCT=PSULCT+1
|
---|
| 24 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,2)
|
---|
| 25 | ...S PSULCT=PSULCT+1
|
---|
| 26 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,3)
|
---|
| 27 | ...Q:'$D(^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,4))
|
---|
| 28 | ...S PSULCT=PSULCT+1
|
---|
| 29 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,4)
|
---|
| 30 | ...Q:'$D(^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,5))
|
---|
| 31 | ...S PSULCT=PSULCT+1
|
---|
| 32 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,5)
|
---|
| 33 | ...Q:'$D(^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,6))
|
---|
| 34 | ...S PSULCT=PSULCT+1
|
---|
| 35 | ...S ^XTMP(PSUOPSUB,"RECMD",PSUDV,PSULCT)=^XTMP(PSUOPSUB,"DATAMD",PSUDV,PSURXIEN,PSURCT,6)
|
---|
| 36 | ;
|
---|
| 37 | ;
|
---|
| 38 | MSG ;Set up the number of lines and messages for mailman
|
---|
| 39 | ;
|
---|
| 40 | S PSUNOREC="",NONE=""
|
---|
| 41 | S PSUMSGT("M")=0,PSUMSGT("L")=0
|
---|
| 42 | I '$D(^XTMP(PSUOPSUB,"RECMD")) D NODATA Q ;Do not go any further if there is no data to report
|
---|
| 43 | S PSUDIV=0,Z=0
|
---|
| 44 | F S PSUDIV=$O(^XTMP(PSUOPSUB,"RECMD",PSUDIV)) Q:PSUDIV="" D
|
---|
| 45 | .S X=PSUDIV,DIC=59,DIC(0)="XM" D ^DIC ;**1
|
---|
| 46 | .S X=+Y,PSUDIVNM=$$VAL^PSUTL(59,X,.01)
|
---|
| 47 | .I PSUMASF!PSUDUZ!PSUPBMG D
|
---|
| 48 | ..D XMD,SETCNT
|
---|
| 49 | Q
|
---|
| 50 | XMD ;
|
---|
| 51 | NEW PSUMAX,PSULC,PSUTMC,PSUTLC,PSUMC,PSUOLD1,PSUOLD2,PSUOLD3
|
---|
| 52 | S PSUMAX=$$VAL^PSUTL(4.3,1,8.3)
|
---|
| 53 | S PSUMAX=$S(PSUMAX="":10000,PSUMAX>10000:10000,1:PSUMAX)
|
---|
| 54 | K ^XTMP(PSUOPSUB,"XMD")
|
---|
| 55 | S PSUMC=1,PSUMLC=0
|
---|
| 56 | F PSULC=1:1 S X=$G(^XTMP(PSUOPSUB,"RECMD",PSUDIV,PSULC)) Q:X="" D
|
---|
| 57 | .S PSUMLC=PSUMLC+1
|
---|
| 58 | .I PSUMLC>PSUMAX D
|
---|
| 59 | ..I $E(X,1)'="*" S PSUMLC=1
|
---|
| 60 | ..I $E(X,1)="*" D OLD
|
---|
| 61 | .I $L(X)<254 S ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC)=X Q
|
---|
| 62 | .F I=254:-1:1 S Z=$E(X,I) Q:Z="^"
|
---|
| 63 | .S ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC)=$E(X,1,I)
|
---|
| 64 | .S PSUMLC=PSUMLC+1
|
---|
| 65 | .S ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC)="*"_$E(X,I+1,999)
|
---|
| 66 | ;
|
---|
| 67 | ; Count Lines sent
|
---|
| 68 | S PSUTLC=0
|
---|
| 69 | F PSUM=1:1:PSUMC S X=$O(^XTMP(PSUOPSUB,"XMD",PSUM,""),-1),PSUTLC=PSUTLC+X
|
---|
| 70 | D VARS
|
---|
| 71 | Q
|
---|
| 72 | ;
|
---|
| 73 | OLD ; THIS SUBROUTINE STOPS MULTI-LINED MESSAGES FORM SPANNING MAILMAN MSG
|
---|
| 74 | S PSUOLD1=^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1) I $E(PSUOLD1,1)="*" D
|
---|
| 75 | .S PSUOLD2=^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-2) I $E(PSUOLD2,1)="*" D
|
---|
| 76 | ..S PSUOLD3=^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-3) I $E(PSUOLD3,1)="*" D
|
---|
| 77 | ...S PSUOLD4=^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-4) I $E(PSUOLD4,1)="*" D
|
---|
| 78 | ....S PSUOLD5=^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-5)
|
---|
| 79 | D:$D(PSUOLD5) OLD5 Q
|
---|
| 80 | D:$D(PSUOLD4) OLD4 Q
|
---|
| 81 | D:$D(PSUOLD3) OLD3 Q
|
---|
| 82 | D:$D(PSUOLD2) OLD2 Q
|
---|
| 83 | D:$D(PSUOLD1) OLD1
|
---|
| 84 | Q
|
---|
| 85 | ;
|
---|
| 86 | OLD5 ; * IF A RECORD EXCEEDS THE 10,000 CHARACTER 5 TIMES
|
---|
| 87 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,1)=PSUOLD5
|
---|
| 88 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-5)
|
---|
| 89 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,2)=PSUOLD4
|
---|
| 90 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-4)
|
---|
| 91 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,3)=PSUOLD3
|
---|
| 92 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-3)
|
---|
| 93 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,4)=PSUOLD2
|
---|
| 94 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-2)
|
---|
| 95 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,5)=PSUOLD1
|
---|
| 96 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1)
|
---|
| 97 | S PSUMLC=6
|
---|
| 98 | K PSUOLD5,PSUOLD4,PSUOLD3,PSUOLD2,PSUOLD1
|
---|
| 99 | Q
|
---|
| 100 | ;
|
---|
| 101 | OLD4 ; * IF A RECORD EXCEEDS THE 10,000 CHARACTER 4 TIMES
|
---|
| 102 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,1)=PSUOLD4
|
---|
| 103 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-4)
|
---|
| 104 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,2)=PSUOLD3
|
---|
| 105 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-3)
|
---|
| 106 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,3)=PSUOLD2
|
---|
| 107 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-2)
|
---|
| 108 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,4)=PSUOLD1
|
---|
| 109 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1)
|
---|
| 110 | S PSUMLC=5
|
---|
| 111 | K PSUOLD4,PSUOLD3,PSUOLD2,PSUOLD1
|
---|
| 112 | Q
|
---|
| 113 | ;
|
---|
| 114 | OLD3 ;
|
---|
| 115 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,1)=PSUOLD3
|
---|
| 116 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-3)
|
---|
| 117 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,2)=PSUOLD2
|
---|
| 118 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-2)
|
---|
| 119 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,3)=PSUOLD1
|
---|
| 120 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1)
|
---|
| 121 | S PSUMLC=4
|
---|
| 122 | K PSUOLD3,PSUOLD2,PSUOLD1
|
---|
| 123 | Q
|
---|
| 124 | ;
|
---|
| 125 | OLD2 ;
|
---|
| 126 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,1)=PSUOLD2
|
---|
| 127 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-2)
|
---|
| 128 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,2)=PSUOLD1
|
---|
| 129 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1)
|
---|
| 130 | S PSUMLC=3
|
---|
| 131 | K PSUOLD2,PSUOLD1
|
---|
| 132 | Q
|
---|
| 133 | ;
|
---|
| 134 | OLD1 ;
|
---|
| 135 | S ^XTMP(PSUOPSUB,"XMD",PSUMC+1,1)=PSUOLD1
|
---|
| 136 | K ^XTMP(PSUOPSUB,"XMD",PSUMC,PSUMLC-1)
|
---|
| 137 | S PSUMLC=2
|
---|
| 138 | K PSUOLD1
|
---|
| 139 | Q
|
---|
| 140 | ;
|
---|
| 141 | ; Transmit Messages
|
---|
| 142 | VARS ; Setup variables for contents
|
---|
| 143 | F PSUM=1:1:PSUMC D
|
---|
| 144 | .S XMSUB="V. 4.0 PBMOP(MULTIDOSE) "_PSUMON_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
---|
| 145 | .S XMTEXT="^XTMP(PSUOPSUB,""XMD"",PSUM,"
|
---|
| 146 | .S XMCHAN=1
|
---|
| 147 | .I PSUMASF!PSUDUZ!PSUPBMG D
|
---|
| 148 | ..M XMY=PSUXMYH
|
---|
| 149 | .I 'PSUMASF M XMY=PSUXMYS1
|
---|
| 150 | .I '$G(PSUSMRY) D ^XMD
|
---|
| 151 | ;
|
---|
| 152 | S:NONE PSUTLC=0
|
---|
| 153 | S PSUMSG("M")=PSUMC
|
---|
| 154 | S PSUMSG("L")=PSUTLC
|
---|
| 155 | Q
|
---|
| 156 | NODATA ;Send "No data to report" message
|
---|
| 157 | S ^XTMP(PSUOPSUB,"RECMD",PSUSNDR,1)="No data to report"
|
---|
| 158 | S NONE=1,PSUDIV=PSUSNDR
|
---|
| 159 | ;S ^XTMP("PSU_"_PSUJOB,"PSUNONE","RX")=""
|
---|
| 160 | S X=PSUDIV,DIC=4,DIC(0)="XM" D ^DIC ;**1
|
---|
| 161 | S X=+Y,PSUDIVNM=$$VAL^PSUTL(4,X,.01)
|
---|
| 162 | D XMD
|
---|
| 163 | SETCNT ;Set message count and line count
|
---|
| 164 | S PSUMSGT(PSUDIV,"MD","M")=$G(PSUMSGT(PSUDIV,"MD","M"))+PSUMSG("M")
|
---|
| 165 | S PSUMSGT(PSUDIV,"MD","L")=$G(PSUMSGT(PSUDIV,"MD","L"))+PSUMSG("L")
|
---|
| 166 | S ^XTMP("PSU_"_PSUJOB,"CONFIRMD",PSUDIV,PSUOPTN,"M")=PSUMSGT(PSUDIV,"MD","M")
|
---|
| 167 | S ^XTMP("PSU_"_PSUJOB,"CONFIRMD",PSUDIV,PSUOPTN,"L")=PSUMSGT(PSUDIV,"MD","L")
|
---|
| 168 | Q
|
---|