| 1 | TIULC1 ; SLC/JER - More computational functions ;11/01/03
 | 
|---|
| 2 |  ;;1.0;TEXT INTEGRATION UTILITIES;**3,4,40,49,100,131,113,112**;Jun 20, 1997
 | 
|---|
| 3 |  ; External References
 | 
|---|
| 4 |  ; DBIA 2324  $$ISA^USRLM
 | 
|---|
| 5 |  ; Any patch which makes ANY changes to this rtn must include a
 | 
|---|
| 6 |  ;note in the patch desc reminding sites to update the Imaging
 | 
|---|
| 7 |  ;Gateway.  See IA # 3622.
 | 
|---|
| 8 |  ; IN ADDITION, if changes are made to components used by Imaging, 
 | 
|---|
| 9 |  ;namely PNAME, backward compatibility may not be enough. If
 | 
|---|
| 10 |  ;changes call additional rtns, TIU should consult with Imaging
 | 
|---|
| 11 |  ;on need to add additional rtns to list of TIU rtns copied for
 | 
|---|
| 12 |  ;Imaging Gateway.
 | 
|---|
| 13 |  ;                         ****
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 | ENCRYPT(X,X1,X2) ; Encrypt Text Strings
 | 
|---|
| 16 |  D EN^XUSHSHP
 | 
|---|
| 17 |  Q X
 | 
|---|
| 18 | DECRYPT(X,X1,X2) ; Decrypt Text Strings
 | 
|---|
| 19 |  D DE^XUSHSHP
 | 
|---|
| 20 |  Q X
 | 
|---|
| 21 | WHOSIGNS(DA) ; Evaluate who should be the expected signer
 | 
|---|
| 22 |  N Y,TIU12
 | 
|---|
| 23 |  S TIU12=$G(^TIU(8925,+DA,12))
 | 
|---|
| 24 |  I $P(TIU12,U,2)'=$P(TIU12,U,9) S Y=$P(TIU12,U,2)
 | 
|---|
| 25 |  E  S Y=$P(TIU12,U,9)
 | 
|---|
| 26 |  Q Y
 | 
|---|
| 27 | WHOCOSIG(DA) ; Evaluate who should be the expected cosigner
 | 
|---|
| 28 |  N Y,TIU12
 | 
|---|
| 29 |  S TIU12=$G(^TIU(8925,+DA,12))
 | 
|---|
| 30 |  I $P(TIU12,U,2)=$P(TIU12,U,9) D
 | 
|---|
| 31 |  . I $P(TIU12,U,8)]"" S Y="@"
 | 
|---|
| 32 |  . E  S Y=""
 | 
|---|
| 33 |  E  S Y=$P(TIU12,U,9)
 | 
|---|
| 34 |  Q Y
 | 
|---|
| 35 |  ;
 | 
|---|
| 36 | HASADDEN(DA,IDKIDFLG) ; Evaluate whether a given record has addenda
 | 
|---|
| 37 |  ; **100**:
 | 
|---|
| 38 |  ; If +IDKIDFLG, check interdisciplinary kids of DA, as well as DA.
 | 
|---|
| 39 |  N TIUI,TIUY,TIUJ,TIUK
 | 
|---|
| 40 |  S (TIUI,TIUJ,TIUY)=0
 | 
|---|
| 41 |  F  S TIUI=$O(^TIU(8925,"DAD",+DA,TIUI)) Q:+TIUI'>0  D  Q:TIUY
 | 
