1 | PSUPR4 ;BIR/PDW - PBMS PROCUREMENT EMAIL GENERATOR ;10 JUL 1999
|
---|
2 | ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
|
---|
3 | ;DBIA(s)
|
---|
4 | ; Reference to file #4.3 supported by DBIA 2496
|
---|
5 | ; Reference to file #40.8 supported by DBIA 2438
|
---|
6 | ;PSULC = Line processing in ^tmp
|
---|
7 | ;PSUTLC = Total Line count
|
---|
8 | ;PSUMC = Message counter
|
---|
9 | ;PSUMLC = Message Line Counter
|
---|
10 | ; RETURNS
|
---|
11 | ;PSUMSG("M") = # Messages
|
---|
12 | ;PSUMSG("L") = # Lines
|
---|
13 | ;
|
---|
14 | EN(PSUMSG) ;Scan and process for Division(s)
|
---|
15 | ; PSUMSGT ("M")= # MESSAGES ("L")= # LINES
|
---|
16 | ;
|
---|
17 | I $G(PSUMASF)!$G(PSUDUZ)!$G(PSUPBMG) D
|
---|
18 | .NEW PSUMAX,PSULC,PSUTMC,PSUTLC,PSUMC
|
---|
19 | .; Scan TMP, split lines, transmit per MAX lines in Netmail
|
---|
20 | .S PSUMAX=$$VAL^PSUTL(4.3,1,8.3)
|
---|
21 | .S:PSUMAX'>0 PSUMAX=10000
|
---|
22 | .;
|
---|
23 | .I '$D(^XTMP(PSUPRSUB,"RECORDS")) D NODATA Q
|
---|
24 | DIV .; Scan by division and send divisional messages
|
---|
25 | .;
|
---|
26 | .S PSUDIV="" F S PSUDIV=$O(^XTMP(PSUPRSUB,"RECORDS",PSUDIV)) Q:PSUDIV="" D MSG
|
---|
27 | Q
|
---|
28 | ;
|
---|
29 | MSG ;EP Send divisional message
|
---|
30 | ; Split and store into ^XTMP(PSUPRSUB,"MESSAGE",PSUMC,PSULC)
|
---|
31 | K ^XTMP(PSUPRSUB,"MESSAGE")
|
---|
32 | S PSUMC=1,PSUMLC=0
|
---|
33 | F PSULC=1:1 S X=$G(^XTMP(PSUPRSUB,"RECORDS",PSUDIV,PSULC)) Q:X="" D
|
---|
34 | . I $D(^XTMP(PSUPRSUB,"RECORDS",PSUDIV,PSULC,1)) S X=X_^XTMP(PSUPRSUB,"RECORDS",PSUDIV,PSULC,1)
|
---|
35 | . S PSUMLC=PSUMLC+1
|
---|
36 | . I PSUMLC>PSUMAX S PSUMC=PSUMC+1,PSUMLC=0,PSULC=PSULC+1 Q ; + message
|
---|
37 | . I $L(X)<235 S ^XTMP(PSUPRSUB,"MESSAGE",PSUMC,PSUMLC)=X Q
|
---|
38 | . F I=235:-1:1 S Z=$E(X,I) Q:Z="^"
|
---|
39 | . S Z=$E(X,1,I),X=$E(X,I+1,999)
|
---|
40 | . S ^XTMP(PSUPRSUB,"MESSAGE",PSUMC,PSUMLC)=Z
|
---|
41 | . S PSUMLC=PSUMLC+1
|
---|
42 | . F Q:X="" D
|
---|
43 | .. F I=235:-1:1 S Z=$E(X,I) Q:Z="^"
|
---|
44 | .. S Z=$E(X,1,I),X=$E(X,I+1,999)
|
---|
45 | .. S ^XTMP(PSUPRSUB,"MESSAGE",PSUMC,PSUMLC)="*"_Z
|
---|
46 | .. S PSUMLC=PSUMLC+1
|
---|
47 | ;
|
---|
48 | ; Count Lines sent
|
---|
49 | S PSUTLC=0
|
---|
50 | F PSUM=1:1:PSUMC S X=$O(^XTMP(PSUPRSUB,"MESSAGE",PSUM,""),-1),PSUTLC=PSUTLC+X
|
---|
51 | ;
|
---|
52 | S PSUMSG(PSUDIV,5,"M")=$G(PSUMSG(PSUDIV,5,"M"))+PSUMC
|
---|
53 | S PSUMSG(PSUDIV,5,"L")=$G(PSUMSG(PSUDIV,5,"L"))+PSUTLC
|
---|
54 | ; Transmit Messages
|
---|
55 | VARS ; Setup variables for contents
|
---|
56 | ;
|
---|
57 | ; Loop through messages generated and transmit them
|
---|
58 | F PSUM=1:1:PSUMC D
|
---|
59 | . S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
|
---|
60 | . S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
|
---|
61 | . S XMSUB="V. 4.0 PBMPR "_$G(PSUMON)_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
---|
62 | . S XMTEXT="^XTMP(PSUPRSUB,""MESSAGE"",PSUM,"
|
---|
63 | . S XMDUZ=DUZ
|
---|
64 | . M XMY=PSUXMYH
|
---|
65 | . S XMCHAN=1
|
---|
66 | . I $G(PSUMASF)!$G(PSUDUZ)!$G(PSUPBMG) D
|
---|
67 | ..I '$G(PSUSMRY) D ^XMD
|
---|
68 | ;
|
---|
69 | Q
|
---|
70 | NODATA ;EP transmit NO DATA FOUND
|
---|
71 | S XMDUZ=DUZ
|
---|
72 | M XMY=PSUXMYH
|
---|
73 | S PSUM=1,PSUMC=1
|
---|
74 | S PSUDIV=PSUSNDR
|
---|
75 | S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
|
---|
76 | S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
|
---|
77 | S XMSUB="V. 4.0 PBMPR "_$G(PSUMON)_" "_PSUM_"/"_PSUMC_" "_PSUDIV_" "_PSUDIVNM
|
---|
78 | S X(1)="No data to report"
|
---|
79 | S XMTEXT="X("
|
---|
80 | S XMCHAN=1
|
---|
81 | I $G(PSUMASF)!$G(PSUDUZ)!$G(PSUPBMG) D ^XMD
|
---|
82 | S PSUMSG(PSUDIV,5,"M")=1,PSUMSG(PSUDIV,5,"L")=0
|
---|
83 | Q
|
---|