| 1 | PSODISP ;BIR/SAB,PWC-MANUAL BARCODE RELEASE FUNCTION ;03/02/93
 | 
|---|
| 2 |  ;;7.0;OUTPATIENT PHARMACY;**15,71,131,156,185,148,247,200,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 |  ; You should have received a copy of the GNU General Public License
 | 
|---|
| 17 |  ; along with this program; if not, write to the Free Software
 | 
|---|
| 18 |  ; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
 | 
|---|
| 19 |  ;Reference to $$SERV^IBARX1 supported by DBIA 2245
 | 
|---|
| 20 |  ;Reference to ^PSD(58.8 supported by DBIA 1036
 | 
|---|
| 21 |  ;Reference to ^PS(55 supported by DBIA 2228
 | 
|---|
| 22 |  ;Reference to ^PSDRUG supported by DBIA 221
 | 
|---|
| 23 |  ;Reference to ^PSDRUG("AQ" supported by DBIA 3165
 | 
|---|
| 24 |  ;Reference to ^XTMP("PSA" supported by DBIA 1036
 | 
|---|
| 25 |  ;Reference to ^PS(59.7 supported by DBIA 694
 | 
|---|
| 26 |  ;Reference to ^DIC(19.2 supported by DBIA 1064
 | 
|---|
| 27 | AC K CX,PSODA,PSODT,PSRH,DA,DR,DIE,X,X1,X2,Y,RXP,CX,PX,REC,DIR,YDT,REC,RDUZ,DIRUT,PSOCPN,PSOCPRX,YY,QDRUG,QTY,TYPE,XTYPE,DUOUT,PSOPID
 | 
|---|
| 28 |  K ^UTILITY($J,"PSOHL") S PSOPID=1
 | 
|---|
| 29 |  I '$D(PSOPAR) D ^PSOLSET I '$D(PSOPAR) W $C(7),!!,?5,"Site Parameters must be defined to use the Release option!",! G EXIT
 | 
|---|
| 30 |  S Y=$G(^PS(59,PSOSITE,"IB")),PSOIBSS=$$SERV^IBARX1(+Y) I 'PSOIBSS D IBSSR^PSOUTL I 'PSOIBFL D   G EXIT
 | 
|---|
| 31 |  .W $C(7),!!,"The IB SERVICE/SECTION defined in your site parameter file is not valid.",!,"You will not be able to release any medication until this is corrected!",!
 | 
|---|
| 32 | AC1 I $G(PSOAFYN)'="Y" W !! S PSIN=+$P($G(^PS(59.7,1,49.99)),"^",2) ;vfah - VOE
 | 
|---|
| 33 |  I $G(PSOAFYN)="Y" S PSIN=+$P($G(^PS(59.7,1,49.99)),"^",2) ;vfah - VOE
 | 
|---|
| 34 |  I $G(PSOAFYN)'="Y" S DIC("S")="I $D(^XUSEC(""PSORPH"",+Y))",DIC("A")="Enter PHARMACIST: ",DIC="^VA(200,",DIC(0)="QEAM" D ^DIC G:"^"[X EXIT K DIC G:$D(DTOUT)!($D(DUOUT))!($D(DIRUT))!(Y=-1) EXIT S PSRH=+Y ;vfah - VOE
 | 
|---|
| 35 |  I $G(PSOAFYN)="Y" S PSRH=DUZ,PSZAR="0" ;vfah - VOE
 | 
|---|
| 36 |  ;check for Drug Acct background job K8 & K7.1
 | 
|---|
| 37 |  S X="PSA IV ALL LOCATIONS",DIC(0)="MZ",DIC=19.2 D ^DIC I Y=-1 K DIC,X,Y G BC
 | 
|---|
| 38 |  I $P($G(Y(0)),U,2)>DT S PSODA=1 S:'$P($G(^XTMP("PSA",0)),U,2) $P(^(0),U,2)=DT G BC
 | 
|---|
| 39 |  S X="PSA IV ALL LOCATIONS",DIC(0)="MZ",DIC=19 D ^DIC K DIC,X G:Y=-1 BC
 | 
|---|
| 40 |  K DIQ,PSA S DA=+Y,DIC=19,DIQ="PSA",DR=200,DIQ(0)="IN" D EN^DIQ1
 | 
|---|
| 41 |  I '$D(PSA(19,DA,200,"I")) K DIC,DA,X,Y,DIQ G BC
 | 
|---|
| 42 |  I PSA(19,DA,200,"I")>DT S PSODA=1 S:'$P($G(^XTMP("PSA",0)),U,2) $P(^(0),U,2)=DT
 | 
|---|
| 43 |  K PSA,DIC,DA,X,Y,DIQ
 | 
|---|
| 44 | BC ;
 | 
|---|
| 45 |  I $G(PSOAFYN)="Y",$G(PSZAR)="1" Q  ;vfah - VOE
 | 
|---|
| 46 |  K MAN I $G(RXP),$D(DISGROUP),$D(BINGNAM),($D(BINGDIV)!$D(BNGPDV)!$D(BNGRDV)),($D(BINGRO)!$D(BINGRPR)) D REL^PSOBING1 K BINGNAM,BINGDIV,BINGRO,BINGRPR,BNGPDV,BNGRDV
 | 
|---|
| 47 |  I $G(PSOAFYN)'="Y" Q:$G(POERR)  W !! K CMOP,ISUF,DIR,LBL,LBLP S DIR("A")="Enter/Wand PRESCRIPTION number",DIR("?")="^D HELP^PSODISP",DIR(0)="FO" D ^DIR ;vfah - VOE
 | 
|---|
| 48 |  I $G(PSOAFYN)="Y" S X=RXN,PSZAR="1" ;vfah - VOE
 | 
|---|
| 49 |  I $D(DIRUT)!($D(DTOUT))!($D(DUOUT)) K DIRUT,DTOUT,DUOUT G AC1
 | 
|---|
| 50 |  I X'["-" D BCI W:'$G(RXP) !,"INVALID PRESCRIPTION NUMBER" G:'$G(RXP) BC S MAN=1 G BC1
 | 
|---|
| 51 |  I X["-",$P(X,"-")'=$P($$SITE^VASITE(),"^",3) W !?7,$C(7),$C(7),"   INVALID STATION NUMBER !!",$C(7),$C(7),! G BC
 | 
|---|
| 52 |  I X["-" S RXP=$P(X,"-",2) I '$D(^PSRX(+$G(RXP),0))!($G(RXP)']"") W !?7,$C(7),$C(7),$C(7),"   NON-EXISTENT PRESCRIPTION" G BC
 | 
|---|
| 53 |  I $D(^PSRX(RXP,0)) D  G BC1
 | 
|---|
| 54 |  .S PSOLOUD=1 D:$P($G(^PS(55,+$P(^PSRX(+RXP,0),"^",2),0)),"^",6)'=2 EN^PSOHLUP($P(^PSRX(+RXP,0),"^",2)) K PSOLOUD
 | 
|---|
| 55 |  W !?7,$C(7),$C(7),$C(7),"   IMPROPER BARCODE FORMAT" G BC
 | 
|---|
| 56 | BC1 ;
 | 
|---|
| 57 |  D ICN^PSODPT(+$P(^PSRX(RXP,0),"^",2))
 | 
|---|
| 58 |  I +$P($G(^PSRX(+RXP,"PKI")),"^") D  Q:$G(POERR)  G BC
 | 
|---|
| 59 |  .I $G(SPEED) W !!?7,$C(7),$C(7),"Rx# "_$P(^PSRX(RXP,0),"^") S PSOLIST=4
 | 
|---|
| 60 |  .W !!,?7,"UNABLE TO RELEASE - THIS ORDER MUST BE RELEASED THROUGH THE OUTPATIENT",!,?7,"RX'S [PSD OUTPATIENT] OPTION IN THE CONTROLLED SUBSTANCE MENU"
 | 
|---|
| 61 |  I +$P($G(^PSRX(+RXP,"STA")),"^")=13!(+$P($G(^PSRX(+RXP,0)),"^",2)=0) W !?7,$C(7),$C(7),"    PRESCRIPTION IS A DELETED PRESCRIPTION NUMBER" Q:$G(POERR)  D DCHK G BC
 | 
|---|
| 62 |  I +$P($G(^PSRX(+RXP,"STA")),"^"),$S($P(^("STA"),"^")=2:0,$P(^("STA"),"^")=5:0,$P(^("STA"),"^")=11:0,$P(^("STA"),"^")=12:0,$P(^("STA"),"^")=14:0,$P(^("STA"),"^")=15:0,1:1) D STAT^PSODISPS Q:$G(POERR)  D DCHK G BC
 | 
|---|
| 63 |  ;drug stocked in Drug Acct Location?
 | 
|---|
| 64 |  S PSODA(1)=$S($D(^PSD(58.8,+$O(^PSD(58.8,"AOP",+PSOSITE,0)),1,+$P(^PSRX(RXP,0),U,6))):1,1:0)
 | 
|---|
| 65 |  I $P(^PSRX(RXP,2),"^",13) S Y=$P(^PSRX(RXP,2),"^",13) X ^DD("DD") S OUT=1 D  K OUT Q:$G(POERR)  D DCHK G BC
 | 
|---|
| 66 |  .W !!?7,$C(7),$C(7),$S($G(SPEED):"Rx# "_$P(^PSRX(RXP,0),"^"),1:"Original prescription")_" was last released on "_Y,!?7,"Checking for unreleased refills/partials " D REF
 | 
|---|
| 67 | BATCH ;
 | 
|---|
| 68 |  I $P(^PSRX(RXP,2),"^",15),'$P(^(2),"^",14) S RESK=$P(^(2),"^",15)  W !!?5,"Rx# "_$P(^PSRX(RXP,0),"^")_" Original Fill returned to stock on "_$E(RESK,4,5)_"/"_$E(RESK,6,7)_"/"_$E(RESK,2,3),! G REF
 | 
|---|
| 69 |  ;flag to determine if site is running HL7 v.2.4 Dispense Machines
 | 
|---|
| 70 |  N PSODISP S PSODISP=$$GET1^DIQ(59,PSOSITE_",",105,"I")
 | 
|---|
| 71 |  S PSOCPN=$P(^PSRX(RXP,0),"^",2),QTY=$P($G(^PSRX(RXP,0)),"^",7),QDRUG=$P(^PSRX(RXP,0),"^",6)
 | 
|---|
| 72 |  ;original
 | 
|---|
| 73 |  I '$P($G(^PSRX(RXP,2)),"^",13),+$P($G(^(2)),"^",2)'<PSIN S RXFD=$P(^(2),"^",2) D  D:$G(LBLP) UPDATE I $G(ISUF) D UPDATE G REF
 | 
|---|
| 74 |  .S SUPN=$O(^PS(52.5,"B",RXP,0)) I SUPN,$D(^PS(52.5,"C",RXFD,SUPN)),$G(^PS(52.5,SUPN,"P"))'=1,'$P($G(^(0)),"^",5) S ISUF=1 Q
 | 
|---|
| 75 |  .I $D(^PSDRUG("AQ",QDRUG)) K CMOP D OREL^PSOCMOPB(RXP) K CMOP I $G(ISUF) K ISUF,CMOP Q
 | 
|---|
| 76 |  .;
 | 
|---|
| 77 |  .F LBL=0:0 S LBL=$O(^PSRX(RXP,"L",LBL)) Q:'LBL  I '+$P(^PSRX(RXP,"L",LBL,0),"^",2),'$P(^(0),"^",5),$P(^(0),"^",3)'["INTERACTION" S LBLP=1
 | 
|---|
| 78 |  .D CHKADDR^PSODISPS(RXP)
 | 
|---|
| 79 |  .Q:'$G(LBLP)
 | 
|---|
| 80 |  .;
 | 
|---|
| 81 |  .; - Checking for OPEN/UNRESOLVED 3rd. Party Payer Rejects / NDC Editing
 | 
|---|
| 82 |  .I $$MANREL^PSOBPSUT(RXP,0,$G(PSOPID))="^" K LBLP Q
 | 
|---|
| 83 |  .;
 | 
|---|
| 84 |  .S:$D(^PSDRUG(QDRUG,660.1))&($G(PSOAFYN)'="Y") ^PSDRUG(QDRUG,660.1)=^PSDRUG(QDRUG,660.1)-QTY ;vfah - VOE
 | 
|---|
| 85 |  .D NOW^%DTC S DIE="^PSRX(",DA=RXP,DR="31///"_%_";23////"_PSRH_";32.1///@;32.2///@",PSODT=% D ^DIE K DIE,DR,DA,LBL
 | 
|---|
| 86 |  .;
 | 
|---|
| 87 |  .; - Notifying IB through ECME of the Rx has been released
 | 
|---|
| 88 |  .D IBSEND^PSOBPSUT(RXP,0)
 | 
|---|
| 89 |  .;
 | 
|---|
| 90 |  .D EN^PSOHLSN1(RXP,"ZD")
 | 
|---|
| 91 |  .;if appropriate update ^XTMP("PSA", for Drug Acct
 | 
|---|
| 92 |  .I $G(PSODA),$G(PSODA(1)),'$D(^PSRX("AR",+PSODT,+RXP,0)) S ^XTMP("PSA",+PSOSITE,+QDRUG,+DT)=$G(^XTMP("PSA",+PSOSITE,+QDRUG,+DT))+QTY
 | 
|---|
| 93 | REF ;release refills and partials
 | 
|---|
| 94 |  K LBLP,IFN F XTYPE=1,"P" K IFN D QTY^PSODISPS
 | 
|---|
| 95 |  Q:+$G(OUT)!($G(POERR))  D DCHK
 | 
|---|
| 96 |  G BC
 | 
|---|
| 97 | UPDATE I $G(ISUF) W $C(7),!!?7,"Prescription "_$P(^PSRX(RXP,0),"^")_" - Original Fill on Suspense !",!,$C(7) Q
 | 
|---|
| 98 |  N BFILL S BFILL=0
 | 
|---|
| 99 |  S PSOCPRX=$P(^PSRX(RXP,0),"^") D CP^PSOCP
 | 
|---|
| 100 |  I $G(PSOAFYN)'="Y" W !?7,"Prescription Number "_$P(^PSRX(RXP,0),"^")_" Released" ;vfah - VOE
 | 
|---|
| 101 |  ;initialize bingo board variables
 | 
|---|
| 102 |  I $G(LBLP),$P(^PSRX(RXP,0),"^",11)["W" S BINGRO="W",BINGNAM=$P(^PSRX(RXP,0),"^",2),BINGDIV=$P(^PSRX(RXP,2),"^",9)
 | 
|---|
| 103 |  I $G(PSODISP)=2.4 D    ;HL7 v2.4 dispensing machines
 | 
|---|
| 104 |  . F I=0:0 S SUB=$O(^PSRX(RXP,"A",I)) Q:'I  I $P(^PSRX(RXP,"A",I,0),"^",2)="N" D XMIT    ;only send release dt/time transmission for dispensed orders
 | 
|---|
| 105 |  Q
 | 
|---|
| 106 | EXIT ;
 | 
|---|
| 107 |  K OUT,RX2,RXFD,RESK,ISUF,SUPN,%,DIC,IFN,J,DA,DR,DIE,X,X1,X2,Y,RXP,CX,PX,REC,DIR,YDT,REC,RDUZ,DIRUT,PSOCPN,PSOCPRX,PSOIBSS,PSOIBFL,PSOIBLP,PSOIBST,YY,QDRUG,QTY,TYPE,XTYPE,DUOUT,PSRH,XX,Y,PSIN,MAN,PSODISP,SUB
 | 
|---|
| 108 |  Q
 | 
|---|
| 109 | GETFILL ; get the fill number
 | 
|---|
| 110 |  S NFLD=0,UU="" F  S UU=$O(^PSRX(+RXP,1,UU)) Q:UU=""  S:$D(^PSRX(+RXP,1,UU,0)) NFLD=NFLD+1
 | 
|---|
| 111 |  Q
 | 
|---|
| 112 | HELP W !!,"Wand the barcode number of the prescription or manually key in",!,"the number below the barcode or the prescription number.",!,"The barcode number should be of the format - 'NNN-NNNNNNN'"
 | 
|---|
| 113 |  Q
 | 
|---|
| 114 | BCI S RXP=0
 | 
|---|
| 115 | RXP S RXP=$O(^PSRX("B",X,RXP)) I $P($G(^PSRX(+RXP,"STA")),"^")=13 G RXP ;GET RECORD NUMBER FROM SCRIPT NUMBER
 | 
|---|
| 116 |  Q
 | 
|---|
| 117 | DCHK ;checks for duplicate
 | 
|---|
| 118 |  Q:'$G(MAN)
 | 
|---|
| 119 |  I $D(DISGROUP),$D(BINGNAM),($D(BINGDIV)!$D(BNGPDV)!$D(BNGRDV)),($D(BINGRO)!$D(BINGRPR)) D REL^PSOBING1 K BINGNAM,BINGDIV,BINGRO,BINGRPR,BNGPDV,BNGRDV
 | 
|---|
| 120 |  S RXP=$O(^PSRX("B",$P(^PSRX(RXP,0),"^"),RXP)) I 'RXP K POERR,MAN Q
 | 
|---|
| 121 |  I $P($G(^PSRX(RXP,"STA")),"^")=13 G DCHK
 | 
|---|
| 122 |  I $D(DISGROUP),$D(BINGNAM),($D(BINGDIV)!$D(BNGPDV)!$D(BNGRDV)),($D(BINGRO)!$D(BINGRPR)) D REL^PSOBING1 K BINGNAM,BINGDIV,BINGRO,BINGRPR,BNGPDV,BNGRDV
 | 
|---|
| 123 |  W !!,"Duplicate Rx # "_$P(^PSRX(RXP,0),"^")_" found."
 | 
|---|
| 124 |  S POERR=1 D BC1^PSODISP
 | 
|---|
| 125 |  I $D(DISGROUP),$D(BINGNAM),($D(BINGDIV)!$D(BNGPDV)!$D(BNGRDV)),($D(BINGRO)!$D(BINGRPR)) D REL^PSOBING1 K BINGNAM,BINGDIV,BINGRO,BINGRPR,BNGPDV,BNGRDV
 | 
|---|
| 126 |  G DCHK
 | 
|---|
| 127 |  Q
 | 
|---|
| 128 | XMIT D NOW^%DTC S PSODTM=%
 | 
|---|
| 129 |  S IDGN=$P(^PSRX(+RXP,0),"^",6)
 | 
|---|
| 130 |  K ^UTILITY($J,"PSOHL")
 | 
|---|
| 131 |  S ^UTILITY($J,"PSOHL",1)=+RXP_"^"_IDGN_"^"_PSODTM_"^"_+$G(PDUZ)_"^0^^PSO DISP^^^"_FP_"^"_FPN
 | 
|---|
| 132 |  S ZTRTN="INIT^PSORELDT",ZTDESC="EXTERNAL INTERFACE FOR RELEASE DATE/TIME",ZTIO="",ZTDTH=$H,ZTSAVE("^UTILITY($J,""PSOHL"",")="",ZTSAVE("PSOSITE")="",ZTSAVE("RXP")="",ZTSAVE("PSOLAP")="" D ^%ZTLOAD K ^UTILITY($J,"PSOHL")
 | 
|---|
| 133 |  Q
 | 
|---|