| 1 | RMPRPIYF ;PHX/RFM,RVD-EDIT ISSUE FROM STOCK ;8/2/02  07:27 | 
|---|
| 2 | ;;3.0;PROSTHETICS;**61,117,139**;Feb 09, 1996;Build 4 | 
|---|
| 3 | ; RVD #61 - phase III of PIP enhancement. | 
|---|
| 4 | ; | 
|---|
| 5 | ;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 6 | COST ; | 
|---|
| 7 | S RMACNT=RMPRCOST*$P(R1(0),U,7),$P(R3("D"),U,16)=RMACNT,$P(R1(0),U,16)=RMACNT | 
|---|
| 8 | ; | 
|---|
| 9 | DATE S:$P(R1(1),U,8) DIR("B")=$P(R1("D"),U,8) S DIR("A")="DATE OF SERVICE",DIR(0)="660,39" D ^DIR K DIR | 
|---|
| 10 | G:X["^" CO^RMPRPIYE G:$D(DTOUT) EXIT I $P(R1(1),U,8)&(X="@") W !,"This field is mandatory!!!",! G DATE | 
|---|
| 11 | I X="" W !,"This field is mandatory!!!",! G DATE | 
|---|
| 12 | S $P(R1(1),U,8)=Y,Y=$P(R1(1),U,8) D DD^%DT S $P(R1("D"),U,8)=Y | 
|---|
| 13 | ; | 
|---|
| 14 | REQ S DIR(0)="660,9" S:$P(R1(0),U,11)'="" DIR("B")=$P(R1(0),U,11) D ^DIR G:$D(DUOUT) CO^RMPRPIYE G:$D(DTOUT) EXIT | 
|---|
| 15 | I X["^" W !,"Jumping not allowed!" G REQ | 
|---|
| 16 | I $P(R1(0),U,11)'=""&(X="@") W !?5,"Deleted..." H 1 S $P(R1(0),U,11)="" G LOT | 
|---|
| 17 | S $P(R1(0),U,11)=X | 
|---|
| 18 | ; | 
|---|
| 19 | LOT K DIR S DIR(0)="660,21" S:$P(R1(0),U,24)'="" DIR("B")=$P(R1(0),U,24) D ^DIR G:$D(DUOUT) CO^RMPRPIYE | 
|---|
| 20 | I X["^" W !,"Jumping not allowed!" G LOT | 
|---|
| 21 | I $P(R1(0),U,24)'=""&(X="@") W !?5,"Deleted..." H 1 S $P(R1(0),U,24)="" G REMA | 
|---|
| 22 | S $P(R1(0),U,24)=X | 
|---|
| 23 | ; | 
|---|
| 24 | REMA K DIR S DIR(0)="660,16" S:$P(R1(0),U,18)'="" DIR("B")=$P(R1(0),U,18) D ^DIR G:$D(DUOUT) CO^RMPRPIYE G:$D(DTOUT) EXIT | 
|---|
| 25 | I X["^" W !,"Jumping not allowed!" G REMA | 
|---|
| 26 | I $P(R1(0),U,18)'=""&(X="@") W !?5,"Deleted..." H 1 S $P(R1(0),U,18)="" G CC | 
|---|
| 27 | S $P(R1(0),U,18)=X | 
|---|
| 28 | CC G CO^RMPRPIYE | 
|---|
| 29 | ; | 
|---|
| 30 | POST ;POSTS EDITED TRANSACTION TO 660 | 
|---|
| 31 | W !,"Posting...." | 
|---|
| 32 | K RMPR60,RMDTTIM,RMPR63 | 
|---|
| 33 | S RMPR60("IEN")=RMPRIEN,RMFLG=0 | 
|---|
| 34 | ;RMPR60 -array of data fields for 660 file record. | 
|---|
| 35 | D SET60^RMPRPIYE | 
|---|
| 36 | ;get 661.6 & 661.63 patient issue | 
|---|
| 37 | S (RMPR6("IEN"),RMIEN6)=$P(R1(1),U,5) | 
|---|
| 38 | I $G(RMIEN6),$D(^RMPR(661.6,RMIEN6,0)) D | 
|---|
| 39 | .S RMDAT6=$G(^RMPR(661.6,RMIEN6,0)) | 
|---|
| 40 | .S RMIEN63=$O(^RMPR(661.63,"B",RMIEN6,0)) | 
|---|
| 41 | .I $G(RMIEN63),$D(^RMPR(661.63,RMIEN63,0)) D | 
|---|
| 42 | ..S RMDAT63=$G(^RMPR(661.63,RMIEN63,0)),RMPR63("IEN")=RMIEN63 | 
|---|
| 43 | ..S (RMPRRET("DATE&TIME"),RMDTTIM)=$P(RMDAT63,U,6) | 
|---|
| 44 | ..S RMPRRET("QUANTITY")=$P(RMDAT63,U,12) | 
|---|
| 45 | ..S RMPRRET("HCPCS")=$P(RMDAT63,U,4) | 
|---|
| 46 | ..S RMPRRET("STATION")=$P(RMDAT63,U,7) | 
|---|
| 47 | ..S RMPRRET("ITEM")=$P(RMDAT63,U,5) | 
|---|
| 48 | ..S RMPRRET("VALUE")=$P(RMDAT63,U,10) | 
|---|
| 49 | ..S RMPRRET("UNIT")=$P(RMDAT63,U,11) | 
|---|
| 50 | ..S RMPRRET("VENDOR")=$P(RMDAT63,U,9) | 
|---|
| 51 | ..S RMPRRET("LOCATION")=$P(RMDAT63,U,8) | 
|---|
| 52 | ;only update 660 if no label scan and quantity the same. | 
|---|
| 53 | I '$D(RMPR7I),($P(R1BCK(0),U,7)=RMPR60("QUANTITY")) D UP660 G PCE | 
|---|
| 54 | ;set update flags: 1=new item/diff barcode 2=only quantity changed. | 
|---|
| 55 | I $G(RMDTTIM),$D(RMPR7I("DATE&TIME")),RMDTTIM'=RMPR7I("DATE&TIME") S RMFLG=1 | 
|---|
| 56 | I '$G(RMDTTIM),$D(RMPR7I("DATE&TIME")) S RMFLG=1 | 
|---|
| 57 | I $P(R1BCK(0),U,7)'=RMPR60("QUANTITY"),'$G(RMFLG) S RMFLG=2 | 
|---|
| 58 | ; | 
|---|
| 59 | API ;call API for 660, 661.7, 661.6, 661.63, 661.9 | 
|---|
| 60 | ; | 
|---|
| 61 | ;file #660, 661.6, 661.7, 661.63, 661.9 | 
|---|
| 62 | I RMFLG=1 D UPDATE | 
|---|
| 63 | I RMFLG=2 D QUAN | 
|---|
| 64 | D UP660 | 
|---|
| 65 | I $G(RMPRERR) W !!,"*** ERROR in 2319 UPDATE, Please notify your IRM..IEN = ",$G(RMPR60("IEN")),!! H 3 | 
|---|
| 66 | ; | 
|---|
| 67 | PCE ;update PCE data | 
|---|
| 68 | I $D(^RMPR(660,RMPR60("IEN"),10)),$P(^RMPR(660,RMPR60("IEN"),10),U,12) D | 
|---|
| 69 | .S RMCHK=0 | 
|---|
| 70 | .S RMCHK=$$SENDPCE^RMPRPCEA(RMPR60("IEN")) | 
|---|
| 71 | .I RMCHK'=1 W !!,"*** ERROR in PCE UPDATE, Please notify your IRM..IEN = ",RMPR60("IEN"),!! H 3 | 
|---|
| 72 | ; | 
|---|
| 73 | ;end posting (edit 2319) | 
|---|
| 74 | G EXIT | 
|---|
| 75 | ; | 
|---|
| 76 | DEL1 ;ENTRY POINT TO DELETE AN ISSUE FROM STOCK | 
|---|
| 77 | ;** MOVED TO RMPRPIFD DUE TO SIZE CONSTRAINTS | 
|---|
| 78 | G DEL1^RMPRPIFD | 
|---|
| 79 | EXIT ;KILL VARIABLES AND EXIT ROUTINE | 
|---|
| 80 | I $G(RMPRIEN),$D(^RMPR(660,RMPRIEN)) L -^RMPR(660,RMPRIEN) | 
|---|
| 81 | K ^TMP($J) N RMPRSITE,RMPR D KILL^XUSCLEAN | 
|---|
| 82 | Q | 
|---|
| 83 | ; | 
|---|
| 84 | UP660 ;update 660 | 
|---|
| 85 | S RMPR60("IEN")=RMPRIEN | 
|---|
| 86 | S RMPRERR=0 | 
|---|
| 87 | S RMPRERR=$$UPD^RMPRPIX2(.RMPR60,.RMPR11I) | 
|---|
| 88 | I $G(RMPRERR) W !,"*** Error in API RMPRPIX2, ERROR = ",RMPRERR,!,"*** Please inform your IRM !!",! | 
|---|
| 89 | Q | 
|---|
| 90 | ; | 
|---|
| 91 | UPDATE ;update the new entries AND delete old data | 
|---|
| 92 | S RMNEWHC=RMPR11I("HCPCS") | 
|---|
| 93 | S RMNEWIT=RMPR11I("ITEM") | 
|---|
| 94 | I $G(RMPR6("IEN")) S RMPR60("IEN")=RMPR6("IEN") D | 
|---|
| 95 | .S RMPRERR=$$UPD^RMPRPIX6(.RMPR60,.RMPR11I) | 
|---|
| 96 | .I $G(RMPR63("IEN")) S RMPRERR=$$UPALL^RMPRPIX3(.RMPR60,.RMPR63,.RMPR11I) | 
|---|
| 97 | .I '$G(RMPR63("IEN")) S RMPRERR=$$CRE^RMPRPIX3(.RMPR60,.RMPR6,.RMPR11I) | 
|---|
| 98 | I '$G(RMPR6("IEN")) D | 
|---|
| 99 | .S RMPRERR=$$CRE^RMPRPIX6(.RMPR60,.RMPR11I) | 
|---|
| 100 | .S (RMPR60("IEN6"),RMPR6("IEN"))=$G(RMPR60("IEN")) | 
|---|
| 101 | .S RMPRERR=$$CRE^RMPRPIX3(.RMPR60,.RMPR6,.RMPR11I) | 
|---|
| 102 | ;create a return stock record | 
|---|
| 103 | S RMPR11I("HCPCS")=$G(RMPRRET("HCPCS")) | 
|---|
| 104 | S RMPR11I("ITEM")=$G(RMPRRET("ITEM")) | 
|---|
| 105 | S RMPRRET("SEQUENCE")=1 | 
|---|
| 106 | S RMPRRET("TRAN TYPE")=8 | 
|---|
| 107 | S RMPRRET("COMMENT")="STOCK ISSUE EDIT" | 
|---|
| 108 | S RMPRRET("USER")=$G(DUZ) | 
|---|
| 109 | I '$D(RMPRRET("QUANTITY")) S RMPRRET("QUANTITY")=RMPR60("QUANTITY") | 
|---|
| 110 | I '$D(RMPRRET("VALUE")) S RMPRRET("VALUE")=RMPR60("COST") | 
|---|
| 111 | I '$D(RMPRRET("UNIT")) S RMPRRET("UNIT")=RMPR60("UNIT") | 
|---|
| 112 | I '$D(RMPRRET("VENDOR")) S RMPRRET("VENDOR")=RMPR60("VENDOR IEN") | 
|---|
| 113 | I '$D(RMPRRET("LOCATION")) S RMPRRET("LOCATION")=$G(RMLO1) | 
|---|
| 114 | I $D(RMPR11I) D  I $G(RMPRERR) Q | 
|---|
| 115 | .S RMPRERR=$$CRE^RMPRPIX6(.RMPRRET,.RMPR11I) | 
|---|
| 116 | ;return/update 661.7 | 
|---|
| 117 | D BACK Q:$G(RMPRERR) | 
|---|
| 118 | S RMPR11I("HCPCS")=$G(RMNEWHC) | 
|---|
| 119 | S RMPR11I("ITEM")=$G(RMNEWIT) | 
|---|
| 120 | S RMPR7I("QUANTITY")=RMPR60("QUANTITY") | 
|---|
| 121 | S RMPR7I("VALUE")=RMPR60("COST") | 
|---|
| 122 | ;update or create 661.7 entry | 
|---|
| 123 | D UP7 | 
|---|
| 124 | S RMPR9("QUANTITY")=RMPR60("QUANTITY") | 
|---|
| 125 | S RMPR9("VALUE")=RMPR60("COST") | 
|---|
| 126 | ;return 661.9 entry | 
|---|
| 127 | I $D(RMDTTIM) D  D UP9 | 
|---|
| 128 | .S RMPR11I("HCPCS")=RMPRRET("HCPCS") | 
|---|
| 129 | .S RMPR11I("ITEM")=RMPRRET("ITEM") | 
|---|
| 130 | .S RMPR9("QUANTITY")=$P(R1BCK(0),U,7) | 
|---|
| 131 | .S RMPR9("VALUE")=$P(R1BCK(0),U,16) | 
|---|
| 132 | ;deduct the new HCPCS in 661.9 | 
|---|
| 133 | S RMPR11I("HCPCS")=RMNEWHC | 
|---|
| 134 | S RMPR11I("ITEM")=RMPR60("ITEM") | 
|---|
| 135 | S RMPR9("QUANTITY")=0-RMPR60("QUANTITY") | 
|---|
| 136 | S RMPR9("VALUE")=0-RMPR60("COST") | 
|---|
| 137 | D UP9 | 
|---|
| 138 | Q | 
|---|
| 139 | ; | 
|---|
| 140 | BACK ; Bring back ITEM into current stock. | 
|---|
| 141 | D NOW^%DTC | 
|---|
| 142 | S (RMPR7R("STATION"),RMST1)=RMPR11I("STATION") | 
|---|
| 143 | S (RMPR7R("HCPCS"),RMHC1)=RMPR11I("HCPCS") | 
|---|
| 144 | S (RMPR7R("ITEM"),RMIT1)=RMPR11I("ITEM") | 
|---|
| 145 | S (RMPR7R("LOCATION"),RMLO1)=RMPRRET("LOCATION") | 
|---|
| 146 | S RMPR7R("VENDOR")=RMPRRET("VENDOR") | 
|---|
| 147 | S RMPR7R("DATE&TIME")=% S:$G(RMPRRET("DATE&TIME"))'="" RMPR7R("DATE&TIME")=RMPRRET("DATE&TIME") | 
|---|
| 148 | S RMPR7R("SEQUENCE")=1 | 
|---|
| 149 | S RMPR7R("QUANTITY")=RMPRRET("QUANTITY") | 
|---|
| 150 | S RMPR7R("VALUE")=RMPRRET("VALUE") | 
|---|
| 151 | S RMPR7R("UNIT")=$G(RMPRRET("UNIT")) | 
|---|
| 152 | I $G(RMDTTIM),$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D  I RMPRERR S RMPRERR=71 Q | 
|---|
| 153 | .S RMPR7R("IEN")=$O(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM,1,0)) | 
|---|
| 154 | .I '$G(RMPR7R("IEN")) S RMPRERR=1 Q | 
|---|
| 155 | .S RMDA7=$G(^RMPR(661.7,RMPR7R("IEN"),0)) | 
|---|
| 156 | .S RMDAVAL=$P(RMDA7,U,8),RMDAQUA=$P(RMDA7,U,7) | 
|---|
| 157 | .S RMPR7R("QUANTITY")=RMPR7R("QUANTITY")+RMDAQUA | 
|---|
| 158 | .S RMPR7R("VALUE")=RMPR7R("VALUE")+RMDAVAL | 
|---|
| 159 | .S RMPR7R("DATE&TIME")=RMDTTIM | 
|---|
| 160 | .S RMPRERR=$$UPD^RMPRPIX7(.RMPR7R,.RMPR11I) | 
|---|
| 161 | I $G(RMDTTIM),'$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D | 
|---|
| 162 | .S RMPR7R("DATE&TIME")=RMDTTIM | 
|---|
| 163 | .S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPR11I) | 
|---|
| 164 | I '$G(RMDTTIM) S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPR11I) | 
|---|
| 165 | Q | 
|---|
| 166 | ; | 
|---|
| 167 | UP6 ;now update file 661.6 | 
|---|
| 168 | S RMPR6("IEN")=$G(RMIEN6) | 
|---|
| 169 | S RMPR6("QUANTITY")=$G(RMPR60("QUANTITY")) | 
|---|
| 170 | S RMPR6("VALUE")=$G(RMPR60("COST")) | 
|---|
| 171 | S RMPRERR=$$UPD^RMPRPIX6(.RMPR6,.RMPR11I) | 
|---|
| 172 | Q | 
|---|
| 173 | ; | 
|---|
| 174 | ; | 
|---|
| 175 | UP63 ;update file 661.63 | 
|---|
| 176 | S RMPR6("IEN")=$G(RMIEN6) | 
|---|
| 177 | S RMPR6("LOCATION")=$G(RMPR5("IEN")) | 
|---|
| 178 | S RMPR6("VENDOR")=$G(RMPR60("VENDOR IEN")) | 
|---|
| 179 | S RMPR63("IEN")=$G(RMIEN63) | 
|---|
| 180 | S RMPRERR=$$UPD^RMPRPIX3(.RMPR60,.RMPR63,.RMPR11I) | 
|---|
| 181 | Q | 
|---|
| 182 | ; | 
|---|
| 183 | UP7 ;file #661.7,deduct quantity | 
|---|
| 184 | Q:'$G(RMPR11I("STATION")) | 
|---|
| 185 | S RMPR7I("STATION IEN")=RMPR11I("STATION") | 
|---|
| 186 | S RMPR7I("LOCATION IEN")=$G(RMPR5("IEN")) | 
|---|
| 187 | S RMPR7I("HCPCS")=RMPR11I("HCPCS") | 
|---|
| 188 | S RMPR7I("ITEM")=RMPR11I("ITEM") | 
|---|
| 189 | S:$G(RMPRRET("DATE&TIME")) RMPR7I("DATE&TIME")=RMPRRET("DATE&TIME") | 
|---|
| 190 | S RMPR7I("ISSUED QTY")=$G(RMPR7I("QUANTITY")) | 
|---|
| 191 | S RMPR7I("ISSUED VALUE")=$G(RMPR7I("VALUE")) | 
|---|
| 192 | S RMPRERR=$$FIFO^RMPRPIUB(.RMPR7I) | 
|---|
| 193 | Q | 
|---|
| 194 | UP9 ;file 661.9 | 
|---|
| 195 | D NOW^%DTC | 
|---|
| 196 | S RMPR9("STA")=RMPR11I("STATION") | 
|---|
| 197 | S RMPR9("HCP")=RMPR11I("HCPCS") | 
|---|
| 198 | S RMPR9("ITE")=RMPR11I("ITEM") | 
|---|
| 199 | S RMPR9("RDT")=$P(%,".",1) | 
|---|
| 200 | S RMPR9("TQTY")=RMPR9("QUANTITY") | 
|---|
| 201 | S RMPR9("TCST")=RMPR9("VALUE") | 
|---|
| 202 | S RMPERR=$$UPCR^RMPRPIXJ(.RMPR9) | 
|---|
| 203 | Q | 
|---|
| 204 | ; | 
|---|
| 205 | QUAN ;only update quantity | 
|---|
| 206 | ;quit if not in PIP | 
|---|
| 207 | Q:'$G(RMIEN6)!'$D(RMDTTIM)!'$D(RMPRRET) | 
|---|
| 208 | S RMPR11I("STATION")=RMPRRET("STATION") | 
|---|
| 209 | S RMPR11I("HCPCS")=RMPRRET("HCPCS") | 
|---|
| 210 | S RMPR11I("ITEM")=RMPRRET("ITEM") | 
|---|
| 211 | S RMPR5("IEN")=RMPRRET("LOCATION") | 
|---|
| 212 | D UP6,UP63 | 
|---|
| 213 | I RMPR60("QUANTITY")>($P(R1BCK(0),U,7)) D  D UP7,UP9 | 
|---|
| 214 | .S RMPR7I("QUANTITY")=RMPR60("QUANTITY")-($P(R1BCK(0),U,7)) | 
|---|
| 215 | .S RMPR7I("VALUE")=RMPR60("COST")-($P(R1BCK(0),U,16)) | 
|---|
| 216 | .S RMPR9("QUANTITY")=0-($G(RMPR60("QUANTITY"))-$P(R1BCK(0),U,7)) | 
|---|
| 217 | .S RMPR9("VALUE")=0-($G(RMPR60("COST"))-$P(R1BCK(0),U,16)) | 
|---|
| 218 | I RMPR60("QUANTITY")<($P(R1BCK(0),U,7)) D  D BACK,UP9 | 
|---|
| 219 | .S RMPR9("QUANTITY")=$P(R1BCK(0),U,7)-$G(RMPR60("QUANTITY")) | 
|---|
| 220 | .S RMPRRET("QUANTITY")=$P(R1BCK(0),U,7)-$G(RMPR60("QUANTITY")) | 
|---|
| 221 | .S RMPR9("VALUE")=$P(R1BCK(0),U,16)-$G(RMPR60("COST")) | 
|---|
| 222 | .S RMPRRET("VALUE")=$P(R1BCK(0),U,16)-$G(RMPR60("COST")) | 
|---|
| 223 | Q | 
|---|
| 224 | ; | 
|---|
| 225 | ERR W !!,"Error encountered while posting to PIP.  Patient 10-2319 not deleted!! Please check with your Application Coordinator." H 5 G EXIT | 
|---|