PSIVRDC ;BIR/MV - RECYCLE, CANCEL, DESTROY ACTIONS ;30 Aug 2001  4:21 PM
 ;;5.0;INPATIENT MEDICATIONS;**85,200,407**;16 DEC 97;Build 26
 ;
 ;;Reference to ^PS(55 is supported by DBIA 2191
 ;
EN ;
 NEW CHK,PSGDT,PSIVPL,PSIVPR,PSIVSITE,PSIVSN,PSJSYSL,PSJSYSP,PSJSYSP0,PSJSYSU
 D ^PSIVXU Q:$D(XQUIT)
 Q:$G(DONE)  ;P407
 NEW DA,DIC,DIR,X,X,Y
 W !
 F  K DIR S DIR(0)="SOA^R:RECYCLE;C:CANCEL;D:DESTROY",DIR("A")="Enter action to take (Recycle/Cancel/Destroy): " D ^DIR Q:$S(Y="R":0,Y="C":0,Y="D":0,1:1)  D GTID(Y)
 Q
GTID(PSJRDC) ;
 F  K DIR S DIR(0)="FO^1:50",DIR("A")="Scan Barcode to "_$$TXT(PSJRDC) D  Q:X=""!$D(DTOUT)!$D(DUOUT)!$D(DIROUT)  D UPDID($$UP^XLFSTR(X),PSJRDC)
 . S DIR("?")="Please enter the barcode ID" D ^DIR
 Q
UPDID(PSJID,PSJRDC)        ;
 NEW ACTION,DA,DIC,DFN,ON,LABELS,PSIVNOL,PSJLB,X,Y
 I '$D(^PS(55,+$P(PSJID,"V"),"BCMA",PSJID)) W !,"...Invalid ID number.  Please try again.",!! Q
 S DA(1)=$P(PSJID,"V"),DIC="^PS(55,"_DA(1)_",""IVBCMA"",",X=$P(PSJID,"V",2),DIC(0)="ZQ" D ^DIC
 I Y=-1 W !!,"...Invalid ID number.  Please try again.",!! Q
 W !
 F X=1:1:8 S PSJLB(X)=$P(Y(0),U,X)
 I $S(PSJLB(4)]""&("CGIS"[PSJLB(4)):1,PSJLB(7)="RP":0,PSJLB(7)]"":1,1:0) D  Q
 . W !,"...The ID entered was marked as "
 . W $S(PSJLB(4)="C":"Completed.",PSJLB(4)="G":"Given.",PSJLB(4)="I":"Infusing.",PSJLB(4)="S":"Stop.",PSJLB(7)="CA":"Cancel.",PSJLB(7)="DT":"Destroy.",PSJLB(7)="RC":"Recycle.",1:""),!
 S ON=PSJLB(2),DFN=$P(PSJID,"V")
 D DSPLY
 K DIR S DIR(0)="FO^1:50",DIR("A")=$$TXT(PSJRDC),DIR("B")=PSJID D ^DIR
 I $D(DTOUT)!$D(DUOUT)!$D(DIROUT) Q
 I X'=PSJID W !,"...Barcode ID did not match.  No action was taken." W ! Q
 K DA,DR,DIE,DIC,DIR
 D NOW^%DTC
 S DA=$P(PSJID,"V",2),DA(1)=DFN,DIE="^PS(55,"_DA(1)_",""IVBCMA"","
 S DR="4////"_%_";5////"_$S(PSJRDC="R":"RC",PSJRDC="D":"DT",1:"CA") D ^DIE
 K DA,DR,DIE,DIC,DTOUT,DUOUT,DIROUT
 ;BHW;PSJ*5*200;Add RDFLAG and RDWARD so PSIVSTAT will update the Cumulative doses.
 N RDFLAG,RDWARD
 S RDFLAG="ON"
 S RDWARD=$P(^PS(55,DFN,"IV",+ON,0),U,22) I 'RDWARD S RDWARD=$S($D(^DPT(DFN,.1)):$O(^DIC(42,"B",^DPT(DFN,.1),0)),1:.5)
 ;BHW;PSJ*5*200;End Changes
 S PSIVNOL=1,LABELS=1,ACTION=$S(PSJRDC="R":2,PSJRDC="D":3,1:4) D ^PSIVLTR,^PSIVSTAT
 W !,"...Done!",!!
 Q
