Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSUAR4

PSUAR4.m

Go to the documentation of this file.
  1. PSUAR4 ;BIR/PDW - AR/WS SUMMARY MAILMESSAGES ;25 SEP 1998
  1. ;;4.0;PHARMACY BENEFITS MANAGEMENT;;MARCH, 2005
  1. ;DBIAs
  1. ; Reference to file #40.8 supported by DBIA 2438
  1. ; Reference to file #50 supported by DBIA 221
  1. ;
  1. EN ;EP Generate mail message summaries
  1. ; also store image for printed reports
  1. ;
  1. D DRUGSUM
  1. ;
  1. Q
  1. ;
  1. DRUGSUM ;EP Generate Drug Summary Message(s) by DIV
  1. ; ^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)=Total Dispenses ;from PSUAR2
  1. S PSUDIV=0
  1. F S PSUDIV=$O(^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)) Q:PSUDIV="" D DRUGXMD
  1. Q
  1. ;
  1. DRUGXMD ;EP Generate Mail Message with PSUDIV provided
  1. ; Assemble top of message
  1. ; Find Division Name
  1. I '$D(^XTMP(PSUARSUB,"DIV_DRUG")) Q
  1. ;
  1. K DIC
  1. S X=PSUDIV,DIC=40.8,DIC(0)="X",D="C" D IX^DIC ;**1
  1. S X=+Y S PSUDIVNM=$$VAL^PSUTL(40.8,X,.01)
  1. S XMSUB="V. 4.0 PBMAR "_$G(PSUMON)_" "_PSUDIV_" "_PSUDIVNM
  1. M XMY=PSUXMYS2
  1. S XMDUZ=DUZ
  1. S XMTEXT="PSUMSG("
  1. S XMCHAN=1
  1. S Y=PSUSDT X ^DD("DD") S PSUDTS=Y ; start date
  1. S Y=PSUEDT X ^DD("DD") S PSUDTE=Y ; end date
  1. N PSUMSG
  1. S PSUMSG(1)=" Automatic Replenishment/Ward Stock Data Summary"
  1. S PSUMSG(2)=" "_PSUDTS_" through "_PSUDTE_" for "_PSUDIVNM
  1. S PSUMSG(3)=" "
  1. S X=""
  1. S X=$$SETSTR^VALM1("Total",X,40,5)
  1. S X=$$SETSTR^VALM1("Total",X,52,5)
  1. S PSUMSG(4)=X
  1. S X="",X=$$SETSTR^VALM1("Dispensed",X,40,9),X=$$SETSTR^VALM1("Dispensed",X,52,9),X=$$SETSTR^VALM1("AMIS",X,64,4)
  1. S PSUMSG(5)=X
  1. 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)
  1. S PSUMSG(6)=X
  1. S X="",$P(X,"-",79)=""
  1. S PSUMSG(7)=X
  1. ;
  1. ; Drug Data: Move into local array ^TMP($J,"PSUDRUG",da)=Total dispenses
  1. K ^TMP($J,"PSUDRUG")
  1. M ^TMP($J,"PSUDRUG")=^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV)
  1. ;
  1. ; alphabetize the list of drugs into PSUDRNM()=PSUDRDA
  1. K ^TMP($J,"PSUDRNM")
  1. S PSUDRDA=0 F S PSUDRDA=$O(^TMP($J,"PSUDRUG",PSUDRDA)) Q:'PSUDRDA S ^TMP($J,"PSUDRNM",$$VAL^PSUTL(50,PSUDRDA,.01))=PSUDRDA
  1. ;
  1. ; Build the drug lines of the message
  1. S PSUNM="",PSUTDISP=0,PSUCOSTT=0
  1. F PSULC=8:1 S PSUNM=$O(^TMP($J,"PSUDRNM",PSUNM)) Q:PSUNM="" D
  1. . S PSUDRDA=^TMP($J,"PSUDRNM",PSUNM)
  1. . ; retrieve drug details
  1. . K PSUD,PSUCAT
  1. . M PSUD=^XTMP(PSUARSUB,"PSUDRUG_DET",PSUDRDA)
  1. . S PSUDISP=^XTMP(PSUARSUB,"DIV_DRUG",PSUDIV,PSUDRDA)
  1. . S PSUCOST=PSUD(16)
  1. . S PSUTCOST=PSUDISP*PSUCOST*100\1/100
  1. . S PSUNFI=PSUD(99999.17),PSUNFI=$S(PSUNFI="":" ",PSUNFI=1:"",1:"#")
  1. . S PSUNONF=PSUD(51),PSUNONF=$S(PSUNONF:"*",1:" ")
  1. . S PSUNMT=$E(PSUNM,1,35)_PSUNONF_PSUNFI
  1. . S PSUCAT=PSUD(301)
  1. . S X=PSUNMT
  1. . S X=$$SETSTR^VALM1($J(PSUDISP,8,2),X,40,8)
  1. . S X=$$SETSTR^VALM1($J(PSUTCOST,8,2),X,52,8)
  1. . S X=$$SETSTR^VALM1(PSUCAT,X,64,$L(PSUCAT))
  1. . S PSUMSG(PSULC)=X
  1. . S PSUTDISP=PSUTDISP+PSUDISP,PSUCOSTT=PSUCOSTT+PSUTCOST
  1. ;
  1. S X=""
  1. S $P(X,"-",79)=""
  1. S PSUMSG(PSULC)=X
  1. S X="TOTALS",X=$$SETSTR^VALM1($J(PSUTDISP,8,2),X,40,8),X=$$SETSTR^VALM1($J(PSUCOSTT,8,2),X,52,8)
  1. S PSUMSG(PSULC+1)=X
  1. S PSUMSG(PSULC+2)=" "
  1. S PSUMSG(PSULC+3)="* Non-Formulary"
  1. S PSUMSG(PSULC+4)="# Not on National Formulary"
  1. S PSUMSG(PSULC+5)=" "
  1. ;
  1. I '$G(PSUSMRY) D ^XMD
  1. M ^XTMP(PSUARSUB,"REPORT2",PSUDIV)=PSUMSG
  1. Q