|---|
| 42 |  . I $P($G(^TIU(8925.1,+$G(^TIU(8925,+TIUI,0)),0)),U)["ADDENDUM" S TIUY=1
 | 
|---|
| 43 |  I TIUY!'$G(IDKIDFLG) G HASX
 | 
|---|
| 44 |  ;**100** Check ID kids for addenda:
 | 
|---|
| 45 |  F  S TIUJ=$O(^TIU(8925,"GDAD",+DA,TIUJ)) Q:+TIUJ'>0  D  Q:TIUY
 | 
|---|
| 46 |  . S TIUK=0
 | 
|---|
| 47 |  . F  S TIUK=$O(^TIU(8925,"DAD",TIUJ,TIUK)) Q:+TIUK'>0  D  Q:TIUY
 | 
|---|
| 48 |  . . I $P($G(^TIU(8925.1,+$G(^TIU(8925,+TIUK,0)),0)),U)["ADDENDUM" S TIUY=1
 | 
|---|
| 49 | HASX Q TIUY
 | 
|---|
| 50 |  ;
 | 
|---|
| 51 | ISADDNDM(DA) ; Evaluate whether a given record IS an addendum
 | 
|---|
| 52 |  N TIUY S TIUY=0
 | 
|---|
| 53 |  I $P($G(^TIU(8925.1,+$G(^TIU(8925,+DA,0)),0)),U)["ADDENDUM",+$P($G(^TIU(8925,+DA,0)),U,6)>0 S TIUY=1
 | 
|---|
| 54 |  Q TIUY
 | 
|---|
| 55 | PNAME(DA) ; Receives pointer to 8925.1, returns display name of
 | 
|---|
| 56 |  ; document class
 | 
|---|
| 57 |  N TIUY,TIUMOM S TIUMOM=0
 | 
|---|
| 58 |  I +$G(DA)'>0 Q "UNKNOWN"
 | 
|---|
| 59 |  S TIUMOM=$O(^TIU(8925.1,"AD",DA,TIUMOM))
 | 
|---|
| 60 |  I $P($G(^TIU(8925.1,+DA,0)),U,4)="CO" S TIUMOM=0
 | 
|---|
| 61 |  I +$P($G(^TIU(8925.1,+DA,0)),U,9)=0 S TIUMOM=0
 | 
|---|
| 62 |  I +TIUMOM>0  D
 | 
|---|
| 63 |  . S TIUY=$P($G(^TIU(8925.1,+TIUMOM,0)),U,3)
 | 
|---|
| 64 |  . I TIUY']"" S TIUY=$$MIXED^TIULS($P($G(^TIU(8925.1,+TIUMOM,0)),U))
 | 
|---|
| 65 |  I +TIUMOM'>0 D
 | 
|---|
| 66 |  . S TIUY=$P($G(^TIU(8925.1,+DA,0)),U,3)
 | 
|---|
| 67 |  . I TIUY']"" S TIUY=$$MIXED^TIULS($P($G(^TIU(8925.1,+DA,0)),U))
 | 
|---|
| 68 |  Q TIUY
 | 
|---|
| 69 | ABBREV(DA) ; Get abbreviaton for a document type or class
 | 
|---|
| 70 |  Q $P($G(^TIU(8925.1,+DA,0)),U,2)
 | 
|---|
| 71 | PERSNAME(USER) ; Receives pointer to 200, returns name field
 | 
|---|
| 72 |  N X S X=$$GET1^DIQ(200,USER,.01)
 | 
|---|
| 73 |  Q $S($L(X):X,1:"UNKNOWN")
 | 
|---|
| 74 | BEEP(USER) ; Get beeper #'s 
 | 
|---|
| 75 |  Q $P($G(^VA(200,+USER,.13)),U,7,8)
 | 
|---|
| 76 | DOCPRM(TIUTYP,TIUDPRM,TIUDA) ; Get Document Parameters, support inheritance
 | 
|---|
| 77 |  N TIUI,TIUDAD
 | 
|---|
| 78 |  S (TIUDPRM(0),TIUDPRM(5))=""
 | 
|---|
| 79 |  I $P($G(^TIU(8925.1,+TIUTYP,0)),U)["ADDENDUM",+$G(TIUDA) S TIUTYP=+$G(^TIU(8925,+$P($G(^TIU(8925,+TIUDA,0)),U,6),0))
 | 
|---|
| 80 |  S TIUI=+$O(^TIU(8925.95,"B",+TIUTYP,0))
 | 
|---|
| 81 |  I +TIUI D  Q
 | 
|---|
| 82 |  . S TIUDPRM(0)=$G(^TIU(8925.95,+TIUI,0))
 | 
|---|
| 83 |  . I +$O(^TIU(8925.95,+TIUI,5,0)) D
 | 
|---|
| 84 |  . . N TIUJ S TIUJ=0
 | 
|---|
| 85 |  . . F  S TIUJ=$O(^TIU(8925.95,+TIUI,5,TIUJ)) Q:+TIUJ'>0  D
 | 
|---|
| 86 |  . . . S $P(TIUDPRM(5),U,TIUJ)=+$G(^TIU(8925.95,+TIUI,5,+TIUJ,0))
 | 
|---|
| 87 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 88 |  I +TIUDAD D DOCPRM(TIUDAD,.TIUDPRM)
 | 
|---|
| 89 |  Q
 | 
|---|
| 90 | POSTFILE(TIUTYP) ; Get Post-filing Code, support inheritance
 | 
|---|
| 91 |  N TIUPOST,TIUDAD
 | 
|---|
| 92 |  S TIUPOST=$G(^TIU(8925.1,+TIUTYP,4.5))
 | 
|---|
| 93 |  I TIUPOST]"" G POSTFILX
 | 
|---|
| 94 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 95 |  I +TIUDAD S TIUPOST=$$POSTFILE(TIUDAD)
 | 
|---|
| 96 | POSTFILX Q TIUPOST
 | 
|---|
| 97 | FIXCODE(TIUTYP) ; Get Error Resolution Code, support inheritance
 | 
|---|
| 98 |  N TIUFIX,TIUDAD
 | 
|---|
| 99 |  S TIUFIX=$G(^TIU(8925.1,+TIUTYP,4.8))
 | 
|---|
| 100 |  I TIUFIX]"" G FIXCODX
 | 
|---|
| 101 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 102 |  ; Don't inherit PN code for consults: TIU*1*131
 | 
|---|
| 103 |  I +TIUTYP=$$CLASS^TIUCNSLT,TIUDAD=3 G FIXCODX
 | 
|---|
| 104 |  I +TIUDAD S TIUFIX=$$FIXCODE(TIUDAD)
 | 
|---|
| 105 | FIXCODX Q TIUFIX
 | 
|---|
| 106 | DOCCLASS(TIUTYP) ; Given a document type, find its parent document class
 | 
|---|
| 107 |  Q +$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 108 | CLINDOC(TIUTYP,TIUDA) ; Given a document type, find the Clinical Document
 | 
|---|
| 109 |  ;                 subclass to which it belongs
 | 
|---|
| 110 |  N TIUI,TIUY S (TIUI,TIUY)=0
 | 
|---|
| 111 |  I +$G(TIUDA),+$$ISADDNDM(TIUDA) S TIUTYP=+$G(^TIU(8925,+$P($G(^TIU(8925,+TIUDA,0)),U,6),0))
 | 
|---|
| 112 |  S TIUI=$O(^TIU(8925.1,"AD",+TIUTYP,TIUI))
 | 
|---|
| 113 |  I +TIUI'>0 G CLINDOX
 | 
|---|
| 114 |  I TIUI=38 S TIUY=TIUTYP
 | 
|---|
| 115 |  I TIUI'=38 S TIUY=$$CLINDOC(TIUI)
 | 
|---|
| 116 | CLINDOX Q TIUY
 | 
|---|
| 117 | REQVER(TIUTYP,TIUDA) ; Does a given document type require verification
 | 
|---|
| 118 |  N TIUDPRM,TIUY
 | 
|---|
| 119 |  I +$G(TIUDA),+$$ISADDNDM(TIUDA) S TIUTYP=+$G(^TIU(8925,+$P($G(^TIU(8925,+TIUDA,0)),U,6),0))
 | 
|---|
| 120 |  D DOCPRM(TIUTYP,.TIUDPRM)
 | 
|---|
| 121 |  I +$P($G(TIUDPRM(0)),U,3) S TIUY=1
 | 
|---|
| 122 |  Q +$G(TIUY)
 | 
|---|
| 123 | REFDATE(TIU,TIUDICDT) ; Identify Reference date
 | 
|---|
| 124 |  N TIURDT
 | 
|---|
| 125 |  I +$G(TIU("LDT")) S TIURDT=+$G(TIU("LDT"))_"^0"
 | 
|---|
| 126 |  I +$G(TIU("LDT"))'>0 D
 | 
|---|
| 127 |  . S TIURDT=$S(+$G(TIUDICDT):+$G(TIUDICDT),1:+$$NOW^TIULC)_"^1"
 | 
|---|
| 128 |  . S TIU("LDT")=TIURDT_U_$$DATE^TIULS(TIURDT,"AMTH DD, CCYY@HR:MIN:SEC")
 | 
|---|
| 129 |  Q TIURDT
 | 
|---|
| 130 | WHATMPL(USER) ; What List Template should a given user get?
 | 
|---|
| 131 |  N TIUY
 | 
|---|
| 132 |  I +$$ISA^USRLM(USER,"PROVIDER") S TIUY="TIU BROWSE FOR CLINICIAN" G WHAX
 | 
|---|
| 133 |  I +$$ISA^USRLM(USER,"MEDICAL RECORDS TECHNICIAN") S TIUY="TIU BROWSE FOR MRT" G WHAX
 | 
|---|
| 134 |  I +$$ISA^USRLM(USER,"CHIEF, MIS") S TIUY="TIU BROWSE FOR MGR" G WHAX
 | 
|---|
| 135 |  I +$$ISA^USRLM(USER,"MEDICAL STUDENT") S TIUY="TIU BROWSE FOR CLINICIAN" G WHAX
 | 
|---|
| 136 |  S TIUY="TIU BROWSE FOR READ ONLY"
 | 
|---|
| 137 | WHAX Q TIUY
 | 
|---|
| 138 | SUPPVSIT(TIUTYP) ; Evaluate whether to suppress visit matching
 | 
|---|
| 139 |  N TIUI,TIUY S TIUY=0
 | 
|---|
| 140 |  I +$P($G(^TIU(8925.1,+TIUTYP,3)),U,3) S TIUY=1 G SUPPVSIX
 | 
|---|
| 141 |  I $L($P($G(^TIU(8925.1,+TIUTYP,3)),U,3)),($P($G(^(3)),U,3)=0) S TIUY=0 G SUPPVSIX ; ** SLC/JER - NOIS NYC-1298-11472
 | 
|---|
| 142 |  S TIUI=0 F  S TIUI=$O(^TIU(8925.1,"AD",+TIUTYP,TIUI)) Q:+TIUI'>0!(+TIUY>0)  D
 | 
|---|
| 143 |  . S TIUY=+$$SUPPVSIT(+TIUI)
 | 
|---|
| 144 | SUPPVSIX Q TIUY
 | 
|---|
| 145 | PTNAME(DFN) ; Resolve Patient Name
 | 
|---|
| 146 |  N TIUY S TIUY=$P($G(^DPT(DFN,0)),U)
 | 
|---|
| 147 |  S:TIUY']"" TIUY="NAME UNKNOWN"
 | 
|---|
| 148 |  Q TIUY
 | 
|---|
| 149 | POSTSIGN(TIUTYP) ; Get Post-Signature Code, support inheritance
 | 
|---|
| 150 |  N TIUPOST,TIUDAD
 | 
|---|
| 151 |  S TIUPOST=$G(^TIU(8925.1,+TIUTYP,4.9))
 | 
|---|
| 152 |  I TIUPOST]"" G POSTSIGX
 | 
|---|
| 153 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 154 |  I +TIUDAD S TIUPOST=$$POSTSIGN(TIUDAD)
 | 
|---|
| 155 | POSTSIGX Q TIUPOST
 | 
|---|
| 156 | COMMIT(TIUTYP) ; Get Commitment action, support inheritance
 | 
|---|
| 157 |  N TIUCOMM,TIUDAD
 | 
|---|
| 158 |  S TIUCOMM=$G(^TIU(8925.1,+TIUTYP,4.1))
 | 
|---|
| 159 |  I TIUCOMM]"" G COMMITX
 | 
