source: FOIAVistA/tag/r/CARE_MANAGEMENT-ORRC/ORRCDPT1.m@ 628

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

initial load of FOIAVistA 6/30/08 version

File size: 5.0 KB
Line 
1ORRCDPT1 ;SLC/MKB - Patient List for Nursing Dashboard ; 19 Sept 2003 10:10 AM
2 ;;1.0;CARE MANAGEMENT;**5**;Jul 15, 2003;Build 4
3 ;
4EN(ORY,ORUSR,ORLST) ; -- Return each patient in ORLSTs for ORUSR
5 ; where ORLST(#) = <list-type>:<list-ID>:<clinic start>:<clinic stop>
6 ; in @ORY@(#) = "Patient=<dfn>^<name>^<ssn>^<dob>^<age>"
7 ; = "Result=ORR:##^ORR:##^...^*ORR:##"
8 ; = "Task=TSK:##^TSK:##^...^*TSK:##"
9 ; = "Event=VST:ID^VST:ID^...^VST:ID"
10 ; = "Unverified=ORV:##^...^ORV:##"
11 ; = "Nursing=ORN:##^...^!ORN:##"
12 ; = "Vital=VIT:ID^...^*VIT:ID"
13 ; = "Error=^<error description>"
14 ; RPC = ORRC NURS DASHBD PATIENTS
15 ;
16 ;
17 K ^TMP($J,"ORRCPTS"),^TMP($J,"ORRCY")
18 N ORI,ORX,X,ORID,ORBEG,OREND,ORTN,ORPAT,ORJ,PAT,ORDMIN,ORDMAX,ERRI
19 N ORSRV,FROM
20 S ORSRV=$G(^VA(200,DUZ,5)) I +ORSRV>0 S ORSRV=$P(ORSRV,U)
21 S FROM=$$GET^XPAR("USR^SRV.`"_+$G(ORSRV),"ORLP DEFAULT LIST SOURCE",1,"Q")
22 S ORUSR=+$G(ORUSR),ERRI=0 D PARAMS
23 S ORI=0 F S ORI=$O(ORLST(ORI)) Q:ORI<1 S ORX=$G(ORLST(ORI)) D
24 . S X=$$UP^XLFSTR($P(ORX,":")),ORID=+$P(ORX,":",2) D Q:'$G(ORPAT(1))
25 .. I X="X" D DEFLIST^ORQPTQ11(.ORPAT) D:$G(FROM)="M" Q
26 ... S ORJ=0 F S ORJ=$O(^TMP("OR",$J,"PATIENTS",ORJ)) Q:ORJ<1 S PAT=+$G(^(ORJ,0)),ORPAT(ORJ)=PAT
27 .. I X="T" D TEAMPTS^ORQPTQ1(.ORPAT,ORID) Q
28 .. S ORTN=$S(X="P":"PROV",X="S":"SPEC",X="W":"WARD",X="C":"CLIN",1:"") Q:'$L(ORTN)
29 .. I X'="C" S ORTN=ORTN_"PTS^ORQPTQ2(.ORPAT,ORID)" D @ORTN Q
30 .. S ORBEG=$P(ORX,":",3),OREND=$P(ORX,":",4)
31 .. S ORTN=ORTN_"PTS^ORQPTQ2(.ORPAT,ORID,ORBEG,OREND)" D @ORTN
32 .. I $D(ORPAT(1)),'+$G(ORPAT(1)),ORPAT(1)'="^No appointments." S ERRI=ERRI+1,^TMP($J,"ORRCDPT1_ERROR",ERRI)=ORPAT(1)
33 . S ORJ=0 F S ORJ=$O(ORPAT(ORJ)) Q:ORJ<1 S PAT=+$G(ORPAT(ORJ)) D
34 .. Q:$D(^TMP($J,"ORRCY",PAT)) ;already processed
35 .. ; build ^TMP($J,"ORRCY",DFN,"<type>",ID)=* or null:
36 .. D RSLT,TASK,EVNT,UNVR,TEXT,VITL
37 .. S ^TMP($J,"ORRCY",PAT)="" ;return all pts on list
38 I $D(^TMP($J,"ORRCY")) D FORMAT
39 I $D(^TMP($J,"ORRCDPT1_ERROR")) D ERROR(.ORY)
40 K ^TMP($J,"ORRCY"),^TMP($J,"ORRCDPT1_ERROR")
41 Q
42 ;
43ERROR(ORY) ;Process errors to be returned
44 N I,J S I=0,J=0
45 I '$D(ORY) S ORY=$$GETRET
46 F S I=$O(@ORY@(I)) Q:I'>0 S J=I
47 S I=0
48 F S I=$O(^TMP($J,"ORRCDPT1_ERROR",I)) Q:I'>0 S J=J+1,@ORY@(J)="Error="_^TMP($J,"ORRCDPT1_ERROR",I)
49 Q
50 ;
51PARAMS ; -- Return date range parameters ORDMIN(type),ORDMAX(type) for ORUSR
52 N SERV,ORX,X,Y,%DT S SERV=+$G(^VA(200,ORUSR,5))
53 F ORX="RESULT","EVENT","TEXT ORDER","UNVERIFIED","VITALS" D
54 . S X=$$GET^XPAR("ALL^USR.`"_ORUSR_"^SRV.`"_SERV,"ORRC NURSE "_ORX_" DATE MIN"),%DT="TX"
55 . D ^%DT S ORDMIN(ORX)=$S(Y>0:Y,1:"")
56 . S X=$$GET^XPAR("ALL^USR.`"_ORUSR_"^SRV.`"_SERV,"ORRC NURSE "_ORX_" DATE MAX"),%DT="TX"
57 . D ^%DT S ORDMAX(ORX)=$S(Y>0:Y,1:"")
58 Q
59 ;
60RSLT ; -- find PAT's results unack'd by ORUSR
61 N ORACK,ORDBEG,ORDEND
62 S ORDBEG=ORDMIN("RESULT"),ORDEND=ORDMAX("RESULT")
63 D IDS^ORRCACK(.ORACK,PAT,ORUSR,ORDBEG,ORDEND)
64 M ^TMP($J,"ORRCY",PAT,"R")=@ORACK@(PAT) K @ORACK
65 Q
66 ;
67TASK ; -- find PAT's due tasks
68 N ORTSK
69 D IDS^ORRCTSK(.ORTSK,PAT)
70 M ^TMP($J,"ORRCY",PAT,"T")=@ORTSK@(PAT) K @ORTSK
71 Q
72 ;
73EVNT ; -- find PAT's appointments
74 N OREVT,ORABEG,ORAEND
75 S ORABEG=ORDMIN("EVENT"),ORAEND=ORDMAX("EVENT")
76 D IDS^ORRCEVT(.OREVT,PAT,ORABEG,ORAEND)
77 M ^TMP($J,"ORRCY",PAT,"E")=@OREVT@(PAT) K @OREVT
78 Q
79 ;
80UNVR ; -- find PAT's unverified orders, by nursing
81 N ORDER,ORDBEG,ORDEND
82 S ORDBEG=ORDMIN("UNVERIFIED"),ORDEND=ORDMAX("UNVERIFIED")
83 D IDS^ORRCOR(.ORDER,PAT,"ORV",ORDBEG,ORDEND)
84 M ^TMP($J,"ORRCY",PAT,"U")=@ORDER@(PAT) K @ORDER
85 Q
86 ;
87TEXT ; -- find patients with active generic text orders
88 N ORDER,ORDBEG,ORDEND
89 S ORDBEG=ORDMIN("TEXT ORDER"),ORDEND=ORDMAX("TEXT ORDER")
90 D IDS^ORRCOR(.ORDER,PAT,"ORN",ORDBEG,ORDEND)
91 M ^TMP($J,"ORRCY",PAT,"N")=@ORDER@(PAT) K @ORDER
92 Q
93 ;
94VITL ; -- find patients with recent vitals
95 N ORVIT,ORVBEG,ORVEND
96 S ORVBEG=ORDMIN("VITALS"),ORVEND=ORDMAX("VITALS")
97 D IDS^ORRCVIT(.ORVIT,PAT,ORVBEG,ORVEND)
98 M ^TMP($J,"ORRCY",PAT,"V")=@ORVIT@(PAT) K @ORVIT
99 Q
100 ;
101FORMAT ; -- Format return array ^TMP($J,"ORRCPTS") from temp array ^TMP($J,"ORRCY")
102 N ORPT,ORN,DFN,VADM,VA,VAERR
103 S ORY=$$GETRET
104 S (ORPT,ORN)=0 F S ORPT=$O(^TMP($J,"ORRCY",ORPT)) Q:ORPT<1 D
105 . S DFN=ORPT D DEM^VADPT
106 . S ORN=ORN+1,@ORY@(ORN)="Patient="_DFN_U_VADM(1)_U_VA("PID")_U_$$FMTHL7^XLFDT(+VADM(3))_U_VADM(4)
107 . I $D(^TMP($J,"ORRCY",ORPT,"R")) D ADD("Result")
108 . I $D(^TMP($J,"ORRCY",ORPT,"T")) D ADD("Task")
109 . I $D(^TMP($J,"ORRCY",ORPT,"E")) D ADD("Event")
110 . I $D(^TMP($J,"ORRCY",ORPT,"U")) D ADD("Unverified")
111 . I $D(^TMP($J,"ORRCY",ORPT,"N")) D ADD("Nursing")
112 . I $D(^TMP($J,"ORRCY",ORPT,"V")) D ADD("Vital")
113 Q
114 ;
115ADD(TYPE) ; -- Add item IDs from ^TMP($J,"ORRCY",PAT,<TYPE>) into return array
116 N ORX,ORSUB,ORID,X,ORU
117 S ORX=TYPE_"=",ORSUB=$E(TYPE),ORID="",ORU=""
118 F S ORID=$O(^TMP($J,"ORRCY",ORPT,ORSUB,ORID)) Q:ORID="" S X=$G(^(ORID))_ORID D
119 . I $L(ORX)+$L(X)>254 S ORN=ORN+1,@ORY@(ORN)=ORX,ORX=TYPE_"=",ORU=""
120 . S ORX=ORX_ORU_X,ORU=U
121 S ORN=ORN+1,@ORY@(ORN)=ORX
122 Q
123 ;
124GETRET() ;Returns the return variable pointer
125 Q $NA(^TMP($J,"ORRCPTS"))
126 ;
Note: See TracBrowser for help on using the repository browser.