95 lines
3.1 KiB
Mathematica
95 lines
3.1 KiB
Mathematica
|
PSULR4 ;BIR/PDW - PBMS LABORATORY EMAIL GENERATOR ;10 JUL 1999
|
||
|
;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
|
||
|
;
|
||
|
;DBIA(s)
|
||
|
; Reference to file #4.3 supported by DBIA 2496,10091
|
||
|
; Reference to file #40.8 supported by DBIA 2438
|
||
|
;PSULC = Line processing in ^tmp
|
||
|
;PSUTLC = Total Line count
|
||
|
;PSUMC = Message counter
|
||
|
;PSUMLC = Message Line Counter
|
||
|
; RETURNS
|
||
|
;PSUMSG("M") = # Messages
|
||
|
;PSUMSG("L") = # Lines
|
||
|
;
|
||
|
EN(PSUMSG) ;Scan and process for Division(s)
|
||
|
; PSUMSGT ("M")= # MESSAGES ("L")= # LINES
|
||
|
;
|
||
|
;I '$G(PSUMASF) Q ;Comment out so user can get detailed msg
|
||
|
;regardless of whether they send to Hines or not
|
||
|
;
|
||
|
;
|
||
|
NEW PSUMAX,PSULC,PSUTMC,PSUTLC,PSUMC
|
||
|
; Scan TMP, split lines, transmit per MAX lines in Netmail
|
||
|
S PSUMAX=$$VAL^PSUTL(4.3,1,8.3)
|
||
|
S:PSUMAX'>0 PSUMAX=10000
|
||
|
;
|
||
|
I '$D(^XTMP(PSULRSUB,"RECORDS")) G NODATA
|
||
|
DIV ; Scan by division and send divisional messages
|
||
|
;
|
||
|
S PSUDIV="" F S PSUDIV=$O(^XTMP(PSULRSUB,"RECORDS",PSUDIV)) Q:PSUDIV="" D MSG
|
||
|
Q
|
||
|
;
|
||
|
MSG ;EP Send divisional message
|
||
|
; Split and store into ^XTMP(PSULRSUB,"MESSAGE",PSUMC,PSULC)
|
||
|
K ^XTMP(PSULRSUB,"MESSAGE")
|
||
|
S PSUMC=1,PSUMLC=0
|
||
|
F PSULC=1:1 S X=$G(^XTMP(PSULRSUB,"RECORDS",PSUDIV,PSULC)) Q:X="" D
|
||
|
. S PSUMLC=PSUMLC+1
|
||
|
. I PSUMLC>PSUMAX S PSUMC=PSUMC+1,PSUMLC=0,PSULC=PSULC-1 Q ; + message
|
||
|
. I $L(X)<235 S ^XTMP(PSULRSUB,"MESSAGE",PSUMC,PSUMLC)=X Q
|
||
|
. F I=235:-1:1 S Z=$E(X,I) Q:Z="^"
|
||
|
. S ^XTMP(PSULRSUB,"MESSAGE",PSUMC,PSUMLC)=$E(X,1,I)
|
||
|
. S PSUMLC=PSUMLC+1
|
||
|
. S ^XTMP(PSULRSUB,"MESSAGE",PSUMC,PSUMLC)="*"_$E(X,I+1,999)
|
||
|
;
|
||
|
; Count Lines sent
|
||
|
S PSUTLC=0
|
||
|
F PSUM=1:1:PSUMC S X=$O(^XTMP(PSULRSUB,"MESSAGE",PSUM,""),-1),PSUTLC=PSUTLC+X
|
||
|
;
|
||
|
S PSUMSG(PSUDIV,13,"M")=+$G(PSUMSG(PSUDIV,13,"M"))+PSUMC
|
||
|
S PSUMSG(PSUDIV,13,"L")=+$G(PSUMSG(PSUDIV,13,"L"))+PSUTLC
|
||
|
TRANS ;EP Transmit Messages
|
||
|
VARS ; Setup variables for contents
|
||
|
;
|
||
|
I $D(^XTMP("PSU_"_PSUJOB,"DIV",PSUDIV)) D Q
|
||
|
.F PSUM=1:1:PSUMC D
|
||
|
..S PSUDIVNM=$P(^XTMP("PSU_"_PSUJOB,"DIV",PSUDIV),U,1)
|
||
|
..S XMSUB="V. 4.0 PBMLR "_$G(PSUMON)_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
||
|
..S XMDUZ=DUZ
|
||
|
..S XMTEXT="^XTMP(PSULRSUB,""MESSAGE"",PSUM,"
|
||
|
..M XMY=PSUXMYH
|
||
|
..S XMCHAN=1
|
||
|
..I $G(PSUMASF)!$G(PSUDUZ)!$G(PSUPBMG) D
|
||
|
...I PSUSMRY'=1 D ^XMD
|
||
|
;
|
||
|
; Loop through messages generated and transmit them
|
||
|
F PSUM=1:1:PSUMC D
|
||
|
. S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
|
||
|
. S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
|
||
|
. S XMSUB="V. 4.0 PBMLR "_$G(PSUMON)_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
||
|
. S XMDUZ=DUZ
|
||
|
. S XMTEXT="^XTMP(PSULRSUB,""MESSAGE"",PSUM,"
|
||
|
. M XMY=PSUXMYH
|
||
|
. S XMCHAN=1
|
||
|
. ;I $G(PSUMASF) D ^XMD
|
||
|
. I $G(PSUMASF)!$G(PSUDUZ)!$G(PSUPBMG) D
|
||
|
..I PSUSMRY'=1 D ^XMD
|
||
|
;
|
||
|
Q
|
||
|
NODATA ;EP transmit NO DATA FOUND
|
||
|
S X=$$VALI^PSUTL(4.3,1,217),PSUSNDR=+$$VAL^PSUTL(4,X,99)
|
||
|
S PSUDIV=PSUSNDR
|
||
|
S PSUMSG(PSUDIV,13,"M")=$G(PSUMASF),PSUMSG(PSUDIV,13,"L")=0
|
||
|
S XMDUZ=DUZ
|
||
|
M XMY=PSUXMYH
|
||
|
S PSUM=1,PSUMC=1
|
||
|
S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
|
||
|
S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
|
||
|
S XMSUB="V. 4.0 PBMLR "_$G(PSUMON)_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
||
|
S X(1)="No data to report"
|
||
|
S XMTEXT="X("
|
||
|
S XMCHAN=1
|
||
|
I $G(PSUMASF)!$G(PSUPBMG)!$G(PSUDUZ) D ^XMD
|
||
|
Q
|