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

BEXRDOW.m

Go to the documentation of this file.
  1. BEXRDOW ;IHS/CMI/DAY - BEX - Transactions by Day of Week Report ; 12 Mar 2012 7:13 PM
  1. ;;1.0;BEX TELEPHONE REFILL SYSTEM;**4,5**;MAR 12, 2012;Build 1
  1. ;
  1. ;Prints the Transactions by Day of Week Report
  1. ;
  1. W #
  1. ;
  1. W !,"Transactions by Day of Week"
  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,DIE,DIR,DA,DD,DO,DR
  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. ;
  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_".240000"
  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^BEXRDOW"
  1. S XBRX="EOJ^BEXRDOW"
  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" 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"
  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
  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
  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,BEXDVIEN="" Q
  1. ..I +BEXDIV,'$D(BEXDIV(BEXDVIEN)) Q
  1. ..;
  1. ..D TOTAL
  1. ;
  1. ;Write Totals
  1. ;
  1. W !
  1. W "------------------------------------------------------------------------------"
  1. W !
  1. W "TOTALS by Day of Week"
  1. W !
  1. W "------------------------------------------------------------------------------"
  1. W !
  1. ;
  1. S BEXDOW=0
  1. F S BEXDOW=$O(BEXTOT(BEXDOW)) Q:'BEXDOW D
  1. .I BEXDOW=1 W "SUN"
  1. .I BEXDOW=2 W "MON"
  1. .I BEXDOW=3 W "TUE"
  1. .I BEXDOW=4 W "WED"
  1. .I BEXDOW=5 W "THU"
  1. .I BEXDOW=6 W "FRI"
  1. .I BEXDOW=7 W "SAT"
  1. .W ?8,"REFILL: "
  1. .W $J($P(BEXTOT(BEXDOW),U),5)
  1. .W ?23,"STATUS: "
  1. .W $J($P(BEXTOT(BEXDOW),U,2),5)
  1. .W ?38,"PHARM: "
  1. .W $J($P(BEXTOT(BEXDOW),U,3),5)
  1. .;Remove LIST since this type does not seem to be used
  1. .;W ?52,"INFO: "
  1. .;W $J($P(BEXTOT(BEXDOW),U,4),5)
  1. .W ?52,"TOTAL: "
  1. .W $J($P(BEXTOT(BEXDOW),U,5),6)
  1. .W !
  1. ;
  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 ?58,$J($P(BEXSUM,U,5),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 Day of Week 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. Q
  1. ;
  1. ;
  1. ;-----------------------------------------------------------------
  1. TOTAL ;EP - Add up totals
  1. ;-----------------------------------------------------------------
  1. ;
  1. S BEXTOT=BEXTOT+1
  1. ;
  1. ;Initialize Counters for this date
  1. S X=BEXDAT
  1. D DOW^%DTC
  1. I Y=-1 Q
  1. ;Add 1 to DOW because Sunday is zero
  1. S BEXDOW=Y+1
  1. I '$D(BEXTOT(BEXDOW)) S BEXTOT(BEXDOW)="0^0^0^0^0"
  1. ;
  1. ;Refills
  1. I BEXTYPE="R" S $P(BEXTOT(BEXDOW),U)=$P(BEXTOT(BEXDOW),U)+1
  1. I BEXTYPE="R" S $P(BEXSUM,U)=$P(BEXSUM,U)+1
  1. ;
  1. ;Status
  1. I BEXTYPE="S" S $P(BEXTOT(BEXDOW),U,2)=$P(BEXTOT(BEXDOW),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(BEXDOW),U,3)=$P(BEXTOT(BEXDOW),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(BEXDOW),U,4)=$P(BEXTOT(BEXDOW),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(BEXDOW),U,5)=$P(BEXTOT(BEXDOW),U,5)+1
  1. S $P(BEXSUM,U,5)=$P(BEXSUM,U,5)+1
  1. ;
  1. Q
  1. ;