DSPLY ;Display the patient name, additives/solutions.
 NEW PSJAS,PSJADSOL,PSJL,PSJLBN,PSJLEN,PSJLN,VA,VADM,X
 K ^TMP("PSIVLB",$J)
 D DEM^VADPT
 S PSJL="",(PSJLEN,PSJLN)=1,PSJLBN=$P(PSJID,"V",2)
 F PSJAS="AD","SOL" D ADSOL^PSIVLB(PSJAS)
 W !,VADM(1),!
 F X=0:0 S X=$O(^TMP("PSIVLB",$J,X)) Q:'X  W !,^(X,0)
 W !
 K ^TMP("PSIVLB",$J)
 Q
TXT(X) ;Expand the set of code to text.
 Q $S(X="R":"Recycle",X="C":"Cancel",X="D":"Destroy",1:"")
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSIVRDC   2695     printed  Sep 23, 2025@19:41:03                                                                                                                                                                                                     Page 2
PSIVRDC   ;BIR/MV - RECYCLE, CANCEL, DESTROY ACTIONS ;30 Aug 2001  4:21 PM
 +1       ;;5.0;INPATIENT MEDICATIONS;**85,200,407**;16 DEC 97;Build 26
 +2       ;
 +3       ;;Reference to ^PS(55 is supported by DBIA 2191
 +4       ;
EN        ;
 +1        NEW CHK,PSGDT,PSIVPL,PSIVPR,PSIVSITE,PSIVSN,PSJSYSL,PSJSYSP,PSJSYSP0,PSJSYSU
 +2        DO ^PSIVXU
           if $DATA(XQUIT)
               QUIT 
 +3       ;P407
           if $GET(DONE)
               QUIT 
 +4        NEW DA,DIC,DIR,X,X,Y
 +5        WRITE !
 +6        FOR 
               KILL DIR
               SET DIR(0)="SOA^R:RECYCLE;C:CANCEL;D:DESTROY"
               SET DIR("A")="Enter action to take (Recycle/Cancel/Destroy): "
               DO ^DIR
               if $SELECT(Y="R"
                   QUIT 
               DO GTID(Y)
 +7        QUIT 
GTID(PSJRDC) ;
 +1        FOR 
               KILL DIR
               SET DIR(0)="FO^1:50"
               SET DIR("A")="Scan Barcode to "_$$TXT(PSJRDC)
               Begin DoDot:1
 +2                SET DIR("?")="Please enter the barcode ID"
                   DO ^DIR
               End DoDot:1
               if X=""!$DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIROUT)
                   QUIT 
               DO UPDID($$UP^XLFSTR(X),PSJRDC)
 +3        QUIT 
UPDID(PSJID,PSJRDC) ;
 +1        NEW ACTION,DA,DIC,DFN,ON,LABELS,PSIVNOL,PSJLB,X,Y
 +2        IF '$DATA(^PS(55,+$PIECE(PSJID,"V"),"BCMA",PSJID))
               WRITE !,"...Invalid ID number.  Please try again.",!!
               QUIT 
 +3        SET DA(1)=$PIECE(PSJID,"V")
           SET DIC="^PS(55,"_DA(1)_",""IVBCMA"","
           SET X=$PIECE(PSJID,"V",2)
           SET DIC(0)="ZQ"
           DO ^DIC
 +4        IF Y=-1
               WRITE !!,"...Invalid ID number.  Please try again.",!!
               QUIT 
 +5        WRITE !
 +6        FOR X=1:1:8
               SET PSJLB(X)=$PIECE(Y(0),U,X)
 +7        IF $SELECT(PSJLB(4)]""&("CGIS"[PSJLB(4)):1,PSJLB(7)="RP":0,PSJLB(7)]"":1,1:0)
               Begin DoDot:1
 +8                WRITE !,"...The ID entered was marked as "
 +9                WRITE $SELECT(PSJLB(4)="C":"Completed.",PSJLB(4)="G":"Given.",PSJLB(4)="I":"Infusing.",PSJLB(4)="S":"Stop.",PSJLB(7)="CA":"Cancel.",PSJLB(7)="DT":"Destroy.",PSJLB(7)="RC":"Recycle.",1:""),!
               End DoDot:1
               QUIT 
 +10       SET ON=PSJLB(2)
           SET DFN=$PIECE(PSJID,"V")
 +11       DO DSPLY
 +12       KILL DIR
           SET DIR(0)="FO^1:50"
           SET DIR("A")=$$TXT(PSJRDC)
           SET DIR("B")=PSJID
           DO ^DIR
 +13       IF $DATA(DTOUT)!$DATA(DUOUT)!$DATA(DIROUT)
               QUIT 
 +14       IF X'=PSJID
               WRITE !,"...Barcode ID did not match.  No action was taken."
               WRITE !
               QUIT 
 +15       KILL DA,DR,DIE,DIC,DIR
 +16       DO NOW^%DTC
 +17       SET DA=$PIECE(PSJID,"V",2)
           SET DA(1)=DFN
           SET DIE="^PS(55,"_DA(1)_",""IVBCMA"","
 +18       SET DR="4////"_%_";5////"_$SELECT(PSJRDC="R":"RC",PSJRDC="D":"DT",1:"CA")
           DO ^DIE
 +19       KILL DA,DR,DIE,DIC,DTOUT,DUOUT,DIROUT
 +20      ;BHW;PSJ*5*200;Add RDFLAG and RDWARD so PSIVSTAT will update the Cumulative doses.
 +21       NEW RDFLAG,RDWARD
 +22       SET RDFLAG="ON"
 +23       SET RDWARD=$PIECE(^PS(55,DFN,"IV",+ON,0),U,22)
           IF 'RDWARD
               SET RDWARD=$SELECT($DATA(^DPT(DFN,.1)):$ORDER(^DIC(42,"B",^DPT(DFN,.1),0)),1:.5)
 +24      ;BHW;PSJ*5*200;End Changes
 +25       SET PSIVNOL=1
           SET LABELS=1
           SET ACTION=$SELECT(PSJRDC="R":2,PSJRDC="D":3,1:4)
           DO ^PSIVLTR
           DO ^PSIVSTAT
 +26       WRITE !,"...Done!",!!
 +27       QUIT 
DSPLY     ;Display the patient name, additives/solutions.
 +1        NEW PSJAS,PSJADSOL,PSJL,PSJLBN,PSJLEN,PSJLN,VA,VADM,X
 +2        KILL ^TMP("PSIVLB",$JOB)
 +3        DO DEM^VADPT
 +4        SET PSJL=""
           SET (PSJLEN,PSJLN)=1
           SET PSJLBN=$PIECE(PSJID,"V",2)
 +5        FOR PSJAS="AD","SOL"
               DO ADSOL^PSIVLB(PSJAS)
 +6        WRITE !,VADM(1),!
 +7        FOR X=0:0
               SET X=$ORDER(^TMP("PSIVLB",$JOB,X))
               if 'X
                   QUIT 
               WRITE !,^(X,0)
 +8        WRITE !
 +9        KILL ^TMP("PSIVLB",$JOB)
 +10       QUIT 
TXT(X)    ;Expand the set of code to text.
 +1        QUIT $SELECT(X="R":"Recycle",X="C":"Cancel",X="D":"Destroy",1:"")