- PSDPSI ;BIR/JPW-Green Sheets Placed on Insp Hold Rpt ; 29 Aug 94
- ;;3.0; CONTROLLED SUBSTANCES ;;13 Feb 97
- I '$D(PSDSITE) D ^PSDSET Q:'$D(PSDSITE)
- ASKD ;ask disp location
- S PSDS=$P(PSDSITE,U,3),PSDSN=$P(PSDSITE,U,4)
- I $P(PSDSITE,U,5) S PSDS=PSDS_"^"_+$P(^PSD(58.8,+PSDS,0),"^",5) G ASKN
- 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: ",DIC("B")=$P(PSDSITE,U,4)
- D ^DIC K DIC G:Y<0 END
- S PSDS=+Y,PSDSN=$P(Y,"^",2),PSDS=PSDS_"^"_+$P(Y(0),"^",5)
- S $P(PSDSITE,U,3)=+Y,$P(PSDSITE,U,4)=PSDSN
- 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 for 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 D NOW^%DTC S PSDT=X,PSDPT=+$E(%,1,12) K DA,DIC S CNT=0
- I SEL="G" D GROUP G:'$D(PSDG) END G DEV
- F S DIC=58.8,DIC("A")="Select NAOU: ",DIC(0)="QEA",DIC("S")="I $P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7),$P(^(0),""^"",4)=+PSDS" 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
- DEV ;ask device and queue info
- W !!,"You may queue this report to print at a later time.",!!
- S Y=$P($G(^PSD(58.8,+PSDS,2)),"^",9),C=$P(^DD(58.8,24,0),"^",2) D Y^DIQ S PSDEV=Y
- 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 ZTRTN="START^PSDPSI",ZTDESC="CS Green Sheets Placed on Insp Hold" D SAVE,^%ZTLOAD,HOME^%ZIS K ZTSK G END
- U IO
- START ;compile data
- K ^TMP("PSDPSI",$J)
- I $D(PSDG) F PSD=0:0 S PSD=$O(PSDG(PSD)) Q:'PSD F PSDN=0:0 S PSDN=$O(^PSI(58.2,PSD,3,PSDN)) Q:'PSDN I $D(^PSD(58.8,PSDN,0)),'$P(^(0),"^",7),$P(^(0),"^",4)=+PSDS S NAOU(PSDN)="",CNT=CNT+1
- I $D(ALL) F PSD=0:0 S PSD=$O(^PSD(58.8,PSD)) Q:'PSD I $D(^PSD(58.8,PSD,0)),$P(^(0),"^",2)="N",$P(^(0),"^",4)=+PSDS,'$P(^(0),"^",7) S NAOU(+PSD)=""
- F PSD=0:0 S PSD=$O(NAOU(PSD)) Q:'PSD F PSDA=0:0 S PSDA=$O(^PSD(58.81,"AD",11,PSD,PSDA)) Q:'PSDA I $D(^PSD(58.81,PSDA,0)) S NODE=^PSD(58.81,PSDA,0) D
- .S PSDNA=$S($P($G(^PSD(58.8,+PSD,0)),"^")]"":$P(^(0),"^"),1:"ZZ/"_PSD)
- .S DRUG=+$P(NODE,"^",5),DRUGN=$S($P($G(^PSDRUG(DRUG,0)),"^")]"":$P(^(0),"^"),1:"ZZ/"_DRUG)
- .S PSDBY=+$P(NODE,"^",7),PSDBY=$P($G(^VA(200,+PSDBY,0)),"^")
- .S (PSDTH,Y)=+$P($G(^PSD(58.81,PSDA,1.5)),"^",3) X ^DD("DD") S PSDTH=Y
- .S PSDANS=$G(^PSD(58.81,PSDA,1.6))
- .S NUM=$P(NODE,"^",17),^TMP("PSDPSI",$J,PSDNA,NUM,DRUGN)=PSDBY_"^"_PSDTH_"^"_PSDANS
- PRINT ;print green sheets picked up naou, green sheet #
- S (PG,PSDOUT,NAOU)=0 D NOW^%DTC S Y=+$E(%,1,12) X ^DD("DD") S RPDT=Y
- K LN S $P(LN,"-",80)="" I '$D(^TMP("PSDPSI",$J)) D HDR W !!,?10,"**** NO GREEN SHEETS ON INSPECTOR HOLD ****" G END
- S NAOU="" F S NAOU=$O(^TMP("PSDPSI",$J,NAOU)) Q:NAOU=""!(PSDOUT) D HDR Q:PSDOUT W !,?2,"=> NAOU: "_NAOU,! D Q:PSDOUT
- .S NUM="" F S NUM=$O(^TMP("PSDPSI",$J,NAOU,NUM)) Q:NUM=""!(PSDOUT) D:$Y+6>IOSL HDR Q:PSDOUT S DRUG=$O(^TMP("PSDPSI",$J,NAOU,NUM,0)) Q:DRUG="" D
- ..W !,NUM,?12,DRUG,?55,$P(^TMP("PSDPSI",$J,NAOU,NUM,DRUG),"^"),!,?15,$P(^TMP("PSDPSI",$J,NAOU,NUM,DRUG),"^",2),!
- ..W:$P(^TMP("PSDPSI",$J,NAOU,NUM,DRUG),"^",3)]"" ?15,$P(^TMP("PSDPSI",$J,NAOU,NUM,DRUG),"^",3),!
- DONE I $E(IOST)'="C" W @IOF
- I $E(IOST,1,2)="C-",'PSDOUT W ! K DIR,DIRUT S DIR(0)="EA",DIR("A")="END OF REPORT! Press <RET> to return to the menu" D ^DIR K DIR
- END K %,%H,%I,%ZIS,ALL,C,CNT,DA,DIC,DIR,DIROUT,DIRUT,DRUG,DRUGN,DTOUT,DUOUT,LN,NAOU,NODE,NUM
- K OK,PG,POP,PSD,PSDBY,PSDA,PSDANS,PSDEV,PSDG,PSDN,PSDNA,PSDS,PSDSN,PSDOUT,PSDPT,PSDT,PSDTH,RPDT,SEL,X,Y,ZTDESC,ZTDTH,ZTRTN,ZTSAVE,ZTSK
- K ^TMP("PSDPSI",$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("PSDT"),ZTSAVE("CNT"),ZTSAVE("PSDS"))="" S:$D(PSDG) ZTSAVE("PSDG(")="" S:$D(NAOU) ZTSAVE("NAOU(")="" S:$D(ALL) ZTSAVE("ALL")=""
- Q
- HDR ;header for log
- I $E(IOST,1,2)="C-",PG W ! K DA,DIR S DIR(0)="E" D ^DIR K DIR I 'Y S PSDOUT=1 Q
- S PG=PG+1 W:$Y @IOF W !,?15,"Green Sheets Placed on Hold for Inspector Review",?70,"Page: ",PG,!,?26,"Run Date: ",RPDT,!
- W !,"DISP #",?12,"DRUG",?55,"PLACED ON HOLD BY",!,?15,"DATE PLACED ON HOLD",!,?15,"HOLD REMARKS"
- W !,LN,!
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDPSI 4662 printed Feb 18, 2025@23:14:37 Page 2
- PSDPSI ;BIR/JPW-Green Sheets Placed on Insp Hold Rpt ; 29 Aug 94
- +1 ;;3.0; CONTROLLED SUBSTANCES ;;13 Feb 97
- +2 IF '$DATA(PSDSITE)
- DO ^PSDSET
- if '$DATA(PSDSITE)
- QUIT
- ASKD ;ask disp location
- +1 SET PSDS=$PIECE(PSDSITE,U,3)
- SET PSDSN=$PIECE(PSDSITE,U,4)
- +2 IF $PIECE(PSDSITE,U,5)
- SET PSDS=PSDS_"^"_+$PIECE(^PSD(58.8,+PSDS,0),"^",5)
- GOTO ASKN
- +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: "
- SET DIC("B")=$PIECE(PSDSITE,U,4)
- +5 DO ^DIC
- KILL DIC
- if Y<0
- GOTO END
- +6 SET PSDS=+Y
- SET PSDSN=$PIECE(Y,"^",2)
- SET PSDS=PSDS_"^"_+$PIECE(Y(0),"^",5)
- +7 SET $PIECE(PSDSITE,U,3)=+Y
- SET $PIECE(PSDSITE,U,4)=PSDSN
- 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 for 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
- DO NOW^%DTC
- SET PSDT=X
- SET PSDPT=+$EXTRACT(%,1,12)
- KILL DA,DIC
- SET CNT=0
- +5 IF SEL="G"
- DO GROUP
- if '$DATA(PSDG)
- GOTO END
- GOTO DEV
- +6 FOR
- SET DIC=58.8
- SET DIC("A")="Select NAOU: "
- SET DIC(0)="QEA"
- SET DIC("S")="I $P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7),$P(^(0),""^"",4)=+PSDS"
- 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
- DEV ;ask device and queue info
- +1 WRITE !!,"You may queue this report to print at a later time.",!!
- +2 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
- +3 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
- +4 IF $DATA(IO("Q"))
- KILL IO("Q"),ZTIO,ZTSAVE,ZTDTH,ZTSK
- SET ZTRTN="START^PSDPSI"
- SET ZTDESC="CS Green Sheets Placed on Insp Hold"
- DO SAVE
- DO ^%ZTLOAD
- DO HOME^%ZIS
- KILL ZTSK
- GOTO END
- +5 USE IO
- START ;compile data
- +1 KILL ^TMP("PSDPSI",$JOB)
- +2 IF $DATA(PSDG)
- FOR PSD=0:0
- SET PSD=$ORDER(PSDG(PSD))
- if 'PSD
- QUIT
- FOR PSDN=0:0
- SET PSDN=$ORDER(^PSI(58.2,PSD,3,PSDN))
- if 'PSDN
- QUIT
- IF $DATA(^PSD(58.8,PSDN,0))
- IF '$PIECE(^(0),"^",7)
- IF $PIECE(^(0),"^",4)=+PSDS
- SET NAOU(PSDN)=""
- SET CNT=CNT+1
- +3 IF $DATA(ALL)
- FOR PSD=0:0
- SET PSD=$ORDER(^PSD(58.8,PSD))
- if 'PSD
- QUIT
- IF $DATA(^PSD(58.8,PSD,0))
- IF $PIECE(^(0),"^",2)="N"
- IF $PIECE(^(0),"^",4)=+PSDS
- IF '$PIECE(^(0),"^",7)
- SET NAOU(+PSD)=""
- +4 FOR PSD=0:0
- SET PSD=$ORDER(NAOU(PSD))
- if 'PSD
- QUIT
- FOR PSDA=0:0
- SET PSDA=$ORDER(^PSD(58.81,"AD",11,PSD,PSDA))
- if 'PSDA
- QUIT
- IF $DATA(^PSD(58.81,PSDA,0))
- SET NODE=^PSD(58.81,PSDA,0)
- Begin DoDot:1
- +5 SET PSDNA=$SELECT($PIECE($GET(^PSD(58.8,+PSD,0)),"^")]"":$PIECE(^(0),"^"),1:"ZZ/"_PSD)
- +6 SET DRUG=+$PIECE(NODE,"^",5)
- SET DRUGN=$SELECT($PIECE($GET(^PSDRUG(DRUG,0)),"^")]"":$PIECE(^(0),"^"),1:"ZZ/"_DRUG)
- +7 SET PSDBY=+$PIECE(NODE,"^",7)
- SET PSDBY=$PIECE($GET(^VA(200,+PSDBY,0)),"^")
- +8 SET (PSDTH,Y)=+$PIECE($GET(^PSD(58.81,PSDA,1.5)),"^",3)
- XECUTE ^DD("DD")
- SET PSDTH=Y
- +9 SET PSDANS=$GET(^PSD(58.81,PSDA,1.6))
- +10 SET NUM=$PIECE(NODE,"^",17)
- SET ^TMP("PSDPSI",$JOB,PSDNA,NUM,DRUGN)=PSDBY_"^"_PSDTH_"^"_PSDANS
- End DoDot:1
- PRINT ;print green sheets picked up naou, green sheet #
- +1 SET (PG,PSDOUT,NAOU)=0
- DO NOW^%DTC
- SET Y=+$EXTRACT(%,1,12)
- XECUTE ^DD("DD")
- SET RPDT=Y
- +2 KILL LN
- SET $PIECE(LN,"-",80)=""
- IF '$DATA(^TMP("PSDPSI",$JOB))
- DO HDR
- WRITE !!,?10,"**** NO GREEN SHEETS ON INSPECTOR HOLD ****"
- GOTO END
- +3 SET NAOU=""
- FOR
- SET NAOU=$ORDER(^TMP("PSDPSI",$JOB,NAOU))
- if NAOU=""!(PSDOUT)
- QUIT
- DO HDR
- if PSDOUT
- QUIT
- WRITE !,?2,"=> NAOU: "_NAOU,!
- Begin DoDot:1
- +4 SET NUM=""
- FOR
- SET NUM=$ORDER(^TMP("PSDPSI",$JOB,NAOU,NUM))
- if NUM=""!(PSDOUT)
- QUIT
- if $Y+6>IOSL
- DO HDR
- if PSDOUT
- QUIT
- SET DRUG=$ORDER(^TMP("PSDPSI",$JOB,NAOU,NUM,0))
- if DRUG=""
- QUIT
- Begin DoDot:2
- +5 WRITE !,NUM,?12,DRUG,?55,$PIECE(^TMP("PSDPSI",$JOB,NAOU,NUM,DRUG),"^"),!,?15,$PIECE(^TMP("PSDPSI",$JOB,NAOU,NUM,DRUG),"^",2),!
- +6 if $PIECE(^TMP("PSDPSI",$JOB,NAOU,NUM,DRUG),"^",3)]""
- WRITE ?15,$PIECE(^TMP("PSDPSI",$JOB,NAOU,NUM,DRUG),"^",3),!
- End DoDot:2
- End DoDot:1
- if PSDOUT
- QUIT
- DONE IF $EXTRACT(IOST)'="C"
- WRITE @IOF
- +1 IF $EXTRACT(IOST,1,2)="C-"
- IF 'PSDOUT
- WRITE !
- KILL DIR,DIRUT
- SET DIR(0)="EA"
- SET DIR("A")="END OF REPORT! Press <RET> to return to the menu"
- DO ^DIR
- KILL DIR
- END KILL %,%H,%I,%ZIS,ALL,C,CNT,DA,DIC,DIR,DIROUT,DIRUT,DRUG,DRUGN,DTOUT,DUOUT,LN,NAOU,NODE,NUM
- +1 KILL OK,PG,POP,PSD,PSDBY,PSDA,PSDANS,PSDEV,PSDG,PSDN,PSDNA,PSDS,PSDSN,PSDOUT,PSDPT,PSDT,PSDTH,RPDT,SEL,X,Y,ZTDESC,ZTDTH,ZTRTN,ZTSAVE,ZTSK
- +2 KILL ^TMP("PSDPSI",$JOB)
- DO ^%ZISC
- +3 if $DATA(ZTQUEUED)
- SET ZTREQ="@"
- +4 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("PSDT"),ZTSAVE("CNT"),ZTSAVE("PSDS"))=""
- if $DATA(PSDG)
- SET ZTSAVE("PSDG(")=""
- if $DATA(NAOU)
- SET ZTSAVE("NAOU(")=""
- if $DATA(ALL)
- SET ZTSAVE("ALL")=""
- +1 QUIT
- HDR ;header for log
- +1 IF $EXTRACT(IOST,1,2)="C-"
- IF PG
- WRITE !
- KILL DA,DIR
- SET DIR(0)="E"
- DO ^DIR
- KILL DIR
- IF 'Y
- SET PSDOUT=1
- QUIT
- +2 SET PG=PG+1
- if $Y
- WRITE @IOF
- WRITE !,?15,"Green Sheets Placed on Hold for Inspector Review",?70,"Page: ",PG,!,?26,"Run Date: ",RPDT,!
- +3 WRITE !,"DISP #",?12,"DRUG",?55,"PLACED ON HOLD BY",!,?15,"DATE PLACED ON HOLD",!,?15,"HOLD REMARKS"
- +4 WRITE !,LN,!
- +5 QUIT