1 | PSUAR4 ;BIR/PDW - AR/WS SUMMARY MAILMESSAGES ;25 SEP 1998
|
---|
2 | ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
|
---|
3 | ;DBIAs
|
---|
4 | ; Reference to file #40.8 supported by DBIA 2438
|
---|
5 | ; Reference to file #50 supported by DBIA 221
|
---|
6 | ;
|
---|
7 | EN ;EP Generate mail message summaries
|
---|
8 | ; also store image for printed reports
|
---|
9 | ;
|
---|
10 | D DRUGSUM
|
---|
11 | ;
|
---|
12 | Q
|
---|
13 | ;
|
---|
14 | DRUGSUM ;EP Generate Drug Summary Message(s) by DIV
|
---|
15 | ; ^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)=Total Dispenses ;from PSUAR2
|
---|
16 | S PSUDIV=0
|
---|
17 | F S PSUDIV=$O(^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)) Q:PSUDIV="" D DRUGXMD
|
---|
18 | Q
|
---|
19 | ;
|
---|
20 | DRUGXMD ;EP Generate Mail Message with PSUDIV provided
|
---|
21 | ; Assemble top of message
|
---|
22 | ; Find Division Name
|
---|
23 | I '$D(^XTMP(PSUARSUB,"DIV_DRUG")) Q
|
---|
24 | ;
|
---|
25 | K DIC
|
---|
26 | S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
|
---|
27 | S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
|
---|
28 | S XMSUB="V. 4.0 PBMAR "_$G(PSUMON)_" "_PSUDIV_" "_PSUDIVNM
|
---|
29 | M XMY=PSUXMYS2
|
---|
30 | S XMDUZ=DUZ
|
---|
31 | S XMTEXT="PSUMSG("
|
---|
32 | S XMCHAN=1
|
---|
33 | S Y=PSUSDT X ^DD("DD") S PSUDTS=Y ; start date
|
---|
34 | S Y=PSUEDT X ^DD("DD") S PSUDTE=Y ; end date
|
---|
35 | N PSUMSG
|
---|
36 | S PSUMSG(1)=" Automatic Replenishment/Ward Stock Data Summary"
|
---|
37 | S PSUMSG(2)=" "_PSUDTS_" through "_PSUDTE_" for "_PSUDIVNM
|
---|
38 | S PSUMSG(3)=" "
|
---|
39 | S X=""
|
---|
40 | S X=$$SETSTR^VALM1("Total",X,40,5)
|
---|
41 | S X=$$SETSTR^VALM1("Total",X,52,5)
|
---|
42 | S PSUMSG(4)=X
|
---|
43 | S X="",X=$$SETSTR^VALM1("Dispensed",X,40,9),X=$$SETSTR^VALM1("Dispensed",X,52,9),X=$$SETSTR^VALM1("AMIS",X,64,4)
|
---|
44 | S PSUMSG(5)=X
|
---|
45 | S X="DRUG NAME",X=$$SETSTR^VALM1("Units",X,40,5),X=$$SETSTR^VALM1("Cost",X,52,4),X=$$SETSTR^VALM1("Category",X,64,8)
|
---|
46 | S PSUMSG(6)=X
|
---|
47 | S X="",$P(X,"-",79)=""
|
---|
48 | S PSUMSG(7)=X
|
---|
49 | ;
|
---|
50 | ; Drug Data: Move into local array ^TMP($J,"PSUDRUG",da)=Total dispenses
|
---|
51 | K ^TMP($J,"PSUDRUG")
|
---|
52 | M ^TMP($J,"PSUDRUG")=^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)
|
---|
53 | ;
|
---|
54 | ; alphabetize the list of drugs into PSUDRNM()=PSUDRDA
|
---|
55 | K ^TMP($J,"PSUDRNM")
|
---|
56 | S PSUDRDA=0 F S PSUDRDA=$O(^TMP($J,"PSUDRUG",PSUDRDA)) Q:'PSUDRDA S ^TMP($J,"PSUDRNM",$$VAL^PSUTL(50,PSUDRDA,.01))=PSUDRDA
|
---|
57 | ;
|
---|
58 | ; Build the drug lines of the message
|
---|
59 | S PSUNM="",PSUTDISP=0,PSUCOSTT=0
|
---|
60 | F PSULC=8:1 S PSUNM=$O(^TMP($J,"PSUDRNM",PSUNM)) Q:PSUNM="" D
|
---|
61 | . S PSUDRDA=^TMP($J,"PSUDRNM",PSUNM)
|
---|
62 | . ; retrieve drug details
|
---|
63 | . K PSUD,PSUCAT
|
---|
64 | . M PSUD=^XTMP(PSUARSUB,"PSUDRUG_DET",PSUDRDA)
|
---|
65 | . S PSUDISP=^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV,PSUDRDA)
|
---|
66 | . S PSUCOST=PSUD(16)
|
---|
67 | . S PSUTCOST=PSUDISP*PSUCOST*100\1/100
|
---|
68 | . S PSUNFI=PSUD(99999.17),PSUNFI=$S(PSUNFI="":" ",PSUNFI=1:"",1:"#")
|
---|
69 | . S PSUNONF=PSUD(51),PSUNONF=$S(PSUNONF:"*",1:" ")
|
---|
70 | . S PSUNMT=$E(PSUNM,1,35)_PSUNONF_PSUNFI
|
---|
71 | . S PSUCAT=PSUD(301)
|
---|
72 | . S X=PSUNMT
|
---|
73 | . S X=$$SETSTR^VALM1($J(PSUDISP,8,2),X,40,8)
|
---|
74 | . S X=$$SETSTR^VALM1($J(PSUTCOST,8,2),X,52,8)
|
---|
75 | . S X=$$SETSTR^VALM1(PSUCAT,X,64,$L(PSUCAT))
|
---|
76 | . S PSUMSG(PSULC)=X
|
---|
77 | . S PSUTDISP=PSUTDISP+PSUDISP,PSUCOSTT=PSUCOSTT+PSUTCOST
|
---|
78 | ;
|
---|
79 | S X=""
|
---|
80 | S $P(X,"-",79)=""
|
---|
81 | S PSUMSG(PSULC)=X
|
---|
82 | S X="TOTALS",X=$$SETSTR^VALM1($J(PSUTDISP,8,2),X,40,8),X=$$SETSTR^VALM1($J(PSUCOSTT,8,2),X,52,8)
|
---|
83 | S PSUMSG(PSULC+1)=X
|
---|
84 | S PSUMSG(PSULC+2)=" "
|
---|
85 | S PSUMSG(PSULC+3)="* Non-Formulary"
|
---|
86 | S PSUMSG(PSULC+4)="# Not on National Formulary"
|
---|
87 | S PSUMSG(PSULC+5)=" "
|
---|
88 | ;
|
---|
89 | I '$G(PSUSMRY) D ^XMD
|
---|
90 | M ^XTMP(PSUARSUB,"REPORT2",PSUDIV)=PSUMSG
|
---|
91 | Q
|
---|