Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: RMPR5NTU

RMPR5NTU.m

Go to the documentation of this file.
  1. RMPR5NTU ;HIN/RVD-PROS INVENTORY TRANS/UPDATE UTILITY ;2/11/98
  1. ;;3.0;PROSTHETICS;**33,34,37**;Feb 09, 1996
  1. D DIV4^RMPRSIT I $D(Y),(Y<0) K DIC("B") Q
  1. W @IOF
  1. ;
  1. TRAN ;ask for Location.
  1. S X="NOW" D ^%DT S RMDAT1=Y D DD^%DT S RMDAT=Y
  1. K DTOUT,DUOUT,DIC("B")
  1. W !!,"Transferring Item Quantity to Another LOCATION....."
  1. S DZ="??",D="B",DIC("S")="I $P(^RMPR(661.3,+Y,0),U,3)=RMPR(""STA"")"
  1. S DIC="^RMPR(661.3,",DIC(0)="AEQM"
  1. ;I $D(^RMPR(661.3,"B")) D DQ^DICQ
  1. S D="B",DIC("A")="From Location: " D MIX^DIC1
  1. G:Y'>0!$D(DTOUT)!$D(DUOUT) EXIT
  1. S (RMLOFDA,RMLODA)=+Y,(RMLOC,RMLOF)=$P(^RMPR(661.3,+Y,0),U,1) K DIC("S"),DIC("B")
  1. S DA(1)=RMLOFDA,DIC="^RMPR(661.3,"_DA(1)_",1,"
  1. ;
  1. THCPCS ;ask for HCPCS to transfer.
  1. S DIC("A")="Enter HCPCS to Transfer: " K DTOUT,DUOUT,DIC("S"),DIC("B")
  1. S DIC(0)="AEMQ",DIC("W")="S RZ=$P(^RMPR(661.3,RMLODA,1,+Y,0),U,1) I RZ W ?25,$P($G(^RMPR(661.1,RZ,0)),U,2)"
  1. S DIC="^RMPR(661.3,"_RMLODA_",1,",DA(1)=RMLODA D ^DIC
  1. I +Y'>0!$D(DTOUT)!$D(DUOUT) W !,"** No HCPCS selected..." G TRAN
  1. S RMHCFDA=+Y,RMDAHC=$P(^RMPR(661.3,RMLODA,1,+Y,0),U,1),RMHCPC=$P(^RMPR(661.1,RMDAHC,0),U,1)
  1. S DIC(0)="ANEMQ",DA(1)=RMHCFDA,DA(2)=RMLOFDA
  1. S DIC="^RMPR(661.3,"_DA(2)_",1,"_DA(1)_",1,"
  1. ;
  1. LIST ;ask for PSAS Item to transfer.
  1. ;I $D(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,"B")) S DZ="??",D="B" D DQ^DICQ
  1. ;S DIC("B")=$O(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,"B",0))
  1. S DIC("A")="Enter item to transfer: " D ^DIC
  1. G:(+Y'>0)!$D(DTOUT)!$D(DUOUT) TRAN
  1. L +^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,+Y):2
  1. I '$T W !,"Record in use. Try again later..." G TRAN
  1. S RMITFDA=+Y,RMIT=$P(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,+Y,0),U,1)
  1. S RMDAFIT=$P(RMIT,"-",2)
  1. S RM3=^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,RMITFDA,0)
  1. S RMBA=$P(RM3,U,2),RMCO=$P(RM3,U,3),RMSO=$P(RM3,U,9),RMAV=$P(RM3,U,10)
  1. ;
  1. TRANQ ;ask for Quantity to transfer.
  1. S RMQTY=0 R !,"Enter Quantity to transfer: ",RMQTY:DTIME
  1. I $D(DTOUT)!($D(DUOUT))!(RMQTY="^") W !,"*** Nothing transferred ..." G EXIT
  1. I RMQTY["?"!(RMQTY<.0001) W $C(7),!!,"Current balance is = ",RMBA W:RMBA>0 !,"Enter quantity 1 to ",RMBA," or" W " enter '^' to QUIT? " G TRANQ
  1. I RMQTY>RMBA W !!,$C(7),"Quantity to transfer is greater than current balance.." G TRANQ
  1. ;
  1. TRANT ;ask for forwarding Location.
  1. S DIC("S")="I $D(^RMPR(661.3,""C"",RMDAHC,+Y)),($P(^RMPR(661.3,+Y,0),U,1)'=RMLOF)"
  1. S DZ="??",D="B"
  1. S DIC="^RMPR(661.3,",DIC(0)="AEQM"
  1. S DIC("A")="Enter Receiving Location: ",DIC="^RMPR(661.3," K DIC("B")
  1. S DIC(0)="AEQ",D="B" D MIX^DIC1
  1. I $D(DTOUT)!($D(DUOUT)) W !,"*** Nothing transferred ..." G EXIT
  1. G:Y'>0 TRANT
  1. S RMLORDA=+Y
  1. I RMLOFDA=RMLORDA W !,$C(7),"***Forwarding and Receiving Location is the same!!!!" G TRANT
  1. ;
  1. TRANI S RMHCRDA=$O(^RMPR(661.3,RMLORDA,1,"B",RMDAHC,0))
  1. S RMDARHC=$P(^RMPR(661.3,RMLORDA,1,RMHCRDA,0),U,1)
  1. ;ask/enter forwarding item
  1. S DIC(0)="ANEMQ",DA(1)=RMHCRDA,DA(2)=RMLORDA K DIC("S")
  1. S DIC="^RMPR(661.3,"_DA(2)_",1,"_DA(1)_",1,"
  1. S DIC("A")="Enter Receiving Item: " D ^DIC
  1. G:(+Y'>0)!$D(DTOUT)!$D(DUOUT) EXIT
  1. L +^RMPR(661.3,RMLORDA,1,RMHCRDA,1,+Y):2
  1. I '$T W !,"Record in use. Try again later..." G TRANI
  1. S RMITRDA=+Y,RMIT=$P(^RMPR(661.3,RMLORDA,1,RMHCRDA,1,+Y,0),U,1)
  1. ;
  1. S RMTO=$G(^RMPR(661.3,RMLORDA,1,RMHCRDA,1,RMITRDA,0))
  1. S RMBAR=$P(RMTO,U,2),RMBAR=RMBAR+RMQTY,RMCOR=RMAV*RMBAR
  1. S RMLOR=$P(^RMPR(661.3,RMLORDA,0),U,1)
  1. S RMFR=$G(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,RMITFDA,0))
  1. S RMBAF=$P(RMFR,U,2),RMBAF=RMBAF-RMQTY,RMCOF=RMAV*RMBAF
  1. W !,"Quantity ",RMQTY," was transferred from ",RMLOF," to ",RMLOR
  1. S $P(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,RMITFDA,0),U,2)=RMBAF
  1. S $P(^RMPR(661.3,RMLORDA,1,RMHCRDA,1,RMITRDA,0),U,2)=RMBAR
  1. S $P(^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,RMITFDA,0),U,3)=RMCOF
  1. S $P(^RMPR(661.3,RMLORDA,1,RMHCRDA,1,RMITRDA,0),U,3)=RMCOR
  1. S RMRSTA=$P($G(^RMPR(661.3,RMLORDA,0)),U,3)
  1. ;
  1. STAT ;create transfer stat for an item
  1. D BAL^RMPR5NU1
  1. L -^RMPR(661.3,RMLORDA,1,RMHCRDA,1,RMITRDA)
  1. L -^RMPR(661.3,RMLOFDA,1,RMHCFDA,1,RMITFDA)
  1. S DIC="^RMPR(661.2,",DLAYGO=661.2,X=RMDAT1,DIC(0)="L" K DD,DO
  1. D FILE^DICN G:Y'>0 TRAN S DA=+Y
  1. S RMMES="QTY "_RMQTY_" transferred from "_$E(RMLOF,1,8)_" to "_$E(RMLOR,1,8)
  1. S ^RMPR(661.2,DA,0)=RMDAT1_"^^^"_RMDAHC_"^^^"_DUZ_"^^"_RMIT_"^^^"_RMTOBA_"^"_RMMES_"^"_$J(RMTOCO,0,2)_"^"_RMPR("STA")_"^"_RMLORDA_"^"_$J(RMAVA,0,2)
  1. S DIK=DIC D IX1^DIK
  1. I RMPR("STA")'=RMRSTA D
  1. .S RMFSTA=RMPR("STA"),RMPR("STA")=RMRSTA D BAL^RMPR5NU1
  1. .S DIC="^RMPR(661.2,",DLAYGO=661.2,X=RMDAT1,DIC(0)="L" K DD,DO
  1. .D FILE^DICN G:Y'>0 TRAN S DA=+Y
  1. .S RMMES="QTY "_RMQTY_" transferred from "_$E(RMLOF,1,8)_" to "_$E(RMLOR,1,8)
  1. .S ^RMPR(661.2,DA,0)=RMDAT1_"^^^"_RMDAHC_"^^^"_DUZ_"^^"_RMIT_"^^^"_RMTOBA_"^"_RMMES_"^"_$J(RMTOCO,0,2)_"^"_RMRSTA_"^"_RMLORDA_"^"_$J(RMAVA,0,2)
  1. .S RMPR("STA")=RMFSTA
  1. .S DIK=DIC D IX1^DIK
  1. W !,"*** Item was transferred..."
  1. H 1 G TRAN
  1. ;
  1. UPD ;update current inventory item balance.
  1. W @IOF
  1. UPD1 W !!,"Updating Item in a Location.....",!
  1. D DIV4^RMPRSIT I $D(Y),(Y<0) K DIC("B") Q
  1. S X="NOW" D ^%DT S RMDAT1=Y D DD^%DT S RMDAT=Y K DTOUT,DUOUT,DIC("B")
  1. S DZ="??",D="B",DIC("S")="I $P(^RMPR(661.3,+Y,0),U,3)=RMPR(""STA"")"
  1. S DIC="^RMPR(661.3,",DIC(0)="AEQM"
  1. ;I $D(^RMPR(661.3,"B")) D DQ^DICQ
  1. S DIC("A")="Enter Pros Location: "
  1. D MIX^DIC1 G:(+Y'>0)!($D(DTOUT))!$D(DUOUT) EXIT S RMLODA=+Y
  1. S RMLOC=$P(^RMPR(661.3,+Y,0),U,1)
  1. ;
  1. HCPC S DA(1)=RMLODA,DIC="^RMPR(661.3,"_DA(1)_",1," K DTOUT,DUOUT
  1. K DTOUT,DUOUT,DIC("S"),DIR
  1. S DIC("A")="Select HCPCS to Update: "
  1. S DIC(0)="AEMQ",DIC("W")="S RZ=$P(^RMPR(661.3,RMLODA,1,+Y,0),U,1) I RZ W ?25,$P($G(^RMPR(661.1,RZ,0)),U,2)"
  1. S DIC="^RMPR(661.3,"_RMLODA_",1," D ^DIC
  1. I +Y'>0!$D(DTOUT)!$D(DUOUT) W !,"** No HCPCS selected..." G UPD1
  1. S RMHCDA=+Y,RMDAHC=$P(^RMPR(661.3,RMLODA,1,+Y,0),U,1),RMHCPC=$P(^RMPR(661.1,RMDAHC,0),U,1)
  1. ;
  1. ITEM ;
  1. S DIC(0)="ANEMQ",DA(1)=RMHCDA,DA(2)=RMLODA
  1. S DIC="^RMPR(661.3,"_DA(2)_",1,"_DA(1)_",1,"
  1. G:'$D(^RMPR(661.3,RMLODA,1,RMHCDA,1,"B")) HCPC
  1. ;I $D(^RMPR(661.3,RMLODA,1,RMHCDA,1,"B")) S DZ="??",D="B" D DQ^DICQ
  1. S DIC("B")=$O(^RMPR(661.3,RMLODA,1,RMHCDA,1,"B",0))
  1. S DIC("A")="Enter ITEM to Update: " D ^DIC K DIC("B")
  1. G:(+Y'>0)!($D(DTOUT))!$D(DUOUT) HCPC S RMITDA=+Y
  1. L +^RMPR(661.3,RMLODA,1,RMHCDA,1,+Y):2
  1. I '$T W !,"Record in use. Try again later..." G ITEM
  1. S RMIT=$P(^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA,0),U,1)
  1. S RMHCPC=$P(RMIT,"-",1),RMDAIT=$P(RMIT,"-",2)
  1. S RM3=^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA,0)
  1. S RMBA=$P(RM3,U,2),RMCO=$P(RM3,U,3),RMUNI=$P(RM3,U,4),RMSOB=$P(RM3,U,9)
  1. S RMRORA=$P(RM3,U,6),RMDIIA=$P(RM3,U,7),RMVENA=$P(RM3,U,5)
  1. S DA(2)=RMLODA,DA(1)=RMHCDA,DA=RMITDA
  1. S DIE="^RMPR(661.3,"_DA(2)_",1,"_DA(1)_",1,"
  1. S DR="29R" D ^DIE
  1. I $P(^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA,0),U,9)="C" S DR="22R;24;25R;26;27"
  1. E S DR="22R;24;27"
  1. D ^DIE
  1. S (RMAVD,RMBAD,RMCOD)=0
  1. S RM3=^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA,0)
  1. S RMBAA=$P(RM3,U,2),RMSO=$P(RM3,U,9),RMAVA=$P(RM3,U,10)
  1. S RMRORAA=$P(RM3,U,6),RMDIIAA=$P(RM3,U,7),RMVENAA=$P(RM3,U,5)
  1. S RMUNIA=$P(RM3,U,4)
  1. I RMBAA=RMBA,RMRORA=RMRORAA,RMDIIA=RMDIIAA,RMVENA=RMVENAA,RMSO=RMSOB,RMUNI=RMUNIA W !,"*** Nothing updated...." G UPD1
  1. S:RMBA'=RMBAA RMBAD=RMBAA-RMBA S RMCOA=RMBAA*RMAVA
  1. S $P(^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA,0),U,3)=RMCOA
  1. ;
  1. STATUPD ;create UPDATE stat for an item
  1. D BAL^RMPR5NU1
  1. L -^RMPR(661.3,RMLODA,1,RMHCDA,1,RMITDA)
  1. S DIC="^RMPR(661.2,",DLAYGO=661.2,X=RMDAT1,DIC(0)="L" K DD,DO
  1. D FILE^DICN G:Y'>0 UPD1 S DA=+Y
  1. S RMMESF="QTY updated by "_$E($P(^VA(200,DUZ,0),U,1),1,15)_":"
  1. S ^RMPR(661.2,DA,0)=RMDAT1_"^^^"_RMDAHC_"^^^"_DUZ_"^"_RMBAD_"^"_RMIT_"^^^"_RMTOBA_"^"_RMMESF_"^"_$J(RMTOCO,0,2)_"^"_RMPR("STA")_"^"_RMLODA_"^"_$J(RMAVA,0,2)
  1. W !,"*** Item was updated..."
  1. S DIK=DIC D IX1^DIK
  1. H 1 G UPD1
  1. ;
  1. EXIT ;MAIN EXIT POINT
  1. N RMPRSITE,RMPR D KILL^XUSCLEAN
  1. Q