| 1 | ORQQPL3 ; 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 |  ;
 | 
|---|
| 6 | PROBL(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 |  ;
 | 
|---|
| 24 | LIST(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 |  ;
 | 
|---|
| 89 | DELLIST(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 |  ;
 | 
|---|
| 136 | GETSP() ; 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 |  ;
 | 
|---|
| 146 | CAT(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 |  ;
 | 
|---|
| 165 | GETUSLST(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 |  ;
 | 
|---|
| 175 | PROB(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 |  ;
 | 
|---|
| 202 | ICDCODE(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 |  ;
 | 
|---|
| 211 | GETRPRV(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 |  ;
 | 
|---|
| 225 | GETCLIN(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 |  ;
 | 
|---|
| 235 | GETSRVC(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
 | 
|---|