| 1 | PSUSUM7 ;BIR/DAM - Pt. Demographics Summary for IV/RX or UD/RX ; 20 DEC 2001
 | 
|---|
| 2 |  ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | EN ;EN CALLED FROM PSUOP0
 | 
|---|
| 5 |  ;Q:$D(^XTMP("PSU_"_PSUJOB,"PSU_"_PSUJOB,"PSUMFLAG"))   ;Do not run if auto extract
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 |  D PULL^PSUCP
 | 
|---|
| 8 |  F I=1:1:$L(PSUOPTS,",") S PSUMOD($P(PSUOPTS,",",I))=""
 | 
|---|
| 9 |  ;
 | 
|---|
| 10 |  K ^XTMP("PSU_"_PSUJOB,"PSUSUMA")
 | 
|---|
| 11 |  I $G(^XTMP("PSU_"_PSUJOB,"PSUFLAG2"))!$G(^XTMP("PSU_"_PSUJOB,"PSUFLAG3")) K ^XTMP("PSU_"_PSUJOB,"PSUSUMA")
 | 
|---|
| 12 |  I $D(^XTMP("PSU_"_PSUJOB,"PSUNONE","RX")) D  Q
 | 
|---|
| 13 |  .I $D(^XTMP("PSU_"_PSUJOB,"PSUNONE","IV"))!$D(^XTMP("PSU_"_PSUJOB,"PSUNONE","UD")) D
 | 
|---|
| 14 |  ..D NODATA
 | 
|---|
| 15 |  ..I $G(^XTMP("PSU_"_PSUJOB,"PSUFLAG1"))!$G(^XTMP("PSU_"_PSUJOB,"PSUFLAG2")) K ^XTMP("PSU_"_PSUJOB,"PSUNONE")
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  D EN1
 | 
|---|
| 18 |  Q
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 | EN1 ;Gather summary data
 | 
|---|
| 21 |  D DATE^PSUSUM6
 | 
|---|
| 22 |  S I=7
 | 
|---|
| 23 |  I $D(PSUMOD(1)) D UNIQUE1
 | 
|---|
| 24 |  I '$D(PSUMOD(1)) D UNIQUE
 | 
|---|
| 25 |  D TOP^PSUSUM6
 | 
|---|
| 26 |  D OPDIV^PSUSUM6
 | 
|---|
| 27 |  D DIVTOT^PSUSUM6
 | 
|---|
| 28 |  D TUDIV
 | 
|---|
| 29 |  I $D(PSUMOD(1)) D
 | 
|---|
| 30 |  .D IPDIV2
 | 
|---|
| 31 |  I $D(PSUMOD(2)) D
 | 
|---|
| 32 |  .D IPDIV^PSUSUM6
 | 
|---|
| 33 |  .D IPDIV1
 | 
|---|
| 34 |  .D TAB4
 | 
|---|
| 35 |  D PDSUM^PSUDEM5
 | 
|---|
| 36 |  K ^XTMP("PSU_"_PSUJOB,"PSUTMP"),^XTMP("PSU_"_PSUJOB,"PSUTOTAL"),^XTMP("PSU_"_PSUJOB,"PSURXUNIQUE")
 | 
|---|
| 37 |  K ^XTMP("PSU_"_PSUJOB,"PSURXTOTAL")
 | 
|---|
| 38 |  K ^XTMP("PSU_"_PSUJOB,"PSURXCTA"),^XTMP("PSU_"_PSUJOB,"PSUIVINDIV")
 | 
|---|
| 39 |  K ^XTMP("PSU_"_PSUJOB,"PSURXSSN"),^XTMP("PSU_"_PSUJOB,"PSUIVDIV"),^XTMP("PSU_"_PSUJOB,"PSUFLAG2")
 | 
|---|
| 40 |  K ^XTMP("PSU_"_PSUJOB,"PSUFLAG3")
 | 
