PSDREC1 ;BIR/LTL-CS Receiving (cont'd) ; 8 Aug 94
;;3.0; CONTROLLED SUBSTANCES ;**30,66**;13 Feb 97;Build 3
;Reference to ^PRC(441 supported by IA #682
;Reference to ^PRC(442 supported by IA #682
;References to $$UNITCODE^PRCPUX1 are covered by IA #259
;References to ^PSDRUG( are covered by IA #221
;Reference to ^PSD(58.8 are covered by DBIA #2711
;Reference to ^PSD(58.81 are covered by DBIA #2808
N X,X1 D SIG^XUSESIG Q:X1=""
LOOP F S PSDI=$O(^PRC(442,+PSDPO,2,"AB",PSDP,PSDI)) Q:'PSDI S PSDREC=$P($G(^PRC(442,+PSDPO,2,+PSDI,3,+$O(^PRC(442,+PSDPO,2,"AB",+PSDP,+PSDI,0)),0)),U,2) D:PSDREC G:$D(DTOUT)!($D(DUOUT)) QUIT
.S PSDIT=$G(^PRC(442,+PSDPO,2,+PSDI,0))
.W !!,$P(PSDIT,U)
.S PSDW=0 F S PSDW=$O(^PRC(442,+PSDPO,2,+PSDI,1,PSDW)) Q:'PSDW W ?5,$E($P($G(^PRC(442,+PSDPO,2,+PSDI,1,PSDW,0)),U),1,75),!
.W !,"Packaging: ",$S($P(PSDIT,U,12):$P(PSDIT,U,12)_"/",1:"")
.;PSD*3*29 changed direct 420.5 lookup to supported IA #259
.W $$UNITCODE^PRCPUX1(+$P(PSDIT,U,3))
.W ?20,"Price: $",$P(PSDIT,U,9)
.W ?35,"Item #: ",$P(PSDIT,U,5),?48,"Vendor Stock #: ",$P(PSDIT,U,6),!
NON .I '$P(PSDIT,U,5)!('$O(^PSDRUG("AB",+$P(PSDIT,U,5),"")))!('$G(^PSD(58.8,+PSDLOC,1,+$O(^PSDRUG("AB",+$P(PSDIT,U,5),"")),0))) D Q:$D(DTOUT)!($D(DUOUT))!(Y<1)
..S DIC="^PSD(58.8,PSDLOC,1,",DIC(0)="AEMQZ",DIC("A")="Select "_PSDLOCN_" drug: ",DIC("S")="I $S($P($G(^(0)),U,14):$P($G(^(0)),U,14)>DT,1:1)",DA(1)=PSDLOC
..D ^DIC K DIC Q:$D(DTOUT)!($D(DUOUT))!(Y<1)
..S PSDRUG=+Y,PSDRUGN=$P($G(^PSDRUG(+Y,0)),U)
..I $P(PSDIT,U,5),$E($G(^PRC(441,+$P(PSDIT,U,5),3)),1)'=1,'$O(^PSDRUG("AB",+$P(PSDIT,U,5),"")) D
...S DIR(0)="Y",DIR("A",1)="Are you sure that you want to link ITEM MASTER file entry,"
...S DIR("A",2)="",DIR("A",3)=$P($G(^PRC(441,+$P(PSDIT,U,5),0)),U,2)_" to DRUG file entry,"
...S DIR("A",4)="",DIR("A",5)=PSDRUGN,DIR("A")="Y/N",DIR("B")="Yes"
...S DIR("?")="Once linked, future receipts for this item will be posted to this drug.",DIR("A",6)=""
...W ! D ^DIR K DIR Q:Y<1
...S DIE=50,DA=PSDRUG,DR="441///^S X=$P(PSDIT,U,5)" D ^DIE K DIE W:'$D(Y) !!,"Now, ",PSDRUGN," is linked to Item # ",$P(PSDIT,U,5),"." S Y=1
IT .S:'$D(PSDRUG) PSDRUG=$O(^PSDRUG("AB",+$P(PSDIT,U,5),"")),PSDRUGN=$P($G(^PSDRUG(+PSDRUG,0)),U)
.W !!,PSDRUGN,!!
.S DIE="^PSDRUG(",DA=PSDRUG,DR="15Dispense units per order unit;13Price per order unit" D ^DIE K DIE I $D(Y) K PSDRUG Q
DISP .W !!,"Quantity rec'd: ",PSDREC
.W ?40,"Converted quantity: " S PSDREC=PSDREC*$P($G(^PSDRUG(+PSDRUG,660)),U,5) W PSDREC,!
.;PSD*3*29 (Dave B) Check to see if drug actually stocked
.I '$D(^PSD(58.8,+PSDLOC,1,+PSDRUG,0)) W !,"Sorry, but this drug is not stocked in this location.",! Q
POST .S DIR(0)="Y",DIR("A")="OK to post",DIR("B")="Yes",DIR("?")="If yes, the balance will be updated and a transaction stored." D ^DIR K DIR D:Y=1 K PSDRUG Q
..W !!,"There were ",$S($P($G(^PSD(58.8,+PSDLOC,1,+PSDRUG,0)),U,4):$P($G(^(0)),U,4),1:0)," on hand.",?40,"There are now ",$P($G(^(0)),U,4)+PSDREC," on hand.",!
..F L +^PSD(58.8,+PSDLOC,1,+PSDRUG,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q
..D NOW^%DTC S PSDAT=+%
..S PSDB=$P($G(^PSD(58.8,+PSDLOC,1,+PSDRUG,0)),U,4)
..S $P(^PSD(58.8,+PSDLOC,1,+PSDRUG,0),U,4)=PSDREC+PSDB
..L -^PSD(58.8,+PSDLOC,1,+PSDRUG,0)
MON ..S:'$D(^PSD(58.8,+PSDLOC,1,+PSDRUG,5,0)) ^(0)="^58.801A^^"
..I '$D(^PSD(58.8,+PSDLOC,1,+PSDRUG,5,$E(DT,1,5)*100,0)) S DIC="^PSD(58.8,+PSDLOC,1,+PSDRUG,5,",DLAYGO="58.8",DIC(0)="LM",(X,DINUM)=$E(DT,1,5)*100,DA(2)=PSDLOC,DA(1)=PSDRUG D ^DIC K DIC
..S DIE="^PSD(58.8,+PSDLOC,1,+PSDRUG,5,",DA(2)=PSDLOC,DA(1)=PSDRUG,DA=$E(DT,1,5)*100,DR="5////^S X=$P($G(^(0)),U,3)+PSDREC" D ^DIE
..W !,"Updating monthly receipts and transaction history.",!
TR ..F L +^PSD(58.81,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q
FIND ..S PSDT=$P(^PSD(58.81,0),U,3)+1 I $D(^PSD(58.81,PSDT)) 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)=PSDT D ^DIC K DIC,DLAYGO L -^PSD(58.81,0)
..S DIE="^PSD(58.81,",DA=PSDT,DR="1////1;2////^S X=PSDLOC;3////^S X=PSDAT;4////^S X=PSDRUG;5////^S X=PSDREC;6////^S X=DUZ;7////^S X=PSDCON;8////^S X=PSDPO;9////^S X=PSDB;100////1" D ^DIE K DIE
..S:'$D(^PSD(58.8,+PSDLOC,1,+PSDRUG,4,0)) ^(0)="^58.800119PA^^"
..S DIC="^PSD(58.8,+PSDLOC,1,+PSDRUG,4,",DLAYGO="58.8",DIC(0)="L",(X,DINUM)=PSDT
..S DA(2)=PSDLOC,DA(1)=PSDRUG D ^DIC K DIC,DA,PSDRUG
G:'PSDPO ^PSDREC2
QUIT Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSDREC1 4413 printed Sep 15, 2024@21:12:38 Page 2
PSDREC1 ;BIR/LTL-CS Receiving (cont'd) ; 8 Aug 94
+1 ;;3.0; CONTROLLED SUBSTANCES ;**30,66**;13 Feb 97;Build 3
+2 ;Reference to ^PRC(441 supported by IA #682
+3 ;Reference to ^PRC(442 supported by IA #682
+4 ;References to $$UNITCODE^PRCPUX1 are covered by IA #259
+5 ;References to ^PSDRUG( are covered by IA #221
+6 ;Reference to ^PSD(58.8 are covered by DBIA #2711
+7 ;Reference to ^PSD(58.81 are covered by DBIA #2808
+8 NEW X,X1
DO SIG^XUSESIG
if X1=""
QUIT
LOOP FOR
SET PSDI=$ORDER(^PRC(442,+PSDPO,2,"AB",PSDP,PSDI))
if 'PSDI
QUIT
SET PSDREC=$PIECE($GET(^PRC(442,+PSDPO,2,+PSDI,3,+$ORDER(^PRC(442,+PSDPO,2,"AB",+PSDP,+PSDI,0)),0)),U,2)
if PSDREC
Begin DoDot:1
+1 SET PSDIT=$GET(^PRC(442,+PSDPO,2,+PSDI,0))
+2 WRITE !!,$PIECE(PSDIT,U)
+3 SET PSDW=0
FOR
SET PSDW=$ORDER(^PRC(442,+PSDPO,2,+PSDI,1,PSDW))
if 'PSDW
QUIT
WRITE ?5,$EXTRACT($PIECE($GET(^PRC(442,+PSDPO,2,+PSDI,1,PSDW,0)),U),1,75),!
+4 WRITE !,"Packaging: ",$SELECT($PIECE(PSDIT,U,12):$PIECE(PSDIT,U,12)_"/",1:"")
+5 ;PSD*3*29 changed direct 420.5 lookup to supported IA #259
+6 WRITE $$UNITCODE^PRCPUX1(+$PIECE(PSDIT,U,3))
+7 WRITE ?20,"Price: $",$PIECE(PSDIT,U,9)
+8 WRITE ?35,"Item #: ",$PIECE(PSDIT,U,5),?48,"Vendor Stock #: ",$PIECE(PSDIT,U,6),!
NON IF '$PIECE(PSDIT,U,5)!('$ORDER(^PSDRUG("AB",+$PIECE(PSDIT,U,5),"")))!('$GET(^PSD(58.8,+PSDLOC,1,+$ORDER(^PSDRUG("AB",+$PIECE(PSDIT,U,5),"")),0)))
Begin DoDot:2
+1 SET DIC="^PSD(58.8,PSDLOC,1,"
SET DIC(0)="AEMQZ"
SET DIC("A")="Select "_PSDLOCN_" drug: "
SET DIC("S")="I $S($P($G(^(0)),U,14):$P($G(^(0)),U,14)>DT,1:1)"
SET DA(1)=PSDLOC
+2 DO ^DIC
KILL DIC
if $DATA(DTOUT)!($DATA(DUOUT))!(Y<1)
QUIT
+3 SET PSDRUG=+Y
SET PSDRUGN=$PIECE($GET(^PSDRUG(+Y,0)),U)
+4 IF $PIECE(PSDIT,U,5)
IF $EXTRACT($GET(^PRC(441,+$PIECE(PSDIT,U,5),3)),1)'=1
IF '$ORDER(^PSDRUG("AB",+$PIECE(PSDIT,U,5),""))
Begin DoDot:3
+5 SET DIR(0)="Y"
SET DIR("A",1)="Are you sure that you want to link ITEM MASTER file entry,"
+6 SET DIR("A",2)=""
SET DIR("A",3)=$PIECE($GET(^PRC(441,+$PIECE(PSDIT,U,5),0)),U,2)_" to DRUG file entry,"
+7 SET DIR("A",4)=""
SET DIR("A",5)=PSDRUGN
SET DIR("A")="Y/N"
SET DIR("B")="Yes"
+8 SET DIR("?")="Once linked, future receipts for this item will be posted to this drug."
SET DIR("A",6)=""
+9 WRITE !
DO ^DIR
KILL DIR
if Y<1
QUIT
+10 SET DIE=50
SET DA=PSDRUG
SET DR="441///^S X=$P(PSDIT,U,5)"
DO ^DIE
KILL DIE
if '$DATA(Y)
WRITE !!,"Now, ",PSDRUGN," is linked to Item # ",$PIECE(PSDIT,U,5),"."
SET Y=1
End DoDot:3
End DoDot:2
if $DATA(DTOUT)!($DATA(DUOUT))!(Y<1)
QUIT
IT if '$DATA(PSDRUG)
SET PSDRUG=$ORDER(^PSDRUG("AB",+$PIECE(PSDIT,U,5),""))
SET PSDRUGN=$PIECE($GET(^PSDRUG(+PSDRUG,0)),U)
+1 WRITE !!,PSDRUGN,!!
+2 SET DIE="^PSDRUG("
SET DA=PSDRUG
SET DR="15Dispense units per order unit;13Price per order unit"
DO ^DIE
KILL DIE
IF $DATA(Y)
KILL PSDRUG
QUIT
DISP WRITE !!,"Quantity rec'd: ",PSDREC
+1 WRITE ?40,"Converted quantity: "
SET PSDREC=PSDREC*$PIECE($GET(^PSDRUG(+PSDRUG,660)),U,5)
WRITE PSDREC,!
+2 ;PSD*3*29 (Dave B) Check to see if drug actually stocked
+3 IF '$DATA(^PSD(58.8,+PSDLOC,1,+PSDRUG,0))
WRITE !,"Sorry, but this drug is not stocked in this location.",!
QUIT
POST SET DIR(0)="Y"
SET DIR("A")="OK to post"
SET DIR("B")="Yes"
SET DIR("?")="If yes, the balance will be updated and a transaction stored."
DO ^DIR
KILL DIR
if Y=1
Begin DoDot:2
+1 WRITE !!,"There were ",$SELECT($PIECE($GET(^PSD(58.8,+PSDLOC,1,+PSDRUG,0)),U,4):$PIECE($GET(^(0)),U,4),1:0)," on hand.",?40,"There are now ",$PIECE($GET(^(0)),U,4)+PSDREC," on hand.",!
+2 FOR
LOCK +^PSD(58.8,+PSDLOC,1,+PSDRUG,0):$SELECT($GET(DILOCKTM)>0:DILOCKTM,1:3)
IF $TEST
QUIT
+3 DO NOW^%DTC
SET PSDAT=+%
+4 SET PSDB=$PIECE($GET(^PSD(58.8,+PSDLOC,1,+PSDRUG,0)),U,4)
+5 SET $PIECE(^PSD(58.8,+PSDLOC,1,+PSDRUG,0),U,4)=PSDREC+PSDB
+6 LOCK -^PSD(58.8,+PSDLOC,1,+PSDRUG,0)
MON if '$DATA(^PSD(58.8,+PSDLOC,1,+PSDRUG,5,0))
SET ^(0)="^58.801A^^"
+1 IF '$DATA(^PSD(58.8,+PSDLOC,1,+PSDRUG,5,$EXTRACT(DT,1,5)*100,0))
SET DIC="^PSD(58.8,+PSDLOC,1,+PSDRUG,5,"
SET DLAYGO="58.8"
SET DIC(0)="LM"
SET (X,DINUM)=$EXTRACT(DT,1,5)*100
SET DA(2)=PSDLOC
SET DA(1)=PSDRUG
DO ^DIC
KILL DIC
+2 SET DIE="^PSD(58.8,+PSDLOC,1,+PSDRUG,5,"
SET DA(2)=PSDLOC
SET DA(1)=PSDRUG
SET DA=$EXTRACT(DT,1,5)*100
SET DR="5////^S X=$P($G(^(0)),U,3)+PSDREC"
DO ^DIE
+3 WRITE !,"Updating monthly receipts and transaction history.",!
TR FOR
LOCK +^PSD(58.81,0):$SELECT($GET(DILOCKTM)>0:DILOCKTM,1:3)
IF $TEST
QUIT
FIND SET PSDT=$PIECE(^PSD(58.81,0),U,3)+1
IF $DATA(^PSD(58.81,PSDT))
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)=PSDT
DO ^DIC
KILL DIC,DLAYGO
LOCK -^PSD(58.81,0)
+2 SET DIE="^PSD(58.81,"
SET DA=PSDT
SET DR="1////1;2////^S X=PSDLOC;3////^S X=PSDAT;4////^S X=PSDRUG;5////^S X=PSDREC;6////^S X=DUZ;7////^S X=PSDCON;8////^S X=PSDPO;9////^S X=PSDB;100////1"
DO ^DIE
KILL DIE
+3 if '$DATA(^PSD(58.8,+PSDLOC,1,+PSDRUG,4,0))
SET ^(0)="^58.800119PA^^"
+4 SET DIC="^PSD(58.8,+PSDLOC,1,+PSDRUG,4,"
SET DLAYGO="58.8"
SET DIC(0)="L"
SET (X,DINUM)=PSDT
+5 SET DA(2)=PSDLOC
SET DA(1)=PSDRUG
DO ^DIC
KILL DIC,DA,PSDRUG
End DoDot:2
KILL PSDRUG
QUIT
End DoDot:1
if $DATA(DTOUT)!($DATA(DUOUT))
GOTO QUIT
+6 if 'PSDPO
GOTO ^PSDREC2
QUIT QUIT