|---|
| 160 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 161 |  I +TIUDAD S TIUCOMM=$$COMMIT(TIUDAD)
 | 
|---|
| 162 | COMMITX Q TIUCOMM
 | 
|---|
| 163 | RELEASE(TIUTYP) ; Get Release Action, support inheritance
 | 
|---|
| 164 |  N TIUREL,TIUDAD
 | 
|---|
| 165 |  S TIUREL=$G(^TIU(8925.1,+TIUTYP,4.2))
 | 
|---|
| 166 |  I TIUREL]"" G RELEASX
 | 
|---|
| 167 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 168 |  I +TIUDAD S TIUREL=$$RELEASE(TIUDAD)
 | 
|---|
| 169 | RELEASX Q TIUREL
 | 
|---|
| 170 | VERIFY(TIUTYP) ; Get Verification action, support inheritance
 | 
|---|
| 171 |  N TIUVER,TIUDAD
 | 
|---|
| 172 |  S TIUVER=$G(^TIU(8925.1,+TIUTYP,4.3))
 | 
|---|
| 173 |  I TIUVER]"" G VERIFYX
 | 
|---|
| 174 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 175 |  I +TIUDAD S TIUVER=$$VERIFY(TIUDAD)
 | 
|---|
| 176 | VERIFYX Q TIUVER
 | 