|---|
| 41 |  K ^XTMP("PSU_"_PSUJOB,"PSUIVOUT"),^XTMP("PSU_"_PSUJOB,"PSUIVSSN"),^XTMP("PSU_"_PSUJOB,"PSUUDDIV")
 | 
|---|
| 42 |  Q
 | 
|---|
| 43 |  ;
 | 
|---|
| 44 | UNIQUE ;Find total unique pharmacy patients across all divisions when
 | 
|---|
| 45 |  ;UD and RX extracts are run together
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 |  S PSURXN=0,PSUUDN1=0,PSUUDN2=0
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 |  S N=1
 | 
|---|
| 50 |  F  S PSURXN=$O(^XTMP("PSU_"_PSUJOB,"PSURXSSN",PSURXN)) Q:PSURXN=""  D
 | 
|---|
| 51 |  .S ^XTMP("PSU_"_PSUJOB,"PSUTMP",PSURXN)=N S N=N+1
 | 
|---|
| 52 |  .F  S PSUUDN1=$O(^XTMP("PSU_"_PSUJOB,"PSUUDSSN",PSUUDN1)) Q:PSUUDN1=""  D
 | 
|---|
| 53 |  ..I '$D(^XTMP("PSU_"_PSUJOB,"PSUTMP",PSUUDN1)) S ^XTMP("PSU_"_PSUJOB,"PSUTMP",PSUUDN1)=N S N=N+1
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 |  S ^XTMP("PSU_"_PSUJOB,"PSUTOTAL")=N-1
 | 
|---|
| 56 |  D TAB2
 | 
|---|
| 57 |  S $P(^XTMP("PSU_"_PSUJOB,"PSUSUMA",I),"-",70)="" S I=I+1
 | 
|---|
| 58 |  Q
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 | TAB2 ;Tab spacing for line 7.  Set line into global
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 |  S PSUTB3=" "
 | 
|---|
| 63 |  S PSUTB4="TOTAL Pharmacy patients across all divisions:"
 | 
|---|
| 64 |  S PSUTB5=(64-$L(PSUTB4))-$L($P($G(^XTMP("PSU_"_PSUJOB,"PSUTOTAL")),U,1))
 | 
|---|
| 65 |  F S3=1:1:(PSUTB5-1) S PSUTB(S3)=" " D
 | 
|---|
| 66 |  .S PSUTB3=PSUTB3_PSUTB(S3)
 | 
|---|
| 67 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)=PSUTB4_PSUTB3_$P($G(^XTMP("PSU_"_PSUJOB,"PSUTOTAL")),U,1)
 | 
|---|
| 68 |  S I=I+1
 | 
|---|
| 69 |  Q
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 | UNIQUE1 ;Find total unique pharmacy patients across all divisions when
 | 
|---|
| 72 |  ;IV and RX extracts are run together
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  S PSURXN=0,PSUIVN=0
 | 
|---|
| 75 |  ;
 | 
|---|
| 76 |  S N=1
 | 
|---|
| 77 |  ;
 | 
|---|
| 78 |  F  S PSURXN=$O(^XTMP("PSU_"_PSUJOB,"PSURXSSN",PSURXN)) Q:PSURXN=""  D
 | 
|---|
| 79 |  .S ^XTMP("PSU_"_PSUJOB,"PSUTMP",PSURXN)=N S N=N+1
 | 
|---|
| 80 |  .F  S PSUIVN=$O(^XTMP("PSU_"_PSUJOB,"PSUIVSSN",PSUIVN)) Q:PSUIVN=""  D
 | 
|---|
| 81 |  ..I '$D(^XTMP("PSU_"_PSUJOB,"PSUTMP",PSUIVN)) S ^XTMP("PSU_"_PSUJOB,"PSUTMP",PSUIVN)=N S N=N+1
 | 
|---|
| 82 |  ;
 | 
|---|
| 83 |  S ^XTMP("PSU_"_PSUJOB,"PSUTOTAL")=N-1
 | 
