source: FOIAVistA/trunk/r/ORDER_ENTRY_RESULTS_REPORTING-OR-OCX--ORRC--ORRJ/ORCSIGN.m@ 1607

Last change on this file since 1607 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 8.6 KB
Line 
1ORCSIGN ;SLC/MKB-Sign/Release orders ;10/29/01 11:44
2 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**7,56,48,79,108,110,134,215**;Dec 17, 1997
3 ;
4EN ; -- start here
5 I '$D(^XUSEC("ORES",DUZ)),'$D(^XUSEC("ORELSE",DUZ)),'$D(^XUSEC("OREMAS",DUZ)) W !,"Insufficient privilege!" H 1 Q
6 N ORPTLK,ORI,NMBR,IDX,ORIFN,ORSIG,OREL,ORNATR,ORPRNT,ORPRINT,ORCHART,ORQUIT,ORERR,ORES,ORDER,OROLDSTS,ORACT,X,OR0,ORA0,ORLAB,ORWAIT,ORDA,ORWORK,ORCCNAT,ORCL,ORLR
7 S ORPTLK=$$LOCK^ORX2(+ORVP) I 'ORPTLK W !!,$C(7),$P(ORPTLK,U,2) H 2 Q
8 I '$G(ORNMBR) S ORNMBR=$$ORDERS^ORCHART("") Q:'ORNMBR
9 D FREEZE^ORCMENU S VALMBCK="R" K OREBUILD
10 I '$G(ORL) S ORL=$$FINDLOC S:'ORL ORL=$$LOCATION^ORCMENU1 G:ORL="^" ENQ
11 S ORACT=$S($D(^XUSEC("ORES",DUZ)):"ES",$D(^XUSEC("OREMAS",DUZ)):"OC",$D(^XUSEC("ORELSE",DUZ)):$$SELSIG,1:"^") G:ORACT="^" ENQ
12 S ORNATR=$S(ORACT="RS":$$NATURE,1:"") Q:ORNATR="^"
13 F ORI="LR","VBEC" S X=+$O(^DIC(9.4,"C",ORI,0)) S:X ORLR(X)=1,ORLR(ORI)=X
14 F ORI=1:1:$L(ORNMBR,",") S NMBR=$P(ORNMBR,",",ORI) I NMBR D
15 . S IDX=$G(^TMP("OR",$J,ORTAB,"IDX",NMBR)),ORDER=$P(IDX,U)
16 . Q:'ORDER S:'$P(ORDER,";",2) ORDER=+ORDER_";1"
17 . S ORIFN=+ORDER,ORDA=+$P(ORDER,";",2) K ORQUIT
18 . D VALID Q:$G(ORQUIT) S ORES(ORDER)=""
19 . S X=$P($G(^OR(100,ORIFN,0)),U,14) S:$G(ORLR(X)) ORES("LAB")=1
20 . S:$P($G(^OR(100,ORIFN,8,ORDA,0)),U,4)=2 ORES("ES")=1
21EN1 G:'$O(ORES(0)) ENQ K ORQUIT,ORWAIT
22 D ORDCHK^ORCMENU1 G:'$O(ORES(0)) ENQ0
23 I $G(ORQUIT) D UNLOCK G ENQ ;quit - ^ at override reason
24 S ORSIG=$S($G(ORES("ES")):2,1:3),OREL=0
25 I ORSIG=3 W !,"These order(s) do not require a signature."
26 E D I ORSIG=2,'OREL W !,"Nothing signed or released!" D UNLOCK H 2 G ENQ
27 . I ORACT="ES" S:$$ESIG ORSIG=1,OREL=1 Q
28 . I ORACT="OC" S:$$ONCHART ORSIG=0,OREL=1,ORNATR="W" Q
29 . I ORACT="RS" W:ORNATR'="I" !!,"A signature is required to RELEASE these orders; the responsible provider will",!,"be alerted to electronically sign them." S:$$ESIG ORSIG=$S(ORNATR="I":1,1:$$SIGSTS^ORX1(ORNATR)),OREL=1
30 S ORPRNT=$$GET^XPAR("ALL","ORPF PRINT CHART COPY WHEN"),ORPRINT=0
31 S ORCCNAT=$$CHART^ORX1($S(ORNATR="":"E",1:ORNATR)),ORCHART=0
32 S ORLAB=0 I '$D(^XUSEC("ORES",DUZ))!$$GET^XPAR("ALL","ORPF SHOW LAB #") S ORLAB=$G(ORLR("LR")) ;show Lab# when released
33 W !!,"Processing orders ..." D:$G(ORES("LAB")) BHS^ORMBLD(ORVP)
34EN2 S ORDER=0 F S ORDER=$O(ORES(ORDER)) Q:ORDER'>0 D
35 . S OROLDSTS=$P($G(^OR(100,+ORDER,3)),U,3),OR0=$G(^(0)),ORA0=$G(^(8,+$P(ORDER,";",2),0))
36 . N ORNP S ORNP=$P(ORA0,U,3),ORIFN=+ORDER,ORDA=+$P(ORDER,";",2)
37 . S ORNATR=$S($P(ORA0,U,4)=3:"",1:ORNATR) ; reset nature of order for sig not reqd orders --added with patch 110
38 . D EN^ORCSEND(ORDER,,ORSIG,OREL,ORNATR,,.ORERR),UNLK1^ORX2(ORIFN)
39 . I $D(^TMP("ORNEW",$J,ORIFN,ORDA)) K ^(ORDA) D UNLK1^ORX2(ORIFN)
40 . I $G(ORERR) D S ORWAIT=1 Q
41 . . W !!,$$ORDITEM^ORCACT(ORDER)_" "_$$STATUS(ORDER)
42 . . W:$L($P($G(ORERR),U,2)) !," >> "_$P(ORERR,U,2)
43 . I $P(ORA0,U,2)="NW",OROLDSTS=11,$P(OR0,U,14)=ORLAB,$G(^OR(100,ORIFN,4)) W !,$$ORDITEM^ORCACT(ORIFN)_" (LB #"_+^OR(100,ORIFN,4)_")" S ORWAIT=1
44 . I $P(ORA0,U,2)="DC",$P(OR0,U,11)=$O(^ORD(100.98,"B","DO",0)),OROLDSTS=6 D ;dc'd active NPO
45 . . N ORSTRT,ORDATE S ORSTRT=+$E($P($$NOW^XLFDT,".",2)_"0000",1,4)
46 . . S ORDATE=DT D LTRAY^ORCDFH ;need late tray for reinstated diet?
47 . D SETPRINT W "."
48 D:$G(ORES("LAB")) BTS^ORMBLD(ORVP)
49EN3 I $O(ORCHART(0))!$O(ORPRINT(0)) S ORCL=$$LOC^ORMEVNT I ORCL,ORCL'=ORL D
50 . N X,Y,DIR S DIR(0)="YA",DIR("B")="YES"
51 . S DIR("A",1)="This patient's location has been changed to "_$P($G(^SC(+ORCL,0)),U)_"."
52 . S DIR("A")="Should the orders be printed using the new location? "
53 . S DIR("?")="Enter NO to continue using "_$P($G(^SC(+ORL,0)),U)_" for ordering and printing, or YES to switch to the patient's current location instead"
54 . D ^DIR S:Y ORL=ORCL
55 D:$O(ORCHART(0)) PRINT^ORPR02(ORVP,.ORCHART,,ORL,"1^0^0^0^0")
56 D:$O(ORPRINT(0)) PRINT^ORPR02(ORVP,.ORPRINT,,ORL,"0^1^1^1^"_$$WORK(ORNATR))
57ENQ0 D UNOTIF S OREBUILD=1
58ENQ D:'$D(^TMP("ORNEW",$J)) UNLOCK^ORX2(+ORVP) D:$G(ORWAIT) READ ;output
59 Q
60 ;
61ESIG() ; -- Get electronic signature
62 N CODE,X,X1,Y
63 S CODE=$P($G(^VA(200,DUZ,20)),U,4),Y=0 I '$L(CODE) D Q Y
64 . W $C(7),!,"You do not have an electronic signature code."
65 . W !,"Please contact your IRM office." ; allow to enter code here?
66 D SIG^XUSESIG S Y=(X1'="")
67 Q Y
68 ;
69ONCHART() ; -- Signed on Chart?
70 N X,Y,DIR S DIR(0)="YA"
71 S DIR("B")=$S($$GET^XPAR("ALL","OR SIGNED ON CHART"):"YES",1:"NO")
72 S DIR("A")="Are you sure you want to mark these orders as already Signed on Chart? "
73 S DIR("?")="Enter YES only if these orders have already been signed in the patient's paper chart"
74 D ^DIR S:$D(DTOUT)!($D(DUOUT)) Y="^"
75 Q Y
76 ;
77SELSIG() ; -- Select type of signature &/or release [ORELSE holders only]
78 N X,Y,DIR,ES,ELSE
79 D CKAUTH(.ES,.ELSE) I ES,'ELSE Q "ES" ;all may be elec signed
80 S DIR("A")="Sign or release: ",DIR(0)="SAOM^"_$S($G(ES):"ES:Electronic Signature;",1:"")_"OC:Signed on Chart;RS:Release w/o MD Signature"
81 S DIR("B")=$S($G(ES):"Electronic Signature",$$GET^XPAR("ALL","OR SIGNATURE DEFAULT ACTION")="OC":"Signed on Chart",1:"Release w/o MD Signature")
82 S:$G(ES) DIR("?",1)="To electronically sign those orders that you are priviledged to, select ES."
83 S DIR("?")="If these orders have already been signed on the paper chart, select OC. To simply release these orders to the appropriate service for action, select RS; the requesting clinician will receive an alert to sign them."
84 W !!,$S($G(ES):" ES Electronic Signature ",1:"")_" OC Signed on Chart RS Release w/o MD Signature",!
85 D ^DIR S:$D(DTOUT)!($D(DUOUT))!(X="") Y="^"
86 Q Y
87 ;
88CKAUTH(SIGN,NOT) ; -- Ck authorization needed
89 N I,N,IFN,ACT S (SIGN,NOT)=0
90 F I=1:1:$L(ORNMBR,",") S N=$P(ORNMBR,",",I) I N D
91 . S IFN=$P($G(^TMP("OR",$J,ORTAB,"IDX",N)),U) Q:'IFN
92 . S ACT=$P(IFN,";",2),IFN=+IFN S:ACT'>0 ACT=1
93 . I $P($G(^OR(100,IFN,0)),U,16)<2 S SIGN=SIGN+1
94 . E S NOT=NOT+1
95 Q
96 ;
97NATURE() ; -- Returns nature of order/activity
98 N X,Y,DIR S DIR("A")="NATURE OF ORDER ACTIVITY: "
99 S DIR("B")=$S($G(ORNP)=DUZ:"Policy",1:"Verbal")
100 S DIR(0)="SAM^V:Verbal;T:Telephoned;P:Policy;"
101 S DIR("?")="Enter how this order was requested or originated."
102 D ^DIR S:$D(DTOUT)!($D(DUOUT)) Y="^" S:Y="P" Y="I" S:Y="T" Y="P"
103 Q Y
104 ;
105SETPRINT ; -- Set print arrays
106 I $P(^OR(100,ORIFN,3),U,3)=10 Q ; Still delayed
107 N Y S Y=$S($P(ORA0,U,15)=10:1,$P(ORA0,U,15)=11:1,1:0)
108 S:Y ORPRINT=ORPRINT+1,ORPRINT(ORPRINT)=ORDER
109 I ("R"[ORPRNT&Y)!(ORPRNT="S"&(ORSIG'=2)),ORCCNAT S ORCHART=ORCHART+1,ORCHART(ORCHART)=ORDER
110 Q
111 ;
112WORK(NATR) ; -- Returns 1 or 0, to print work copies for NATR
113 S:$G(NATR)="" NATR="E" S:'NATR NATR=+$O(^ORD(100.02,"C",NATR,0))
114 Q +$P($G(^ORD(100.02,NATR,1)),U,5)
115 ;
116CHART ; -- Trigger chart signature notification
117 N ORB S ORB=+ORVP_U_+ORIFN_U_ORNP_"^^1"
118 D EN^OCXOERR(ORB)
119 Q
120 ;
121NOTIF ; -- Trigger unsigned orders notification
122 N ORB S ORB=+ORVP_U_+ORIFN_U_ORNP_"^^^^^1"
123 D EN^OCXOERR(ORB)
124 Q
125 ;
126UNOTIF ; -- Undo unsigned orders notification
127 Q:$O(^OR(100,"AS",ORVP,0)) ; more left
128 N XQAKILL,ORNIFN
129 S ORNIFN=$O(^ORD(100.9,"B","ORDER REQUIRES ELEC SIGNATURE",0))
130 S XQAKILL=$$XQAKILL^ORB3F1(ORNIFN) ; unsigned orders notif
131 I $D(XQAID),$P($P(XQAID,";"),",",3)=ORNIFN D DELETE^XQALERT
132 I '$D(XQAID) S XQAID=$P($G(^ORD(100.9,ORNIFN,0)),U,2)_","_+ORVP_","_ORNIFN D DELETEA^XQALERT K XQAID
133 Q
134 ;
135VALID ; -- validate ORDER for signature/release
136 N ORLK,ORDIALOG,OROUT,ORPKG
137 I '$$VALID^ORCACT0(ORDER,ORACT,.ORERR,ORNATR) W !!,"Cannot sign "_$$ORDITEM^ORCACT(ORDER),!," >> "_ORERR S (ORQUIT,ORWAIT)=1 Q
138 S ORLK=$$LOCK1^ORX2(ORIFN) I 'ORLK W !!,"Cannot sign "_$$ORDITEM^ORCACT(ORDER),!," >> "_$P(ORLK,U,2) S (ORQUIT,ORWAIT)=1 Q ;order locked
139 S ORDIALOG=+$P(^OR(100,ORIFN,0),U,5),ORPKG=+$P(^(0),U,14)
140 I $P($G(^OR(100,ORIFN,8,ORDA,0)),U,15)'=11,ORPKG'=$$PKG^ORMPS1("PSO") Q
141 S OROUT=$$MSG^ORXD(ORDIALOG) I OROUT W !!,"Cannot release "_$$ORDITEM^ORCACT(ORDER),!," >> "_$P(OROUT,U,2) S (ORQUIT,ORWAIT)=1 Q ;dlg out of order
142 I ORDA'>1,$L($G(^ORD(101.41,ORDIALOG,7))) X ^(7) ;validate new orders
143 Q
144 ;
145UNLOCK ; -- Unlock orders in ORES(ORDER)
146 N ORIFN S ORIFN=0
147 F S ORIFN=$O(ORES(ORIFN)) Q:ORIFN'>0 D UNLK1^ORX2(+ORIFN)
148 Q
149 ;
150STATUS(ORD) ; -- return [release] status of order ORD
151 N STS,X,Y S STS=$P($G(^OR(100,+ORD,8,+$P(ORD,";",2),0)),U,15)
152 I STS S Y=$S(STS=10:"delayed",STS=11:"not released",STS=13:"cancelled",1:"")
153 E S X=$P($G(^OR(100,+ORD,3)),U,3),X=$P($G(^ORD(100.01,+X,0)),U),Y=$$LOW^XLFSTR(X)
154 Q Y
155 ;
156READ ; -- Press return to continue
157 N X,Y,DIR
158 S DIR(0)="EA",DIR("A")="Press <return> to continue ..."
159 D ^DIR
160 Q
161 ;
162FINDLOC() ; -- Determine location from selected orders
163 N ORI,ORN,ORIFN,ORX,ORY S ORY=""
164 F ORI=1:1:$L(ORNMBR,",") S ORN=+$P(ORNMBR,",",ORI) I ORN D Q:ORY="^"
165 . S ORIFN=+$G(^TMP("OR",$J,ORTAB,"IDX",ORN)) Q:'ORIFN
166 . S ORX=$P($G(^OR(100,ORIFN,0)),U,10) Q:'ORX S:ORY="" ORY=ORX
167 . I ORY'="",ORY'=ORX S ORY="^" Q ;different loc's -> prompt
168 Q ORY
Note: See TracBrowser for help on using the repository browser.