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

BEXRDAT.m

Go to the documentation of this file.
  1. BEXRDAT ;IHS/CMI/DAY - BEX - Transactions by Date Report ; 12 Mar 2012 7:12 PM
  1. ;;1.0;BEX TELEPHONE REFILL SYSTEM;**4,5**;MAR 12, 2012;Build 1
  1. ;
  1. ;Prints the Transactions by Date Report
  1. ;
  1. W #
  1. ;
  1. W !,"Transactions by Date Report"
  1. W !
  1. W !,"This option prints a list of Transactions that were processed within"
  1. W !,"a selected date/time range."
  1. W !
  1. ;
  1. K BEXDIV
  1. S BEXDIV=0
  1. S BEXSITE=0
  1. S BEXQUIT=0
  1. ;
  1. W !,"Press Enter to select ALL Pharmacy Divisions, or"
  1. F D Q:BEXQUIT=1
  1. .K DIC,DIR,DIE,DA,DR,DO,DD
  1. .S DIC(0)="AEQMZ"
  1. .S DIC("A")="Select a Pharmacy Division: "
  1. .S DIC=59
  1. .D ^DIC
  1. .K DIC,DIR,DIE,DA,DD,DR,DO
  1. .I X="" S BEXQUIT=1 Q
  1. .I Y<0 S BEXQUIT=1 Q
  1. .S BEXSITE=+Y
  1. .S BEXDIV=BEXDIV+1
  1. .S Y=$P($G(^PS(59,BEXSITE,"INI")),U)
  1. .I +Y S BEXDIV(Y)=""
  1. ;
  1. W !
  1. K DIR
  1. S DIR("B")="N"
  1. S DIR("A")="Do you want TOTALS only"
  1. S DIR(0)="Y"
  1. S DIR("?")="Answering NO will print detailed transactions"
  1. D ^DIR
  1. K DIR
  1. I Y=0 S BEXRTYPE="DETAIL"
  1. I Y=1 S BEXRTYPE="TOTALS"
  1. ;
  1. ;
  1. ;--------------------------------------------------------------------------
  1. BEGDATE ;EP - Come here if end date is before begin date
  1. ;--------------------------------------------------------------------------
  1. ;
  1. W !
  1. K DIRUT
  1. K %DT
  1. S %DT("A")="Select the Beginning Date/Time: "
  1. S %DT="AET"
  1. D ^%DT
  1. K %DT
  1. I ($D(DIRUT))!(Y<0) W !!,"No Beginning Date selected" G EOJ
  1. S BEXBEG=Y
  1. ;
  1. W !
  1. K DIRUT
  1. K %DT
  1. S %DT("A")="Select the Ending Date/Time: "
  1. S %DT="AET"
  1. D ^%DT
  1. K %DT
  1. I ($D(DIRUT))!(Y<0) W !!,"No Ending Date selected" G EOJ
  1. S BEXEND=Y
  1. I $P(BEXEND,".",2)="" S BEXEND=BEXEND_".24"
  1. ;
  1. I BEXBEG>BEXEND W !!,"Beginning Date is later than the Ending Date. Try Again!",! G BEGDATE
  1. ;
  1. W !
  1. S XBRP="LIST^BEXRDAT"
  1. S XBRX="EOJ^BEXRDAT"
  1. S XBNS="BEX"
  1. D ^XBDBQUE
  1. Q
  1. ;
  1. ;
  1. ;---------------------------------------------------------------
  1. EOJ ;EP - End of Job Processing
  1. ;---------------------------------------------------------------
  1. ;
  1. X ^%ZIS("C")
  1. I $E(IOST)="C",$G(BEXEXIT)'=1 W ! K DIR S DIR(0)="E" D ^DIR K DIR
  1. K BEX
  1. D EN^XBVK("BEX")
  1. K DIR,DIE,DIC,DD,DA,DR
  1. Q
  1. ;
  1. ;
  1. ;---------------------------------------------------------------
  1. LIST ;EP - Entry Point from XBDBQUE
  1. ;---------------------------------------------------------------
  1. ;
  1. ;
  1. W #
  1. D HEADER
  1. ;
  1. K BEXTOT
  1. S BEXTOT=0
  1. K BEXSUM
  1. S BEXSUM="0^0^0^0^0^0^0"
  1. ;
  1. S BEXQUIT=0
  1. S BEXEXIT=0
  1. ;
  1. S BEXDATE=$O(^VEXHRX0(19080.1,"C",BEXBEG),-1)
  1. F S BEXDATE=$O(^VEXHRX0(19080.1,"C",BEXDATE)) Q:'BEXDATE D Q:BEXQUIT=1 Q:BEXEXIT=1
  1. .;
  1. .I BEXDATE>BEXEND S BEXQUIT=1 Q
  1. .;
  1. .;This loops around to some non-numeric dates
  1. .I +BEXDATE<BEXBEG S BEXQUIT=1 Q
  1. .;
  1. .S BEXIEN=0
  1. .F S BEXIEN=$O(^VEXHRX0(19080.1,"C",BEXDATE,BEXIEN)) Q:'BEXIEN D Q:BEXQUIT=1 Q:BEXEXIT=1
  1. ..;
  1. ..S BEX(0)=$G(^VEXHRX0(19080.1,BEXIEN,0))
  1. ..I BEX(0)="" Q
  1. ..;
  1. ..D PARSE^BEXRUTL
  1. ..;
  1. ..;Screen by Division
  1. ..I +BEXDIV,$G(BEXDVIEN)="" Q
  1. ..I +BEXDIV,'$D(BEXDIV(BEXDVIEN)) Q
  1. ..;
  1. ..D DETAIL
  1. ;
  1. ;Write Totals
  1. ;
  1. I BEXEXIT=1 Q
  1. ;
  1. I BEXTOT>0 D
  1. .W !
  1. .W "-------------------------------------------------------------------------------"
  1. .W !
  1. .W "TRANSACTION TOTALS by Date"
  1. .W !
  1. .W "-------------------------------------------------------------------------------"
  1. .W !
  1. ;
  1. S BEXDAT=""
  1. F S BEXDAT=$O(BEXTOT(BEXDAT)) Q:'BEXDAT D Q:BEXEXIT=1
  1. .S X=BEXDAT
  1. .W $E(X,4,5),"/",$E(X,6,7)
  1. .W ?8,"REFILL: "
  1. .W $J($P(BEXTOT(BEXDAT),U),5)
  1. .W ?23,"STATUS: "
  1. .W $J($P(BEXTOT(BEXDAT),U,2),5)
  1. .W ?38,"PHARM: "
  1. .W $J($P(BEXTOT(BEXDAT),U,3),5)
  1. .;W ?52,"INFO: "
  1. .;W $J($P(BEXTOT(BEXDAT),U,4),5)
  1. .W ?52,"TOTAL: "
  1. .W $J($P(BEXTOT(BEXDAT),U,5),5)
  1. .W !
  1. .;
  1. .I $Y>(IOSL-4) D
  1. ..I $E(IOST)="C" K DIR S DIR(0)="E" D ^DIR S:X="^" BEXEXIT=1 K DIR
  1. ..I BEXEXIT=1 Q
  1. ..S BEXRTYPE="TOTALS"
  1. ..D HEADER
  1. ..W !
  1. ..W "-------------------------------------------------------------------------------"
  1. ..W !
  1. ..W "TRANSACTION TOTALS by Date"
  1. ..W !
  1. ..W "-------------------------------------------------------------------------------"
  1. ..W !
  1. ;
  1. I BEXTOT>0 D
  1. .W "TOTAL"
  1. .W ?14,$J($P(BEXSUM,U),7)
  1. .W ?29,$J($P(BEXSUM,U,2),7)
  1. .W ?43,$J($P(BEXSUM,U,3),7)
  1. .;W ?56,$J($P(BEXSUM,U,4),7)
  1. .W ?57,$J($P(BEXSUM,U,5),7)
  1. .W !
  1. ;
  1. I BEXEXIT=1 Q
  1. ;
  1. I BEXTOT>0 D
  1. .;
  1. .W !
  1. .W "-------------------------------------------------------------------------------"
  1. .W !
  1. .W "REFILL TOTALS by Originating Transaction Date"
  1. .W !
  1. .W "-------------------------------------------------------------------------------"
  1. .W !
  1. ;
  1. S BEXDAT=""
  1. F S BEXDAT=$O(BEXTOT(BEXDAT)) Q:'BEXDAT D Q:BEXEXIT=1
  1. .S X=BEXDAT
  1. .W $E(X,4,5),"/",$E(X,6,7)
  1. .W ?12,"MAIL:"
  1. .W $J($P(BEXTOT(BEXDAT),U,6),7)
  1. .W ?30,"WINDOW:"
  1. .W $J($P(BEXTOT(BEXDAT),U,7),7)
  1. .W ?50,"TOTAL: "
  1. .W $J(($P(BEXTOT(BEXDAT),U,6)+$P(BEXTOT(BEXDAT),U,7)),7)
  1. .W !
  1. .;
  1. .I $Y>(IOSL-4) D
  1. ..I $E(IOST)="C" K DIR S DIR(0)="E" D ^DIR S:X="^" BEXEXIT=1 K DIR
  1. ..I BEXEXIT=1 Q
  1. ..S BEXRTYPE="TOTALS"
  1. ..D HEADER
  1. ..W !
  1. ..W "-------------------------------------------------------------------------------"
  1. ..W !
  1. ..W "REFILL TOTALS by Originating Transaction Date"
  1. ..W !
  1. ..W "-------------------------------------------------------------------------------"
  1. ..W !
  1. ;
  1. I $P(BEXSUM,U,7)>0 D
  1. .W "TOTAL"
  1. .W ?17,$J($P(BEXSUM,U,6),7)
  1. .W ?37,$J($P(BEXSUM,U,7),7)
  1. .W ?57,$J(($P(BEXSUM,U,6)+$P(BEXSUM,U,7)),7)
  1. .W !
  1. ;
  1. W !,"TOTAL Transactions:",?25,$J(BEXTOT,8)
  1. W !
  1. ;
  1. Q
  1. ;
  1. ;
  1. ;---------------------------------------------------------------
  1. ;---------------------------------------------------------------
  1. ;
  1. W #
  1. W !,"REPORT: Transactions by Date Report"
  1. W " for "
  1. I BEXSITE>0 W $$GET1^DIQ(59,BEXSITE,.01)
  1. I BEXSITE=0 W "all Divisions"
  1. W !,"DATE RUN: " S Y=DT X ^DD("DD") W Y
  1. W !,"PARAMETERS: "
  1. ;
  1. W "Between "
  1. S Y=BEXBEG
  1. W $E(Y,4,5),"/",$E(Y,6,7),"/",$E(Y,2,3)
  1. X ^DD("DD")
  1. W "@"
  1. I $P(Y,"@",2)]"" W $E($P(Y,"@",2),1,5)
  1. I $P(Y,"@",2)="" W "00:00"
  1. ;
  1. W " and "
  1. S Y=BEXEND
  1. W $E(Y,4,5),"/",$E(Y,6,7),"/",$E(Y,2,3)
  1. X ^DD("DD")
  1. W "@"
  1. I $P(Y,"@",2)]"" W $E($P(Y,"@",2),1,5)
  1. I $P(Y,"@",2)="" W "00:00"
  1. ;
  1. W !
  1. W "-------------------------------------------------------------------------------"
  1. W !
  1. ;
  1. ;Quit if totals only
  1. I BEXRTYPE="TOTALS" Q
  1. ;
  1. W "Date of TX"
  1. W ?15,"HRNO"
  1. W ?23,"RX #"
  1. W ?33,"Date Filled"
  1. W ?47,"Type"
  1. W ?57,"Result/[Status]"
  1. W !
  1. W "-------------------------------------------------------------------------------"
  1. W !
  1. Q
  1. ;
  1. ;
  1. ;-----------------------------------------------------------------
  1. DETAIL ;EP - Write Detail for each Record and Add up totals
  1. ;-----------------------------------------------------------------
  1. ;
  1. S BEXTOT=BEXTOT+1
  1. ;
  1. ;Initialize Counters for this date
  1. I '$D(BEXTOT(BEXDAT)) S BEXTOT(BEXDAT)="0^0^0^0^0^0^0"
  1. ;
  1. ;Add to Counters by Type
  1. ;
  1. ;Refills
  1. I BEXTYPE="R" S $P(BEXTOT(BEXDAT),U)=$P(BEXTOT(BEXDAT),U)+1
  1. I BEXTYPE="R" S $P(BEXSUM,U)=$P(BEXSUM,U)+1
  1. ;
  1. ;Status
  1. I BEXTYPE="S" S $P(BEXTOT(BEXDAT),U,2)=$P(BEXTOT(BEXDAT),U,2)+1
  1. I BEXTYPE="S" S $P(BEXSUM,U,2)=$P(BEXSUM,U,2)+1
  1. ;
  1. ;Pharmacy
  1. I BEXTYPE="P" S $P(BEXTOT(BEXDAT),U,3)=$P(BEXTOT(BEXDAT),U,3)+1
  1. I BEXTYPE="P" S $P(BEXSUM,U,3)=$P(BEXSUM,U,3)+1
  1. ;
  1. ;RX Info
  1. I BEXTYPE="I" S $P(BEXTOT(BEXDAT),U,4)=$P(BEXTOT(BEXDAT),U,4)+1
  1. I BEXTYPE="I" S $P(BEXSUM,U,4)=$P(BEXSUM,U,4)+1
  1. ;
  1. ;Total (for this date)
  1. S $P(BEXTOT(BEXDAT),U,5)=$P(BEXTOT(BEXDAT),U,5)+1
  1. S $P(BEXSUM,U,5)=$P(BEXSUM,U,5)+1
  1. ;
  1. ;Calculate Mail/Windows
  1. I $G(BEXRFDAT)]"",$G(BEXMLWIN)="M" S $P(BEXTOT(BEXDAT),U,6)=$P(BEXTOT(BEXDAT),U,6)+1 S $P(BEXSUM,U,6)=$P(BEXSUM,U,6)+1
  1. I $G(BEXRFDAT)]"",$G(BEXMLWIN)="W" S $P(BEXTOT(BEXDAT),U,7)=$P(BEXTOT(BEXDAT),U,7)+1 S $P(BEXSUM,U,7)=$P(BEXSUM,U,7)+1
  1. ;
  1. ;Quit if totals only
  1. I BEXRTYPE="TOTALS" Q
  1. ;
  1. ;--> Let's write out the record detail
  1. ;
  1. ;Write Transaction Date/Time
  1. S Y=BEXTXDAT
  1. I Y]"" D
  1. .W $E(Y,4,5),"/",$E(Y,6,7)
  1. .X ^DD("DD")
  1. .W "@"
  1. .I $P(Y,"@",2)]"" W $E($P(Y,"@",2),1,5)
  1. .I $P(Y,"@",2)="" W "00:00"
  1. ;
  1. ;Write Patient HRNO
  1. I +BEXDVIEN S Y=$$HRN^AUPNPAT(BEXPTIEN,BEXDVIEN)
  1. I BEXDVIEN="" S Y=$$HRN^AUPNPAT(BEXPTIEN,DUZ(2))
  1. I Y>0 W ?13,$J(Y,6)
  1. ;
  1. ;Write RX Number
  1. ;Align numbers, then add any alpha to the end
  1. I BEXRXNUM W ?22,$J(+BEXRXNUM,8)
  1. S Y=$E(BEXRXNUM,$L(BEXRXNUM)) I Y?1A W Y
  1. ;
  1. ;Write Date Filled
  1. S Y=BEXRFDAT
  1. I Y]"" W ?33,$E(Y,4,5),"/",$E(Y,6,7),"/",$E(Y,2,3)
  1. ;
  1. ;Mail/Window Code
  1. I $G(BEXRDDAT)]"",$G(BEXMLWIN)="M" W " (M)"
  1. I $G(BEXRFDAT)]"",$G(BEXMLWIN)="W" W " (W)"
  1. ;
  1. ;Write Type
  1. S Y=""
  1. I BEXTYPE="R" S Y="REFILL"
  1. I BEXTYPE="S" S Y="STATUS"
  1. I BEXTYPE="I" S Y="RX INFO"
  1. I BEXTYPE="P" S Y="PHARMACY"
  1. W ?47,Y
  1. ;
  1. ;Write Results
  1. W ?57,$E(BEXRESLT,1,22)
  1. I BEXTYPE="P",BEXRESLT="" S Y=$$GET1^DIQ(52,BEXRXIEN,100) W ?57,"[",$E(Y,1,20),"]"
  1. ;
  1. W !
  1. ;
  1. I $Y>(IOSL-4) D
  1. .I $E(IOST)="C" K DIR S DIR(0)="E" D ^DIR K DIR
  1. .I X="^" S BEXEXIT=1 Q
  1. .D HEADER
  1. ;
  1. Q
  1. ;