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

PSALEVRP.m

Go to the documentation of this file.
  1. PSALEVRP ;BIR/LTL,JMB-Stock and Reorder Report ;7/23/97
  1. ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**15**; 10/24/97
  1. ;This routine prints a report of all drugs with their stock and reorder
  1. ;levels in a pharmacy location.
  1. ;
  1. ;References to ^PSDRUG( are covered by IA #2095
  1. ;
  1. D LOC G MASTER
  1. ;
  1. ;Gets locations
  1. LOC S PSAOUT=0,PSALOC=+$O(^PSD(58.8,"ADISP","P",0))
  1. I 'PSALOC W !!?5,"No Drug Accountability location has been created yet." S PSAOUT=1 G MASTER
  1. ;
  1. ;Collect locations in alpha order
  1. S (PSACNT,PSALOC)=0 W !
  1. F S PSALOC=+$O(^PSD(58.8,"ADISP","P",PSALOC)) Q:'PSALOC D
  1. .Q:'$D(^PSD(58.8,PSALOC,0))!($P($G(^PSD(58.8,PSALOC,0)),"^")="")
  1. .I +$G(^PSD(58.8,PSALOC,"I")),+^PSD(58.8,PSALOC,"I")'>DT Q
  1. .Q:'$O(^PSD(58.8,PSALOC,1,0)) D SITES^PSAUTL1
  1. .S PSACNT=PSACNT+1
  1. .S PSALOCA($P(^PSD(58.8,PSALOC,0),"^")_PSACOMB,PSALOC)=$P(^(0),"^",3)_"^"_$P(^(0),"^",10)_"^"_+$G(^PSD(58.8,PSALOC,"I"))
  1. S PSACHK=$O(PSALOCA("")) I PSACHK="" G MASTER
  1. Q:$G(PSAHIS)&(PSACNT=1)
  1. ;
  1. DISPLOC ;Displays the available pharmacy locations.
  1. W @IOF,!,"Choose one or many pharmacy locations:",!
  1. S PSACNT=0,PSALOCN=""
  1. F S PSALOCN=$O(PSALOCA(PSALOCN)) Q:PSALOCN="" D
  1. .S PSALOC=0 F S PSALOC=$O(PSALOCA(PSALOCN,PSALOC)) Q:'PSALOC D
  1. ..S PSACNT=PSACNT+1,PSAMENU(PSACNT,PSALOCN,PSALOC)=""
  1. ..W !,$J(PSACNT,2)
  1. ..W:$L(PSALOCN)>76 ?4,$P(PSALOCN,"(IP)",1)_"(IP)",!?21,$P(PSALOCN,"(IP)",2) W:$L(PSALOCN)<77 ?4,PSALOCN
  1. ;
  1. SELLOC W ! S DIR(0)="LO^1:"_PSACNT,DIR("A")="Select PHARMACY LOCATION",DIR("?")="Enter the number(s) of the Pharmacy Location",DIR("??")="^D HELP^PSAUTL3"
  1. D ^DIR K DIR I $G(DTOUT)!($G(DUOUT)) S PSAOUT=1 G EXIT
  1. Q:Y=""&('$G(PSAHIS)) I Y="",$G(PSAHIS) S PSAOUT=1 Q
  1. S PSASEL=Y
  1. F PSAPC=1:1 S PSANUM=+$P(PSASEL,",",PSAPC) Q:'PSANUM D
  1. .S PSALOCN=$O(PSAMENU(PSANUM,"")),PSALOC=$O(PSAMENU(PSANUM,PSALOCN,0))
  1. .S PSALOC(PSALOCN,PSALOC)=PSALOCA(PSALOCN,PSALOC)
  1. ;
  1. S PSACHK=$O(PSALOC(""))
  1. I PSACHK="",'PSALOC W !,"There are no active pharmacy locations." G EXIT1
  1. W ! S PSALOCN="" F S PSALOCN=$O(PSALOC(PSALOCN)) Q:PSALOCN=""!(PSAOUT) S PSALOC=0 F S PSALOC=$O(PSALOC(PSALOCN,PSALOC)) Q:'PSALOC!(PSAOUT) D
  1. .I '$O(^PSD(58.8,PSALOC,1,0)) D
  1. ..W:$L(PSALOCN)>79 !!,$P(PSALOCN,"(IP)",1)_"(IP)",!!?17,$P(PSALOCN,"(IP)",2) W:$L(PSALOCN)<80 !!,PSALOCN
  1. ..W !,"There are no drugs in the pharmacy location."
  1. Q
  1. ;
  1. MASTER G:'$D(^XUSEC("PSA ORDERS",DUZ)) TEST S (PSAMVN,PSAMV)=0
  1. F S PSAMV=+$O(^PSD(58.8,"ADISP","M",PSAMV)) Q:'PSAMV D
  1. .I +$G(^PSD(58.8,PSAMV,"I")),+^PSD(58.8,PSAMV,"I")'>DT Q
  1. .S PSAMVN=PSAMVN+1,PSAMV($P(^PSD(58.8,PSAMV,0),"^"),PSAMV)=""
  1. G:'PSAMVN TEST
  1. ;
  1. DISPMV ;Displays active master vaults
  1. W @IOF,!,"Choose one or many master vaults:",!
  1. S PSA=0,PSAMVA="" F S PSAMVA=$O(PSAMV(PSAMVA)) Q:PSAMVA="" D
  1. .S PSAMV=0 F S PSAMV=$O(PSAMV(PSAMVA,PSAMV)) Q:'PSAMV D
  1. ..S PSA=PSA+1,PSAVAULT(PSA,PSAMVA,PSAMV)="" W !,$J(PSA,2)_".",?4,PSAMVA
  1. K PSAMV
  1. ;
  1. SELMV ;Select displayed master vaults
  1. W ! S DIR(0)="LO^1:"_PSA,DIR("A")="Select Master Vault",DIR("?")="Select the Master Vault that received the invoice's drugs",DIR("??")="^D MV^PSAPROC"
  1. D ^DIR K DIR I $G(DTOUT)!($G(DUOUT)) S PSAOUT=1 Q
  1. G:Y="" TEST S PSASEL=Y
  1. F PSAPC=1:1 S PSA=+$P(PSASEL,",",PSAPC) Q:'PSA D
  1. .S PSAMVA="",PSAMVA=$O(PSAVAULT(PSA,PSAMVA)) Q:PSAMVA=""
  1. .S PSAMVIEN=+$O(PSAVAULT(PSA,PSAMVA,0)) Q:'PSAMVIEN
  1. .S PSAMAST(PSAMVA,PSAMVIEN)=""
  1. K PSAVAULT
  1. ;
  1. TEST G:PSAOUT EXIT
  1. S PSA=$O(PSALOC("")),PSAMV=$O(PSAMAST(""))
  1. I PSA="",PSAMV="" G EXIT
  1. ;
  1. DEV ;Asks device & queueing info
  1. W !!,"Each pharmacy location can contain all drugs in the DRUG file. Therefore,",!,"this report could be very long. It is advised to queue the report to run",!,"during non-critical hours.",!
  1. K IO("Q") K %ZIS,IOP,POP S %ZIS="Q",%ZIS("B")=""
  1. D ^%ZIS I POP W !,"NO DEVICE SELECTED OR OUTPUT PRINTED!" Q
  1. I $D(IO("Q")) D G EXIT
  1. .N ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTDTH,ZTSK
  1. .S ZTRTN="COMPILE^PSALEVRP",ZTDESC="Drug Acct. - Stock and Reorder Report"
  1. .S:PSA'="" ZTSAVE("PSALOC(")="" S:PSAMV'="" ZTSAVE("PSAMAST(")=""
  1. .D ^%ZTLOAD
  1. ;
  1. COMPILE ;Compiles data
  1. S PSA=$O(PSALOC("")) G:PSA="" MV
  1. S PSALOCN="" F S PSALOCN=$O(PSALOC(PSALOCN)) Q:PSALOCN="" D
  1. .S PSALOC=0 F S PSALOC=$O(PSALOC(PSALOCN,PSALOC)) Q:'PSALOC D
  1. ..S PSADRG=0 F S PSADRG=+$O(^PSD(58.8,PSALOC,1,PSADRG)) Q:'PSADRG D
  1. ...Q:'$D(^PSD(58.8,PSALOC,1,PSADRG,0))!($P($G(^PSDRUG(PSADRG,0)),"^")="")
  1. ...S ^TMP("PSALEV",$J,1,PSALOC,$P(^PSDRUG(PSADRG,0),"^"))=+$P(^PSD(58.8,PSALOC,1,PSADRG,0),"^",3)_"^"_+$P(^(0),"^",5)
  1. ;
  1. MV S PSA=$O(PSAMAST("")) G:PSA="" PRINT
  1. S PSAMVN="" F S PSAMVN=$O(PSAMAST(PSAMVN)) Q:PSAMVN="" D
  1. .S PSAMV=0 F S PSAMV=$O(PSAMAST(PSAMVN,PSAMV)) Q:'PSAMV D
  1. ..S PSADRG=0 F S PSADRG=+$O(^PSD(58.8,PSAMV,1,PSADRG)) Q:'PSADRG D
  1. ...Q:'$D(^PSD(58.8,PSAMV,1,PSADRG,0))!($P($G(^PSDRUG(PSADRG,0)),"^")="")
  1. ...S ^TMP("PSALEV",$J,2,PSAMV,$P(^PSDRUG(PSADRG,0),"^"))=+$P(^PSD(58.8,PSAMV,1,PSADRG,0),"^",3)_"^"_+$P(^(0),"^",5)
  1. ;
  1. PRINT ;Prints report
  1. D NOW^%DTC S PSARUN=%,PSARUN=$E(PSARUN,4,5)_"/"_$E(PSARUN,6,7)_"/"_$E(PSARUN,2,3)_"@"_$E($P(PSARUN,".",2),1,2)_":"_$E($P(PSARUN,".",2),3,4)
  1. S PSAPG=0,PSASLN="",$P(PSASLN,"-",80)="",PSAOUT=0 K Y
  1. S PSAFIRST=1,PSALOC=0 F S PSALOC=+$O(^TMP("PSALEV",$J,1,PSALOC)) Q:'PSALOC!(PSAOUT) D
  1. .D SITES^PSAUTL1 S PSALOCN=$P(^PSD(58.8,PSALOC,0),"^")_PSACOMB
  1. .I PSAFIRST D HDR Q:PSAOUT S PSAFIRST=0
  1. .S PSADRG="" F S PSADRG=$O(^TMP("PSALEV",$J,1,PSALOC,PSADRG)) Q:PSADRG=""!(PSAOUT) D
  1. ..I $Y+5>IOSL D HDR Q:PSAOUT
  1. ..S PSASTOCK=$P(^TMP("PSALEV",$J,1,PSALOC,PSADRG),"^"),PSAREORD=$P(^(PSADRG),"^",2)
  1. ..W !,PSADRG
  1. ..W ?(45-$L($P(PSASTOCK,".",2))),$J(PSASTOCK,9,+$L($P(PSASTOCK,".",2)))
  1. ..W ?(67-$L($P(PSAREORD,".",2))),$J(PSAREORD,9,+$L($P(PSAREORD,".",2)))
  1. ;
  1. S PSA=$O(^TMP("PSALEV",$J,2,"")) G:PSA="" EXIT
  1. S PSAFIRST=1,PSAMV=0
  1. F S PSAMV=+$O(^TMP("PSALEV",$J,2,PSAMV)) Q:'PSAMV!(PSAOUT) D S PSAFIRST=1
  1. .I PSAFIRST D HDR Q:PSAOUT S PSAFIRST=0
  1. .S PSADRG="" F S PSADRG=$O(^TMP("PSALEV",$J,2,PSAMV,PSADRG)) Q:PSADRG=""!(PSAOUT) D
  1. ..I $Y+5>IOSL D HDR Q:PSAOUT
  1. ..S PSASTOCK=$P(^TMP("PSALEV",$J,2,PSAMV,PSADRG),"^"),PSAREORD=$P(^(PSADRG),"^",2)
  1. ..W !,PSADRG
  1. ..W ?(45-$L($P(PSASTOCK,".",2))),$J(PSASTOCK,9,+$L($P(PSASTOCK,".",2)))
  1. ..W ?(67-$L($P(PSAREORD,".",2))),$J(PSAREORD,9,+$L($P(PSAREORD,".",2)))
  1. I 'PSAOUT,$E(IOST,1,2)="C-" S PSAOUT=1 D END^PSAPROC G:PSAOUT EXIT1
  1. ;
  1. EXIT W:$E(IOST,1,2)="C-" @IOF D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
  1. EXIT1 K IO("Q"),^TMP("PSALEV",$J)
  1. K %,%ZIS,DIR,DTOUT,DUOUT,PSA,PSACHK,PSACNT,PSACOMB,PSADRG,PSAFIRST,PSAISIT,PSAISITN,PSALOC,PSALOCA,PSALOCN,PSAMAST,PSAMENU,PSAMV,PSAMVA,PSAMVIEN,PSAMVN
  1. K PSANUM,PSAOSIT,PSAOSITN,PSAOUT,PSAPC,PSAPG,PSAREORD,PSARUN,PSASEL,PSASLN,PSASTOCK,PSAVAULT,Y,ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE,ZTSK
  1. Q
  1. ;
  1. HDR ;Report header
  1. I $E(IOST,1,2)="C-" W:'PSAPG @IOF D:+PSAPG END^PSAPROC Q:PSAOUT
  1. I $E(IOST)'="C",+PSAPG W @IOF
  1. S PSAPG=PSAPG+1
  1. W !?20,"DRUG ACCOUNTABILITY/INVENTORY INTERFACE",?72,"PAGE "_PSAPG
  1. W !?25,"STOCK AND REORDER LEVEL REPORT",!
  1. I $E(IOST)'="C" W "RUN: "_PSARUN
  1. I $G(PSALOC) W ?31,"PHARMACY LOCATION" W:$L(PSALOCN)>79 !!,$P(PSALOCN,"(IP)",1)_"(IP)",!!?17,$P(PSALOCN,"(IP)",2) W:$L(PSALOCN)<80 !!,PSALOCN
  1. I $G(PSAMV) W !,"MASTER VAULT: "_$P($G(^PSD(58.8,PSAMV,0)),"^")
  1. W !!,"DRUG",?43,"STOCK LEVEL",?63,"REORDER LEVEL",!,PSASLN
  1. Q