RMPRPIU3 ;HINCIO/ODJ - PIP STOCK ISSUE TO PATIENT DELETE UILITY ;3/8/01
;;3.0;PROSTHETICS;**61,117**;Feb 09, 1996
Q
;
; DEL - Delete a Stock 'Issue to Patient' Transaction
; Deletes the 2319 record in file 660
; the patient issue record in 661.63
; Creates a type 8 'Return In' transaction
; Brings back issue quantity into stock
; Updates running balance
;
; Inputs:
; RMPR60 - array of data fields for 660 file record...
; RMPR60("IEN") must be set to the ien of 660 rec.
; being deleted.
; RMPR60("IEN") - IEN of 660 record being deleted
;
; Outputs:
; RMPRERR - 0 - no problems
; 11 - problem reading 660 rec. to delete
; 12 - problem reading 661.6 rec. to delete
; 29 - problem with 660 rec. delete
; 39 - problem with 661.6,661.63 rec. delete
; 49 - problem with 661.6 return rec. creation
; 59 - problem with bringing back into stock
;
DEL(RMPR60) ;
N RMPRERR,RMPRC60,RMPRC60I,RMPRC1,RMPRC1I,RMPRC6,RMPRC6I
N RMPRC5,RMPRC11,RMPRRET,RMPR7R
S RMPRERR=0
;
; STEP 1
; read in existing 660 and 661.6 recs.
S RMPRC60("IEN")=RMPR60("IEN")
S RMPRERR=$$GET^RMPRPIX2(.RMPRC60,.RMPRC1) ;read in current 660 rec
I RMPRERR S RMPRERR=11 G DELX
S RMPRERR=$$ETOI^RMPRPIX2(.RMPRC60,.RMPRC1,.RMPRC60I,.RMPRC1I)
I RMPRERR S RMPRERR=11 G DELX
S RMPRC6("IEN")=RMPRC60("TRANS IEN")
S RMPRERR=$$GET^RMPRPIX6(.RMPRC6) ;read in current 661.6 rec
I RMPRERR S RMPRERR=12 G DELX
S RMPRERR=$$ETOI^RMPRPIX6(.RMPRC6,.RMPRC6I)
I RMPRERR S RMPRERR=12 G DELX
S RMPRC5("IEN")=RMPRC6I("LOCATION")
S RMPRC11("STATION")=RMPRC6I("STATION")
S RMPRC11("STATION IEN")=RMPRC6I("STATION")
S RMPRC11("HCPCS")=RMPRC6I("HCPCS")
S RMPRC11("ITEM")=RMPRC6I("ITEM")
S RMST1=RMPRC6I("STATION"),RMHC1=RMPRC6I("HCPCS")
S RMLO1=RMPRC6I("LOCATION"),RMIT1=RMPRC6I("ITEM")
;
; STEP 2
; Delete the 660 record
S RMPRERR=$$DEL^RMPRPIX2(.RMPR60)
I RMPRERR S RMPRERR=29 G DELX ;err 29 if 660 delete problem
;
; STEP 3
; get 661.63 information
K RMDTTIM
S RM6613I=$O(^RMPR(661.63,"B",RMPRC6("IEN"),0))
I $G(RM6613I),$D(^RMPR(661.63,RM6613I,0)) D
.S RM63DAT=$G(^RMPR(661.63,RM6613I,0))
.S RMDTTIM=$P(RM63DAT,U,6)
.Q:'$G(RMDTTIM)
.S RMPRRET("DATE&TIME")=RMDTTIM
.S RMPRRET("QUANTITY")=$P(RM63DAT,U,12)
.S RMPRRET("VALUE")=$P(RM63DAT,U,10)
.S RMPRRET("UNIT")=$P(RM63DAT,U,11)
.S RMPRRET("VENDOR")=$P(RM63DAT,U,9)
.S RMPRRET("LOCATION")=$P(RM63DAT,U,8)
; Delete 661.63 Patient Issue record
S RMPRERR=$$DEL^RMPRPIX3(.RMPRC6)
I RMPRERR S RMPRERR=39
;
; STEP 4
; Create a Return to Stock Record
S RMPRRET("SEQUENCE")=1
S RMPRRET("TRAN TYPE")=8
S RMPRRET("COMMENT")=""
S RMPRRET("USER")=$G(DUZ)
I '$D(RMPRRET("QUANTITY")) S RMPRRET("QUANTITY")=RMPRC60I("QUANTITY")
I '$D(RMPRRET("VALUE")) S RMPRRET("VALUE")=$G(RMPRC60I("COST"))
I '$D(RMPRRET("UNIT")) S RMPRRET("UNIT")=$G(RMPRC60I("UNIT"))
I '$D(RMPRRET("VENDOR")) S RMPRRET("VENDOR")=$G(RMPRC60I("VENDOR"))
I '$D(RMPRRET("LOCATION")) S RMPRRET("LOCATION")=$G(RMPRC5("IEN"))
S RMPRERR=$$CRE^RMPRPIX6(.RMPRRET,.RMPRC11)
I RMPRERR S RMPRERR=49
;
; STEP 5
; Bring back into current stock
D NOW^%DTC
S RMPR7R("STATION")=RMPRC11("STATION")
S RMPR7R("HCPCS")=RMPRC11("HCPCS")
S RMPR7R("ITEM")=RMPRC11("ITEM")
S RMPR7R("LOCATION")=RMPRC5("IEN")
S RMPR7R("VENDOR")=RMPRRET("VENDOR")
S RMPR7R("DATE&TIME")=% S:$G(RMPRRET("DATE&TIME"))'="" RMPR7R("DATE&TIME")=RMPRRET("DATE&TIME")
S RMPR7R("SEQUENCE")=RMPRRET("SEQUENCE")
S RMPR7R("QUANTITY")=RMPRRET("QUANTITY")
S RMPR7R("VALUE")=RMPRRET("VALUE")
S RMPR7R("UNIT")=$G(RMPRRET("UNIT"))
I $G(RMDTTIM),$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D I RMPRERR S RMPRERR=71
.S RMPR7R("IEN")=$O(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM,1,0))
.I '$G(RMPR7R("IEN")) S RMPRERR=1 Q
.S RMDA7=$G(^RMPR(661.7,RMPR7R("IEN"),0))
.S RMDAVAL=$P(RMDA7,U,8),RMDAQUA=$P(RMDA7,U,7)
.S RMPR7R("QUANTITY")=RMPR7R("QUANTITY")+RMDAQUA
.S RMPR7R("VALUE")=RMPR7R("VALUE")+RMDAVAL
.S RMPRERR=0
.S RMPR7R("DATE&TIME")=RMDTTIM
.S RMPRERR=$$UPD^RMPRPIX7(.RMPR7R,.RMPRC11)
I $G(RMDTTIM),'$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D I RMPRERR S RMPRERR=72
.S RMPRERR=0
.S RMPR7R("DATE&TIME")=RMDTTIM
.S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPRC11)
I '$G(RMDTTIM) D I RMPRERR S RMPRERR=73
.;create an entry
.S RMPRERR=0
.S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPRC11)
;update 661.9
S RMPR9("STA")=RMPRC6I("STATION")
S RMPR9("HCP")=RMPRC6I("HCPCS")
S RMPR9("ITE")=RMPRC6I("ITEM")
S RMPR9("RDT")=$P(RMPRC6I("DATE&TIME"),".",1)
S RMPR9("TQTY")=RMPRC6I("QUANTITY")
S RMPR9("TCST")=RMPRC6I("VALUE")
S RMPRERR=0
S RMPRERR=$$UPCR^RMPRPIXJ(.RMPR9)
I RMPRERR S RMPRERR=59
;
;exit
DELX Q RMPRERR
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRMPRPIU3 4942 printed Oct 16, 2024@18:36:53 Page 2
RMPRPIU3 ;HINCIO/ODJ - PIP STOCK ISSUE TO PATIENT DELETE UILITY ;3/8/01
+1 ;;3.0;PROSTHETICS;**61,117**;Feb 09, 1996
+2 QUIT
+3 ;
+4 ; DEL - Delete a Stock 'Issue to Patient' Transaction
+5 ; Deletes the 2319 record in file 660
+6 ; the patient issue record in 661.63
+7 ; Creates a type 8 'Return In' transaction
+8 ; Brings back issue quantity into stock
+9 ; Updates running balance
+10 ;
+11 ; Inputs:
+12 ; RMPR60 - array of data fields for 660 file record...
+13 ; RMPR60("IEN") must be set to the ien of 660 rec.
+14 ; being deleted.
+15 ; RMPR60("IEN") - IEN of 660 record being deleted
+16 ;
+17 ; Outputs:
+18 ; RMPRERR - 0 - no problems
+19 ; 11 - problem reading 660 rec. to delete
+20 ; 12 - problem reading 661.6 rec. to delete
+21 ; 29 - problem with 660 rec. delete
+22 ; 39 - problem with 661.6,661.63 rec. delete
+23 ; 49 - problem with 661.6 return rec. creation
+24 ; 59 - problem with bringing back into stock
+25 ;
DEL(RMPR60) ;
+1 NEW RMPRERR,RMPRC60,RMPRC60I,RMPRC1,RMPRC1I,RMPRC6,RMPRC6I
+2 NEW RMPRC5,RMPRC11,RMPRRET,RMPR7R
+3 SET RMPRERR=0
+4 ;
+5 ; STEP 1
+6 ; read in existing 660 and 661.6 recs.
+7 SET RMPRC60("IEN")=RMPR60("IEN")
+8 ;read in current 660 rec
SET RMPRERR=$$GET^RMPRPIX2(.RMPRC60,.RMPRC1)
+9 IF RMPRERR
SET RMPRERR=11
GOTO DELX
+10 SET RMPRERR=$$ETOI^RMPRPIX2(.RMPRC60,.RMPRC1,.RMPRC60I,.RMPRC1I)
+11 IF RMPRERR
SET RMPRERR=11
GOTO DELX
+12 SET RMPRC6("IEN")=RMPRC60("TRANS IEN")
+13 ;read in current 661.6 rec
SET RMPRERR=$$GET^RMPRPIX6(.RMPRC6)
+14 IF RMPRERR
SET RMPRERR=12
GOTO DELX
+15 SET RMPRERR=$$ETOI^RMPRPIX6(.RMPRC6,.RMPRC6I)
+16 IF RMPRERR
SET RMPRERR=12
GOTO DELX
+17 SET RMPRC5("IEN")=RMPRC6I("LOCATION")
+18 SET RMPRC11("STATION")=RMPRC6I("STATION")
+19 SET RMPRC11("STATION IEN")=RMPRC6I("STATION")
+20 SET RMPRC11("HCPCS")=RMPRC6I("HCPCS")
+21 SET RMPRC11("ITEM")=RMPRC6I("ITEM")
+22 SET RMST1=RMPRC6I("STATION")
SET RMHC1=RMPRC6I("HCPCS")
+23 SET RMLO1=RMPRC6I("LOCATION")
SET RMIT1=RMPRC6I("ITEM")
+24 ;
+25 ; STEP 2
+26 ; Delete the 660 record
+27 SET RMPRERR=$$DEL^RMPRPIX2(.RMPR60)
+28 ;err 29 if 660 delete problem
IF RMPRERR
SET RMPRERR=29
GOTO DELX
+29 ;
+30 ; STEP 3
+31 ; get 661.63 information
+32 KILL RMDTTIM
+33 SET RM6613I=$ORDER(^RMPR(661.63,"B",RMPRC6("IEN"),0))
+34 IF $GET(RM6613I)
IF $DATA(^RMPR(661.63,RM6613I,0))
Begin DoDot:1
+35 SET RM63DAT=$GET(^RMPR(661.63,RM6613I,0))
+36 SET RMDTTIM=$PIECE(RM63DAT,U,6)
+37 if '$GET(RMDTTIM)
QUIT
+38 SET RMPRRET("DATE&TIME")=RMDTTIM
+39 SET RMPRRET("QUANTITY")=$PIECE(RM63DAT,U,12)
+40 SET RMPRRET("VALUE")=$PIECE(RM63DAT,U,10)
+41 SET RMPRRET("UNIT")=$PIECE(RM63DAT,U,11)
+42 SET RMPRRET("VENDOR")=$PIECE(RM63DAT,U,9)
+43 SET RMPRRET("LOCATION")=$PIECE(RM63DAT,U,8)
End DoDot:1
+44 ; Delete 661.63 Patient Issue record
+45 SET RMPRERR=$$DEL^RMPRPIX3(.RMPRC6)
+46 IF RMPRERR
SET RMPRERR=39
+47 ;
+48 ; STEP 4
+49 ; Create a Return to Stock Record
+50 SET RMPRRET("SEQUENCE")=1
+51 SET RMPRRET("TRAN TYPE")=8
+52 SET RMPRRET("COMMENT")=""
+53 SET RMPRRET("USER")=$GET(DUZ)
+54 IF '$DATA(RMPRRET("QUANTITY"))
SET RMPRRET("QUANTITY")=RMPRC60I("QUANTITY")
+55 IF '$DATA(RMPRRET("VALUE"))
SET RMPRRET("VALUE")=$GET(RMPRC60I("COST"))
+56 IF '$DATA(RMPRRET("UNIT"))
SET RMPRRET("UNIT")=$GET(RMPRC60I("UNIT"))
+57 IF '$DATA(RMPRRET("VENDOR"))
SET RMPRRET("VENDOR")=$GET(RMPRC60I("VENDOR"))
+58 IF '$DATA(RMPRRET("LOCATION"))
SET RMPRRET("LOCATION")=$GET(RMPRC5("IEN"))
+59 SET RMPRERR=$$CRE^RMPRPIX6(.RMPRRET,.RMPRC11)
+60 IF RMPRERR
SET RMPRERR=49
+61 ;
+62 ; STEP 5
+63 ; Bring back into current stock
+64 DO NOW^%DTC
+65 SET RMPR7R("STATION")=RMPRC11("STATION")
+66 SET RMPR7R("HCPCS")=RMPRC11("HCPCS")
+67 SET RMPR7R("ITEM")=RMPRC11("ITEM")
+68 SET RMPR7R("LOCATION")=RMPRC5("IEN")
+69 SET RMPR7R("VENDOR")=RMPRRET("VENDOR")
+70 SET RMPR7R("DATE&TIME")=%
if $GET(RMPRRET("DATE&TIME"))'=""
SET RMPR7R("DATE&TIME")=RMPRRET("DATE&TIME")
+71 SET RMPR7R("SEQUENCE")=RMPRRET("SEQUENCE")
+72 SET RMPR7R("QUANTITY")=RMPRRET("QUANTITY")
+73 SET RMPR7R("VALUE")=RMPRRET("VALUE")
+74 SET RMPR7R("UNIT")=$GET(RMPRRET("UNIT"))
+75 IF $GET(RMDTTIM)
IF $DATA(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM))
Begin DoDot:1
+76 SET RMPR7R("IEN")=$ORDER(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM,1,0))
+77 IF '$GET(RMPR7R("IEN"))
SET RMPRERR=1
QUIT
+78 SET RMDA7=$GET(^RMPR(661.7,RMPR7R("IEN"),0))
+79 SET RMDAVAL=$PIECE(RMDA7,U,8)
SET RMDAQUA=$PIECE(RMDA7,U,7)
+80 SET RMPR7R("QUANTITY")=RMPR7R("QUANTITY")+RMDAQUA
+81 SET RMPR7R("VALUE")=RMPR7R("VALUE")+RMDAVAL
+82 SET RMPRERR=0
+83 SET RMPR7R("DATE&TIME")=RMDTTIM
+84 SET RMPRERR=$$UPD^RMPRPIX7(.RMPR7R,.RMPRC11)
End DoDot:1
IF RMPRERR
SET RMPRERR=71
+85 IF $GET(RMDTTIM)
IF '$DATA(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM))
Begin DoDot:1
+86 SET RMPRERR=0
+87 SET RMPR7R("DATE&TIME")=RMDTTIM
+88 SET RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPRC11)
End DoDot:1
IF RMPRERR
SET RMPRERR=72
+89 IF '$GET(RMDTTIM)
Begin DoDot:1
+90 ;create an entry
+91 SET RMPRERR=0
+92 SET RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPRC11)
End DoDot:1
IF RMPRERR
SET RMPRERR=73
+93 ;update 661.9
+94 SET RMPR9("STA")=RMPRC6I("STATION")
+95 SET RMPR9("HCP")=RMPRC6I("HCPCS")
+96 SET RMPR9("ITE")=RMPRC6I("ITEM")
+97 SET RMPR9("RDT")=$PIECE(RMPRC6I("DATE&TIME"),".",1)
+98 SET RMPR9("TQTY")=RMPRC6I("QUANTITY")
+99 SET RMPR9("TCST")=RMPRC6I("VALUE")
+100 SET RMPRERR=0
+101 SET RMPRERR=$$UPCR^RMPRPIXJ(.RMPR9)
+102 IF RMPRERR
SET RMPRERR=59
+103 ;
+104 ;exit
DELX QUIT RMPRERR