source: WorldVistAEHR/trunk/r/ORDER_ENTRY_RESULTS_REPORTING-OR-OCX--ORRC--ORRJ/ORQQPL3.m@ 1226

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

revised back to 6/30/08 version

File size: 8.0 KB
Line 
1ORQQPL3 ; ALB/PDR/REV ; Problem List RPC's ; 8-OCT-1998 09:08:49.29
2 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**10,148,173**;Dec 17, 1997
3 ;
4 ;---------------- LIST PATIENT PROBLEMS ------------------------
5 ;
6PROBL(ROOT,DFN,CONTEXT) ; GET LIST OF PATIENT PROBLEMS
7 N DIWL,DIWR,DIWF
8 N ST,ORI,ORX
9 S (LCNT,NUM)=0
10 S DIWL=1,DIWR=48,DIWF="C48"
11 S CONTEXT=";;"_$G(CONTEXT)
12 I CONTEXT=";;" S CONTEXT=";;A"
13 S ST=$P(CONTEXT,";",3)
14 ;
15 I ST="R" D DELLIST(.ROOT,+DFN) ; show deleted only
16 I ST'="R" D LIST(.ROOT,+DFN,ST) ; show others - don't trust ELSE here
17 ;
18 I ROOT(0)<1 D
19 . S LCNT=1
20 . S ROOT(1)=" "_$$PAD^ORCHTAB("No data available.",49)_"|"
21 Q
22 ;
23 ;
24LIST(GMPL,GMPDFN,GMPSTAT) ; -- Returns list of problems for patient GMPDFN
25 ; in GMPL(#)=ifn^status^description^ICD^onset^last modified^SC^SpExp^Condition^Loc^
26 ; loc.type^prov^service
27 ; & GMPL(0)=number of problems returned
28 ; This is virtually same as LIST^GMPLUTL2 except that it appends the
29 ; condition - T)ranscribed or P)ermanent,location,loc type,provider, service.
30 ;
31 N I,IFN,CNT,GMPL0,GMPL1,SP,ST,NUM,ONSET,ICD,LASTMOD,PRIO,DTREC
32 N SC,ORLIST,ORVIEW,GMPARAM,ORTOTAL,LIN,LOC,LT,PROV,SERV,HASCMT
33 N SCCOND,AO,IR,ENV,HNC,MST,ORICD186,INACT
34 Q:$G(GMPDFN)'>0
35 S CNT=0,SP=""
36 S GMPARAM("QUIET")=1
37 S GMPARAM("REV")=$P($G(^GMPL(125.99,1,0)),U,5)="R"
38 S ORVIEW("ACT")=GMPSTAT
39 S ORVIEW("PROV")=0
40 S ORVIEW("VIEW")=""
41 S ORICD186=$$PATCH^XPDUTL("ICD*18.0*6")
42 ;
43 D GETPLIST^GMPLMGR1(.ORLIST,.ORTOTAL,.ORVIEW)
44 ;
45 F NUM=0:0 S NUM=$O(ORLIST(NUM)) Q:NUM'>0 D
46 . S IFN=+ORLIST(NUM) Q:IFN'>0
47 . S INACT=""
48 . S GMPL0=$G(^AUPNPROB(IFN,0))
49 . S GMPL1=$G(^AUPNPROB(IFN,1))
50 . S HASCMT=($D(^AUPNPROB(IFN,11,0))>0)
51 . S CNT=CNT+1
52 . I +ORICD186 D
53 . . S ICD=$$CODEC^ICDCODE(+GMPL0)
54 . . I '+$$STATCHK^ICDAPIU(ICD,DT) S INACT="#"
55 . E D
56 . . S ICD=$P($G(^ICD9(+GMPL0,0)),U)
57 . S LASTMOD=$P(GMPL0,U,3)
58 . S ST=$P(GMPL0,U,12)
59 . S ONSET=$P(GMPL0,U,13)
60 . S SC=$S(+$P(GMPL1,U,10):"SC",$P(GMPL1,U,10)=0:"NSC",1:"")
61 . S AO=$S(+$P(GMPL1,U,11):"/AO",1:"")
62 . S IR=$S(+$P(GMPL1,U,12):"/IR",1:"")
63 . S ENV=$S(+$P(GMPL1,U,13):"/EC",1:"")
64 . S HNC=$S(+$P(GMPL1,U,15):"/HNC",1:"")
65 . S MST=$S(+$P(GMPL1,U,16):"/MST",1:"")
66 . S SCCOND=SC_AO_IR_ENV_HNC_MST
67 . S LOC=$P(GMPL1,U,8)
68 . S DTREC=$P(GMPL1,U,9)
69 . S LT=""
70 . I LOC'="" S LT=$P($G(^SC(LOC,0)),"^",3),LOC=LOC_";"_$P($G(^SC(LOC,0)),U,1)
71 . S PROV=$P(GMPL1,U,5) ; responsible provider
72 . I PROV'="" S PROV=PROV_";"_$P($G(^VA(200,PROV,0)),U,1)
73 . S SERV=$P(GMPL1,U,6)
74 . I SERV=0 S SERV="" ; not sure how it gets set to 0, but need consistency in GUI
75 . I SERV'="" S SERV=SERV_";"_$P($G(^DIC(49,SERV,0)),U,1)
76 . S SP=""
77 . F I=11,12,13 S:$P(GMPL1,U,I) SP=SP_$S(I=11:"A",I=12:"I",1:"P")
78 . S PRIO=$P(GMPL1,U,14)
79 . S LIN=IFN_U_ST_U_$$PROBTEXT^GMPLX(IFN)_U_ICD_U_ONSET
80 . S LIN=LIN_U_LASTMOD_U_SC_U_SP_U_$P(GMPL1,U,2)
81 . S LIN=LIN_U_LOC_U_LT_U_PROV_U_SERV_U_PRIO_U_HASCMT_U_DTREC_U_SCCOND_U_INACT
82 . S GMPL(CNT)=LIN
83 S GMPL(0)=CNT
84 Q
85 ;
86 ;
87 ;------------------------------------- GET LIST OF DELETED PROBLEMS -----------------------------
88 ;
89DELLIST(RETURN,GMPDFN) ; GET LIST OF DELETED PROBLEMS
90 ; see GETPLIST^GMPLMGR1 and LIST^GMPUTL2
91 N S,IFN,I,L0,L1,ST,TXT,ICD,ONSET,MOD,SC,SP,LOC,LT,PROV,SERV,PRIO,HASCMT,DTREC
92 N SCCOND,AO,IR,ENV,HNC,MST,ORICD186,INACT
93 S I=0,S=""
94 S ORICD186=$$PATCH^XPDUTL("ICD*18.0*6")
95 F S S=$O(^AUPNPROB("ACTIVE",GMPDFN,S)) Q:S="" D
96 . S IFN=""
97 . F S IFN=$O(^AUPNPROB("ACTIVE",+GMPDFN,S,IFN)) Q:IFN="" D
98 .. I $P($G(^AUPNPROB(IFN,1)),U,2)="H" D
99 ... S L0=$G(^AUPNPROB(IFN,0))
100 ... Q:L0=""
101 ... S INACT=""
102 ... S L1=$G(^AUPNPROB(IFN,1))
103 ... S ST=$P(L0,U,12)
104 ... S TXT=$$PROBTEXT^GMPLX(IFN)
105 ... I +ORICD186 D
106 ... . S ICD=$$CODEC^ICDCODE(+L0)
107 ... . I '+$$STATCHK^ICDAPIU(ICD,DT) S INACT="#"
108 ... E D
109 ... . S ICD=$P($G(^ICD9(+L0,0)),U)
110 ... S ONSET=$P(L0,U,13)
111 ... S MOD=$P(L0,U,3)
112 ... S SC=$S(+$P(L1,U,10):"SC",$P(L1,U,10)=0:"NSC",1:"")
113 ... S AO=$S(+$P(L1,U,11):"/AO",1:"")
114 ... S IR=$S(+$P(L1,U,12):"/IR",1:"")
115 ... S ENV=$S(+$P(L1,U,13):"/EC",1:"")
116 ... S HNC=$S(+$P(L1,U,15):"/HNC",1:"")
117 ... S MST=$S(+$P(L1,U,16):"/MST",1:"")
118 ... S SCCOND=SC_AO_IR_ENV_HNC_MST
119 ... S SP=$$GETSP
120 ... S LOC=$P(L1,U,8)
121 ... S LT=""
122 ... I LOC'="" S LT=$P($G(^SC(LOC,0)),"^",3)
123 ... S PROV=$P(L1,U,5) ; responsible provider
124 ... S SERV=$P(L1,U,6)
125 ... S PRIO=$P(L1,U,14)
126 ... S HASCMT=($D(^AUPNPROB(IFN,11,0))>0)
127 ... S DTREC=$P(L1,U,9)
128 ... S I=I+1
129 ... S RETURN(I)=IFN_U_ST_U_TXT_U_ICD_U_ONSET
130 ... S RETURN(I)=RETURN(I)_U_MOD_U_SC_U_SP_U_$P(L1,U,2)
131 ... S RETURN(I)=RETURN(I)_U_LOC_U_LT_U_PROV_U_SERV
132 ... S RETURN(I)=RETURN(I)_U_PRIO_U_HASCMT_U_DTREC_U_SCCOND_U_INACT
133 S RETURN(0)=I
134 Q
135 ;
136GETSP() ; GET EXPOSURES
137 N I
138 S SP=""
139 F I=11,12,13 S:$P(L1,U,I) SP=SP_$S(I=11:"A",I=12:"I",1:"P")
140 Q SP
141 ;
142 ; adapted from ^GMPLBLD3 ;9/96
143 ;
144 ; ----------------------- GET USER PROBLEM CATEGORIES --------------
145 ;
146CAT(TMP,ORDUZ,CLIN) ; Get user category list
147 N GSEQ,GCNT,GROUP,HDR,IFN,LCNT,ITEM,TG,GMPLSLST
148 ; S TG=$NAME(^TMP("GMPLMENU",$J)) ; put list in global for testing
149 S TG=$NAME(TMP) ; put list in local
150 K @TG
151 S (GSEQ,GCNT,LCNT)=0
152 ;
153 S GMPLSLST=$$GETUSLST(DUZ,CLIN) ; get approp list for user
154 ; Build multiple of category\problems
155 ; Iterate categories
156 F S GSEQ=$O(^GMPL(125.1,"C",+GMPLSLST,GSEQ)) Q:GSEQ'>0 D
157 . S IFN=$O(^GMPL(125.1,"C",+GMPLSLST,GSEQ,0)) Q:IFN'>0
158 . S ITEM=$G(^GMPL(125.1,IFN,0))
159 . S GROUP=+$P(ITEM,U,3)
160 . S HDR=GROUP_U_$P(ITEM,U,4,5)
161 . S GCNT=GCNT+1
162 . S @TG@(GCNT)=HDR ; put category into temp global
163 Q
164 ;
165GETUSLST(ORDUZ,CLIN) ; GET AN APPROPRIATE CATEGORY LIST FOR THE USER
166 N GMPLSLST
167 S GMPLSLST=$P($G(^VA(200,DUZ,125)),U,2)
168 ;I 'GMPLSLST D
169 I 'GMPLSLST,CLIN,$D(^GMPL(125,"C",+CLIN)) S GMPLSLST=$O(^(+CLIN,0))
170 ;. S GMPLSLST=$O(^VA(200,DUZ,+CLIN,0)) ;$O(^(+CLIN,0))
171 Q GMPLSLST
172 ;
173 ;----------------------- USER PROBLEM LIST --------------------------
174 ;
175PROB(TMP,GROUP) ; Get user problem list for given group
176 N PSEQ,PCNT,IFN,ITEM,TG,CODE,TEXT,ORICD186
177 ; S TG=$NAME(^TMP("GMPLMENU",$J)) ; put list in global for testing
178 S TG=$NAME(TMP) ; put list in local
179 K @TG
180 S LCNT=0
181 S ORICD186=$$PATCH^XPDUTL("ICD*18.0*6")
182 ;
183 ; iterate through problems in category
184 S (PSEQ,PCNT)=0
185 F S PSEQ=$O(^GMPL(125.12,"C",GROUP,PSEQ)) Q:PSEQ'>0 D
186 . S IFN=$O(^GMPL(125.12,"C",GROUP,PSEQ,0)) Q:IFN'>0
187 . S ITEM=$G(^GMPL(125.12,IFN,0))
188 . S TEXT=$P(ITEM,U,4)
189 . ; SEE DD for GMPL(125.12,4 :
190 . ; "...code which is to be displayed... generally assumed to be ICD"
191 . S CODE=$P(ITEM,U,5)
192 . I +ORICD186,'+$$STATCHK^ICDAPIU(CODE,DT) Q
193 . S PCNT=PCNT+1
194 . ; RETURN:
195 . ; PROBLEM^DISPLAY TEXT^CODE^CODE IFN
196 . I +ORICD186 D
197 . . S @TG@(PCNT)=$P(ITEM,U,3,5)_U_$$CODEN^ICDCODE(CODE,80)
198 . E D
199 . . S @TG@(PCNT)=$P(ITEM,U,3,5)_U_$$ICDCODE(CODE)
200 Q
201 ;
202ICDCODE(COD) ; RETURN INTERNAL ICD FOR EXTERNAL CODE (obsolete after CSV patches released - RV)
203 N CODIEN
204 I COD="" Q ""
205 S CODIEN=+$O(^ICD9("AB",$P(COD,U)_" ",0))
206 S:CODIEN'>0 CODIEN=+$O(^ICD9("AB",$P(COD,U)_"0 ",0))
207 Q CODIEN
208 ;
209 ;------------------ Filter Providers ---------------------
210 ;
211GETRPRV(RETURN,INP) ; GET LIST OF RESPONSIBLE PROVIDERS FROM PRBLM LIST
212 ; RETURN - aa list of responsible providers from which to select for filtering
213 ; INP - array of problem list providers to select from
214 ;
215 N S
216 S S=""
217 F I=1:1 S S=$O(INP(S)) Q:S="" D
218 . I INP(S)'="",$G(^VA(200,INP(S),0))'="" D Q ; get next
219 .. S RETURN(I)=INP(S)_U_$P(^VA(200,INP(S),0),U)
220 S RETURN(0)="-1"_U_"<None recorded>" ; return empty provider
221 Q
222 ;
223 ;---------------------------------------------------- GET FILTERED CLINIC LIST ------------------------
224 ;
225GETCLIN(RETURN,INP) ; Get FILTERED LIST OF CLINICS
226 ; RETURN NAMES FOR LIST OF CLINICS PASSED IN
227 N I,S
228 S S=""
229 F I=1:1 S S=$O(INP(S)) Q:S="" D
230 . I INP(S)'="",$G(^SC(INP(S),0))'="" D Q ; get next
231 .. S RETURN(I)=INP(S)_U_$P(^SC(INP(S),0),U,1)
232 ;. S RETURN(I)="-1"_U_"None" ; return empty location
233 Q
234 ;
235GETSRVC(RETURN,INP) ; GET FILTERED LIST OF INPATIENT SERVICES
236 ; RETURN NAMES FOR LIST OF IEN PASSED IN
237 N I,S
238 S S=""
239 F I=1:1 S S=$O(INP(S)) Q:S="" D
240 . I INP(S)'="",$G(^DIC(49,INP(S),0))'="" D Q ; get next
241 .. S RETURN(I)=INP(S)_U_$P(^DIC(49,INP(S),0),U,1)
242 ;. S RETURN(I)="-1"_U_"None" ; return empty service
243 Q
Note: See TracBrowser for help on using the repository browser.