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

ORPR07.m

Go to the documentation of this file.
  1. ORPR07 ; slc/dcm - Printless in Tuscaloosa ;6/10/97 15:36
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**15,11,94,141**;Dec 17, 1997
  1. ORDT(IFN,ACT) ;Get order date
  1. ;IFN=ORIFN
  1. ;ACT=DA of action
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X="" I $G(ACT) S Y=$$ACT(IFN,ACT) Q +Y
  1. S X=$P(^OR(100,IFN,0),"^",7)
  1. Q X
  1. ACT(IFN,ACT) ;This is an action
  1. N X
  1. Q:'$D(^OR(100,+$G(IFN),8,+$G(ACT),0)) "" S X=^(0)
  1. Q X
  1. VNURSE(IFN,ACT) ;Get verifying nurse data
  1. ;Returns 1^name^initials^title^date/time verified if data, "" if not
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y,Z S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT),Z=$G(^VA(200,+$P(Y,"^",8),0)) I $L(Z) S X=1_"^"_$P(Z,"^")_"^"_$P(Z,"^",2)_"^"_$P($G(^DIC(3.1,+$P(Z,"^",9),0)),"^")_"^"_$P(Y,"^",9)
  1. Q X
  1. VCLERK(IFN,ACT) ;Get verifying clerk data
  1. ;Returns 1^name^initials^title^date/time verified if data, "" if not
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y,Z S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT),Z=$G(^VA(200,+$P(Y,"^",10),0)) I $L(Z) S X=1_"^"_$P(Z,"^")_"^"_$P(Z,"^",2)_"^"_$P($G(^DIC(3.1,+$P(Z,"^",9),0)),"^")_"^"_$P(Y,"^",11)
  1. Q X
  1. RVIEW(IFN,ACT) ;Get Chart reviewed by data
  1. ;Returns 1^name^initials^titel^date/time reviewed, "" if not
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y,Z S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT),Z=$G(^VA(200,+$P(Y,"^",18),0)) I $L(Z) S X=1_"^"_$P(Z,"^")_"^"_$P(Z,"^",2)_"^"_$P($G(^DIC(3.1,+$P(Z,"^",9),0)),"^")_"^"_$P(Y,"^",19)
  1. Q X
  1. ORDOC(IFN,ACT) ;Get Ordering provider
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y,Z
  1. S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT),Z=$G(^VA(200,+$P(Y,"^",3),0)) I $L(Z) S X=$P(Z,"^")
  1. I '$L(X) S Y=$P(^OR(100,IFN,0),"^",4),Z=$G(^VA(200,+Y,0)) I $L(Z) S X=$P(Z,"^")
  1. Q X
  1. PHONE(IFN,ACT,PIECE) ;Get Ordering provider's phone number (multiple choice)
  1. ;PIECE=the piece of data to get from node ^VA(200,DUZ,.13)
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. Q:'$G(PIECE)
  1. N X,Y,Z
  1. S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT),Z=$G(^VA(200,+$P(Y,"^",3),.13)) I $L(Z) S X=$P(Z,"^",PIECE) Q X
  1. S Y=$P(^OR(100,IFN,0),"^",4) S:Y X=$P($G(^VA(200,Y,.13)),"^",PIECE)
  1. Q X
  1. NAT(IFN,ACT) ;Get Nature of order
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X=""
  1. I $G(ACT) S Y=$P($$ACT(IFN,ACT),"^",12),X=$S($D(^ORD(100.02,+Y,0)):$P(^(0),"^"),1:"")
  1. Q X
  1. ESNAME(IFN,ACT) ;Get Electronic Sig Name
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X=""
  1. I $G(ACT) S Y=$$ACT(IFN,ACT) D Q X
  1. . I $P(Y,"^",5) S X=$P($G(^VA(200,$P(Y,"^",5),20)),"^",2) S:$L(X) X=$S($P(Y,"^",4)=7:"/ds/",1:"/es/")_X Q
  1. . I $P(Y,"^",4),"42"[$P(Y,"^",4) S X="_______________" Q
  1. Q X
  1. ESTIT(IFN,ACT) ;Get Electronic Sig Title
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X="" I $G(ACT) S Y=$$ACT(IFN,ACT) S:$P(Y,"^",5) X=$E($P($G(^VA(200,$P(Y,"^",5),20)),"^",3),1,20)
  1. Q X
  1. ESDATE(IFN,ACT) ;Get Electronic Sig Date
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X
  1. S X=""
  1. I $G(ACT) S X=$P($$ACT(IFN,ACT),"^",6)
  1. Q X
  1. ESODATE(IFN,ACT) ;Get Date/time Signed online
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X
  1. S X=""
  1. I $G(ACT),$P($$ACT(IFN,ACT),"^",4)=1 S X=$P($$ACT(IFN,ACT),"^",6)
  1. Q X
  1. ENTBY(IFN,ACT) ;Get Entered by
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X="" I $G(ACT) S Y=$$ACT(IFN,ACT) S:$P(Y,"^",13) X=$P($G(^VA(200,$P(Y,"^",13),0)),"^") Q X
  1. S X=$P(^OR(100,IFN,0),"^",6) S:X X=$P(^VA(200,X,0),"^")
  1. Q X
  1. ENTINT(IFN,ACT) ;Get Entered by Initials
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X="" I $G(ACT) S Y=$$ACT(IFN,ACT) S:$P(Y,"^",13) X=$P($G(^VA(200,$P(Y,"^",13),0)),"^",2) Q X
  1. S X=$P(^OR(100,IFN,0),"^",6) S:X X=$P(^VA(200,X,0),"^",2)
  1. Q X
  1. ENTIT(IFN,ACT) ;Get Electronic Sig Title of Entering Person
  1. Q:'$G(IFN) ""
  1. Q:'$D(^OR(100,IFN,0)) ""
  1. N X,Y
  1. S X="" I $G(ACT) S Y=$$ACT(IFN,ACT) S:$P(Y,"^",13) X=$E($P($G(^VA(200,$P(Y,"^",13),20)),"^",3),1,20) Q X
  1. S X=$P(^OR(100,IFN,0),"^",6) S:X X=$E($P(^VA(200,X,20),"^",3),1,20)
  1. Q X
  1. BY(ORIFN) ;Get DC info for DC by & when PRINT FIELD
  1. Q:'$G(ORIFN) ""
  1. N Y,Z,X6,X1,ORDCBY
  1. I $P($G(^OR(100,ORIFN,6)),"^",2) S X6=^(6) D Q ORDCBY
  1. . S Y=+$J($P(X6,"^",3),0,4),Z=$G(^VA(200,+$P(X6,"^",2),0)) I $L(Z) S X1=$P(Z,"^")_$S($P(Z,"^",9):" ("_$E($P(^DIC(3.1,$P(Z,"^",9),0),"^"),1,10)_")",1:""),Y=$$DATE^ORU(Y)_" "_$$TIME^ORU(Y)
  1. . S ORDCBY="DC'ed "_$S(+$P(X6,"^",4):"("_$P(^ORD(100.03,+$P(X6,"^",4),0),"^")_")",1:"")_" by:"_X1_" "_Y
  1. Q ""
  1. WARDREM(ORIFN) ;Get Ward Remarks
  1. N ORI,X
  1. S X=""
  1. I $G(ORIFN) S ORI=$O(^OR(100,ORIFN,4.5,"ID","COMMENT",0)) I ORI S X="^OR(100,"_+ORIFN_",4.5,"_ORI_",2)"
  1. Q X
  1. RX(IFN,FLD,Y) ;Get Pharmacy Fields
  1. ;IFN=internal # of 100
  1. ;FLD=code for RX field to lookup
  1. ;Y=output returned in Y
  1. Q:'$G(IFN) Q:'$L($G(FLD))
  1. Q:'$D(^OR(100,IFN,0))
  1. N X,X4,PKG,DFN,I S X=^OR(100,IFN,0),X4=$G(^(4)) Q:'$L(X4)
  1. S PKG=$P(X,"^",14) Q:'PKG
  1. S PKG=$S($P(^DIC(9.4,PKG,0),"^")="INPATIENT MEDICATIONS":"I",$P(^(0),"^")="OUTPATIENT MEDICATIONS":"O",$P(^(0),"^")="IV MEDICATIONS":"I",$P(^(0),"^")="UNIT DOSE MEDICATIONS":"I",1:"") Q:'$L(PKG)
  1. S DFN=+$P(X,"^",2)
  1. D OEL^PSOORRL(DFN,X4_";"_PKG)
  1. I FLD="SI" S Y=$P($G(^TMP("PS",$J,"SI")),"^",1,99) Q ;Special Instructions
  1. I FLD="SCH" S I=0 D Q ;Schedule & Admin Times
  1. . F S I=$O(^TMP("PS",$J,"SCH",I)) Q:I<1 S Y(I)=$P(^(I,0),"^") ;_" "_$P(^(0),"^",2)
  1. I FLD="OTH" S Y=$P($G(^TMP("PS",$J,"OPI")),1,99) Q ;Other print info
  1. I FLD="DRUG" S Y=$P($G(^TMP("PS",$J,0)),"^") Q ;Drug
  1. I FLD="INF" S Y=$P($G(^TMP("PS",$J,0)),"^",2) Q ;Infusion rate
  1. I FLD="STOP" S Y=$P($G(^TMP("PS",$J,0)),"^",3) Q ;Stop date
  1. I FLD="REFIL" S Y=$P($G(^TMP("PS",$J,0)),"^",4) Q ;Refills
  1. I FLD="MDRT" S I=0 D Q ;Med Route
  1. . F S I=$O(^TMP("PS",$J,"MDR",I)) Q:I<1 S Y(I)=^(I,0)
  1. I FLD="SIG" S I=0 D Q ;SIG (outpat) Instructions (inpat)
  1. . F S I=$O(^TMP("PS",$J,"SIG",I)) Q:I<1 S Y(I)=^(I,0)
  1. I FLD="PC" S I=0 D Q ;Provider comments
  1. . F S I=$O(^TMP("PS",$J,"PC",I)) Q:I<1 S Y(I)=^(I,0)
  1. I FLD="ADD" S I=0 D Q ;Additive, amount, bottle
  1. . F S I=$O(^TMP("PS",$J,"A",I)) Q:I<1 S Y(I)=$P(^(I,0),"^")_" "_$P(^(0),"^",2)_" #"_$P(^(0),"^",3)
  1. I FLD="SOL" S I=0 D Q ;Solution & amount
  1. . F S I=$O(^TMP("PS",$J,"B",I)) Q:I<1 S Y(I)=$P(^(I,0),"^")_" "_$P(^(0),"^",2)
  1. Q
  1. TEST ;Test RX call
  1. W !,"Enter Pharmacy Order # (ORIFN): " R X:DTIME Q:X=""!(X["^") I '$D(^OR(100,+$G(X),0)) W !,$C(7),X_" does not exist" G TEST
  1. S ORIFN=X F ORI="SCH","SI","ADM","OTH","DRUG","INF","STOP","REFIL","MDRT","SIG","PC","ADD","SOL" K TEST D RX(ORIFN,ORI,.TEST) I $D(TEST) W !,ORI_"- " ;ZW TEST
  1. Q
  1. LABEL(Y,ORIFN,QUIET,OACTION) ;Print pharmacy label
  1. I $G(ORTEST) D TEST1 Q
  1. N X,X4,ORC
  1. Q:'$D(^OR(100,+$G(ORIFN),0)) Q:'$L($G(^(4))) S X=^(0),X4=^(4)
  1. I $S($P($G(^DIC(9.4,+$P(X,"^",14),0)),"^")="INPATIENT MEDICATIONS":0,$P($G(^DIC(9.4,+$P(X,"^",14),0)),"^")="IV MEDICATIONS":0,$P($G(^DIC(9.4,+$P(X,"^",14),0)),"^")="UNIT DOSE MEDICATIONS":0,1:1) Q
  1. N LINES,ORXPTMP,I,ACT
  1. I $G(OACTION),$D(^OR(100,+$G(ORIFN),8,OACTION,0)) S ACT=$P(^(0),"^",2)
  1. I $L($T(MAR^PSJORMAR),",")>4 D MAR^PSJORMAR(+$P(X,"^",2),$P(X4,"^"),1,.LINES,$G(ACT))
  1. I $L($T(MAR^PSJORMAR),",")'>4 D MAR^PSJORMAR(+$P(X,"^",2),$P(X4,"^"),1,.LINES)
  1. I $G(QUIET) K Y S (I,Y)=0 D Q
  1. . F S I=$O(LINES(I)) Q:'I S Y(I,0)=LINES(I),ORPICKUP=I
  1. S (ORC,I)=0
  1. I '$D(ORIOSL) N ORIOSL S ORIOSL=$S($D(IOSL):IOSL,1:50)
  1. I '$D(ORIOF) N ORIOF S ORIOF=$S($D(IOF):IOF,1:"!")
  1. F S I=$O(LINES(I)) Q:I<1 S ORC=ORC+1 D
  1. . I $Y>(ORIOSL-2) W @ORIOF S ORC=1
  1. . W:ORC>1 ! W LINES(I)
  1. Q
  1. TEST1 ;Print test label
  1. W !,"03/03 | | (F1990)|"
  1. W !,"Test Pharmacy Label"
  1. W !,"Give: 1GM TOP QD"
  1. W !!," RPH: _____RN: _____|"
  1. Q