|---|
| 84 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="TOTAL Pharmacy patients across all divisions:               "_$P($G(^XTMP("PSU_"_PSUJOB,"PSUTOTAL")),U,1) S I=I+1
 | 
|---|
| 85 |  S $P(^XTMP("PSU_"_PSUJOB,"PSUSUMA",I),"-",70)="" S I=I+1
 | 
|---|
| 86 |  Q
 | 
|---|
| 87 |  ;
 | 
|---|
| 88 | TUDIV ;Calculate total inpatient count and tab spacing for 'Total
 | 
|---|
| 89 |  ;INPATIENT (UD or IV)' line and set into message global
 | 
|---|
| 90 |  ;
 | 
|---|
| 91 |  N PSUTB3,PSUTB4,PSUTB5,PSUDT
 | 
|---|
| 92 |  ;
 | 
|---|
| 93 |  I '$D(PSUMOD(1)) D
 | 
|---|
| 94 |  .S PSUDT=$P($G(^XTMP("PSU_"_PSUJOB,"PSUUDSSN")),U) D
 | 
|---|
| 95 |  ..S ^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")=PSUDT                 ;Total UD inpatient count
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 |  I '$D(PSUMOD(2)) D
 | 
|---|
| 98 |  .S ^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")=$P($G(^XTMP("PSU_"_PSUJOB,"PSUIVIN")),U,1)-1   ;Total IV inpatient count
 | 
|---|
| 99 |  ;
 | 
|---|
| 100 |  I '$G(^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")) S ^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")=0
 | 
|---|
| 101 |  S PSUTB3=" "
 | 
|---|
| 102 |  S PSUTB4="   Total INPATIENT (UD or IV):"
 | 