|---|
| 177 | DELETE(TIUTYP) ; Get Delete Action, support inheritance
 | 
|---|
| 178 |  N TIUDEL,TIUDAD
 | 
|---|
| 179 |  S TIUDEL=$G(^TIU(8925.1,+TIUTYP,4.4))
 | 
|---|
| 180 |  I TIUDEL]"" G DELETEX
 | 
|---|
| 181 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 182 |  I +TIUDAD S TIUDEL=$$DELETE(TIUDAD)
 | 
|---|
| 183 | DELETEX Q TIUDEL
 | 
|---|
| 184 | REASSIGN(TIUTYP) ; Get Package Reassign Action, support inheritance
 | 
|---|
| 185 |  N TIUREASS,TIUDAD
 | 
|---|
| 186 |  S TIUREASS=$G(^TIU(8925.1,+TIUTYP,4.45))
 | 
|---|
| 187 |  I TIUREASS]"" G REASSIX
 | 
|---|
| 188 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 189 |  I +TIUDAD S TIUREASS=$$REASSIGN(TIUDAD)
 | 
|---|
| 190 | REASSIX Q TIUREASS
 | 
|---|
| 191 | ONBROWSE(TIUTYP)        ; Get OnBrowse Event, support inheritance
 | 
|---|
| 192 |  N TIUBRWS,TIUDAD
 | 
