Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSODRDU2

PSODRDU2.m

Go to the documentation of this file.
  1. PSODRDU2 ;BHAM ISC/SAB - dup drug/class display for outpatient orders ;08/23/17 19:54
  1. ;;7.0;OUTPATIENT PHARMACY;**132,251,375,387,441,768**;DEC 1997;Build 12
  1. ;External reference ^PS(50.7 - 2223
  1. ;External reference ^PS(50.606 - 2174
  1. ;External reference ^PSDRUG( - 221
  1. ;External reference to ^PS(55 - 2228
  1. EN(PSODFN,ORN,LIST) ;psodfn=patient's ifn, orn=ordertype;order#;drugtype;counter
  1. N DUPRXO,I,ISSD,J,BSIG,RFLS,RXREC,ST,PSONULN,LSTFL
  1. S $P(PSONULN,"-",79)="-"
  1. I $P(ORN,";")="O" G RX
  1. I $P(ORN,";")="P" G PND
  1. I $P(ORN,";")="N" G NVA
  1. I $P(ORN,";")="R" G RDI
  1. Q
  1. RX ;Rx info
  1. Q:'$D(^PSRX($P(ORN,";",2),0)) N ISSD,LSTFLD S RXREC=$P(ORN,";",2)
  1. S DUPRX0=^PSRX(RXREC,0),RFLS=$P(DUPRX0,"^",9),ISSD=$P(^PSRX(RXREC,0),"^",13),ISSD=$E(ISSD,4,5)_"/"_$E(ISSD,6,7)_"/"_$E(ISSD,2,3)
  1. S LSTFL=(+^PSRX(RXREC,3)),LSTFL=$E(LSTFL,4,5)_"/"_$E(LSTFL,6,7)_"/"_$E(LSTFL,2,3),RX0=DUPRX0,RX2=^PSRX(RXREC,2)
  1. S STA="ACTIVE^NON-VERIFIED^REFILL^HOLD^NON-VERIFIED^SUSPENDED^^^^^DONE^EXPIRED^DISCONTINUED^DELETED^DISCONTINUED BY PROVIDER^DISCONTINUED (EDIT)^HELD BY PROVIDER"
  1. S ST=$P(STA,"^",(+$P(^PSRX(RXREC,"STA"),"^")+1)) D K STA ;441 PAPI
  1. . I ST="ACTIVE",$G(^PSRX(RXREC,"PARK")) S ST="PARKED"
  1. W !,"Local Rx #"_$P(DUPRX0,"^")_" ("_ST_") for "_$P(^PSDRUG($P(DUPRX0,"^",6),0),"^")
  1. K FSIG,BSIG I $P($G(^PSRX(RXREC,"SIG")),"^",2) D FSIG^PSOUTLA("R",RXREC,60) F PSREV=1:1 Q:'$D(FSIG(PSREV)) S BSIG(PSREV)=FSIG(PSREV)
  1. K FSIG,PSREV I '$P($G(^PSRX(RXREC,"SIG")),"^",2) D EN2^PSOUTLA1(RXREC,60)
  1. W !,"SIG: "_$G(BSIG(1)) I $O(BSIG(1)) F PSREV=1:0 S PSREV=$O(BSIG(PSREV)) Q:'PSREV W !?20,$G(BSIG(PSREV))
  1. D PRSTAT(RXREC) W !
  1. Q
  1. PND ;op pending orders
  1. Q:'$D(^PS(52.41,$P(ORN,";",2),0))
  1. N DUPRX0,FSIG
  1. S DUPRX0=^PS(52.41,$P(ORN,";",2),0)
  1. W !,"Pending Outpatient Drug for "_$S('$P(DUPRX0,"^",9):$P(^PS(50.7,$P(DUPRX0,"^",8),0),"^")_" "_$P(^PS(50.606,$P(^(0),"^",2),0),"^"),1:$P(^PSDRUG($P(DUPRX0,"^",9),0),"^"))
  1. D FSIG^PSOUTLA("P",$P(ORN,";",2),IOM-6)
  1. W !,"SIG: " F I=0:0 S I=$O(FSIG(I)) Q:'I W FSIG(I),!?5
  1. Q
  1. NVA ;non-va meds
  1. Q:'$D(^PS(55,PSODFN,"NVA",$P(ORN,";",2),0))
  1. S DUPRX0=^PS(55,PSODFN,"NVA",$P(ORN,";",2),0)
  1. W !,"NON-VA Med: "_$S('$P(DUPRX0,"^",2):$P(^PS(50.7,$P(DUPRX0,"^"),0),"^")_" "_$P(^PS(50.606,$P(^(0),"^",2),0),"^"),1:$P(^PSDRUG($P(DUPRX0,"^",2),0),"^")) ;_" (ACTIVE)"
  1. W !,"Dosage: "_$P(DUPRX0,"^",3),?25,"Schedule: "_$P(DUPRX0,"^",5)
  1. W !
  1. ;W !?3,"Date Documented: "_$E($P(DUPRX0,"^",10),4,5)_"/"_$E($P(DUPRX0,"^",10),6,7)_"/"_$E($P(DUPRX0,"^",10),2,3),?30,"Status: Active",!
  1. K DUPRX0
  1. Q
  1. RDI ;RDI orders
  1. Q:'$D(^TMP($J,LIST,"OUT","REMOTE",$P(ORN,";",2)))
  1. S RXREC=^TMP($J,LIST,"OUT","REMOTE",$P(ORN,";",2))
  1. W !,"LOCATION: "_$P(RXREC,"^")
  1. W !,"Remote Rx #"_$P(RXREC,"^",5)_" ("_$P(RXREC,"^",4)_") for "_$P(RXREC,"^",3)
  1. W !,"SIG: " S I="" F S I=$O(^TMP($J,LIST,"OUT","REMOTE",$P(ORN,";",2),"SIG",I)) Q:I="" D
  1. .W ^TMP($J,LIST,"OUT","REMOTE",$P(ORN,";",2),"SIG",I),!
  1. .I $O(^TMP($J,LIST,"OUT","REMOTE",$P(ORN,";",2),"SIG",I))'="" W ?5
  1. W "Last Filled On: "_$P(RXREC,"^",6),!
  1. K RXREC,I
  1. Q
  1. PRSTAT(DA) ;Displays the prescription's status
  1. N PSOTRANS,PSOREL,PSOCMOP,RXPSTA,PSOX,RFLZRO,PSOLRD,PSORTS,CMOP,PSOMW,PSORFL
  1. D HD^PSODDPR2():(($Y+5)'>IOSL) Q:$G(PSODLQT) S RXPSTA="Processing Status: ",PSOLRD=$P($G(^PSRX(RXREC,2)),"^",13)
  1. D ^PSOCMOPA I $G(PSOCMOP)]"" D K CMOP,PSOTRANS,PSOREL
  1. .S PSOTRANS=$E($P(PSOCMOP,"^",2),4,5)_"/"_$E($P(PSOCMOP,"^",2),6,7)_"/"_$E($P(PSOCMOP,"^",2),2,3)
  1. .S PSOREL=$S(CMOP("L")=0:$P($G(^PSRX(DA,2)),"^",13),1:$P(^PSRX(DA,1,CMOP("L"),0),"^",18))
  1. .S PSOREL=$E(PSOREL,4,5)_"/"_$E(PSOREL,6,7)_"/"_$E(PSOREL,2,3)_"@"_$E($P(PSOREL,".",2),1,4)
  1. .I '$D(IOINORM)!('$D(IOINHI)) S X="IORVOFF;IORVON;IOINHI;IOINORM" D ENDR^%ZISS
  1. .I $P($G(^PSRX(RXREC,"STA")),"^")=0 W:$$TRANCMOP^PSOUTL(RXREC) ?5,IORVON_IOINHI
  1. .W !,RXPSTA_$S($P(PSOCMOP,"^")=0!($P(PSOCMOP,"^")=2):"Transmitted to CMOP on "_PSOTRANS,$P(PSOCMOP,"^")=1:"Released by CMOP on "_PSOREL,1:"Not Dispensed"),IOINORM_IORVOFF
  1. D HD^PSODDPR2():(($Y+5)'>IOSL) Q:$G(PSODLQT)
  1. I $G(PSOCMOP)']"" D
  1. .S PSORFL=""
  1. .F PSOX=0:0 S PSOX=$O(^PSRX(RXREC,1,PSOX)) Q:'PSOX D
  1. ..S PSORFL=PSOX ;PSO*7*768
  1. ..S RFLZRO=$G(^PSRX(RXREC,1,PSOX,0))
  1. ..S:$P(RFLZRO,"^",18)'="" PSOLRD=$P(RFLZRO,"^",18) I $P(RFLZRO,"^",16) S PSOLRD=PSOLRD_"^R",PSORTS=$P(RFLZRO,"^",16)
  1. .I '$O(^PSRX(RXREC,1,0)),$P(^PSRX(RXREC,2),"^",15) S PSOLRD=PSOLRD_"^R",PSORTS=$P(^PSRX(RXREC,2),"^",15)
  1. .W !,RXPSTA I +$G(PSORTS) W "Returned to stock on "_$$FMTE^XLFDT(PSORTS,2) Q
  1. .;pso768
  1. .S PSOMW=""
  1. .I PSORFL S PSOMW=$S($P(^PSRX(RXREC,1,PSORFL,0),"^",2)="W":" (Window)",1:" (Mail)")
  1. .I PSOMW="" S PSOMW=$S($P(^PSRX(RXREC,0),"^",11)="W":" (Window)",1:" (Mail)")
  1. .W $S(PSOLRD="":"Not released locally",1:"Released locally on "_$$FMTE^XLFDT($P(PSOLRD,"^"),2)_" "_$P(PSOLRD,"^",2))_PSOMW
  1. Q