1 | ORRCDPT ;SLC/MKB - Patient List for Physician Dashboard ; 19 Sept 2003 10:09 AM
|
---|
2 | ;;1.0;CARE MANAGEMENT;**5**;Jul 15, 2003;Build 4
|
---|
3 | ;
|
---|
4 | MAIN(ORY,USER,TYPE,LIST) ; -- Return patient list for dashboard
|
---|
5 | ; where USER = pointer to #200
|
---|
6 | ; TYPE = (C)linician or (N)urse view
|
---|
7 | ; LIST(#) = <list-type>:<list-ID>:<clinic start>:<clinic stop>
|
---|
8 | ; RPC = ORRC DASHBOARD PATIENTS
|
---|
9 | ;
|
---|
10 | D EXPDATES(.LIST) ;expand dates
|
---|
11 | S USER=+$G(USER),TYPE=$$UP^XLFSTR($G(TYPE))
|
---|
12 | I TYPE="N" D EN^ORRCDPT1(.ORY,USER,.LIST) Q
|
---|
13 | I $O(LIST(0)) D EN1(.ORY,USER,.LIST) Q
|
---|
14 | D EN(.ORY,USER)
|
---|
15 | Q
|
---|
16 | ;
|
---|
17 | EN(ORY,ORUSR) ; -- Return each patient to list on dashboard for ORUSR
|
---|
18 | ; in @ORY@(#) = "Patient=<dfn>^<name>^<ssn>^<dob>^<age>"
|
---|
19 | ; = "Result=ORR:##^ORR:##^...^*ORR:##"
|
---|
20 | ; = "Task=TSK:##^TSK:##^...^*TSK:##"
|
---|
21 | ; = "Event=VST:ID^VST:ID^...^VST:ID"
|
---|
22 | ; = "Unsigned=ORD:##^...^ORD:##^DOC:##^...^DOC:##"
|
---|
23 | ; = "Notifications=1"
|
---|
24 | ; RPC = ORRC PHY DASHBD PATIENTS
|
---|
25 | S ORUSR=+$G(ORUSR) K ^TMP($J,"ORRCPTS"),^TMP($J,"ORRCY"),^TMP($J,"ORRCLST")
|
---|
26 | D RSLT,TASK,EVNT,SIGN ;build ^TMP($J,"ORRCY",DFN,"<type>",ID)=* or null
|
---|
27 | I $D(^TMP($J,"ORRCY")) D FORMAT
|
---|
28 | K ^TMP($J,"ORRCY")
|
---|
29 | Q
|
---|
30 | ;
|
---|
31 | EN1(ORY,ORUSR,ORLST) ; -- Return patients on ORLST for ORUSR's dashboard
|
---|
32 | ; in @ORY@(#) = "Patient=<dfn>^<name>^<ssn>^<dob>^<age>"
|
---|
33 | ; = "Result=ORR:##^ORR:##^...^*ORR:##"
|
---|
34 | ; = "Task=TSK:##^TSK:##^...^*TSK:##"
|
---|
35 | ; = "Event=VST:ID^VST:ID^...^VST:ID"
|
---|
36 | ; = "Unsigned=ORD:##^...^ORD:##^DOC:##^...^DOC:##"
|
---|
37 | ; = "Error=^<error description>"
|
---|
38 | N ORI,ORX,X,ORID,ORPAT,ORTN,ORBEG,OREND,ORJ,PAT,ERRI S ORUSR=+$G(ORUSR),ERRI=0
|
---|
39 | K ^TMP($J,"ORRCY"),^TMP($J,"ORRCNOTF"),^TMP($J,"ORRCPTS")
|
---|
40 | S ^TMP($J,"ORRCLST")=""
|
---|
41 | N ORSRV,FROM
|
---|
42 | S ORSRV=$G(^VA(200,DUZ,5)) I +ORSRV>0 S ORSRV=$P(ORSRV,U)
|
---|
43 | S FROM=$$GET^XPAR("USR^SRV.`"_+$G(ORSRV),"ORLP DEFAULT LIST SOURCE",1,"Q")
|
---|
44 | S ORI=0 F S ORI=$O(ORLST(ORI)) Q:ORI<1 S ORX=$G(ORLST(ORI)) D
|
---|
45 | . S X=$$UP^XLFSTR($P(ORX,":")),ORID=+$P(ORX,":",2) D Q:'$G(ORPAT(1))
|
---|
46 | .. I X="X" D DEFLIST^ORQPTQ11(.ORPAT) D:$G(FROM)="M" Q
|
---|
47 | ... S ORJ=0 F S ORJ=$O(^TMP("OR",$J,"PATIENTS",ORJ)) Q:ORJ<1 S PAT=+$G(^(ORJ,0)),^TMP($J,"ORRCY",PAT)=""
|
---|
48 | .. I X="T" D TEAMPTS^ORQPTQ1(.ORPAT,ORID) Q
|
---|
49 | .. S ORTN=$S(X="P":"PROV",X="S":"SPEC",X="W":"WARD",X="C":"CLIN",1:"") Q:'$L(ORTN)
|
---|
50 | .. I X'="C" S ORTN=ORTN_"PTS^ORQPTQ2(.ORPAT,ORID)" D @ORTN Q
|
---|
51 | .. S ORBEG=$P(ORX,":",3),OREND=$P(ORX,":",4)
|
---|
52 | .. D CLINPTS^ORQPTQ2(.ORPAT,ORID,ORBEG,OREND)
|
---|
53 | .. I $D(ORPAT(1)),'+$G(ORPAT(1)),ORPAT(1)'="^No appointments." S ERRI=ERRI+1,^TMP($J,"ORRCDPT_ERROR",ERRI)=ORPAT(1)
|
---|
54 | . S ORJ=0 F S ORJ=$O(ORPAT(ORJ)) Q:ORJ<1 S PAT=+$G(ORPAT(ORJ)),^TMP($J,"ORRCY",PAT)=""
|
---|
55 | I $D(^TMP($J,"ORRCY")) D ;there are patients on selected list(s)
|
---|
56 | . ; build ^TMP($J,"ORRCY",DFN,"<type>",ID)=* or null:
|
---|
57 | . D RSLT,TASK,EVNT,SIGN,FORMAT
|
---|
58 | D ERROR(.ORY)
|
---|
59 | K ^TMP($J,"ORRCY"),^TMP($J,"ORRCNOTF"),^TMP($J,"ORRCLST"),^TMP($J,"ORRCDPT_ERROR")
|
---|
60 | Q
|
---|
61 | ;
|
---|
62 | ERROR(ORY) ; -- process errors
|
---|
63 | I '$D(^TMP($J,"ORRCDPT_ERROR")) Q
|
---|
64 | N I,J S I=0,J=0
|
---|
65 | I '$D(ORY) S ORY=$$GETRET
|
---|
66 | F S I=$O(@ORY@(I)) Q:I'>0 S J=I
|
---|
67 | S I=0
|
---|
68 | F S I=$O(^TMP($J,"ORRCDPT_ERROR",I)) Q:I'>0 S J=J+1,@ORY@(J)="Error="_^TMP($J,"ORRCDPT_ERROR",I)
|
---|
69 | Q
|
---|
70 | ;
|
---|
71 | RSLT ; -- find patients with unack'd results for ORUSR's orders
|
---|
72 | N ORACK,PAT
|
---|
73 | D PATS^ORRCACK(.ORACK,ORUSR) S PAT=0
|
---|
74 | F S PAT=+$O(@ORACK@(PAT)) Q:PAT<1 M ^TMP($J,"ORRCY",PAT,"R")=@ORACK@(PAT)
|
---|
75 | K @ORACK
|
---|
76 | Q
|
---|
77 | ;
|
---|
78 | TASK ; -- find patients with tasks not complete
|
---|
79 | N ORTSK,PAT
|
---|
80 | D PATS^ORRCTSK(.ORTSK,ORUSR) S PAT=0
|
---|
81 | F S PAT=+$O(@ORTSK@(PAT)) Q:PAT<1 M ^TMP($J,"ORRCY",PAT,"T")=@ORTSK@(PAT)
|
---|
82 | K @ORTSK
|
---|
83 | Q
|
---|
84 | ;
|
---|
85 | EVNT ; -- find patients that ORUSR has outstanding ADT alerts for
|
---|
86 | N OREVT,PAT
|
---|
87 | D PATS^ORRCEVT(.OREVT,ORUSR) S PAT=0
|
---|
88 | F S PAT=+$O(@OREVT@(PAT)) Q:PAT<1 M ^TMP($J,"ORRCY",PAT,"E")=@OREVT@(PAT)
|
---|
89 | K @OREVT
|
---|
90 | Q
|
---|
91 | ;
|
---|
92 | SIGN ; -- find patients that have orders or notes ORUSR needs to sign
|
---|
93 | N ORDER,ORDOC,PAT
|
---|
94 | ;D PTUNS^ORRCOR(.ORDER,ORUSR) S PAT=0
|
---|
95 | ;F S PAT=+$O(ORDER(PAT)) Q:PAT<1 M ^TMP($J,"ORRCY",PAT,"U")=ORDER(PAT)
|
---|
96 | D GETPTUNS^ORRCTIU(.ORDOC,ORUSR) S PAT=0
|
---|
97 | F S PAT=+$O(@ORDOC@(PAT)) Q:PAT<1 M ^TMP($J,"ORRCY",PAT,"U")=@ORDOC@(PAT)
|
---|
98 | K @ORDOC
|
---|
99 | Q
|
---|
100 | ;
|
---|
101 | FORMAT ; -- 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("Unsigned")
|
---|
111 | . I $G(^TMP($J,"ORRCNOTF",ORPT)) S ORN=ORN+1,@ORY@(ORN)="Notifications=1"
|
---|
112 | Q
|
---|
113 | ;
|
---|
114 | GETRET() ;Returns the return variable pointer
|
---|
115 | Q $NA(^TMP($J,"ORRCPTS"))
|
---|
116 | ;
|
---|
117 | ADD(TYPE) ; -- Add item IDs from ^TMP($J,"ORRCY",PAT,<TYPE>) into return array
|
---|
118 | N ORX,ORSUB,ORID,X,ORU
|
---|
119 | S ORX=TYPE_"=",ORSUB=$E(TYPE),ORID="",ORU=""
|
---|
120 | F S ORID=$O(^TMP($J,"ORRCY",ORPT,ORSUB,ORID)) Q:ORID="" S X=$G(^(ORID))_ORID D
|
---|
121 | . I $L(ORX)+$L(X)>254 S ORN=ORN+1,@ORY@(ORN)=ORX,ORX=TYPE_"=",ORU=""
|
---|
122 | . S ORX=ORX_ORU_X,ORU=U
|
---|
123 | S ORN=ORN+1,@ORY@(ORN)=ORX
|
---|
124 | Q
|
---|
125 | ;
|
---|
126 | EXPDATES(LIST) ;Expand dates for clinic appointments, if they need to be expanded. These would be a year or quarter indicators on clinic appt lists.
|
---|
127 | ;Ex. YC = current year, YC-4 = current year - 4, etc.
|
---|
128 | N I,RANGE S I=0
|
---|
129 | F S I=$O(LIST(I)) Q:I'>0 D
|
---|
130 | .I $P(LIST(I),":",1)="c",$L(LIST(I),":")=3 D
|
---|
131 | ..S RANGE=$$RNG2FM^ORRHCU($P(LIST(I),":",3))
|
---|
132 | ..S $P(LIST(I),":",3)=$P(RANGE,":",1)
|
---|
133 | ..S $P(LIST(I),":",4)=$P(RANGE,":",2)
|
---|
134 | Q
|
---|
135 | ;
|
---|