| 1 | PSOREF ;BIR/SAB-refill data entry ;1/27/07  13:31 | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**1,23,27,36,46,78,130,131,148,208**;DEC 1997;Build 39 | 
|---|
| 3 | ; Modified from FOIA VISTA, | 
|---|
| 4 | ; Copyright (C) 2007 WorldVistA | 
|---|
| 5 | ; | 
|---|
| 6 | ; This program is free software; you can redistribute it and/or modify | 
|---|
| 7 | ; it under the terms of the GNU General Public License as published by | 
|---|
| 8 | ; the Free Software Foundation; either version 2 of the License, or | 
|---|
| 9 | ; (at your option) any later version. | 
|---|
| 10 | ; | 
|---|
| 11 | ; This program is distributed in the hope that it will be useful, | 
|---|
| 12 | ; but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 13 | ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 14 | ; GNU General Public License for more details. | 
|---|
| 15 | ; | 
|---|
| 16 | ;External reference to ^PSDRUG supported by DBIA 221 | 
|---|
| 17 | ;External references PSOL and PSOUL^PSSLOCK supported by DBIA 2789 | 
|---|
| 18 | ; | 
|---|
| 19 | EOJ ; | 
|---|
| 20 | K PSOMSG,PSOREF,PSORX("BAR CODE"),PSOLIST,LFD,MAX,MIN,NODE,PS,PSOERR,REF,RF,RXO,RXN,RXP,RXS,SD,VAERR,PSORX("FILL DATE") | 
|---|
| 21 | D PSOUL^PSSLOCK($P(PSOLST(ORN),"^",2)) | 
|---|
| 22 | Q | 
|---|
| 23 | OERR ;single refil | 
|---|
| 24 | ; | 
|---|
| 25 | S DIC="^VA(200,",DIC(0)="QEZ",X="AUTOFINISH,RX" ;vfah | 
|---|
| 26 | D ^DIC K DIC ;vfah | 
|---|
| 27 | S PSOZAF=+Y ;vfah | 
|---|
| 28 | I $P($G(^PSRX(RXN,"OR1")),"^",5)=$G(PSOZAF) S VALMBCK="",VALMSG="Refill option is not available for Autofinshed Rxs" K PSOZAF Q  ;vfah | 
|---|
| 29 | I $$LMREJ^PSOREJU1($P(PSOLST(ORN),"^",2),,.VALMSG,.VALMBCK) Q | 
|---|
| 30 | I $D(RXRP($P(PSOLST(ORN),"^",2))) S VALMBCK="",VALMSG="A Reprint Label has been requested!" Q | 
|---|
| 31 | I $D(RXPR($P(PSOLST(ORN),"^",2))) S VALMBCK="",VALMSG="A Partial has already been requested!" Q | 
|---|
| 32 | I $D(RXRS($P(PSOLST(ORN),"^",2))) S VALMBCK="",VALMSG="Rx is being pulled from suspense!" Q | 
|---|
| 33 | I $D(RXFL($P(PSOLST(ORN),"^",2))) S PTRX=$P(PSOLST(ORN),"^",2) D ^PSOCMOPT I '$G(PSOXFLAG) K PSOXFLAG S VALMBCK="",VALMSG="Fill already requested for CMOP!" Q | 
|---|
| 34 | K PSOXFLAG | 
|---|
| 35 | D PSOL^PSSLOCK($P(PSOLST(ORN),"^",2)) I '$G(PSOMSG) S VALMSG=$S($P($G(PSOMSG),"^",2)'="":$P($G(PSOMSG),"^",2),1:"Another person is editing this order."),VALMBCK="" K PSOMSG Q | 
|---|
| 36 | N RXN K PSORX("FILL DATE") D FULL^VALM1 S:$G(PSOFROM)'="NEW" PSOFROM="REFILL" S PSOREF("DFLG")=0,PSOREF("IRXN")=$P(PSOLST(ORN),"^",2),PSOREF("QFLG")=0 | 
|---|
| 37 | K PSOID D ^PSOREF1 I PSOREF("DFLG") D EOJ S VALMBCK="R" Q | 
|---|
| 38 | D ^PSOREF0 | 
|---|
| 39 | W ! K DIR,DIRUT,DTOUT,DUOUT S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR,DIRUT,DTOUT,DUOUT S PSORXED=1 D ^PSOBUILD,ACT^PSOORNE2 K PSORXED S VALMBCK="Q" D EOJ | 
|---|
| 40 | Q | 
|---|
| 41 | SPEED ;speed refill | 
|---|
| 42 | K LST,PSORX("FILL DATE") N VALMCNT I '$G(PSOCNT) S VALMSG="This patient has no Prescriptions!" S VALMBCK="" Q | 
|---|
| 43 | K DIR,DIRUT S DIR(0)="Y",DIR("B")="NO",DIR("A")="Barcode Refill",DIR("?")="If you want to use a barcode reader to process refills enter 'Y'." | 
|---|
| 44 | D ^DIR K DIR,DUOUT,DTOUT I $D(DIRUT) S VALMBCK="" Q | 
|---|
| 45 | G BCREF:Y | 
|---|
| 46 | K PSOREF,PSOFDR,DIR,DUOUT,DIRUT S DIR("A")="Select Orders by number",DIR(0)="LO^1:"_PSOCNT D ^DIR I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DUOUT S VALMBCK="" Q | 
|---|
| 47 | K DIR,DIRUT,DTOUT,PSOOELSE,DTOUT I +Y S (ASK,SPEED,PSOOELSE)=1 D FULL^VALM1 S LST=Y D  G:$G(PSOREF("DFLG"))!($G(PSOREF("QFLG"))) SPEEDX | 
|---|
| 48 | .F ORD=1:1:$L(LST,",") Q:$P(LST,",",ORD)']""!($G(PSOREF("QFLG")))  S ORN=$P(LST,",",ORD) D:+PSOLST(ORN)=52 | 
|---|
| 49 | ..S DIC="^VA(200,",DIC(0)="QEZ",X="AUTOFINISH,RX" ;vfah | 
|---|
| 50 | ..D ^DIC K DIC ;vfah | 
|---|
| 51 | ..S PSOZAF=+Y ;vfah | 
|---|
| 52 | ..I $P($G(^PSRX($P(PSOLST(ORN),"^",2),"OR1")),"^",5)=$G(PSOZAF) W $C(7),!!,"Rx "_$$GET1^DIQ(52,$P(PSOLST(ORN),"^",2),.01)_" is an Autofinish,Rx and can not be refilled" K PSOZAF D PAUSE^VALM1 Q  ;vfah | 
|---|
| 53 | ..I $$LMREJ^PSOREJU1($P(PSOLST(ORN),"^",2)) W $C(7),!!,"Rx "_$$GET1^DIQ(52,$P(PSOLST(ORN),"^",2),.01)_" has OPEN/UNRESOLVED 3rd Party Payer Reject!" K DIR D PAUSE^VALM1 Q | 
|---|
| 54 | ..D PSOL^PSSLOCK($P(PSOLST(ORN),"^",2)) I '$G(PSOMSG) W $C(7),!!,$S($P($G(PSOMSG),"^",2)'="":$P($G(PSOMSG),"^",2),1:"Another person is editing Rx "_$P(^PSRX($P(PSOLST(ORN),"^",2),0),"^")),! D PAUSE^VALM1 K PSOMSG Q | 
|---|
| 55 | ..K PSOMSG I $D(RXRP($P(PSOLST(ORN),"^",2))) W $C(7),!!,"A Reprint Label has been requested!" D ULK D PAUSE^VALM1 Q | 
|---|
| 56 | ..I $D(RXPR($P(PSOLST(ORN),"^",2))) W $C(7),!!,"A Partial has already been requested!" D ULK D PAUSE^VALM1 Q | 
|---|
| 57 | ..I $D(RXFL($P(PSOLST(ORN),"^",2))) S PTRX=$P(PSOLST(ORN),"^",2) D ^PSOCMOPT I '$G(PSOXFLAG) K PSOXFLAG W $C(7),!!,"A CMOP fill has already been requested for Rx "_$P($G(^PSRX($P(PSOLST(ORN),"^",2),0)),"^") D ULK D PAUSE^VALM1 Q | 
|---|
| 58 | ..K PSOXFLAG I $D(RXRS($P(PSOLST(ORN),"^",2))) W $C(7),!!,"Rx is being pulled from suspense!" D ULK D PAUSE^VALM1 Q | 
|---|
| 59 | ..I $P($G(^PSRX($P(PSOLST(ORN),"^",2),"STA")),"^")=11 D  D ULK Q | 
|---|
| 60 | ...W $C(7),!!?5,"RX "_$P($G(^PSRX($P(PSOLST(ORN),"^",2),0)),"^")_" is in an EXPIRED status." W ! K DIR S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR | 
|---|
| 61 | ..S PSOREF("IRXN")=$P(PSOLST(ORN),"^",2) I ASK D ^PSOREF1 S ASK=0 D:$G(PSOREF("QFLG")) ULK Q:$G(PSOREF("QFLG")) | 
|---|
| 62 | ..N RXN D FULL^VALM1 S:$G(PSOFROM)'="NEW" PSOFROM="REFILL" S PSOREF("DFLG")=0,PSOREF("IRXN")=$P(PSOLST(ORN),"^",2) | 
|---|
| 63 | ..I PSOREF("DFLG") D EOJ S VALMBCK="R" Q | 
|---|
| 64 | ..D ^PSOREF0 D ULK | 
|---|
| 65 | S:'$G(PSOOELSE) VALMBCK="" | 
|---|
| 66 | S PSORXED=1 D ^PSOBUILD,BLD^PSOORUT1 | 
|---|
| 67 | SPEEDX K PSOREF,PSORX("BAR CODE"),PSOLIST,LFD,MAX,MIN,NODE,PS,PSOERR,REF,RF,RXO,RXN,RXP,RXS,SD,VAERR,PSORX("FILL DATE") | 
|---|
| 68 | K LST,SPEED,PSORXED,PSOREF,PSOFDR,PSOOELSE,ASK S:'$D(VALMBCK) VALMBCK="R" | 
|---|
| 69 | K PSORX("FILL DATE"),PSORX("MAIL/WINDOW"),PSORX("METHOD OF PICK-UP") | 
|---|
| 70 | Q | 
|---|
| 71 | BCREF ;barcode refills | 
|---|
| 72 | K LST,DIR,DIRUT,DUOUT,DTOUT D FULL^VALM1 | 
|---|
| 73 | ASK S DIR(0)="FO^5:245^K:X'?3N1""-""1.N X",DIR("A")="WAND BARCODE" | 
|---|
| 74 | S DIR("?",1)="Wand the barcoded number of the prescription to be processed." | 
|---|
| 75 | S DIR("?",2)="The number should be of the form NNN-NNNNNN",DIR("?",3)="where the number before the dash is your station number." | 
|---|
| 76 | S DIR("?")="Enter ""^"", or a RETURN to quit." | 
|---|
| 77 | D ^DIR I $D(DUOUT)!($D(DTOUT)) S VALMBCK="" G BCREFX | 
|---|
| 78 | I $G(X)']"",'$G(LST) S VALMBCK="" G BCREFX | 
|---|
| 79 | I $D(DIRUT),+$G(LST) D  S VALMBCK="R" G BCREFX | 
|---|
| 80 | .K DIR,DIRUT,DTOUT,PSOOELSE,DTOUT | 
|---|
| 81 | .S (BCREF,ASK,SPEED,PSOOELSE)=1 D FULL^VALM1 D | 
|---|
| 82 | ..F ORD=1:1:$L(LST,",") Q:$P(LST,",",ORD)']""!($G(PSOREF("QFLG")))  S ORN=$P(LST,",",ORD) D:+PSOLST(ORN)=52 | 
|---|
| 83 | ...I $$LMREJ^PSOREJU1($P(PSOLST(ORN),"^",2)) W $C(7),!!,"Rx "_$$GET1^DIQ(52,$P(PSOLST(ORN),"^",2),.01)_" has OPEN/UNRESOLVED 3rd Party Payer Reject!" K DIR D PAUSE^VALM1 Q | 
|---|
| 84 | ...D PSOL^PSSLOCK($P(PSOLST(ORN),"^",2)) I '$G(PSOMSG) W $C(7),!!,$S($P($G(PSOMSG),"^",2)'="":$P($G(PSOMSG),"^",2),1:"Another person is editing Rx "_$P(^PSRX($P(PSOLST(ORN),"^",2),0),"^")),! D PAUSE^VALM1 K PSOMSG Q | 
|---|
| 85 | ...K PSOMSG I $D(RXRP($P(PSOLST(ORN),"^",2))) W $C(7),!!,"A Reprint Label has been requested for Rx "_$P(^PSRX($P(PSOLST(ORN),"^",2),0),"^"),! D ULK D PAUSE^VALM1 Q | 
|---|
| 86 | ...I $D(RXPR($P(PSOLST(ORN),"^",2))) W $C(7),!!,"A Partial has already been requested for Rx "_$P(^PSRX($P(PSOLST(ORN),"^",2),0),"^"),! D ULK D PAUSE^VALM1 Q | 
|---|
| 87 | ...I $D(RXFL($P(PSOLST(ORN),"^",2))) S PTRX=$P(PSOLST(ORN),"^",2) D ^PSOCMOPT I '$G(PSOXFLAG) K PSOXFLAG W $C(7),!!,"A CMOP fill has already been requested for Rx "_$P($G(^PSRX($P(PSOLST(ORN),"^",2),0)),"^") D ULK D PAUSE^VALM1 Q | 
|---|
| 88 | ...K PSOXFLAG I $D(RXRS($P(PSOLST(ORN),"^",2))) W $C(7),!!,"Rx "_$P(^PSRX($P(PSOLST(ORN),"^",2),0),"^")_" is being pulled from suspense!" D ULK D PAUSE^VALM1 Q | 
|---|
| 89 | ...S PSOREF("IRXN")=$P(PSOLST(ORN),"^",2) I ASK D ^PSOREF1 S ASK=0 D:$G(PSOREF("DFLG")) ULK Q:$G(PSOREF("DFLG")) | 
|---|
| 90 | ...N RXN D FULL^VALM1 S:$G(PSOFROM)'="NEW" PSOFROM="REFILL" S PSOREF("DFLG")=0,PSOREF("IRXN")=$P(PSOLST(ORN),"^",2) | 
|---|
| 91 | ...I PSOREF("DFLG") D EOJ S VALMBCK="R" Q | 
|---|
| 92 | ...D ^PSOREF0 D ULK | 
|---|
| 93 | F RX=1:1:PSOCNT I $P(PSOLST(RX),"^",2)=$P(X,"-",2) D  Q | 
|---|
| 94 | .I $D(PSOBBC(RX)) Q | 
|---|
| 95 | .S LST=$G(LST)_RX_",",PSOBBC(RX)=1 | 
|---|
| 96 | G ASK | 
|---|
| 97 | BCREFX K BCREF,ASK,LST,SPEED,RX,PSOBBC,DIR,DIRUT,PSORXED,PSOREF,PSOFDR,PSOOELSE S PSORXED=1 D ^PSOBUILD,BLD^PSOORUT1 | 
|---|
| 98 | S VALMBCK="R" Q | 
|---|
| 99 | REFILL(PLACER) ;passes flag to CPRS for front door refill request | 
|---|
| 100 | ;PLACER=PHARMACY NUMBER | 
|---|
| 101 | N PSORFRM,PSOLC,PSODRG,PSODRUG0,RXN,ST,PSODEA | 
|---|
| 102 | I $G(PLACER)["S"!('$G(PLACER)) Q "-1^Not a Valid Outpatient Medication Order." | 
|---|
| 103 | S RXN=PLACER I '$D(^PSRX(RXN,0)) Q "-1^Not a Valid Outpatient Medication Order." | 
|---|
| 104 | S RX0=^PSRX(RXN,0),PSODRG=$P(^PSRX(RXN,0),"^",6),ST=+^("STA"),PSODRUG0=^PSDRUG(PSODRG,0),PSODEA=$P($G(^(0)),"^",3),DIV=$P(^PSRX(RXN,2),"^",9),PSORFRM=$P(RX0,"^",9) | 
|---|
| 105 | I PSODEA["2" Q "0^Schedule 2 Drug. Order cannot be refilled." | 
|---|
| 106 | I '$P($G(^PSRX(RXN,"OR1")),"^"),'$P($G(^PSDRUG(PSODRG,2)),"^") Q "0^Cannot Refill. Drug not matched to a Pharmacy Orderable Item." | 
|---|
| 107 | I '$P($G(^PSRX(RXN,"OR1")),"^"),$P($G(^PSDRUG(PSODRG,2)),"^") S $P(^PSRX(RXN,"OR1"),"^")=$P(^PSDRUG(PSODRG,2),"^") | 
|---|
| 108 | S CLOZPAT=$S($P($G(^PSDRUG(PSODRG,"CLOZ1")),"^")="PSOCLO1":1,1:0) | 
|---|
| 109 | I 'CLOZPAT I PSODEA["A"&(PSODEA'["B")!(PSODEA["F") Q "0^"_$S(PSODEA["F":"",1:"Narcotic Drug. ")_"Order Non-Refillable." | 
|---|
| 110 | K CLOZPAT I DT>$P($G(^PSRX(RXN,2)),"^",6) Q "0^Non-Refillable.  Prescription has Expired." | 
|---|
| 111 | I $P(^PSRX(RXN,3),"^",2)>$P(^PSRX(RXN,2),"^",6) Q "0^Next Refill Date Past Expiration Date.  New Order Required." | 
|---|
| 112 | I '$P($G(^PS(59,DIV,1)),"^",11),$G(^PSDRUG(PSODRG,"I"))]"",DT>$G(^("I")) Q "0^Inactive Drug, Non Refillable." | 
|---|
| 113 | I ST Q "0^Prescription is in a Non-Refillable Status." | 
|---|
| 114 | I $P($G(^PSDRUG(PSODRG,2)),"^",3)'["O" Q "0^Cannot Refill. Drug No Longer Used by Outpatient Pharmacy." | 
|---|
| 115 | S PSORFRM=$P(RX0,"^",9) F PSOJ=0:0 S PSOJ=$O(^PSRX(RXN,1,PSOJ)) Q:'PSOJ  S PSORFRM=PSORFRM-1 | 
|---|
| 116 | I PSORFRM<1 Q "0^No Refills remaining. New Med order required." | 
|---|
| 117 | I $P(^PSRX(RXN,3),"^"),DT=$P(^PSRX(RXN,3),"^") Q "0^Can't Refill, Fill Date already exists for "_$E($P(^PSRX(RXN,3),"^"),4,5)_"/"_$E($P(^PSRX(RXN,3),"^"),6,7)_"/"_$E($P(^PSRX(RXN,3),"^"),2,3)_"." | 
|---|
| 118 | I $P(^PSRX(RXN,3),"^"),DT<$P(^PSRX(RXN,3),"^") Q "0^Can't Refill, later Refill Date already exists for "_$E($P(^PSRX(RXN,3),"^"),4,5)_"/"_$E($P(^PSRX(RXN,3),"^"),6,7)_"/"_$E($P(^PSRX(RXN,3),"^"),2,3)_"." | 
|---|
| 119 | I $O(^PS(52.41,"ARF",RXN,0)) Q "0^Pending Refill Request already exists." | 
|---|
| 120 | Q 1 | 
|---|
| 121 | ; | 
|---|
| 122 | ULK D PSOUL^PSSLOCK($P(PSOLST(ORN),"^",2)) | 
|---|
| 123 | Q | 
|---|