PSANAC ;BIR/LTL-Populate Pharmacy Location with Inventory Items ;7/23/97
 ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**15,64**; 10/24/97;Build 4
 ;This routine loads inventory/DA items into a pharmacy location.
 ;
 ;References to ^PSDRUG( are covered by IA #2095
 ;References to ^PSDRUG("AB" are covered by IA #2095
 ;References to ^PRC( are covered by IA #214
 ;References to ^PRCP( are covered by IA #214
 ;References to ^PS(52.6 are covered by IA #270
 ;References to ^PS(52.7 are covered by IA #770
 ;
 ;
SETUP N DA,DIE,DIC,DIR,DIRUT,DTOUT,DUOUT,DR,PSAOUT,PSADRUG,PSAIT,PSAINV,PSAQTY,PSAY,X,Y
 ;LOOK UP LOCATION
LOOK D ^PSADA I '$G(PSALOC) S PSAOUT=1 G QUIT
NOINV I '$O(^PSD(58.8,+PSALOC,4,0)) W !,$G(PSALOCN)_" is not linked to an Inventory Point.",! S DIR(0)="Y",DIR("A")="Would you like to attempt a link now",DIR("B")="Yes" D ^DIR K DIR G:Y'=1 QUIT D  G:$D(Y)!('$G(PSAINV)) QUIT
INV .S DIE=58.8,DA=PSALOC,DR="[PSAGIP]" D ^DIE
CHEC S DIR(0)="Y",DIR("A")="Have you looked at the loadable Inventory items",DIR("B")="No" D ^DIR K DIR G:$D(DIRUT) QUIT D:Y'=1  G:$G(PSAOUT) QUIT
 .S DIR(0)="Y",DIR("A")="Would you like to look at them now",DIR("B")="Yes" D ^DIR K DIR D:Y=1 DEV^PSARIN
 .S:$D(DTOUT)!($D(DUOUT))!('$G(PSADRUG(1))) PSAOUT=1 Q:$G(PSAOUT)  S DIR(0)="Y",DIR("A")="Ready to load",DIR("B")="No" D ^DIR K DIR S:Y'=1 PSAOUT=1
 S DIR(0)="Y",DIR("A")="Load inventory quantities also",DIR("B")="Yes",DIR("?")="If yes, I'll bring over the current inventory quantity with each item." D ^DIR K DIR S:Y=1 PSAY=1 I $D(DIRUT) S PSAOUT=1 G QUIT
EXP W !,"I will display each item as it is loaded",!
 K IO("Q") N %ZIS,IOP,POP S %ZIS="Q",%ZIS("A")="Please select DEVICE for output:  " D ^%ZIS I POP W !,"NO DEVICE SELECTED OR REPORT PRINTED!" S PSAOUT=1 G QUIT
 I $D(IO("Q")) N ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTDTH,ZTSK S ZTRTN="START^PSANAC",ZTDESC="Inventory items loading into DA Location",ZTSAVE("PSA*")="" D ^%ZTLOAD,HOME^%ZIS S PSAOUT=1 G QUIT
START N %DT,DIC,PSAD,PSADT,PSAL,PSALN,PSAT,PSAPG,PSARPDT,X,Y S (PSAPG,PSAOUT)=0,Y=DT D DD^%DT S PSARPDT=Y,PSAIT=0
 S PSAD="W !,PSAIT,?10,$E($$DESCR^PRCPUX1(PSAINV,PSAIT),1,34),?45,$E($P(^PSDRUG($O(^PSDRUG(""AB"",PSAIT,0)),0),U),1,34)"
 S PSAINV=$O(^PSD(58.8,+PSALOC,4,0))
 I $O(^PSD(58.8,+PSALOC,4,PSAINV)) D  S:Y<1 PSAOUT=1 G QUIT
 .S DIC="^PSD(58.8,+PSALOC,4,",DIC(0)="AEMQ",DA(1)=PSALOC D ^DIC K DIC
 .S PSAINV=+Y
 D HEADER
 S:'$D(^PSD(58.8,+PSALOC,1,0)) ^(0)="^58.8001IP^^"
LOOP F  S PSAIT=$O(^PRCP(445,PSAINV,1,PSAIT)) Q:'PSAIT  D:$Y+4>IOSL HEADER Q:PSAOUT  I '$G(^PRC(441,+PSAIT,3)),$O(^PSDRUG("AB",PSAIT,0)) S PSADRUG=$O(^PSDRUG("AB",PSAIT,0)) D:'$D(^PSD(58.8,+PSALOC,1,+PSADRUG,0))
 .I $S('$D(^PSDRUG(PSADRUG,"I")):1,+^("I")>DT:1,1:0) X PSAD D
STUFF ..S PSAQTY=$P($G(^PRCP(445,+PSAINV,1,+PSAIT,0)),U,7)*$S($P($G(^(0)),U,29):$P($G(^(0)),U,29),1:1)
 ..S:$G(PSAY) DIC("DR")="3////^S X=PSAQTY"
 ..S DIC="^PSD(58.8,+PSALOC,1,",DIC(0)="L",DA(1)=PSALOC,X=PSADRUG,DLAYGO=58.8 D ^DIC  K DIC,DLAYGO
 ..W !,"Loaded "_$P(^PSDRUG(PSADRUG,0),U)
 ..Q:'$G(PSAY)
 ..W !,"Updating beginning balance and transaction history.",!
 ..D NOW^%DTC S PSADT=+$E(%,1,12) K %
 ..S ^PSD(58.8,+PSALOC,1,+PSADRUG,5,0)="^58.801A^^"
 ..S DIC="^PSD(58.8,+PSALOC,1,+PSADRUG,5,",DIC(0)="L",(X,DINUM)=$E(DT,1,5)*100,DA(2)=PSALOC,DA(1)=PSADRUG,DIC("DR")="1////^S X=PSAQTY",DLAYGO=58.8 D ^DIC K DIC,DINUM,DLAYGO
 ..F  L +^PSD(58.81,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I  Q
FIND ..S PSAT=$P(^PSD(58.81,0),U,3)+1 I $D(^PSD(58.81,PSAT)) S $P(^PSD(58.81,0),U,3)=$P(^PSD(58.81,0),U,3)+1 G FIND
 ..S DIC="^PSD(58.81,",DIC(0)="L",DLAYGO=58.81,(DINUM,X)=PSAT D ^DIC K DIC,DINUM,DLAYGO L -^PSD(58.81,0)
 ..S DIE="^PSD(58.81,",DA=PSAT,DR="1////11;2////^S X=PSALOC;3////^S X=PSADT;4////^S X=PSADRUG;5////^S X=PSAQTY;6////^S X=DUZ;9////0" D ^DIE K DIE
 ..S:'$D(^PSD(58.8,+PSALOC,1,+PSADRUG,4,0)) ^(0)="^58.800119PA^^"
 ..S DIC="^PSD(58.8,+PSALOC,1,+PSADRUG,4,",DIC(0)="L",(X,DINUM)=PSAT
 ..S DA(2)=PSALOC,DA(1)=PSADRUG,DLAYGO=58.8 D ^DIC K DA,DIC,DINUM,DLAYGO
 ..I $E(IOST,1,2)="C-"&($O(^PS(52.6,"AC",+PSADRUG,0))!($O(^PS(52.7,"AC",+PSADRUG,0)))) S PSAIT(1)=PSAIT,PSAIT(2)=$P($G(^PSDRUG(+PSADRUG,0)),U),PSAIT(4)=$G(^PSDRUG(+PSADRUG,660)),PSAIT=PSADRUG D ^PSAPSI4 S PSAIT=PSAIT(1)
QUIT I $E(IOST)'="C" W @IOF
 I $E(IOST,1,2)="C-",'$G(PSAOUT) W !! S DIR(0)="EA",DIR("A")="END OF REPORT!  Press <RET> to return to the menu." D ^DIR
 D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
 K %ZIS("B"),IO("Q") Q
 I $$S^%ZTLOAD W !!,"Task #",$G(ZTSK),", ",$G(ZTDESC)," was stopped by ",$P($G(^VA(200,+$G(DUZ),0)),U),"." S PSAOUT=1 Q
 ;PSA*3*25 Dave B - removed single reference for OP site
 D OPSITE^PSAUTL1 S PSAINV(1)=$G(PSAOSITN)
 S:$E(PSAINV(1),10)="(" PSAINV(1)=$E(PSAINV(1),1,9)
 W:$Y @IOF S $P(PSALN,"-",81)="",PSAPG=PSAPG+1 W !,$E($P(^PRCP(445,+PSAINV,0),U),1,24)," items loading into ",PSAINV(1),?56,PSARPDT,?70,"PAGE: ",PSAPG,!,PSALN,!,"ITEM",?10,"DESCRIPTION",?50,"DRUG FILE LINK",!
 Q
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSANAC   5010     printed  Sep 23, 2025@19:25:46                                                                                                                                                                                                      Page 2
PSANAC    ;BIR/LTL-Populate Pharmacy Location with Inventory Items ;7/23/97
 +1       ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**15,64**; 10/24/97;Build 4
 +2       ;This routine loads inventory/DA items into a pharmacy location.
 +3       ;
 +4       ;References to ^PSDRUG( are covered by IA #2095
 +5       ;References to ^PSDRUG("AB" are covered by IA #2095
 +6       ;References to ^PRC( are covered by IA #214
 +7       ;References to ^PRCP( are covered by IA #214
 +8       ;References to ^PS(52.6 are covered by IA #270
 +9       ;References to ^PS(52.7 are covered by IA #770
 +10      ;
 +11      ;
SETUP      NEW DA,DIE,DIC,DIR,DIRUT,DTOUT,DUOUT,DR,PSAOUT,PSADRUG,PSAIT,PSAINV,PSAQTY,PSAY,X,Y
 +1       ;LOOK UP LOCATION
LOOK       DO ^PSADA
           IF '$GET(PSALOC)
               SET PSAOUT=1
               GOTO QUIT
NOINV      IF '$ORDER(^PSD(58.8,+PSALOC,4,0))
               WRITE !,$GET(PSALOCN)_" is not linked to an Inventory Point.",!
               SET DIR(0)="Y"
               SET DIR("A")="Would you like to attempt a link now"
               SET DIR("B")="Yes"
               DO ^DIR
               KILL DIR
               if Y'=1
                   GOTO QUIT
               Begin DoDot:1
INV                SET DIE=58.8
                   SET DA=PSALOC
                   SET DR="[PSAGIP]"
                   DO ^DIE
               End DoDot:1
               if $DATA(Y)!('$GET(PSAINV))
                   GOTO QUIT
CHEC       SET DIR(0)="Y"
           SET DIR("A")="Have you looked at the loadable Inventory items"
           SET DIR("B")="No"
           DO ^DIR
           KILL DIR
           if $DATA(DIRUT)
               GOTO QUIT
           if Y'=1
               Begin DoDot:1
 +1                SET DIR(0)="Y"
                   SET DIR("A")="Would you like to look at them now"
                   SET DIR("B")="Yes"
                   DO ^DIR
                   KILL DIR
                   if Y=1
                       DO DEV^PSARIN
 +2                if $DATA(DTOUT)!($DATA(DUOUT))!('$GET(PSADRUG(1)))
                       SET PSAOUT=1
                   if $GET(PSAOUT)
                       QUIT 
                   SET DIR(0)="Y"
                   SET DIR("A")="Ready to load"
                   SET DIR("B")="No"
                   DO ^DIR
                   KILL DIR
                   if Y'=1
                       SET PSAOUT=1
               End DoDot:1
           if $GET(PSAOUT)
               GOTO QUIT
 +3        SET DIR(0)="Y"
           SET DIR("A")="Load inventory quantities also"
           SET DIR("B")="Yes"
           SET DIR("?")="If yes, I'll bring over the current inventory quantity with each item."
           DO ^DIR
           KILL DIR
           if Y=1
               SET PSAY=1
           IF $DATA(DIRUT)
               SET PSAOUT=1
               GOTO QUIT
EXP        WRITE !,"I will display each item as it is loaded",!
 +1        KILL IO("Q")
           NEW %ZIS,IOP,POP
           SET %ZIS="Q"
           SET %ZIS("A")="Please select DEVICE for output:  "
           DO ^%ZIS
           IF POP
               WRITE !,"NO DEVICE SELECTED OR REPORT PRINTED!"
               SET PSAOUT=1
               GOTO QUIT
 +2        IF $DATA(IO("Q"))
               NEW ZTDESC,ZTIO,ZTRTN,ZTSAVE,ZTDTH,ZTSK
               SET ZTRTN="START^PSANAC"
               SET ZTDESC="Inventory items loading into DA Location"
               SET ZTSAVE("PSA*")=""
               DO ^%ZTLOAD
               DO HOME^%ZIS
               SET PSAOUT=1
               GOTO QUIT
START      NEW %DT,DIC,PSAD,PSADT,PSAL,PSALN,PSAT,PSAPG,PSARPDT,X,Y
           SET (PSAPG,PSAOUT)=0
           SET Y=DT
           DO DD^%DT
           SET PSARPDT=Y
           SET PSAIT=0
 +1        SET PSAD="W !,PSAIT,?10,$E($$DESCR^PRCPUX1(PSAINV,PSAIT),1,34),?45,$E($P(^PSDRUG($O(^PSDRUG(""AB"",PSAIT,0)),0),U),1,34)"
 +2        SET PSAINV=$ORDER(^PSD(58.8,+PSALOC,4,0))
 +3        IF $ORDER(^PSD(58.8,+PSALOC,4,PSAINV))
               Begin DoDot:1
 +4                SET DIC="^PSD(58.8,+PSALOC,4,"
                   SET DIC(0)="AEMQ"
                   SET DA(1)=PSALOC
                   DO ^DIC
                   KILL DIC
 +5                SET PSAINV=+Y
               End DoDot:1
               if Y<1
                   SET PSAOUT=1
               GOTO QUIT
 +6        DO HEADER
 +7        if '$DATA(^PSD(58.8,+PSALOC,1,0))
               SET ^(0)="^58.8001IP^^"
LOOP       FOR 
               SET PSAIT=$ORDER(^PRCP(445,PSAINV,1,PSAIT))
               if 'PSAIT
                   QUIT 
               if $Y+4>IOSL
                   DO HEADER
               if PSAOUT
                   QUIT 
               IF '$GET(^PRC(441,+PSAIT,3))
                   IF $ORDER(^PSDRUG("AB",PSAIT,0))
                       SET PSADRUG=$ORDER(^PSDRUG("AB",PSAIT,0))
                       if '$DATA(^PSD(58.8,+PSALOC,1,+PSADRUG,0))
                           Begin DoDot:1
 +1                            IF $SELECT('$DATA(^PSDRUG(PSADRUG,"I")):1,+^("I")>DT:1,1:0)
                                   XECUTE PSAD
                                   Begin DoDot:2
STUFF                                  SET PSAQTY=$PIECE($GET(^PRCP(445,+PSAINV,1,+PSAIT,0)),U,7)*$SELECT($PIECE($GET(^(0)),U,29):$PIECE($GET(^(0)),U,29),1:1)
 +1                                    if $GET(PSAY)
                                           SET DIC("DR")="3////^S X=PSAQTY"
 +2                                    SET DIC="^PSD(58.8,+PSALOC,1,"
                                       SET DIC(0)="L"
                                       SET DA(1)=PSALOC
                                       SET X=PSADRUG
                                       SET DLAYGO=58.8
                                       DO ^DIC
                                       KILL DIC,DLAYGO
 +3                                    WRITE !,"Loaded "_$PIECE(^PSDRUG(PSADRUG,0),U)
 +4                                    if '$GET(PSAY)
                                           QUIT 
 +5                                    WRITE !,"Updating beginning balance and transaction history.",!
 +6                                    DO NOW^%DTC
                                       SET PSADT=+$EXTRACT(%,1,12)
                                       KILL %
 +7                                    SET ^PSD(58.8,+PSALOC,1,+PSADRUG,5,0)="^58.801A^^"
 +8                                    SET DIC="^PSD(58.8,+PSALOC,1,+PSADRUG,5,"
                                       SET DIC(0)="L"
                                       SET (X,DINUM)=$EXTRACT(DT,1,5)*100
                                       SET DA(2)=PSALOC
                                       SET DA(1)=PSADRUG
                                       SET DIC("DR")="1////^S X=PSAQTY"
                                       SET DLAYGO=58.8
                                       DO ^DIC
                                       KILL DIC,DINUM,DLAYGO
 +9                                    FOR 
                                           LOCK +^PSD(58.81,0):$SELECT($GET(DILOCKTM)>0:DILOCKTM,1:3)
                                          IF $TEST
                                               QUIT 
FIND                                   SET PSAT=$PIECE(^PSD(58.81,0),U,3)+1
                                       IF $DATA(^PSD(58.81,PSAT))
                                           SET $PIECE(^PSD(58.81,0),U,3)=$PIECE(^PSD(58.81,0),U,3)+1
                                           GOTO FIND
 +1                                    SET DIC="^PSD(58.81,"
                                       SET DIC(0)="L"
                                       SET DLAYGO=58.81
                                       SET (DINUM,X)=PSAT
                                       DO ^DIC
                                       KILL DIC,DINUM,DLAYGO
                                       LOCK -^PSD(58.81,0)
 +2                                    SET DIE="^PSD(58.81,"
                                       SET DA=PSAT
                                       SET DR="1////11;2////^S X=PSALOC;3////^S X=PSADT;4////^S X=PSADRUG;5////^S X=PSAQTY;6////^S X=DUZ;9////0"
                                       DO ^DIE
                                       KILL DIE
 +3                                    if '$DATA(^PSD(58.8,+PSALOC,1,+PSADRUG,4,0))
                                           SET ^(0)="^58.800119PA^^"
 +4                                    SET DIC="^PSD(58.8,+PSALOC,1,+PSADRUG,4,"
                                       SET DIC(0)="L"
                                       SET (X,DINUM)=PSAT
 +5                                    SET DA(2)=PSALOC
                                       SET DA(1)=PSADRUG
                                       SET DLAYGO=58.8
                                       DO ^DIC
                                       KILL DA,DIC,DINUM,DLAYGO
 +6                                    IF $EXTRACT(IOST,1,2)="C-"&($ORDER(^PS(52.6,"AC",+PSADRUG,0))!($ORDER(^PS(52.7,"AC",+PSADRUG,0))))
                                           SET PSAIT(1)=PSAIT
                                           SET PSAIT(2)=$PIECE($GET(^PSDRUG(+PSADRUG,0)),U)
                                           SET PSAIT(4)=$GET(^PSDRUG(+PSADRUG,660))
                                           SET PSAIT=PSADRUG
                                           DO ^PSAPSI4
                                           SET PSAIT=PSAIT(1)
                                   End DoDot:2
                           End DoDot:1
QUIT       IF $EXTRACT(IOST)'="C"
               WRITE @IOF
 +1        IF $EXTRACT(IOST,1,2)="C-"
               IF '$GET(PSAOUT)
                   WRITE !!
                   SET DIR(0)="EA"
                   SET DIR("A")="END OF REPORT!  Press <RET> to return to the menu."
                   DO ^DIR
 +2        DO ^%ZISC
           if $DATA(ZTQUEUED)
               SET ZTREQ="@"
 +3        KILL %ZIS("B"),IO("Q")
           QUIT 
               IF PSAPG
                   SET DIR(0)="E"
                   DO ^DIR
                   KILL DIR
                   IF 'Y
                       SET PSAOUT=1
                       QUIT 
 +1        IF $$S^%ZTLOAD
               WRITE !!,"Task #",$GET(ZTSK),", ",$GET(ZTDESC)," was stopped by ",$PIECE($GET(^VA(200,+$GET(DUZ),0)),U),"."
               SET PSAOUT=1
               QUIT 
 +2       ;PSA*3*25 Dave B - removed single reference for OP site
 +3        DO OPSITE^PSAUTL1
           SET PSAINV(1)=$GET(PSAOSITN)
 +4        if $EXTRACT(PSAINV(1),10)="("
               SET PSAINV(1)=$EXTRACT(PSAINV(1),1,9)
 +5        if $Y
               WRITE @IOF
           SET $PIECE(PSALN,"-",81)=""
           SET PSAPG=PSAPG+1
           WRITE !,$EXTRACT($PIECE(^PRCP(445,+PSAINV,0),U),1,24)," items loading into ",PSAINV(1),?56,PSARPDT,?70,"PAGE: ",PSAPG,!,PSALN,!,"ITEM",?10,"DESCRIPTION",?50,"DRUG FILE LINK",!
 +6        QUIT