PSDRLOG ;BIR/BJW-CS Inspector's Log By Date ; 12 Feb 98
;;3.0; CONTROLLED SUBSTANCES ;**8**;13 Feb 97
;**Y2K compliance**,"P" added to date input string in (DATE,RDATE)
I '$D(PSDSITE) D ^PSDSET Q:'$D(PSDSITE)
;S OK=$S($D(^XUSEC("PSJ RPHARM",DUZ)):1,$D(^XUSEC("PSJ PHARM TECH",DUZ)):1,1:0) I 'OK W $C(7),!!,?9,"** Please contact your Pharmacy Coordinator for access to",!,?12,"print the CS Inspector's Log.",! K OK Q
W !,?5,"Inspector's Log by Date Received",!
DATE ;ask date range
W ! K %DT S %DT="AEP",%DT("A")="Start with Date Received: " D ^%DT I Y<0 S PSDOUT=1 D MSG G END
S PSDSD=Y D D^DIQ S PSDATE=Y
S PSDSD=PSDSD-.0001
RET ;ask ret to stk
K DA,DIR S DIR(0)="Y",DIR("A")="Include Returns to Stock",DIR("B")="YES"
S DIR("?")="Answer 'YES' or return to include returns to stock, 'NO' to continue without returns, or '^' to quit."
D ^DIR K DIR I $D(DIRUT) D MSG G END
S PSDRET=Y G:'PSDRET ASKN
RDATE ;ask return date
W ! K %DT S %DT="AEP",%DT("A")="Start with Date Returned to Stock: " D ^%DT I Y<0 S PSDOUT=1 D MSG G END
S PSDRD=Y,PSDRD=PSDRD-.0001
ASKN ;ask naou or group
W !!,?5,"Select one of the following:",!!,?10,"N",?20,"NAOU (One, Some, or ^ALL)",!,?10,"G",?20,"Group of NAOUs",!
K DA,DIR,DIRUT S DIR(0)="SOA^N:NAOU;G:Group of NAOUs",DIR("A")="Select Method: "
S DIR("?",1)="Enter 'N' to select one, some or ^ALL NAOU(s),",DIR("?")="enter 'G' to select a group of NAOUs, or '^' to quit"
D ^DIR K DIR G:$D(DIRUT) END S SEL=Y K DA,DIC S CNT=0
I SEL="G" D GROUP G:'$D(PSDG) END G SORT
F S DIC=58.8,DIC("A")="Select NAOU: ",DIC(0)="QEA",DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)" D ^DIC K DIC Q:Y<0 D
.S NAOU(+Y)="",CNT=CNT+1
I '$D(NAOU)&(X'="^ALL") G END
S:X="^ALL" ALL=1
SORT ;asks sort
W ! K DA,DIR,DIRUT S DIR(0)="YO",DIR("A")="Do you wish to sort by Inventory Type",DIR("B")="NO"
S DIR("?")="Answer YES to sort drugs by Inventory Type, NO or <RET> to sort by drug."
D ^DIR K DIR G:$D(DIRUT) END S ASKN=Y
SORT2 ;asks second sort
K DA,DIR,DIRUT S DIR(0)="SO^D:DRUG/DISPENSING #S;N:NUMERIC DISPENSING #S"
S DIR("A")="Select Print Order for Inspector's Log",DIR("?",1)="Select D to print Dispensing Number numerically by drug, within an NAOU,",DIR("?")="select N to print numerically within an NAOU, or '^' to quit."
D ^DIR K DIR G:$D(DIRUT) END S ASK=Y
DEV ;ask device and queue info
W !!,"This report is designed for a 132 column format.",!,"You may queue this report to print at a later time.",!!
K %ZIS,IOP,IO("Q"),POP S %ZIS="QM",%ZIS("B")="" D ^%ZIS I POP W !,"NO DEVICE SELECTED OR REPORT PRINTED!" G END
I $D(IO("Q")) K IO("Q") S PSDIO=ION,ZTIO="" K ZTSAVE,ZTDTH,ZTSK S ZTRTN="START^PSDRLOG1",ZTDESC="Compile Narcotic Inspector Log By Date" D SAVE,^%ZTLOAD,HOME^%ZIS K ZTSK G END
U IO G START^PSDRLOG1
END K %,%DT,%H,%I,%ZIS,ALL,ASK,ASKN,CNT,DA,DIC,DIE,DIR,DIROUT,DIRUT,DR,DTOUT,DUOUT,EXP,EXPD,FLAG,JJ,KK,NAOU,NODE,NODE1,NODE3,NODE7,NUM
K OK,PSD,PSDA,PSDATE,PSDCNT,PSDDT,PSDED,PSDG,PSDIO,PSDOK,PSDOUT,PSDN,PSDNA,PSDPN,PSDR,PSDRD,PSDRET,PSDRN,PSDSD,PSDST,PSDTR,PSDTYP
K QTY,SEL,STAT,TYP,TYPN,X,Y,ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE,ZTSK
K ^TMP("PSDRLOG",$J) D ^%ZISC
S:$D(ZTQUEUED) ZTREQ="@"
Q
GROUP ;select group of naous
K DA,DIC F S DIC=58.2,DIC("A")="Select NAOU INVENTORY GROUP NAME: ",DIC(0)="QEA",DIC("S")="I $S($D(^PSI(58.2,""CS"",+Y)):1,1:0)" D ^DIC K DIC Q:Y<0 S PSDG(+Y)=""
Q
SAVE S (ZTSAVE("PSDIO"),ZTSAVE("CNT"),ZTSAVE("PSDSITE"),ZTSAVE("ASK"),ZTSAVE("ASKN"))=""
S:$D(PSDG) ZTSAVE("PSDG(")="" S:$D(NAOU) ZTSAVE("NAOU(")="" S:$D(ALL) ZTSAVE("ALL")=""
S:$D(PSDSD) ZTSAVE("PSDSD")=""
S:$D(PSDATE) ZTSAVE("PSDATE")=""
S:$D(PSDRET) ZTSAVE("PSDRET")=""
S:$D(PSDRD) ZTSAVE("PSDRD")=""
Q
MSG W !!,"No action taken.",!!
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDRLOG 3784 printed Oct 16, 2024@17:49:38 Page 2
PSDRLOG ;BIR/BJW-CS Inspector's Log By Date ; 12 Feb 98
+1 ;;3.0; CONTROLLED SUBSTANCES ;**8**;13 Feb 97
+2 ;**Y2K compliance**,"P" added to date input string in (DATE,RDATE)
+3 IF '$DATA(PSDSITE)
DO ^PSDSET
if '$DATA(PSDSITE)
QUIT
+4 ;S OK=$S($D(^XUSEC("PSJ RPHARM",DUZ)):1,$D(^XUSEC("PSJ PHARM TECH",DUZ)):1,1:0) I 'OK W $C(7),!!,?9,"** Please contact your Pharmacy Coordinator for access to",!,?12,"print the CS Inspector's Log.",! K OK Q
+5 WRITE !,?5,"Inspector's Log by Date Received",!
DATE ;ask date range
+1 WRITE !
KILL %DT
SET %DT="AEP"
SET %DT("A")="Start with Date Received: "
DO ^%DT
IF Y<0
SET PSDOUT=1
DO MSG
GOTO END
+2 SET PSDSD=Y
DO D^DIQ
SET PSDATE=Y
+3 SET PSDSD=PSDSD-.0001
RET ;ask ret to stk
+1 KILL DA,DIR
SET DIR(0)="Y"
SET DIR("A")="Include Returns to Stock"
SET DIR("B")="YES"
+2 SET DIR("?")="Answer 'YES' or return to include returns to stock, 'NO' to continue without returns, or '^' to quit."
+3 DO ^DIR
KILL DIR
IF $DATA(DIRUT)
DO MSG
GOTO END
+4 SET PSDRET=Y
if 'PSDRET
GOTO ASKN
RDATE ;ask return date
+1 WRITE !
KILL %DT
SET %DT="AEP"
SET %DT("A")="Start with Date Returned to Stock: "
DO ^%DT
IF Y<0
SET PSDOUT=1
DO MSG
GOTO END
+2 SET PSDRD=Y
SET PSDRD=PSDRD-.0001
ASKN ;ask naou or group
+1 WRITE !!,?5,"Select one of the following:",!!,?10,"N",?20,"NAOU (One, Some, or ^ALL)",!,?10,"G",?20,"Group of NAOUs",!
+2 KILL DA,DIR,DIRUT
SET DIR(0)="SOA^N:NAOU;G:Group of NAOUs"
SET DIR("A")="Select Method: "
+3 SET DIR("?",1)="Enter 'N' to select one, some or ^ALL NAOU(s),"
SET DIR("?")="enter 'G' to select a group of NAOUs, or '^' to quit"
+4 DO ^DIR
KILL DIR
if $DATA(DIRUT)
GOTO END
SET SEL=Y
KILL DA,DIC
SET CNT=0
+5 IF SEL="G"
DO GROUP
if '$DATA(PSDG)
GOTO END
GOTO SORT
+6 FOR
SET DIC=58.8
SET DIC("A")="Select NAOU: "
SET DIC(0)="QEA"
SET DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)"
DO ^DIC
KILL DIC
if Y<0
QUIT
Begin DoDot:1
+7 SET NAOU(+Y)=""
SET CNT=CNT+1
End DoDot:1
+8 IF '$DATA(NAOU)&(X'="^ALL")
GOTO END
+9 if X="^ALL"
SET ALL=1
SORT ;asks sort
+1 WRITE !
KILL DA,DIR,DIRUT
SET DIR(0)="YO"
SET DIR("A")="Do you wish to sort by Inventory Type"
SET DIR("B")="NO"
+2 SET DIR("?")="Answer YES to sort drugs by Inventory Type, NO or <RET> to sort by drug."
+3 DO ^DIR
KILL DIR
if $DATA(DIRUT)
GOTO END
SET ASKN=Y
SORT2 ;asks second sort
+1 KILL DA,DIR,DIRUT
SET DIR(0)="SO^D:DRUG/DISPENSING #S;N:NUMERIC DISPENSING #S"
+2 SET DIR("A")="Select Print Order for Inspector's Log"
SET DIR("?",1)="Select D to print Dispensing Number numerically by drug, within an NAOU,"
SET DIR("?")="select N to print numerically within an NAOU, or '^' to quit."
+3 DO ^DIR
KILL DIR
if $DATA(DIRUT)
GOTO END
SET ASK=Y
DEV ;ask device and queue info
+1 WRITE !!,"This report is designed for a 132 column format.",!,"You may queue this report to print at a later time.",!!
+2 KILL %ZIS,IOP,IO("Q"),POP
SET %ZIS="QM"
SET %ZIS("B")=""
DO ^%ZIS
IF POP
WRITE !,"NO DEVICE SELECTED OR REPORT PRINTED!"
GOTO END
+3 IF $DATA(IO("Q"))
KILL IO("Q")
SET PSDIO=ION
SET ZTIO=""
KILL ZTSAVE,ZTDTH,ZTSK
SET ZTRTN="START^PSDRLOG1"
SET ZTDESC="Compile Narcotic Inspector Log By Date"
DO SAVE
DO ^%ZTLOAD
DO HOME^%ZIS
KILL ZTSK
GOTO END
+4 USE IO
GOTO START^PSDRLOG1
END KILL %,%DT,%H,%I,%ZIS,ALL,ASK,ASKN,CNT,DA,DIC,DIE,DIR,DIROUT,DIRUT,DR,DTOUT,DUOUT,EXP,EXPD,FLAG,JJ,KK,NAOU,NODE,NODE1,NODE3,NODE7,NUM
+1 KILL OK,PSD,PSDA,PSDATE,PSDCNT,PSDDT,PSDED,PSDG,PSDIO,PSDOK,PSDOUT,PSDN,PSDNA,PSDPN,PSDR,PSDRD,PSDRET,PSDRN,PSDSD,PSDST,PSDTR,PSDTYP
+2 KILL QTY,SEL,STAT,TYP,TYPN,X,Y,ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE,ZTSK
+3 KILL ^TMP("PSDRLOG",$JOB)
DO ^%ZISC
+4 if $DATA(ZTQUEUED)
SET ZTREQ="@"
+5 QUIT
GROUP ;select group of naous
+1 KILL DA,DIC
FOR
SET DIC=58.2
SET DIC("A")="Select NAOU INVENTORY GROUP NAME: "
SET DIC(0)="QEA"
SET DIC("S")="I $S($D(^PSI(58.2,""CS"",+Y)):1,1:0)"
DO ^DIC
KILL DIC
if Y<0
QUIT
SET PSDG(+Y)=""
+2 QUIT
SAVE SET (ZTSAVE("PSDIO"),ZTSAVE("CNT"),ZTSAVE("PSDSITE"),ZTSAVE("ASK"),ZTSAVE("ASKN"))=""
+1 if $DATA(PSDG)
SET ZTSAVE("PSDG(")=""
if $DATA(NAOU)
SET ZTSAVE("NAOU(")=""
if $DATA(ALL)
SET ZTSAVE("ALL")=""
+2 if $DATA(PSDSD)
SET ZTSAVE("PSDSD")=""
+3 if $DATA(PSDATE)
SET ZTSAVE("PSDATE")=""
+4 if $DATA(PSDRET)
SET ZTSAVE("PSDRET")=""
+5 if $DATA(PSDRD)
SET ZTSAVE("PSDRD")=""
+6 QUIT
MSG WRITE !!,"No action taken.",!!
+1 QUIT