| 1 | PSDNTFPC        ;BIR/JPW-Transfer Green Sheet - From this NAOU ; 8/16/07 2:20pm
 | 
|---|
| 2 |         ;;3.0; CONTROLLED SUBSTANCES ;**64**;13 Feb 97;Build 33
 | 
|---|
| 3 |         ;**Y2K compliance**;display 4 digit year on va forms
 | 
|---|
| 4 |         I '$D(PSDSITE) D ^PSDSET Q:'$D(PSDSITE)
 | 
|---|
| 5 |         S OK=$S($D(^XUSEC("PSJ RNURSE",DUZ)):1,$D(^XUSEC("PSD NURSE",DUZ)):1,$D(^XUSEC("PSJ RPHARM",DUZ)):1,1:0)
 | 
|---|
| 6 |         I 'OK W $C(7),!!,?9,"** Please contact your Coordinator for access to",!,?12,"transfer narcotic orders.",!!,"PSJ RNURSE, PSD NURSE, or PSJ RPHARM security key required.",! K OK Q
 | 
|---|
| 7 |         W !!,"Transfer a Green Sheet from this NAOU" S PSDUZ=DUZ,PSDUZN=$P($G(^VA(200,PSDUZ,0)),"^")
 | 
|---|
| 8 |         W !!,"THIS OPTION WILL TRANSFER A QUANTITY OF ZERO"
 | 
|---|
| 9 | ASKN    ;ask transfer from naou
 | 
|---|
| 10 |         W ! K DA,DIC S DIC=58.8,DIC(0)="QEAZ",DIC("A")="Select Transfer from NAOU: "
 | 
|---|
| 11 |         S DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S('$D(^(""I"")):1,'^(""I""):1,+^(""I"")>DT:1,1:0),$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)"
 | 
|---|
| 12 |         D ^DIC K DIC G:Y<0 END S AOU=+Y,AOUN=$P(Y,"^",2)
 | 
|---|
| 13 | GS      ;select green sheet #
 | 
|---|
| 14 |         W ! K DA,DIC S DIC("A")="Select the Green Sheet #: ",DIC=58.81,DIC(0)="QEASZ",D="D"
 | 
|---|
| 15 |         S DIC("S")="I $P(^(0),""^"",11)=4!($P(^(0),U,11)=13),$P(^(0),""^"",18)=AOU",DIC("W")="W "" "",$P($G(^PSDRUG($P(^(0),U,5),0)),U),"" => "",$P($G(^DPT(+$P($G(^PSD(58.81,Y,9)),U),0)),U)"
 | 
|---|
| 16 |         D IX^DIC K DIC G:Y<0 END S PSDA=+Y
 | 
|---|
| 17 |         S STAT=+$P(Y(0),"^",11),PSDPN=$P(Y(0),"^",17),STATN="" I STAT S STATN=$P($G(^PSD(58.82,STAT,0)),"^")
 | 
|---|
| 18 |         S ORD=+$P(Y(0),"^",20),NAOU=+$P(Y(0),"^",18),NAOUN=$P($G(^PSD(58.8,NAOU,0)),"^"),PSDR=+$P(Y(0),"^",5),PSDRN=$P($G(^PSDRUG(PSDR,0)),"^")
 | 
|---|
| 19 |         S MFG=$P(Y(0),"^",13),LOT=$P(Y(0),"^",14),EXP=$P(Y(0),"^",15),QTY=0,PSDS=+$P(Y(0),"^",3)  ;;*64
 | 
|---|
| 20 |         S NBKU=$P($G(^PSD(58.8,+PSDS,1,+PSDR,0)),"^",8)
 | 
|---|
| 21 |         ;*64
 | 
|---|
| 22 |         N PSDGS,PSDGSP,PSDGS0,PSDGSPT1
 | 
|---|
| 23 |         S PSDGS=0 F  S PSDGS=$O(^PSD(58.81,"D",PSDPN,PSDGS)) Q:'PSDGS  D
 | 
|---|
| 24 |         .S PSDGSP=$G(^PSD(58.81,PSDGS,9)),PSDGS0=$G(^PSD(58.81,PSDGS,0))
 | 
|---|
| 25 |         .I $P(PSDGSP,"^")]"",$P(PSDGS0,"^",2)=17 S PSDGSPT1=1
 | 
|---|
| 26 |         I '$G(PSDGSPT1) W !!,"Green Sheet not signed out to Patient.",!,"Use option 'Transfer Green Sheet and Drug to another NAOU'.",! G END      ;;*64
 | 
|---|
| 27 |         I AOU'=NAOU W !!,"The Green Sheet # ",PSDPN," does not reside on ",AOUN,".",!,"Please select another Green Sheet.",! G ASKN
 | 
|---|
| 28 |         I '$D(^PSD(58.8,NAOU,1,PSDR,3,ORD,0)) W $C(7),!!,"There's no data on ",NAOUN," for Green Sheet # ",PSDPN,".",!,"Contact your Pharmacy Coordinator for assistance.",! G END
 | 
|---|
| 29 |         I STAT'=4,STAT'=13 W !!,"This Green Sheet has a status of "_$S(STATN]"":STATN,1:"UNKNOWN")_".",!,"Please contact your Pharmacy Coordinator for assistance.",! G END
 | 
|---|
| 30 | ASKT    ;ask transfer to naou
 | 
|---|
| 31 |         W ! K DA,DIC S DIC=58.8,DIC(0)="QEAZ",DIC("A")="Select Transfer To NAOU: "
 | 