|---|
| 103 |  S PSUTB5=(64-$L(PSUTB4))-$L($P($G(^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")),U,1))
 | 
|---|
| 104 |  F S3=1:1:(PSUTB5-1) S PSUTB(S3)=" " D
 | 
|---|
| 105 |  .S PSUTB3=PSUTB3_PSUTB(S3)                ;Tab position
 | 
|---|
| 106 |  ;
 | 
|---|
| 107 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)=PSUTB4_PSUTB3_$P($G(^XTMP("PSU_"_PSUJOB,"PSUUDIVTOT")),U,1) S I=I+1
 | 
|---|
| 108 |  S $P(^XTMP("PSU_"_PSUJOB,"PSUSUMA",I),"-",70)="" S I=I+1
 | 
|---|
| 109 |  Q
 | 
|---|
| 110 |  ;
 | 
|---|
| 111 | IPDIV1 ;Find UD inpatient division totals
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 |  S PSULBL=0
 | 
|---|
| 114 |  N PSUTTL
 | 
|---|
| 115 |  ;
 | 
|---|
| 116 |  I $D(PSUMOD(2)) D           ;UD inpatients
 | 
|---|
| 117 |  .F  S PSULBL=$O(^XTMP("PSU_"_PSUJOB,"PSUUDDIV",PSULBL)) Q:PSULBL=""  D
 | 
|---|
| 118 |  ..S PSUTTL=$P($G(^XTMP("PSU_"_PSUJOB,"PSUUDDIV",PSULBL)),U,1)
 | 
|---|
| 119 |  ..D TAB1^PSUSUM6
 | 
|---|
| 120 |  ..D IPMSG
 | 
|---|
| 121 |  Q
 | 
|---|
| 122 |  ;
 | 
|---|
| 123 | IPMSG ;Set UD inpatient division totals into message global
 | 
|---|
| 124 |  ;
 | 
|---|
| 125 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="     "_PSULBL_" Division:"_PSUTB1_PSUTTL
 | 
|---|
| 126 |  S I=I+1
 | 
|---|
| 127 |  Q
 | 
|---|
| 128 |  ;
 | 
|---|
| 129 | IPDIV2 ;Calculate inpatient totals for IV divisions
 | 
|---|
| 130 |  ;
 | 
|---|
| 131 |  ;
 | 
|---|
| 132 |  ;Construct a storage global containing unique IV inpatients
 | 
|---|
| 133 |  ;per division 
 | 
|---|
| 134 |  S PSUDV=0
 | 
|---|
| 135 |  F  S PSUDV=$O(^XTMP("PSU_"_PSUJOB,"PSUDIV1",PSUDV)) Q:PSUDV=""  D
 | 
|---|
| 136 |  .S PSUPT=0
 | 
|---|
| 137 |  .F  S PSUPT=$O(^XTMP("PSU_"_PSUJOB,"PSUDIV1",PSUDV,PSUPT)) Q:PSUPT=""  D
 | 
|---|
| 138 |  ..S PSUPT1=0
 | 
|---|
| 139 |  ..F  S PSUPT1=$O(^XTMP("PSU_"_PSUJOB,"PSUIN1",PSUPT1)) Q:PSUPT1=""  D
 | 
|---|
| 140 |  ...I PSUPT1=PSUPT S ^XTMP("PSU_"_PSUJOB,"PSUDIV",PSUDV,PSUPT1)=""
 | 
|---|
| 141 |  D IPDIV3
 | 
|---|
| 142 |  Q
 | 
|---|
| 143 |  ;
 | 
|---|
| 144 | IPDIV3 ;Find unique inpatient count for each division
 | 
|---|
| 145 |  S PSUCT1=0,PSUCT2=0,T=1
 | 
|---|
| 146 |  ;
 | 
|---|
| 147 |  F  S PSUCT1=$O(^XTMP("PSU_"_PSUJOB,"PSUDIV",PSUCT1)) Q:PSUCT1=""  D
 | 
|---|
| 148 |  .F  S PSUCT2=$O(^XTMP("PSU_"_PSUJOB,"PSUDIV",PSUCT1,PSUCT2)) Q:PSUCT2=""  D
 | 
|---|
| 149 |  ..S ^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")=T S T=T+1    ;Total count
 | 
|---|
| 150 |  ..I $D(^XTMP("PSU_"_PSUJOB,"PSUCT",PSUCT1)) D
 | 
|---|
| 151 |  ...S C=C+1
 | 
|---|
| 152 |  ...S ^XTMP("PSU_"_PSUJOB,"PSUCT",PSUCT1)=C
 | 
|---|
| 153 |  ..I '$D(^XTMP("PSU_"_PSUJOB,"PSUCT",PSUCT1)) D
 | 
|---|
| 154 |  ...S C=1
 | 
|---|
| 155 |  ...S ^XTMP("PSU_"_PSUJOB,"PSUCT",PSUCT1)=C
 | 
|---|
| 156 |  D DIVNUM
 | 
|---|
| 157 |  D MSG
 | 
|---|
| 158 |  Q
 | 
|---|
| 159 |  ;
 | 
|---|
| 160 | DIVNUM ;Set number of inpatients per division into summary message
 | 
|---|
| 161 |  ;
 | 
|---|
| 162 |  N PSUTB1,PSUTB2
 | 
|---|
| 163 |  S N=1
 | 
|---|
| 164 |  ;
 | 
|---|
| 165 |  N PSUCT2
 | 
|---|
| 166 |  S PSUDIVA1=0
 | 
|---|
| 167 |  F  S PSUDIVA1=$O(^XTMP("PSU_"_PSUJOB,"PSUCT",PSUDIVA1)) Q:PSUDIVA1=""  D
 | 
|---|
| 168 |  .S PSUCT2=$P($G(^XTMP("PSU_"_PSUJOB,"PSUCT",PSUDIVA1)),U,1)
 | 
|---|
| 169 |  .D TAB5
 | 
|---|
| 170 |  .S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="     "_PSUDIVA1_" Division:"_PSUTB1_PSUCT2
 | 
|---|
| 171 |  .S I=I+1
 | 
|---|
| 172 |  Q
 | 
|---|
| 173 |  ;
 | 
|---|
| 174 | TAB5 ;Calculate tab spacing
 | 
|---|
| 175 |  ;
 | 
|---|
| 176 |  S PSUTB1=" "
 | 
|---|
| 177 |  S PSUTB2=(59-$L(PSUCT2))-$L(PSUDIVA1)-10
 | 
|---|
| 178 |  F S2=1:1:(PSUTB2-1) S PSUTB(S2)=" " D
 | 
|---|
| 179 |  .S PSUTB1=PSUTB1_PSUTB(S2)                ;Tab position
 | 
|---|
| 180 |  Q
 | 
|---|
| 181 |  ;
 | 
|---|
| 182 | TAB4 ;Calculate UD totals of all divisions and place in summary
 | 
|---|
| 183 |  ;message
 | 
|---|
| 184 |  ;
 | 
|---|
| 185 |  S N=0,PSUMKER=0,R=1
 | 
|---|
| 186 |  ;
 | 
|---|
| 187 |  I $D(PSUMOD(2)) D
 | 
|---|
| 188 |  .F  S PSUMKER=$O(^XTMP("PSU_"_PSUJOB,"PSUUDDIV",PSUMKER)) Q:PSUMKER=""  D
 | 
|---|
| 189 |  ..S N=$P(^XTMP("PSU_"_PSUJOB,"PSUUDDIV",PSUMKER),U)+N
 | 
|---|
| 190 |  ..S ^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")=N                   ;Sum of all UD inpatients
 | 
|---|
| 191 |  ;
 | 
|---|
| 192 |  D MSG
 | 
|---|
| 193 |  Q
 | 
|---|
| 194 |  ;
 | 
|---|
| 195 | MSG ;Final lines of message
 | 
|---|
| 196 |  ;
 | 
|---|
| 197 |  I '$D(^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")) S ^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")=0
 | 
|---|
| 198 |  ;
 | 
|---|
| 199 |  N PSUTB3,PSUTB4,PSUTB5
 | 
|---|
| 200 |  ;
 | 
|---|
| 201 |  S PSUTB3=" "
 | 
|---|
| 202 |  S PSUTB4="     Inpatient Total of all Divisions:"
 | 
|---|
| 203 |  S PSUTB5=(64-$L(PSUTB4))-$L($P($G(^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")),U,1))
 | 
|---|
| 204 |  F S3=1:1:(PSUTB5-1) S PSUTB(S3)=" " D
 | 
|---|
| 205 |  .S PSUTB3=PSUTB3_PSUTB(S3)                ;Tab position
 | 
|---|
| 206 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="                                                          ----------" S I=I+1
 | 
|---|
| 207 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)=PSUTB4_PSUTB3_$P($G(^XTMP("PSU_"_PSUJOB,"PSUTOTAL1")),U,1) S I=I+1
 | 
|---|
| 208 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="" S I=I+1
 | 
|---|
| 209 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="**PLEASE NOTE: Final TOTAL may not match sum of all SUBTOTALS.  A patient may" S I=I+1
 | 
|---|
| 210 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="have been provided pharmacy services at more than one outpatient and/or" S I=I+1
 | 
|---|
| 211 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",I)="inpatient division."
 | 
|---|
| 212 |  Q
 | 
|---|
| 213 |  ;
 | 
|---|
| 214 | NODATA ;Summary report line to be sent if there is no data
 | 
|---|
| 215 |  ;
 | 
|---|
| 216 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",1)="PHARMACY UNIQUE PATIENTS REPORT"
 | 
|---|
| 217 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",2)=" "
 | 
|---|
| 218 |  S ^XTMP("PSU_"_PSUJOB,"PSUSUMA",3)="No data to report"
 | 
|---|
| 219 |  D PDSUM^PSUDEM5
 | 
|---|
| 220 |  Q
 | 
|---|