|---|
| 193 |  S TIUBRWS=$G(^TIU(8925.1,+TIUTYP,6.5))
 | 
|---|
| 194 |  I TIUBRWS]"" G ONBRWSX
 | 
|---|
| 195 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 196 |  I +TIUDAD S TIUBRWS=$$ONBROWSE(TIUDAD)
 | 
|---|
| 197 | ONBRWSX Q TIUBRWS
 | 
|---|
| 198 | ONRTRCT(TIUTYP) ; Get OnRetract Event, support inheritance
 | 
|---|
| 199 |  N TIURTRCT,TIUDAD
 | 
|---|
| 200 |  S TIURTRCT=$G(^TIU(8925.1,+TIUTYP,6.51))
 | 
|---|
| 201 |  I TIURTRCT]"" G ONRTRX
 | 
|---|
| 202 |  S TIUDAD=$O(^TIU(8925.1,"AD",+TIUTYP,0))
 | 
|---|
| 203 |  I +TIUDAD S TIURTRCT=$$ONRTRCT(TIUDAD)
 | 
|---|
| 204 | ONRTRX Q TIURTRCT
 | 
|---|
| 205 | DIVISION(TIULOC) ; Get Division
 | 
|---|
| 206 |  ; Input  -- TIULOC  HOSPITAL LOCATION file (#44) IEN
 | 
|---|
| 207 |  ; Output -- TIUIN   INSTITUTION file (#4) IEN^
 | 
|---|
| 208 |  ;                   INSTITUTION file (#4) NAME
 | 
|---|
| 209 |  N TIUDVHL,TIUSTN,TIUIN
 | 
|---|
| 210 |  S TIUDVHL=$P($G(^SC(+TIULOC,0)),U,15)
 | 
|---|
| 211 |  I +TIUDVHL D
 | 
|---|
| 212 |  . S TIUSTN=$$SITE^VASITE(,TIUDVHL)
 | 
|---|
| 213 |  . I $P(TIUSTN,U)>0,($P(TIUSTN,U,2)]"") D
 | 
|---|
| 214 |  . . S TIUIN=$P(TIUSTN,U)_U_$P(TIUSTN,U,2)
 | 
|---|
| 215 |  I '$G(TIUIN) D
 | 
|---|
| 216 |  . S TIUIN=+$G(DUZ(2))_U_$P($$NS^XUAF4(+$G(DUZ(2))),U)
 | 
|---|
| 217 |  Q TIUIN
 | 
|---|