|---|
| 32 |         S DIC("S")="I $P(^(0),""^"",3)=+PSDSITE,$S('$D(^(""I"")):1,'^(""I""):1,+^(""I"")>DT:1,1:0),$P(^(0),""^"",2)=""N"",'$P(^(0),""^"",7)"
 | 
|---|
| 33 |         D ^DIC K DIC G:Y<0 END S NAOUT=+Y,NAOUTN=$P(Y,"^",2)
 | 
|---|
| 34 |         I NAOUT=AOU W !!,"You may not transfer a Green Sheet to your NAOU!",!,"Please select another NAOU.",!! G ASKT
 | 
|---|
| 35 |         S RQTY=0 W !,"Quantity to Transfer (",NBKU,"/0)",! G OK
 | 
|---|
| 36 | QTY     ;
 | 
|---|
| 37 | OK      ;already signed out to patient
 | 
|---|
| 38 |         ;ask ok to transfer
 | 
|---|
| 39 |         W ! K DA,DIR,DIRUT S DIR(0)="Y",DIR("A")="Are you sure",DIR("B")="NO"
 | 
|---|
| 40 |         S DIR("?",1)="Answer 'YES' to transfer this Green Sheet to another NAOU or",DIR("?")="answer 'NO' to leave the Green Sheet status active on your NAOU."
 | 
|---|
| 41 |         D ^DIR K DIR G:$D(DIRUT) END G:'Y GS
 | 
|---|
| 42 |         D NOW^%DTC S (RECD,Y)=+$E(%,1,12) X ^DD("DD") S RECDT=Y
 | 
|---|
| 43 | COM     ;complete at order level in 58.8
 | 
|---|
| 44 |         W !!,"Accessing ",PSDRN," information...",!!
 | 
|---|
| 45 |         S BQTY=$S($P($G(^PSD(58.8,NAOU,1,PSDR,3,ORD,0)),"^",22):$P(^(0),"^",22),1:QTY)  ;;*64
 | 
|---|
| 46 |         W !!,"Updating your records now..."
 | 
|---|
| 47 |         ;update transaction file (58.81)
 | 
|---|
| 48 |         K DA,DIE,DR S DA=PSDA,DIE=58.81,DR="64////"_RECD_";65////"_PSDUZ_";66////"_NAOUT_";70////"_RQTY_";10////10;73////"_$G(PAT) D ^DIE K DA,DIE,DR
 | 
|---|
| 49 |         I $D(Y)!$D(DTOUT) W $C(7),!!,"** THIS GREEN SHEET HAS NOT BEEN TRANSFERRED **",!!,"The status remains "_STATN,! G END
 | 
|---|
| 50 |         ;update order
 | 
|---|
| 51 |         K DA,DIE,DR S DA=ORD,DA(1)=PSDR,DA(2)=NAOU,DIE="^PSD(58.8,"_DA(2)_",1,"_DA(1)_",3,",DR="10////10;22////"_BQTY D ^DIE K DA,DIE,DR
 | 
|---|
| 52 |         ;update naou bal
 | 
|---|
| 53 |         F  L +^PSD(58.8,NAOU,1,PSDR,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I  Q
 | 
|---|
| 54 |         W:$P($G(^PSD(58.8,NAOU,2)),U,5) !,PSDRN," Remaining Balance:  ",$P($G(^PSD(58.8,NAOU,1,PSDR,0)),U,4)," ",NBKU,!
 | 
|---|
| 55 |         L -^PSD(58.8,NAOU,1,PSDR,0)   ;; *64 - fixed unlock bug
 | 
|---|
| 56 |         S STAT=$P($G(^PSD(58.81,PSDA,0)),"^",11)
 | 
|---|
| 57 |         W ?2,!,"*** The status of your Green Sheet #"_PSDPN_" is now",!,$S($P($G(^PSD(58.82,STAT,0)),"^")]"":$P(^(0),"^"),1:"UNKNOWN")_" ***",!
 | 
|---|
| 58 | PRINT   ;print 2321
 | 
|---|
| 59 |         W !!,"Number of copies of VA FORM 10-2321? " R NUM:DTIME I '$T!(NUM="^")!(NUM="") W !!,"No copies printed!!",!! Q
 | 
|---|
| 60 |         I NUM'?1N!(NUM=0)  W !!,"Enter a whole number between 1 and 9",! G PRINT
 | 
|---|
| 61 |         S Y=RECD X ^DD("DD") S PSDYR=$P(Y,",",2),PSDYR=$E(PSDYR,1,4)
 | 
|---|
| 62 |         S (PG,PSDOUT)=0,REAS="",COMP=999,RECDT=$E(RECD,4,5)_"/"_$E(RECD,6,7)_"/"_PSDYR
 | 
|---|
| 63 |         I EXP S (EXP1,EXPD)=$$FMTE^XLFDT(EXP,"5D") S:'$P(EXP1,"/",2) EXPD=$P(EXP1,"/")_"/"_$P(EXP1,"/",3) S EXP=EXPD
 | 
|---|
| 64 |         D ^PSDGSRV2
 | 
|---|
| 65 | END     K %,%DT,%H,%I,AOU,AOUN,BQTY,COMP,D,DA,DIC,DIE,DIR,DIROUT,DIRUT,DR,DTOUT,DUOUT,EXP,EXP1,EXPD,LOT,MFG
 | 
|---|
| 66 |         K NAOU,NAOUN,NAOUT,NAOUTN,NBKU,NUM,OK,ORD,PG,PSDA,PSDOUT,PSDPN,PSDR,PSDRN,PSDS,PSDUZ,PSDUZN,PSDYR,QTY,REAS,RECD,RECDT,RQTY,STAT,STATN,X,Y
 | 
|---|
| 67 |         Q
 | 
|---|