- PSDACT ;BIR/BJW-Print Daily Activity Log ; 3 Feb 98
- ;;3.0;CONTROLLED SUBSTANCES ;**8,84**;13 Feb 97;Build 15
- ;**Y2K compliance**,"P" added to date input string
- I '$D(PSDSITE) D ^PSDSET Q:'$D(PSDSITE)
- I '$D(^XUSEC("PSJ RPHARM",DUZ))&('$D(^XUSEC("PSD TECH",DUZ))) W !!,"Contact your Pharmacy Coordinator for access to display the daily CS activity.",!!,"PSJ RPHARM or PSD TECH security key required.",! Q
- ASKD ;ask disp location
- S PSDS=$P(PSDSITE,U,3),PSDSN=$P(PSDSITE,U,4)
- G:$P(PSDSITE,U,5) CHKD
- K DIC,DA S DIC=58.8,DIC(0)="QEAZ",DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S($P(^(0),""^"",2)[""M"":1,$P(^(0),""^"",2)[""S"":1,1:0)"
- S DIC("A")="Select Primary Dispensing Site: "
- S DIC("B")=$P(PSDSITE,U,4)
- D ^DIC K DIC G:Y<0 END
- S PSDS=+Y,PSDSN=$P(Y,"^",2),$P(PSDSITE,U,3)=+Y,$P(PSDSITE,U,4)=PSDSN
- CHKD I '$O(^PSD(58.8,PSDS,1,0)) W !!,"There are no CS stocked drugs for your dispensing vault.",!! G END
- DRUG ;ask drug
- W !!,?5,"You may select a single drug, several drugs,",!,?5,"or enter ^ALL to select all drugs.",!!
- W ?5,"You may also enter ^ALL CII DRUGS to select all",!,?5,"schedule 2 controlled substances.",!! ;rtw NSR 20171111
- W ! K DA,DIC
- F S DIC("W")="W:$P(^PSDRUG(Y,0),""^"",9) "" N/F"" I $P(^PSD(58.8,PSDS,1,Y,0),""^"",14)]"""",$P(^(0),""^"",14)'>DT W $C(7),"" *** INACTIVE ***""",DA(1)=+PSDS,DIC(0)="QEAM",DIC="^PSD(58.8,"_PSDS_",1," D ^DIC K DIC Q:Y<0 D
- .S PSDRG(+Y)=""
- ;I '$D(PSDRG)&(X'="^ALL") G END ;rtw rem'd NSR20171111
- I '$D(PSDRG)&(X'="^ALL")&(X'="^ALL CII DRUGS") G END ;rtw replacement NSR20171111
- N PSDALL
- I X="^ALL" S ALL=1
- I X="^ALL CII DRUGS" S PSDALL=1 ;;rtw add NSR20171111
- DATE W ! K %DT S %DT="AEPTX",%DT("A")="Start with Date: " D ^%DT I Y<0 G END
- S PSDSD=Y D D^DIQ S PSDATE=Y,%DT("A")="End with Date: " D ^%DT I Y<0 G END
- I Y<PSDSD W !!,"The ending date of the range must be later than the starting date." G DATE
- S PSDED=Y D D^DIQ S PSDATE=PSDATE_"^"_Y,PSDSD=PSDSD-.00001
- S:'$P(PSDED,".",2) PSDED=PSDED+.99999
- W !!,"This report is designed for a 132 column format.",!,"You may queue this report to print at a later time.",!!
- DEV ;sel device
- S Y=$P($G(^PSD(58.8,+PSDS,2)),"^",9),C=$P(^DD(58.8,24,0),"^",2) D Y^DIQ S PSDEV=Y
- W ! K %ZIS,IOP,IO("Q"),POP S %ZIS="QM",%ZIS("B")=PSDEV D ^%ZIS I POP W !!,"NO DEVICE SELECTED OR REPORT PRINTED!!",! G END
- I $D(IO("Q")) K IO("Q"),ZTIO,ZTSAVE,ZTDTH,ZTSK S PSDIO=ION,ZTIO="",ZTRTN="START^PSDACT1",ZTDESC="CS PHARM Compile Daily Activity Log" D SAVE,^%ZTLOAD,HOME^%ZIS K ZTSK G END
- U IO G START^PSDACT1
- END ;
- D KVAR^VADPT
- K %,%DT,%H,%I,%ZIS,ACT,ALL,BFWD,C,DA,DATE,DIC,DIR,DIROUT,DIRUT,DTOUT,DUOUT,LN,MFG,NAOU,NODE,NQTY,NUM
- K PAT,PG,PHARM,POP,PSD,PSDA,PSDATE,PSDED,PSDEV,PSDIO,PSDOUT,PSDPN,PSDR,PSDRG,PSDRGN,PSDS,PSDSD,PSDSN,PSDUZ,PSDUZN,RX,TEXT,TYP,QTY,TYPE,X,Y,VA("BID"),VA("PID")
- K ^TMP("PSDACT",$J),ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE,ZTSK
- D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
- Q
- SAVE ;sets variables for queueing
- S (ZTSAVE("PSDS"),ZTSAVE("PSDSN"),ZTSAVE("PSDSD"),ZTSAVE("PSDED"),ZTSAVE("PSDATE"),ZTSAVE("PSDIO"))=""
- S:$D(ALL) ZTSAVE("ALL")="" S:$D(PSDRG) ZTSAVE("PSDRG(")=""
- S:$D(PSDALL) ZTSAVE("PSDALL")="" ;rtw add NSR20171111
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDACT 3184 printed Mar 13, 2025@20:49:27 Page 2
- PSDACT ;BIR/BJW-Print Daily Activity Log ; 3 Feb 98
- +1 ;;3.0;CONTROLLED SUBSTANCES ;**8,84**;13 Feb 97;Build 15
- +2 ;**Y2K compliance**,"P" added to date input string
- +3 IF '$DATA(PSDSITE)
- DO ^PSDSET
- if '$DATA(PSDSITE)
- QUIT
- +4 IF '$DATA(^XUSEC("PSJ RPHARM",DUZ))&('$DATA(^XUSEC("PSD TECH",DUZ)))
- WRITE !!,"Contact your Pharmacy Coordinator for access to display the daily CS activity.",!!,"PSJ RPHARM or PSD TECH security key required.",!
- QUIT
- ASKD ;ask disp location
- +1 SET PSDS=$PIECE(PSDSITE,U,3)
- SET PSDSN=$PIECE(PSDSITE,U,4)
- +2 if $PIECE(PSDSITE,U,5)
- GOTO CHKD
- +3 KILL DIC,DA
- SET DIC=58.8
- SET DIC(0)="QEAZ"
- SET DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S($P(^(0),""^"",2)[""M"":1,$P(^(0),""^"",2)[""S"":1,1:0)"
- +4 SET DIC("A")="Select Primary Dispensing Site: "
- +5 SET DIC("B")=$PIECE(PSDSITE,U,4)
- +6 DO ^DIC
- KILL DIC
- if Y<0
- GOTO END
- +7 SET PSDS=+Y
- SET PSDSN=$PIECE(Y,"^",2)
- SET $PIECE(PSDSITE,U,3)=+Y
- SET $PIECE(PSDSITE,U,4)=PSDSN
- CHKD IF '$ORDER(^PSD(58.8,PSDS,1,0))
- WRITE !!,"There are no CS stocked drugs for your dispensing vault.",!!
- GOTO END
- DRUG ;ask drug
- +1 WRITE !!,?5,"You may select a single drug, several drugs,",!,?5,"or enter ^ALL to select all drugs.",!!
- +2 ;rtw NSR 20171111
- WRITE ?5,"You may also enter ^ALL CII DRUGS to select all",!,?5,"schedule 2 controlled substances.",!!
- +3 WRITE !
- KILL DA,DIC
- +4 FOR
- SET DIC("W")="W:$P(^PSDRUG(Y,0),""^"",9) "" N/F"" I $P(^PSD(58.8,PSDS,1,Y,0),""^"",14)]"""",$P(^(0),""^"",14)'>DT W $C(7),"" *** INACTIVE ***"""
- SET DA(1)=+PSDS
- SET DIC(0)="QEAM"
- SET DIC="^PSD(58.8,"_PSDS_",1,"
- DO ^DIC
- KILL DIC
- if Y<0
- QUIT
- Begin DoDot:1
- +5 SET PSDRG(+Y)=""
- End DoDot:1
- +6 ;I '$D(PSDRG)&(X'="^ALL") G END ;rtw rem'd NSR20171111
- +7 ;rtw replacement NSR20171111
- IF '$DATA(PSDRG)&(X'="^ALL")&(X'="^ALL CII DRUGS")
- GOTO END
- +8 NEW PSDALL
- +9 IF X="^ALL"
- SET ALL=1
- +10 ;;rtw add NSR20171111
- IF X="^ALL CII DRUGS"
- SET PSDALL=1
- DATE WRITE !
- KILL %DT
- SET %DT="AEPTX"
- SET %DT("A")="Start with Date: "
- DO ^%DT
- IF Y<0
- GOTO END
- +1 SET PSDSD=Y
- DO D^DIQ
- SET PSDATE=Y
- SET %DT("A")="End with Date: "
- DO ^%DT
- IF Y<0
- GOTO END
- +2 IF Y<PSDSD
- WRITE !!,"The ending date of the range must be later than the starting date."
- GOTO DATE
- +3 SET PSDED=Y
- DO D^DIQ
- SET PSDATE=PSDATE_"^"_Y
- SET PSDSD=PSDSD-.00001
- +4 if '$PIECE(PSDED,".",2)
- SET PSDED=PSDED+.99999
- +5 WRITE !!,"This report is designed for a 132 column format.",!,"You may queue this report to print at a later time.",!!
- DEV ;sel device
- +1 SET Y=$PIECE($GET(^PSD(58.8,+PSDS,2)),"^",9)
- SET C=$PIECE(^DD(58.8,24,0),"^",2)
- DO Y^DIQ
- SET PSDEV=Y
- +2 WRITE !
- KILL %ZIS,IOP,IO("Q"),POP
- SET %ZIS="QM"
- SET %ZIS("B")=PSDEV
- DO ^%ZIS
- IF POP
- WRITE !!,"NO DEVICE SELECTED OR REPORT PRINTED!!",!
- GOTO END
- +3 IF $DATA(IO("Q"))
- KILL IO("Q"),ZTIO,ZTSAVE,ZTDTH,ZTSK
- SET PSDIO=ION
- SET ZTIO=""
- SET ZTRTN="START^PSDACT1"
- SET ZTDESC="CS PHARM Compile Daily Activity Log"
- DO SAVE
- DO ^%ZTLOAD
- DO HOME^%ZIS
- KILL ZTSK
- GOTO END
- +4 USE IO
- GOTO START^PSDACT1
- END ;
- +1 DO KVAR^VADPT
- +2 KILL %,%DT,%H,%I,%ZIS,ACT,ALL,BFWD,C,DA,DATE,DIC,DIR,DIROUT,DIRUT,DTOUT,DUOUT,LN,MFG,NAOU,NODE,NQTY,NUM
- +3 KILL PAT,PG,PHARM,POP,PSD,PSDA,PSDATE,PSDED,PSDEV,PSDIO,PSDOUT,PSDPN,PSDR,PSDRG,PSDRGN,PSDS,PSDSD,PSDSN,PSDUZ,PSDUZN,RX,TEXT,TYP,QTY,TYPE,X,Y,VA("BID"),VA("PID")
- +4 KILL ^TMP("PSDACT",$JOB),ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE,ZTSK
- +5 DO ^%ZISC
- if $DATA(ZTQUEUED)
- SET ZTREQ="@"
- +6 QUIT
- SAVE ;sets variables for queueing
- +1 SET (ZTSAVE("PSDS"),ZTSAVE("PSDSN"),ZTSAVE("PSDSD"),ZTSAVE("PSDED"),ZTSAVE("PSDATE"),ZTSAVE("PSDIO"))=""
- +2 if $DATA(ALL)
- SET ZTSAVE("ALL")=""
- if $DATA(PSDRG)
- SET ZTSAVE("PSDRG(")=""
- +3 ;rtw add NSR20171111
- if $DATA(PSDALL)
- SET ZTSAVE("PSDALL")=""
- +4 QUIT