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