| 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 | 
|---|