Ignore:
Timestamp:
Dec 4, 2009, 12:11:15 AM (15 years ago)
Author:
George Lilly
Message:

revised back to 6/30/08 version

File:
1 edited

Legend:

Unmodified
Added
Removed
  • WorldVistAEHR/trunk/r/PROSTHETICS-RMPR-RMPO-RMPS/RMPRPIYF.m

    r613 r623  
    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
     1RMPRPIYF ;PHX/RFM,RVD-EDIT ISSUE FROM STOCK ;8/2/02  07:27
     2 ;;3.0;PROSTHETICS;**61,117**;Feb 09, 1996
     3 ; RVD #61 - phase III of PIP enhancement.
     4 ;
     5 ;Per VHA Directive 10-93-142, this routine should not be modified.
     6COST ;
     7 S RMACNT=RMPRCOST*$P(R1(0),U,7),$P(R3("D"),U,16)=RMACNT,$P(R1(0),U,16)=RMACNT
     8 ;
     9DATE 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 ;
     14REQ 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 ;
     19LOT 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 ;
     24REMA 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
     28CC G CO^RMPRPIYE
     29 ;
     30POST ;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 ;
     59API ;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 ;
     67PCE ;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 ;
     76DEL1 ;ENTRY POINT TO DELETE AN ISSUE FROM STOCK
     77 K DIR
     78 S DIR("A")="Are you sure you want to DELETE this entry",DIR("B")="N",DIR(0)="Y"
     79 D ^DIR I $D(DTOUT)!$D(DUOUT)!$D(DIRUT) G EXIT
     80 I Y'=1 G CO^RMPRPIYE
     81 ;
     82DEL2 ;call API for returning item to PIP
     83 S (RMCHK,RMERPCE)=0
     84 S RMI68=$P($G(^RMPR(660,RMPRIEN,10)),U,1) I RMI68>0 D  I RMERPCE W !!,"** STOCK ISSUE DELETE ABORTED",!! G EXIT
     85 .S RMCHK=$$DEL^RMPRPCED(RMPRIEN)
     86 .I RMCHK'=0 W !!,"*** ERROR in PCE DELETE, Please notify your IRM..660 IEN = ",RMPRIEN,!! S RMERPCE=1 H 3
     87 S RMPR60("IEN")=RMPRIEN
     88 S RMCHK=$$DEL^RMPRPIU3(.RMPR60)
     89 I $G(RMCHK) W !,"*** Error in API RMPRPIU3, ERROR = ",RMCHK,!,"*** Please inform your IRM !!",! G EXIT
     90 ;
     91 W $C(7),!?10,"Deleted..." H 1
     92EXIT ;KILL VARIABLES AND EXIT ROUTINE
     93 I $G(RMPRIEN),$D(^RMPR(660,RMPRIEN)) L -^RMPR(660,RMPRIEN)
     94 K ^TMP($J) N RMPRSITE,RMPR D KILL^XUSCLEAN
     95 Q
     96 ;
     97UP660 ;update 660
     98 S RMPR60("IEN")=RMPRIEN
     99 S RMPRERR=0
     100 S RMPRERR=$$UPD^RMPRPIX2(.RMPR60,.RMPR11I)
     101 I $G(RMPRERR) W !,"*** Error in API RMPRPIX2, ERROR = ",RMPRERR,!,"*** Please inform your IRM !!",!
     102 Q
     103 ;
     104UPDATE ;update the new entries AND delete old data
     105 S RMNEWHC=RMPR11I("HCPCS")
     106 S RMNEWIT=RMPR11I("ITEM")
     107 I $G(RMPR6("IEN")) S RMPR60("IEN")=RMPR6("IEN") D
     108 .S RMPRERR=$$UPD^RMPRPIX6(.RMPR60,.RMPR11I)
     109 .I $G(RMPR63("IEN")) S RMPRERR=$$UPALL^RMPRPIX3(.RMPR60,.RMPR63,.RMPR11I)
     110 .I '$G(RMPR63("IEN")) S RMPRERR=$$CRE^RMPRPIX3(.RMPR60,.RMPR6,.RMPR11I)
     111 I '$G(RMPR6("IEN")) D
     112 .S RMPRERR=$$CRE^RMPRPIX6(.RMPR60,.RMPR11I)
     113 .S (RMPR60("IEN6"),RMPR6("IEN"))=$G(RMPR60("IEN"))
     114 .S RMPRERR=$$CRE^RMPRPIX3(.RMPR60,.RMPR6,.RMPR11I)
     115 ;create a return stock record
     116 S RMPR11I("HCPCS")=$G(RMPRRET("HCPCS"))
     117 S RMPR11I("ITEM")=$G(RMPRRET("ITEM"))
     118 S RMPRRET("SEQUENCE")=1
     119 S RMPRRET("TRAN TYPE")=8
     120 S RMPRRET("COMMENT")="STOCK ISSUE EDIT"
     121 S RMPRRET("USER")=$G(DUZ)
     122 I '$D(RMPRRET("QUANTITY")) S RMPRRET("QUANTITY")=RMPR60("QUANTITY")
     123 I '$D(RMPRRET("VALUE")) S RMPRRET("VALUE")=RMPR60("COST")
     124 I '$D(RMPRRET("UNIT")) S RMPRRET("UNIT")=RMPR60("UNIT")
     125 I '$D(RMPRRET("VENDOR")) S RMPRRET("VENDOR")=RMPR60("VENDOR IEN")
     126 I '$D(RMPRRET("LOCATION")) S RMPRRET("LOCATION")=$G(RMLO1)
     127 I $D(RMPR11I) D  I $G(RMPRERR) Q
     128 .S RMPRERR=$$CRE^RMPRPIX6(.RMPRRET,.RMPR11I)
     129 ;return/update 661.7
     130 D BACK Q:$G(RMPRERR)
     131 S RMPR11I("HCPCS")=$G(RMNEWHC)
     132 S RMPR11I("ITEM")=$G(RMNEWIT)
     133 S RMPR7I("QUANTITY")=RMPR60("QUANTITY")
     134 S RMPR7I("VALUE")=RMPR60("COST")
     135 ;update or create 661.7 entry
     136 D UP7
     137 S RMPR9("QUANTITY")=RMPR60("QUANTITY")
     138 S RMPR9("VALUE")=RMPR60("COST")
     139 ;return 661.9 entry
     140 I $D(RMDTTIM) D  D UP9
     141 .S RMPR11I("HCPCS")=RMPRRET("HCPCS")
     142 .S RMPR11I("ITEM")=RMPRRET("ITEM")
     143 .S RMPR9("QUANTITY")=$P(R1BCK(0),U,7)
     144 .S RMPR9("VALUE")=$P(R1BCK(0),U,16)
     145 ;deduct the new HCPCS in 661.9
     146 S RMPR11I("HCPCS")=RMNEWHC
     147 S RMPR11I("ITEM")=RMPR60("ITEM")
     148 S RMPR9("QUANTITY")=0-RMPR60("QUANTITY")
     149 S RMPR9("VALUE")=0-RMPR60("COST")
     150 D UP9
     151 Q
     152 ;
     153BACK ; Bring back ITEM into current stock.
     154 D NOW^%DTC
     155 S (RMPR7R("STATION"),RMST1)=RMPR11I("STATION")
     156 S (RMPR7R("HCPCS"),RMHC1)=RMPR11I("HCPCS")
     157 S (RMPR7R("ITEM"),RMIT1)=RMPR11I("ITEM")
     158 S (RMPR7R("LOCATION"),RMLO1)=RMPRRET("LOCATION")
     159 S RMPR7R("VENDOR")=RMPRRET("VENDOR")
     160 S RMPR7R("DATE&TIME")=% S:$G(RMPRRET("DATE&TIME"))'="" RMPR7R("DATE&TIME")=RMPRRET("DATE&TIME")
     161 S RMPR7R("SEQUENCE")=1
     162 S RMPR7R("QUANTITY")=RMPRRET("QUANTITY")
     163 S RMPR7R("VALUE")=RMPRRET("VALUE")
     164 S RMPR7R("UNIT")=$G(RMPRRET("UNIT"))
     165 I $G(RMDTTIM),$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D  I RMPRERR S RMPRERR=71 Q
     166 .S RMPR7R("IEN")=$O(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM,1,0))
     167 .I '$G(RMPR7R("IEN")) S RMPRERR=1 Q
     168 .S RMDA7=$G(^RMPR(661.7,RMPR7R("IEN"),0))
     169 .S RMDAVAL=$P(RMDA7,U,8),RMDAQUA=$P(RMDA7,U,7)
     170 .S RMPR7R("QUANTITY")=RMPR7R("QUANTITY")+RMDAQUA
     171 .S RMPR7R("VALUE")=RMPR7R("VALUE")+RMDAVAL
     172 .S RMPR7R("DATE&TIME")=RMDTTIM
     173 .S RMPRERR=$$UPD^RMPRPIX7(.RMPR7R,.RMPR11I)
     174 I $G(RMDTTIM),'$D(^RMPR(661.7,"XSLHIDS",RMST1,RMLO1,RMHC1,RMIT1,RMDTTIM)) D
     175 .S RMPR7R("DATE&TIME")=RMDTTIM
     176 .S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPR11I)
     177 I '$G(RMDTTIM) S RMPRERR=$$CRE^RMPRPIX7(.RMPR7R,.RMPR11I)
     178 Q
     179 ;
     180UP6 ;now update file 661.6
     181 S RMPR6("IEN")=$G(RMIEN6)
     182 S RMPR6("QUANTITY")=$G(RMPR60("QUANTITY"))
     183 S RMPR6("VALUE")=$G(RMPR60("COST"))
     184 S RMPRERR=$$UPD^RMPRPIX6(.RMPR6,.RMPR11I)
     185 Q
     186 ;
     187 ;
     188UP63 ;update file 661.63
     189 S RMPR6("IEN")=$G(RMIEN6)
     190 S RMPR6("LOCATION")=$G(RMPR5("IEN"))
     191 S RMPR6("VENDOR")=$G(RMPR60("VENDOR IEN"))
     192 S RMPR63("IEN")=$G(RMIEN63)
     193 S RMPRERR=$$UPD^RMPRPIX3(.RMPR60,.RMPR63,.RMPR11I)
     194 Q
     195 ;
     196UP7 ;file #661.7,deduct quantity
     197 Q:'$G(RMPR11I("STATION"))
     198 S RMPR7I("STATION IEN")=RMPR11I("STATION")
     199 S RMPR7I("LOCATION IEN")=$G(RMPR5("IEN"))
     200 S RMPR7I("HCPCS")=RMPR11I("HCPCS")
     201 S RMPR7I("ITEM")=RMPR11I("ITEM")
     202 S:$G(RMPRRET("DATE&TIME")) RMPR7I("DATE&TIME")=RMPRRET("DATE&TIME")
     203 S RMPR7I("ISSUED QTY")=$G(RMPR7I("QUANTITY"))
     204 S RMPR7I("ISSUED VALUE")=$G(RMPR7I("VALUE"))
     205 S RMPRERR=$$FIFO^RMPRPIUB(.RMPR7I)
     206 Q
     207UP9 ;file 661.9
     208 D NOW^%DTC
     209 S RMPR9("STA")=RMPR11I("STATION")
     210 S RMPR9("HCP")=RMPR11I("HCPCS")
     211 S RMPR9("ITE")=RMPR11I("ITEM")
     212 S RMPR9("RDT")=$P(%,".",1)
     213 S RMPR9("TQTY")=RMPR9("QUANTITY")
     214 S RMPR9("TCST")=RMPR9("VALUE")
     215 S RMPERR=$$UPCR^RMPRPIXJ(.RMPR9)
     216 Q
     217 ;
     218QUAN ;only update quantity
     219 ;quit if not in PIP
     220 Q:'$G(RMIEN6)!'$D(RMDTTIM)!'$D(RMPRRET)
     221 S RMPR11I("STATION")=RMPRRET("STATION")
     222 S RMPR11I("HCPCS")=RMPRRET("HCPCS")
     223 S RMPR11I("ITEM")=RMPRRET("ITEM")
     224 S RMPR5("IEN")=RMPRRET("LOCATION")
     225 D UP6,UP63
     226 I RMPR60("QUANTITY")>($P(R1BCK(0),U,7)) D  D UP7,UP9
     227 .S RMPR7I("QUANTITY")=RMPR60("QUANTITY")-($P(R1BCK(0),U,7))
     228 .S RMPR7I("VALUE")=RMPR60("COST")-($P(R1BCK(0),U,16))
     229 .S RMPR9("QUANTITY")=0-($G(RMPR60("QUANTITY"))-$P(R1BCK(0),U,7))
     230 .S RMPR9("VALUE")=0-($G(RMPR60("COST"))-$P(R1BCK(0),U,16))
     231 I RMPR60("QUANTITY")<($P(R1BCK(0),U,7)) D  D BACK,UP9
     232 .S RMPR9("QUANTITY")=$P(R1BCK(0),U,7)-$G(RMPR60("QUANTITY"))
     233 .S RMPRRET("QUANTITY")=$P(R1BCK(0),U,7)-$G(RMPR60("QUANTITY"))
     234 .S RMPR9("VALUE")=$P(R1BCK(0),U,16)-$G(RMPR60("COST"))
     235 .S RMPRRET("VALUE")=$P(R1BCK(0),U,16)-$G(RMPR60("COST"))
     236 Q
     237 ;
     238ERR W !!,"Error encountered while posting to PIP.  Patient 10-2319 not deleted!! Please check with your Application Coordinator." H 5 G EXIT
Note: See TracChangeset for help on using the changeset viewer.