[1293] | 1 | Released NHIN*1*1 SEQ #1
|
---|
| 2 | Extracted from mail message
|
---|
| 3 | **KIDS**:NHIN*1.0*1^
|
---|
| 4 |
|
---|
| 5 | **INSTALL NAME**
|
---|
| 6 | NHIN*1.0*1
|
---|
| 7 | "BLD",7816,0)
|
---|
| 8 | NHIN*1.0*1^NATIONAL HEALTH INFO NETWORK^0^3110215^y
|
---|
| 9 | "BLD",7816,4,0)
|
---|
| 10 | ^9.64PA^^
|
---|
| 11 | "BLD",7816,6.3)
|
---|
| 12 | 11
|
---|
| 13 | "BLD",7816,"ABPKG")
|
---|
| 14 | n
|
---|
| 15 | "BLD",7816,"KRN",0)
|
---|
| 16 | ^9.67PA^8989.52^19
|
---|
| 17 | "BLD",7816,"KRN",.4,0)
|
---|
| 18 | .4
|
---|
| 19 | "BLD",7816,"KRN",.401,0)
|
---|
| 20 | .401
|
---|
| 21 | "BLD",7816,"KRN",.402,0)
|
---|
| 22 | .402
|
---|
| 23 | "BLD",7816,"KRN",.403,0)
|
---|
| 24 | .403
|
---|
| 25 | "BLD",7816,"KRN",.5,0)
|
---|
| 26 | .5
|
---|
| 27 | "BLD",7816,"KRN",.84,0)
|
---|
| 28 | .84
|
---|
| 29 | "BLD",7816,"KRN",3.6,0)
|
---|
| 30 | 3.6
|
---|
| 31 | "BLD",7816,"KRN",3.8,0)
|
---|
| 32 | 3.8
|
---|
| 33 | "BLD",7816,"KRN",9.2,0)
|
---|
| 34 | 9.2
|
---|
| 35 | "BLD",7816,"KRN",9.8,0)
|
---|
| 36 | 9.8
|
---|
| 37 | "BLD",7816,"KRN",9.8,"NM",0)
|
---|
| 38 | ^9.68A^28^18
|
---|
| 39 | "BLD",7816,"KRN",9.8,"NM",1,0)
|
---|
| 40 | NHINV^^0^B15789004
|
---|
| 41 | "BLD",7816,"KRN",9.8,"NM",2,0)
|
---|
| 42 | NHINVART^^0^B30332823
|
---|
| 43 | "BLD",7816,"KRN",9.8,"NM",4,0)
|
---|
| 44 | NHINVIT^^0^B33591565
|
---|
| 45 | "BLD",7816,"KRN",9.8,"NM",5,0)
|
---|
| 46 | NHINVLR^^0^B25540846
|
---|
| 47 | "BLD",7816,"KRN",9.8,"NM",11,0)
|
---|
| 48 | NHINVRA^^0^B18363736
|
---|
| 49 | "BLD",7816,"KRN",9.8,"NM",12,0)
|
---|
| 50 | NHINVSR^^0^B25931760
|
---|
| 51 | "BLD",7816,"KRN",9.8,"NM",13,0)
|
---|
| 52 | NHINVTIU^^0^B18326219
|
---|
| 53 | "BLD",7816,"KRN",9.8,"NM",14,0)
|
---|
| 54 | NHINVIMM^^0^B9313203
|
---|
| 55 | "BLD",7816,"KRN",9.8,"NM",15,0)
|
---|
| 56 | NHINVSIT^^0^B60599762
|
---|
| 57 | "BLD",7816,"KRN",9.8,"NM",16,0)
|
---|
| 58 | NHINVPRC^^0^B6896734
|
---|
| 59 | "BLD",7816,"KRN",9.8,"NM",17,0)
|
---|
| 60 | NHINVAPT^^0^B9234836
|
---|
| 61 | "BLD",7816,"KRN",9.8,"NM",21,0)
|
---|
| 62 | NHINVLRA^^0^B45252098
|
---|
| 63 | "BLD",7816,"KRN",9.8,"NM",22,0)
|
---|
| 64 | NHINVLRO^^0^B32647424
|
---|
| 65 | "BLD",7816,"KRN",9.8,"NM",24,0)
|
---|
| 66 | NHINVPSI^^0^B41411886
|
---|
| 67 | "BLD",7816,"KRN",9.8,"NM",25,0)
|
---|
| 68 | NHINVPT^^0^B59592091
|
---|
| 69 | "BLD",7816,"KRN",9.8,"NM",26,0)
|
---|
| 70 | NHINVPL^^0^B19846807
|
---|
| 71 | "BLD",7816,"KRN",9.8,"NM",27,0)
|
---|
| 72 | NHINVPS^^0^B14129801
|
---|
| 73 | "BLD",7816,"KRN",9.8,"NM",28,0)
|
---|
| 74 | NHINVPSO^^0^B65991145
|
---|
| 75 | "BLD",7816,"KRN",9.8,"NM","B","NHINV",1)
|
---|
| 76 |
|
---|
| 77 | "BLD",7816,"KRN",9.8,"NM","B","NHINVAPT",17)
|
---|
| 78 |
|
---|
| 79 | "BLD",7816,"KRN",9.8,"NM","B","NHINVART",2)
|
---|
| 80 |
|
---|
| 81 | "BLD",7816,"KRN",9.8,"NM","B","NHINVIMM",14)
|
---|
| 82 |
|
---|
| 83 | "BLD",7816,"KRN",9.8,"NM","B","NHINVIT",4)
|
---|
| 84 |
|
---|
| 85 | "BLD",7816,"KRN",9.8,"NM","B","NHINVLR",5)
|
---|
| 86 |
|
---|
| 87 | "BLD",7816,"KRN",9.8,"NM","B","NHINVLRA",21)
|
---|
| 88 |
|
---|
| 89 | "BLD",7816,"KRN",9.8,"NM","B","NHINVLRO",22)
|
---|
| 90 |
|
---|
| 91 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPL",26)
|
---|
| 92 |
|
---|
| 93 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPRC",16)
|
---|
| 94 |
|
---|
| 95 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPS",27)
|
---|
| 96 |
|
---|
| 97 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPSI",24)
|
---|
| 98 |
|
---|
| 99 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPSO",28)
|
---|
| 100 |
|
---|
| 101 | "BLD",7816,"KRN",9.8,"NM","B","NHINVPT",25)
|
---|
| 102 |
|
---|
| 103 | "BLD",7816,"KRN",9.8,"NM","B","NHINVRA",11)
|
---|
| 104 |
|
---|
| 105 | "BLD",7816,"KRN",9.8,"NM","B","NHINVSIT",15)
|
---|
| 106 |
|
---|
| 107 | "BLD",7816,"KRN",9.8,"NM","B","NHINVSR",12)
|
---|
| 108 |
|
---|
| 109 | "BLD",7816,"KRN",9.8,"NM","B","NHINVTIU",13)
|
---|
| 110 |
|
---|
| 111 | "BLD",7816,"KRN",19,0)
|
---|
| 112 | 19
|
---|
| 113 | "BLD",7816,"KRN",19.1,0)
|
---|
| 114 | 19.1
|
---|
| 115 | "BLD",7816,"KRN",101,0)
|
---|
| 116 | 101
|
---|
| 117 | "BLD",7816,"KRN",409.61,0)
|
---|
| 118 | 409.61
|
---|
| 119 | "BLD",7816,"KRN",771,0)
|
---|
| 120 | 771
|
---|
| 121 | "BLD",7816,"KRN",870,0)
|
---|
| 122 | 870
|
---|
| 123 | "BLD",7816,"KRN",8989.51,0)
|
---|
| 124 | 8989.51
|
---|
| 125 | "BLD",7816,"KRN",8989.52,0)
|
---|
| 126 | 8989.52
|
---|
| 127 | "BLD",7816,"KRN",8994,0)
|
---|
| 128 | 8994
|
---|
| 129 | "BLD",7816,"KRN",8994,"NM",0)
|
---|
| 130 | ^9.68A^^0
|
---|
| 131 | "BLD",7816,"KRN","B",.4,.4)
|
---|
| 132 |
|
---|
| 133 | "BLD",7816,"KRN","B",.401,.401)
|
---|
| 134 |
|
---|
| 135 | "BLD",7816,"KRN","B",.402,.402)
|
---|
| 136 |
|
---|
| 137 | "BLD",7816,"KRN","B",.403,.403)
|
---|
| 138 |
|
---|
| 139 | "BLD",7816,"KRN","B",.5,.5)
|
---|
| 140 |
|
---|
| 141 | "BLD",7816,"KRN","B",.84,.84)
|
---|
| 142 |
|
---|
| 143 | "BLD",7816,"KRN","B",3.6,3.6)
|
---|
| 144 |
|
---|
| 145 | "BLD",7816,"KRN","B",3.8,3.8)
|
---|
| 146 |
|
---|
| 147 | "BLD",7816,"KRN","B",9.2,9.2)
|
---|
| 148 |
|
---|
| 149 | "BLD",7816,"KRN","B",9.8,9.8)
|
---|
| 150 |
|
---|
| 151 | "BLD",7816,"KRN","B",19,19)
|
---|
| 152 |
|
---|
| 153 | "BLD",7816,"KRN","B",19.1,19.1)
|
---|
| 154 |
|
---|
| 155 | "BLD",7816,"KRN","B",101,101)
|
---|
| 156 |
|
---|
| 157 | "BLD",7816,"KRN","B",409.61,409.61)
|
---|
| 158 |
|
---|
| 159 | "BLD",7816,"KRN","B",771,771)
|
---|
| 160 |
|
---|
| 161 | "BLD",7816,"KRN","B",870,870)
|
---|
| 162 |
|
---|
| 163 | "BLD",7816,"KRN","B",8989.51,8989.51)
|
---|
| 164 |
|
---|
| 165 | "BLD",7816,"KRN","B",8989.52,8989.52)
|
---|
| 166 |
|
---|
| 167 | "BLD",7816,"KRN","B",8994,8994)
|
---|
| 168 |
|
---|
| 169 | "BLD",7816,"QUES",0)
|
---|
| 170 | ^9.62^^
|
---|
| 171 | "BLD",7816,"REQB",0)
|
---|
| 172 | ^9.611^1^1
|
---|
| 173 | "BLD",7816,"REQB",1,0)
|
---|
| 174 | NHIN 1.0^2
|
---|
| 175 | "BLD",7816,"REQB","B","NHIN 1.0",1)
|
---|
| 176 |
|
---|
| 177 | "MBREQ")
|
---|
| 178 | 0
|
---|
| 179 | "PKG",568,-1)
|
---|
| 180 | 1^1
|
---|
| 181 | "PKG",568,0)
|
---|
| 182 | NATIONAL HEALTH INFO NETWORK^NHIN^NATIONAL HEALTH INFORMATION NETWORK ADAPTER
|
---|
| 183 | "PKG",568,20,0)
|
---|
| 184 | ^9.402P^^
|
---|
| 185 | "PKG",568,22,0)
|
---|
| 186 | ^9.49I^1^1
|
---|
| 187 | "PKG",568,22,1,0)
|
---|
| 188 | 1.0^3100914^3101007^10000000219
|
---|
| 189 | "PKG",568,22,1,"PAH",1,0)
|
---|
| 190 | 1^3110215^10000000219
|
---|
| 191 | "QUES","XPF1",0)
|
---|
| 192 | Y
|
---|
| 193 | "QUES","XPF1","??")
|
---|
| 194 | ^D REP^XPDH
|
---|
| 195 | "QUES","XPF1","A")
|
---|
| 196 | Shall I write over your |FLAG| File
|
---|
| 197 | "QUES","XPF1","B")
|
---|
| 198 | YES
|
---|
| 199 | "QUES","XPF1","M")
|
---|
| 200 | D XPF1^XPDIQ
|
---|
| 201 | "QUES","XPF2",0)
|
---|
| 202 | Y
|
---|
| 203 | "QUES","XPF2","??")
|
---|
| 204 | ^D DTA^XPDH
|
---|
| 205 | "QUES","XPF2","A")
|
---|
| 206 | Want my data |FLAG| yours
|
---|
| 207 | "QUES","XPF2","B")
|
---|
| 208 | YES
|
---|
| 209 | "QUES","XPF2","M")
|
---|
| 210 | D XPF2^XPDIQ
|
---|
| 211 | "QUES","XPI1",0)
|
---|
| 212 | YO
|
---|
| 213 | "QUES","XPI1","??")
|
---|
| 214 | ^D INHIBIT^XPDH
|
---|
| 215 | "QUES","XPI1","A")
|
---|
| 216 | Want KIDS to INHIBIT LOGONs during the install
|
---|
| 217 | "QUES","XPI1","B")
|
---|
| 218 | NO
|
---|
| 219 | "QUES","XPI1","M")
|
---|
| 220 | D XPI1^XPDIQ
|
---|
| 221 | "QUES","XPM1",0)
|
---|
| 222 | PO^VA(200,:EM
|
---|
| 223 | "QUES","XPM1","??")
|
---|
| 224 | ^D MG^XPDH
|
---|
| 225 | "QUES","XPM1","A")
|
---|
| 226 | Enter the Coordinator for Mail Group '|FLAG|'
|
---|
| 227 | "QUES","XPM1","B")
|
---|
| 228 |
|
---|
| 229 | "QUES","XPM1","M")
|
---|
| 230 | D XPM1^XPDIQ
|
---|
| 231 | "QUES","XPO1",0)
|
---|
| 232 | Y
|
---|
| 233 | "QUES","XPO1","??")
|
---|
| 234 | ^D MENU^XPDH
|
---|
| 235 | "QUES","XPO1","A")
|
---|
| 236 | Want KIDS to Rebuild Menu Trees Upon Completion of Install
|
---|
| 237 | "QUES","XPO1","B")
|
---|
| 238 | NO
|
---|
| 239 | "QUES","XPO1","M")
|
---|
| 240 | D XPO1^XPDIQ
|
---|
| 241 | "QUES","XPZ1",0)
|
---|
| 242 | Y
|
---|
| 243 | "QUES","XPZ1","??")
|
---|
| 244 | ^D OPT^XPDH
|
---|
| 245 | "QUES","XPZ1","A")
|
---|
| 246 | Want to DISABLE Scheduled Options, Menu Options, and Protocols
|
---|
| 247 | "QUES","XPZ1","B")
|
---|
| 248 | NO
|
---|
| 249 | "QUES","XPZ1","M")
|
---|
| 250 | D XPZ1^XPDIQ
|
---|
| 251 | "QUES","XPZ2",0)
|
---|
| 252 | Y
|
---|
| 253 | "QUES","XPZ2","??")
|
---|
| 254 | ^D RTN^XPDH
|
---|
| 255 | "QUES","XPZ2","A")
|
---|
| 256 | Want to MOVE routines to other CPUs
|
---|
| 257 | "QUES","XPZ2","B")
|
---|
| 258 | NO
|
---|
| 259 | "QUES","XPZ2","M")
|
---|
| 260 | D XPZ2^XPDIQ
|
---|
| 261 | "RTN")
|
---|
| 262 | 18
|
---|
| 263 | "RTN","NHINV")
|
---|
| 264 | 0^1^B15789004^n/a
|
---|
| 265 | "RTN","NHINV",1,0)
|
---|
| 266 | NHINV ;SLC/MKB - Serve VistA data as XML via RPC
|
---|
| 267 | "RTN","NHINV",2,0)
|
---|
| 268 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 269 | "RTN","NHINV",3,0)
|
---|
| 270 | ;
|
---|
| 271 | "RTN","NHINV",4,0)
|
---|
| 272 | ; External References DBIA#
|
---|
| 273 | "RTN","NHINV",5,0)
|
---|
| 274 | ; ------------------- -----
|
---|
| 275 | "RTN","NHINV",6,0)
|
---|
| 276 | ; ^DPT 10035
|
---|
| 277 | "RTN","NHINV",7,0)
|
---|
| 278 | ; ^SC 10040
|
---|
| 279 | "RTN","NHINV",8,0)
|
---|
| 280 | ; DIQ 2056
|
---|
| 281 | "RTN","NHINV",9,0)
|
---|
| 282 | ; MPIF001 2701
|
---|
| 283 | "RTN","NHINV",10,0)
|
---|
| 284 | ; VASITE 10112
|
---|
| 285 | "RTN","NHINV",11,0)
|
---|
| 286 | ; XLFDT 10103
|
---|
| 287 | "RTN","NHINV",12,0)
|
---|
| 288 | ; XLFSTR 10104
|
---|
| 289 | "RTN","NHINV",13,0)
|
---|
| 290 | ; XUAF4 2171
|
---|
| 291 | "RTN","NHINV",14,0)
|
---|
| 292 | ;
|
---|
| 293 | "RTN","NHINV",15,0)
|
---|
| 294 | GET(NHIN,DFN,TYPE,START,STOP,MAX,ID) ; -- Return search results as XML in @NHIN@(n)
|
---|
| 295 | "RTN","NHINV",16,0)
|
---|
| 296 | ; RPC = NHIN GET VISTA DATA
|
---|
| 297 | "RTN","NHINV",17,0)
|
---|
| 298 | N ICN,NHINI,NHINTOTL
|
---|
| 299 | "RTN","NHINV",18,0)
|
---|
| 300 | S NHIN=$NA(^TMP("NHINV",$J)) K @NHIN
|
---|
| 301 | "RTN","NHINV",19,0)
|
---|
| 302 | ;
|
---|
| 303 | "RTN","NHINV",20,0)
|
---|
| 304 | ; parse & validate input parameters
|
---|
| 305 | "RTN","NHINV",21,0)
|
---|
| 306 | S ICN=+$P(DFN,";",2),DFN=+$G(DFN)
|
---|
| 307 | "RTN","NHINV",22,0)
|
---|
| 308 | I 'DFN S DFN=+$$GETDFN^MPIF001(ICN)
|
---|
| 309 | "RTN","NHINV",23,0)
|
---|
| 310 | I DFN<1!'$D(^DPT(DFN)) D ERR(1,DFN) G GTQ
|
---|
| 311 | "RTN","NHINV",24,0)
|
---|
| 312 | S TYPE=$G(TYPE) I TYPE="" S TYPE=$$ALL
|
---|
| 313 | "RTN","NHINV",25,0)
|
---|
| 314 | S:'$G(START) START=1410101 S:'$G(STOP) STOP=9999998 S:'$G(MAX) MAX=9999
|
---|
| 315 | "RTN","NHINV",26,0)
|
---|
| 316 | I START,STOP,STOP<START N X S X=START,START=STOP,STOP=X ;switch
|
---|
| 317 | "RTN","NHINV",27,0)
|
---|
| 318 | I STOP,$L(STOP,".")<2 S STOP=STOP_".24"
|
---|
| 319 | "RTN","NHINV",28,0)
|
---|
| 320 | S ID=$G(ID)
|
---|
| 321 | "RTN","NHINV",29,0)
|
---|
| 322 | ;
|
---|
| 323 | "RTN","NHINV",30,0)
|
---|
| 324 | ; extract data
|
---|
| 325 | "RTN","NHINV",31,0)
|
---|
| 326 | N NHINTYPE,NHINP,RTN
|
---|
| 327 | "RTN","NHINV",32,0)
|
---|
| 328 | S NHINTYPE=TYPE D ADD("<results>")
|
---|
| 329 | "RTN","NHINV",33,0)
|
---|
| 330 | F NHINP=1:1:$L(NHINTYPE,";") S TYPE=$P(NHINTYPE,";",NHINP) I $L(TYPE) D
|
---|
| 331 | "RTN","NHINV",34,0)
|
---|
| 332 | . S RTN="EN^"_$$RTN(TYPE) Q:'$L($T(@RTN)) ;D ERR(2) Q
|
---|
| 333 | "RTN","NHINV",35,0)
|
---|
| 334 | . D @(RTN_"(DFN,START,STOP,MAX,ID)")
|
---|
| 335 | "RTN","NHINV",36,0)
|
---|
| 336 | D ADD("</results>")
|
---|
| 337 | "RTN","NHINV",37,0)
|
---|
| 338 | ;
|
---|
| 339 | "RTN","NHINV",38,0)
|
---|
| 340 | I $G(NHINTOTL),$G(@NHIN@(1))="<results>" S @NHIN@(1)="<results total='"_NHINTOTL_"' >"
|
---|
| 341 | "RTN","NHINV",39,0)
|
---|
| 342 | ;
|
---|
| 343 | "RTN","NHINV",40,0)
|
---|
| 344 | GTQ ; end
|
---|
| 345 | "RTN","NHINV",41,0)
|
---|
| 346 | Q
|
---|
| 347 | "RTN","NHINV",42,0)
|
---|
| 348 | ;
|
---|
| 349 | "RTN","NHINV",43,0)
|
---|
| 350 | RTN(X) ; -- Return name of NHINVxxx routine for clinical domain X
|
---|
| 351 | "RTN","NHINV",44,0)
|
---|
| 352 | S X=$$UP^XLFSTR(X),Y="NHINV"
|
---|
| 353 | "RTN","NHINV",45,0)
|
---|
| 354 | I X="ACCESSION" S Y="NHINVLRA"
|
---|
| 355 | "RTN","NHINV",46,0)
|
---|
| 356 | I X="ALLERGY" S Y="NHINVART"
|
---|
| 357 | "RTN","NHINV",47,0)
|
---|
| 358 | I X="APPOINTMENT" S Y="NHINVAPT"
|
---|
| 359 | "RTN","NHINV",48,0)
|
---|
| 360 | ; X="CONSULT" S Y="NHINVCON"
|
---|
| 361 | "RTN","NHINV",49,0)
|
---|
| 362 | I X="DOCUMENT" S Y="NHINVTIU"
|
---|
| 363 | "RTN","NHINV",50,0)
|
---|
| 364 | I X="IMMUNIZATION" S Y="NHINVIMM"
|
---|
| 365 | "RTN","NHINV",51,0)
|
---|
| 366 | I X="LAB" S Y="NHINVLR"
|
---|
| 367 | "RTN","NHINV",52,0)
|
---|
| 368 | I X="PANEL" S Y="NHINVLRO"
|
---|
| 369 | "RTN","NHINV",53,0)
|
---|
| 370 | I X="MED" S Y="NHINVPS"
|
---|
| 371 | "RTN","NHINV",54,0)
|
---|
| 372 | I X="RX" S Y="NHINVPSO"
|
---|
| 373 | "RTN","NHINV",55,0)
|
---|
| 374 | ; X="ORDER" S Y="NHINVOR"
|
---|
| 375 | "RTN","NHINV",56,0)
|
---|
| 376 | I X="PATIENT" S Y="NHINVPT"
|
---|
| 377 | "RTN","NHINV",57,0)
|
---|
| 378 | I X="PROBLEM" S Y="NHINVPL"
|
---|
| 379 | "RTN","NHINV",58,0)
|
---|
| 380 | I X="PROCEDURE" S Y="NHINVPRC"
|
---|
| 381 | "RTN","NHINV",59,0)
|
---|
| 382 | I X="SURGERY" S Y="NHINVSR"
|
---|
| 383 | "RTN","NHINV",60,0)
|
---|
| 384 | I X="VISIT" S Y="NHINVSIT"
|
---|
| 385 | "RTN","NHINV",61,0)
|
---|
| 386 | I X="VITAL" S Y="NHINVIT"
|
---|
| 387 | "RTN","NHINV",62,0)
|
---|
| 388 | I X="RADIOLOGY" S Y="NHINVRA"
|
---|
| 389 | "RTN","NHINV",63,0)
|
---|
| 390 | I X="NEW" S Y="NHINVPR"
|
---|
| 391 | "RTN","NHINV",64,0)
|
---|
| 392 | Q Y
|
---|
| 393 | "RTN","NHINV",65,0)
|
---|
| 394 | ;
|
---|
| 395 | "RTN","NHINV",66,0)
|
---|
| 396 | ALL() ; -- return string for all types of data
|
---|
| 397 | "RTN","NHINV",67,0)
|
---|
| 398 | Q "patient;allergy;problem;vital;lab;med;immunization;visit;appointment;document;procedure"
|
---|
| 399 | "RTN","NHINV",68,0)
|
---|
| 400 | ;
|
---|
| 401 | "RTN","NHINV",69,0)
|
---|
| 402 | ERR(X,VAL) ; -- return error message
|
---|
| 403 | "RTN","NHINV",70,0)
|
---|
| 404 | N MSG S MSG="Error"
|
---|
| 405 | "RTN","NHINV",71,0)
|
---|
| 406 | I X=1 S MSG="Patient with dfn '"_$G(VAL)_"' not found"
|
---|
| 407 | "RTN","NHINV",72,0)
|
---|
| 408 | I X=2 S MSG="Requested domain type '"_$G(VAL)_"' not recognized"
|
---|
| 409 | "RTN","NHINV",73,0)
|
---|
| 410 | I X=99 S MSG="Unknown request"
|
---|
| 411 | "RTN","NHINV",74,0)
|
---|
| 412 | ;
|
---|
| 413 | "RTN","NHINV",75,0)
|
---|
| 414 | D ADD("<error>")
|
---|
| 415 | "RTN","NHINV",76,0)
|
---|
| 416 | D ADD("<message>"_MSG_"</message>")
|
---|
| 417 | "RTN","NHINV",77,0)
|
---|
| 418 | D ADD("</error>")
|
---|
| 419 | "RTN","NHINV",78,0)
|
---|
| 420 | Q
|
---|
| 421 | "RTN","NHINV",79,0)
|
---|
| 422 | ;
|
---|
| 423 | "RTN","NHINV",80,0)
|
---|
| 424 | ESC(X) ; -- escape outgoing XML
|
---|
| 425 | "RTN","NHINV",81,0)
|
---|
| 426 | ; Q $ZCONVERT(X,"O","HTML") ; uncomment for fastest performance on Cache
|
---|
| 427 | "RTN","NHINV",82,0)
|
---|
| 428 | ;
|
---|
| 429 | "RTN","NHINV",83,0)
|
---|
| 430 | N I,Y,QOT S QOT=""""
|
---|
| 431 | "RTN","NHINV",84,0)
|
---|
| 432 | S Y=$P(X,"&") F I=2:1:$L(X,"&") S Y=Y_"&"_$P(X,"&",I)
|
---|
| 433 | "RTN","NHINV",85,0)
|
---|
| 434 | S X=Y,Y=$P(X,"<") F I=2:1:$L(X,"<") S Y=Y_"<"_$P(X,"<",I)
|
---|
| 435 | "RTN","NHINV",86,0)
|
---|
| 436 | S X=Y,Y=$P(X,">") F I=2:1:$L(X,">") S Y=Y_">"_$P(X,">",I)
|
---|
| 437 | "RTN","NHINV",87,0)
|
---|
| 438 | S X=Y,Y=$P(X,"'") F I=2:1:$L(X,"'") S Y=Y_"'"_$P(X,"'",I)
|
---|
| 439 | "RTN","NHINV",88,0)
|
---|
| 440 | S X=Y,Y=$P(X,QOT) F I=2:1:$L(X,QOT) S Y=Y_"""_$P(X,QOT,I)
|
---|
| 441 | "RTN","NHINV",89,0)
|
---|
| 442 | Q Y
|
---|
| 443 | "RTN","NHINV",90,0)
|
---|
| 444 | ;
|
---|
| 445 | "RTN","NHINV",91,0)
|
---|
| 446 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 447 | "RTN","NHINV",92,0)
|
---|
| 448 | S NHINI=$G(NHINI)+1
|
---|
| 449 | "RTN","NHINV",93,0)
|
---|
| 450 | S @NHIN@(NHINI)=X
|
---|
| 451 | "RTN","NHINV",94,0)
|
---|
| 452 | Q
|
---|
| 453 | "RTN","NHINV",95,0)
|
---|
| 454 | ;
|
---|
| 455 | "RTN","NHINV",96,0)
|
---|
| 456 | STRING(ARRAY) ; -- Return text in ARRAY(n) or ARRAY(n,0) as a string
|
---|
| 457 | "RTN","NHINV",97,0)
|
---|
| 458 | N I,X,Y S Y=""
|
---|
| 459 | "RTN","NHINV",98,0)
|
---|
| 460 | S I=+$O(ARRAY("")) I I=0 S I=+$O(ARRAY(0))
|
---|
| 461 | "RTN","NHINV",99,0)
|
---|
| 462 | S Y=$S($D(ARRAY(I,0)):ARRAY(I,0),1:$G(ARRAY(I)))
|
---|
| 463 | "RTN","NHINV",100,0)
|
---|
| 464 | F S I=$O(ARRAY(I)) Q:I<1 D
|
---|
| 465 | "RTN","NHINV",101,0)
|
---|
| 466 | . S X=$S($D(ARRAY(I,0)):ARRAY(I,0),1:ARRAY(I))
|
---|
| 467 | "RTN","NHINV",102,0)
|
---|
| 468 | . I $E(X)=" " S Y=Y_$C(13,10)_X Q
|
---|
| 469 | "RTN","NHINV",103,0)
|
---|
| 470 | . S Y=Y_$S($E(Y,$L(Y))=" ":"",1:" ")_X
|
---|
| 471 | "RTN","NHINV",104,0)
|
---|
| 472 | Q Y
|
---|
| 473 | "RTN","NHINV",105,0)
|
---|
| 474 | ;
|
---|
| 475 | "RTN","NHINV",106,0)
|
---|
| 476 | FAC(X) ; -- return Institution file station# for location X
|
---|
| 477 | "RTN","NHINV",107,0)
|
---|
| 478 | N HLOC,FAC,Y0,Y S Y=""
|
---|
| 479 | "RTN","NHINV",108,0)
|
---|
| 480 | S HLOC=$G(^SC(+$G(X),0)),FAC=$P(HLOC,U,4) ;Institution ien
|
---|
| 481 | "RTN","NHINV",109,0)
|
---|
| 482 | ; Get P:4 via Med Ctr Div, if not directly linked
|
---|
| 483 | "RTN","NHINV",110,0)
|
---|
| 484 | I 'FAC,$P(HLOC,U,15) S FAC=$$GET1^DIQ(40.8,+$P(HLOC,U,15)_",",.07,"I")
|
---|
| 485 | "RTN","NHINV",111,0)
|
---|
| 486 | S Y0=$S(FAC:$$NS^XUAF4(FAC),1:$P($$SITE^VASITE,U,2,3)) ;name^stn#
|
---|
| 487 | "RTN","NHINV",112,0)
|
---|
| 488 | S:$L(Y0) Y=$P(Y0,U,2)_U_$P(Y0,U) ;switch to stn#^name
|
---|
| 489 | "RTN","NHINV",113,0)
|
---|
| 490 | I $L(Y),'Y S $P(Y,U)=FAC
|
---|
| 491 | "RTN","NHINV",114,0)
|
---|
| 492 | Q Y
|
---|
| 493 | "RTN","NHINV",115,0)
|
---|
| 494 | ;
|
---|
| 495 | "RTN","NHINV",116,0)
|
---|
| 496 | VUID(IEN,FILE) ; -- Return VUID for item
|
---|
| 497 | "RTN","NHINV",117,0)
|
---|
| 498 | Q $$GET1^DIQ(FILE,IEN_",",99.99)
|
---|
| 499 | "RTN","NHINVAPT")
|
---|
| 500 | 0^17^B9234836^n/a
|
---|
| 501 | "RTN","NHINVAPT",1,0)
|
---|
| 502 | NHINVAPT ;SLC/MKB -- Appointment extract
|
---|
| 503 | "RTN","NHINVAPT",2,0)
|
---|
| 504 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 505 | "RTN","NHINVAPT",3,0)
|
---|
| 506 | ;
|
---|
| 507 | "RTN","NHINVAPT",4,0)
|
---|
| 508 | ; External References DBIA#
|
---|
| 509 | "RTN","NHINVAPT",5,0)
|
---|
| 510 | ; ------------------- -----
|
---|
| 511 | "RTN","NHINVAPT",6,0)
|
---|
| 512 | ; DIQ 2056
|
---|
| 513 | "RTN","NHINVAPT",7,0)
|
---|
| 514 | ; SDAMA201 3859
|
---|
| 515 | "RTN","NHINVAPT",8,0)
|
---|
| 516 | ; VADPT 10061
|
---|
| 517 | "RTN","NHINVAPT",9,0)
|
---|
| 518 | ;
|
---|
| 519 | "RTN","NHINVAPT",10,0)
|
---|
| 520 | ; ------------ Get appointment(s) from VistA ------------
|
---|
| 521 | "RTN","NHINVAPT",11,0)
|
---|
| 522 | ;
|
---|
| 523 | "RTN","NHINVAPT",12,0)
|
---|
| 524 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's appointments
|
---|
| 525 | "RTN","NHINVAPT",13,0)
|
---|
| 526 | N NHICNT,NHITOT,NHI,X1,X2,X3,X12,NHITM
|
---|
| 527 | "RTN","NHINVAPT",14,0)
|
---|
| 528 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 529 | "RTN","NHINVAPT",15,0)
|
---|
| 530 | S BEG=$G(BEG,DT),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 531 | "RTN","NHINVAPT",16,0)
|
---|
| 532 | ;
|
---|
| 533 | "RTN","NHINVAPT",17,0)
|
---|
| 534 | ; get one appt
|
---|
| 535 | "RTN","NHINVAPT",18,0)
|
---|
| 536 | I $L($G(ID)) D Q
|
---|
| 537 | "RTN","NHINVAPT",19,0)
|
---|
| 538 | . S (BEG,END)=$P(ID,";",2)
|
---|
| 539 | "RTN","NHINVAPT",20,0)
|
---|
| 540 | . D GETAPPT^SDAMA201(DFN,"1;2;3;12","",BEG,END,.NHITOT)
|
---|
| 541 | "RTN","NHINVAPT",21,0)
|
---|
| 542 | . I NHITOT>0 F NHI=1:1:NHITOT D
|
---|
| 543 | "RTN","NHINVAPT",22,0)
|
---|
| 544 | .. S X1=+$G(^TMP($J,"SDAMA201","GETAPPT",NHI,1)),X2=$G(^(2)),X3=$G(^(3)),X12=$G(^(12))
|
---|
| 545 | "RTN","NHINVAPT",23,0)
|
---|
| 546 | .. Q:+X2'=$P(ID,";",3) ;not same location
|
---|
| 547 | "RTN","NHINVAPT",24,0)
|
---|
| 548 | .. D EN1(X1,X2,X3,X12,.NHITM),XML(.NHITM)
|
---|
| 549 | "RTN","NHINVAPT",25,0)
|
---|
| 550 | . K ^TMP($J,"SDAMA201","GETAPPT")
|
---|
| 551 | "RTN","NHINVAPT",26,0)
|
---|
| 552 | ;
|
---|
| 553 | "RTN","NHINVAPT",27,0)
|
---|
| 554 | ; get all [future] appointments
|
---|
| 555 | "RTN","NHINVAPT",28,0)
|
---|
| 556 | D GETAPPT^SDAMA201(DFN,"1;2;3;12","",BEG,END,.NHITOT)
|
---|
| 557 | "RTN","NHINVAPT",29,0)
|
---|
| 558 | I NHITOT>0 S NHICNT=0 F NHI=1:1:NHITOT D Q:NHICNT'<MAX
|
---|
| 559 | "RTN","NHINVAPT",30,0)
|
---|
| 560 | . S X1=+$G(^TMP($J,"SDAMA201","GETAPPT",NHI,1)),X2=+$G(^(2)),X3=$G(^(3))
|
---|
| 561 | "RTN","NHINVAPT",31,0)
|
---|
| 562 | . ;no cancelled, or prior kept appointments [ORWCV]
|
---|
| 563 | "RTN","NHINVAPT",32,0)
|
---|
| 564 | . Q:X3="C" I X1<DT,(X3="R"!(X3="NT")) Q
|
---|
| 565 | "RTN","NHINVAPT",33,0)
|
---|
| 566 | . K NHITM D EN1(X1,X2,X3,X12,.NHITM) Q:'$D(NHITM)
|
---|
| 567 | "RTN","NHINVAPT",34,0)
|
---|
| 568 | . D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 569 | "RTN","NHINVAPT",35,0)
|
---|
| 570 | K ^TMP($J,"SDAMA201","GETAPPT")
|
---|
| 571 | "RTN","NHINVAPT",36,0)
|
---|
| 572 | Q
|
---|
| 573 | "RTN","NHINVAPT",37,0)
|
---|
| 574 | ;
|
---|
| 575 | "RTN","NHINVAPT",38,0)
|
---|
| 576 | EN1(DATE,HLOC,STS,CLS,APPT) ; -- return an appointment in APPT("attribute")=value
|
---|
| 577 | "RTN","NHINVAPT",39,0)
|
---|
| 578 | N X,VIEN K APPT
|
---|
| 579 | "RTN","NHINVAPT",40,0)
|
---|
| 580 | S DATE=+$G(DATE),HLOC=$G(HLOC),STS=$G(STS),CLS=$G(CLS)
|
---|
| 581 | "RTN","NHINVAPT",41,0)
|
---|
| 582 | S APPT("id")="A;"_DATE_";"_+HLOC,APPT("dateTime")=DATE I HLOC D
|
---|
| 583 | "RTN","NHINVAPT",42,0)
|
---|
| 584 | . S APPT("location")=$P(HLOC,U,2)
|
---|
| 585 | "RTN","NHINVAPT",43,0)
|
---|
| 586 | . S APPT("type")=U_$P(HLOC,U,2)_" APPOINTMENT"
|
---|
| 587 | "RTN","NHINVAPT",44,0)
|
---|
| 588 | . S X=$$GET1^DIQ(44,+HLOC_",",9.5,"I")
|
---|
| 589 | "RTN","NHINVAPT",45,0)
|
---|
| 590 | . I X S APPT("service")=$$SERV(X)
|
---|
| 591 | "RTN","NHINVAPT",46,0)
|
---|
| 592 | S APPT("facility")=$$FAC^NHINV(+HLOC)
|
---|
| 593 | "RTN","NHINVAPT",47,0)
|
---|
| 594 | S APPT("patientClass")=$S(CLS="I":"IMP",1:"AMB")
|
---|
| 595 | "RTN","NHINVAPT",48,0)
|
---|
| 596 | S APPT("serviceCategory")=$S(CLS="I":"I^INPATIENT VISIT",1:"A^AMBULATORY")
|
---|
| 597 | "RTN","NHINVAPT",49,0)
|
---|
| 598 | S X=$S(STS="N":"NO-SHOW",STS="C":"CANCELLED",STS="R":"SCHEDULED/KEPT",STS="NT":"NO ACTION TAKEN",1:"")
|
---|
| 599 | "RTN","NHINVAPT",50,0)
|
---|
| 600 | S:$L(X) APPT("apptStatus")=X
|
---|
| 601 | "RTN","NHINVAPT",51,0)
|
---|
| 602 | S APPT("visitString")=+HLOC_";"_DATE_";A"
|
---|
| 603 | "RTN","NHINVAPT",52,0)
|
---|
| 604 | Q
|
---|
| 605 | "RTN","NHINVAPT",53,0)
|
---|
| 606 | ;
|
---|
| 607 | "RTN","NHINVAPT",54,0)
|
---|
| 608 | SERV(FTS) ; -- Return #42.4 Service for a Facility Treating Specialty
|
---|
| 609 | "RTN","NHINVAPT",55,0)
|
---|
| 610 | N Y S Y="",FTS=+$G(FTS)
|
---|
| 611 | "RTN","NHINVAPT",56,0)
|
---|
| 612 | S Y=$$GET1^DIQ(45.7,FTS_",","1:3","E")
|
---|
| 613 | "RTN","NHINVAPT",57,0)
|
---|
| 614 | Q Y
|
---|
| 615 | "RTN","NHINVAPT",58,0)
|
---|
| 616 | ;
|
---|
| 617 | "RTN","NHINVAPT",59,0)
|
---|
| 618 | ; ------------ Return data to middle tier ------------
|
---|
| 619 | "RTN","NHINVAPT",60,0)
|
---|
| 620 | ;
|
---|
| 621 | "RTN","NHINVAPT",61,0)
|
---|
| 622 | XML(APPT) ; -- Return appointment as XML
|
---|
| 623 | "RTN","NHINVAPT",62,0)
|
---|
| 624 | N ATT,X,Y,NAMES
|
---|
| 625 | "RTN","NHINVAPT",63,0)
|
---|
| 626 | D ADD("<appointment>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 627 | "RTN","NHINVAPT",64,0)
|
---|
| 628 | S ATT="" F S ATT=$O(APPT(ATT)) Q:ATT="" D
|
---|
| 629 | "RTN","NHINVAPT",65,0)
|
---|
| 630 | . S X=$G(APPT(ATT)),Y="" Q:'$L(X)
|
---|
| 631 | "RTN","NHINVAPT",66,0)
|
---|
| 632 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />"
|
---|
| 633 | "RTN","NHINVAPT",67,0)
|
---|
| 634 | . I $L(X)>1 S NAMES="code^name^Z",Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 635 | "RTN","NHINVAPT",68,0)
|
---|
| 636 | . D:$L(Y) ADD(Y)
|
---|
| 637 | "RTN","NHINVAPT",69,0)
|
---|
| 638 | D ADD("</appointment>")
|
---|
| 639 | "RTN","NHINVAPT",70,0)
|
---|
| 640 | Q
|
---|
| 641 | "RTN","NHINVAPT",71,0)
|
---|
| 642 | ;
|
---|
| 643 | "RTN","NHINVAPT",72,0)
|
---|
| 644 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 645 | "RTN","NHINVAPT",73,0)
|
---|
| 646 | N STR,P,TAG S STR=""
|
---|
| 647 | "RTN","NHINVAPT",74,0)
|
---|
| 648 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 649 | "RTN","NHINVAPT",75,0)
|
---|
| 650 | Q STR
|
---|
| 651 | "RTN","NHINVAPT",76,0)
|
---|
| 652 | ;
|
---|
| 653 | "RTN","NHINVAPT",77,0)
|
---|
| 654 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 655 | "RTN","NHINVAPT",78,0)
|
---|
| 656 | S NHINI=$G(NHINI)+1
|
---|
| 657 | "RTN","NHINVAPT",79,0)
|
---|
| 658 | S @NHIN@(NHINI)=X
|
---|
| 659 | "RTN","NHINVAPT",80,0)
|
---|
| 660 | Q
|
---|
| 661 | "RTN","NHINVART")
|
---|
| 662 | 0^2^B30332823^n/a
|
---|
| 663 | "RTN","NHINVART",1,0)
|
---|
| 664 | NHINVART ;SLC/MKB -- Allergy/Reaction extract
|
---|
| 665 | "RTN","NHINVART",2,0)
|
---|
| 666 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 667 | "RTN","NHINVART",3,0)
|
---|
| 668 | ;
|
---|
| 669 | "RTN","NHINVART",4,0)
|
---|
| 670 | ; External References DBIA#
|
---|
| 671 | "RTN","NHINVART",5,0)
|
---|
| 672 | ; ------------------- -----
|
---|
| 673 | "RTN","NHINVART",6,0)
|
---|
| 674 | ; %DT 10003
|
---|
| 675 | "RTN","NHINVART",7,0)
|
---|
| 676 | ; GMRADPT 10099
|
---|
| 677 | "RTN","NHINVART",8,0)
|
---|
| 678 | ; EN1^GMRAOR2 2422
|
---|
| 679 | "RTN","NHINVART",9,0)
|
---|
| 680 | ; PSN50P41 4531
|
---|
| 681 | "RTN","NHINVART",10,0)
|
---|
| 682 | ; PSN50P65 4543
|
---|
| 683 | "RTN","NHINVART",11,0)
|
---|
| 684 | ;
|
---|
| 685 | "RTN","NHINVART",12,0)
|
---|
| 686 | ; ------------ Get reactions from VistA ------------
|
---|
| 687 | "RTN","NHINVART",13,0)
|
---|
| 688 | ;
|
---|
| 689 | "RTN","NHINVART",14,0)
|
---|
| 690 | EN(DFN,BEG,END,MAX,IFN) ; -- find patient's allergies/reactions
|
---|
| 691 | "RTN","NHINVART",15,0)
|
---|
| 692 | N GMRA,GMRAL,NHI,NHITM,NHICNT
|
---|
| 693 | "RTN","NHINVART",16,0)
|
---|
| 694 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 695 | "RTN","NHINVART",17,0)
|
---|
| 696 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999),NHICNT=0
|
---|
| 697 | "RTN","NHINVART",18,0)
|
---|
| 698 | D EN1^GMRADPT
|
---|
| 699 | "RTN","NHINVART",19,0)
|
---|
| 700 | ;
|
---|
| 701 | "RTN","NHINVART",20,0)
|
---|
| 702 | ; get one reaction
|
---|
| 703 | "RTN","NHINVART",21,0)
|
---|
| 704 | I $G(IFN) D EN1(IFN,.NHITM),XML(.NHITM) Q
|
---|
| 705 | "RTN","NHINVART",22,0)
|
---|
| 706 | ;
|
---|
| 707 | "RTN","NHINVART",23,0)
|
---|
| 708 | ; get all reactions
|
---|
| 709 | "RTN","NHINVART",24,0)
|
---|
| 710 | I 'GMRAL S NHITM("assessment")=$S(GMRAL=0:"nka",1:"not done") D XML(.NHITM) Q
|
---|
| 711 | "RTN","NHINVART",25,0)
|
---|
| 712 | S NHI=0 F S NHI=+$O(GMRAL(NHI)) Q:NHI<1 D Q:NHICNT'<MAX
|
---|
| 713 | "RTN","NHINVART",26,0)
|
---|
| 714 | . K NHITM D EN1(NHI,.NHITM) Q:'$D(NHITM)
|
---|
| 715 | "RTN","NHINVART",27,0)
|
---|
| 716 | . D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 717 | "RTN","NHINVART",28,0)
|
---|
| 718 | Q
|
---|
| 719 | "RTN","NHINVART",29,0)
|
---|
| 720 | ;
|
---|
| 721 | "RTN","NHINVART",30,0)
|
---|
| 722 | EN1(ID,REAC) ; -- return a reaction in REAC("attribute")=value
|
---|
| 723 | "RTN","NHINVART",31,0)
|
---|
| 724 | ; from EN: expects GMRAL(ID)
|
---|
| 725 | "RTN","NHINVART",32,0)
|
---|
| 726 | N NHY,GMRA,I,J,X,Y,SEV,TXT,NM,SEV K REAC
|
---|
| 727 | "RTN","NHINVART",33,0)
|
---|
| 728 | S GMRA=$G(GMRAL(ID)) D EN1^GMRAOR2(ID,"NHY")
|
---|
| 729 | "RTN","NHINVART",34,0)
|
---|
| 730 | S X=$P(NHY,U,10) I $L(X) S X=$$DATE(X) Q:X<BEG Q:X>END S REAC("entered")=X
|
---|
| 731 | "RTN","NHINVART",35,0)
|
---|
| 732 | S REAC("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 733 | "RTN","NHINVART",36,0)
|
---|
| 734 | S REAC("id")=ID,REAC("name")=$P(NHY,U) I $P(GMRA,U,9) D
|
---|
| 735 | "RTN","NHINVART",37,0)
|
---|
| 736 | . S X=$P(GMRA,U,9),Y=+$P(X,"(",2) I 'Y,X["PSDRUG" S Y=50
|
---|
| 737 | "RTN","NHINVART",38,0)
|
---|
| 738 | . S REAC("localCode")=X,REAC("vuid")=$$VUID^NHINV(+X,Y)
|
---|
| 739 | "RTN","NHINVART",39,0)
|
---|
| 740 | S X=$P(NHY,U,6) S:$L(X) REAC("mechanism")=X
|
---|
| 741 | "RTN","NHINVART",40,0)
|
---|
| 742 | S X=$P(NHY,U,5),REAC("source")=$E(X)
|
---|
| 743 | "RTN","NHINVART",41,0)
|
---|
| 744 | S REAC("adverseEventType")=$S($L(GMRA):$P(GMRA,U,7),1:$$DFO($P(NHY,U,7)))
|
---|
| 745 | "RTN","NHINVART",42,0)
|
---|
| 746 | I $P(NHY,U,4)="VERIFIED",$P(NHY,U,9) S REAC("verified")=$P(NHY,U,9)
|
---|
| 747 | "RTN","NHINVART",43,0)
|
---|
| 748 | S I=0,SEV="" F S I=$O(NHY("O",I)) Q:I<1 S X=$P(NHY("O",I),U,2) S:X]SEV SEV=X ;find highest severity
|
---|
| 749 | "RTN","NHINVART",44,0)
|
---|
| 750 | S:$L(SEV) REAC("severity")=SEV
|
---|
| 751 | "RTN","NHINVART",45,0)
|
---|
| 752 | ; reactions
|
---|
| 753 | "RTN","NHINVART",46,0)
|
---|
| 754 | S I=0 F S I=$O(NHY("S",I)) Q:I<1 D
|
---|
| 755 | "RTN","NHINVART",47,0)
|
---|
| 756 | . S X=NHY("S",I),NM=$P(X," (") S:NM="" NM="OTHER REACTION"
|
---|
| 757 | "RTN","NHINVART",48,0)
|
---|
| 758 | . S Y=+$$FIND1^DIC(120.83,,"QX",NM)
|
---|
| 759 | "RTN","NHINVART",49,0)
|
---|
| 760 | . S REAC("reaction",I)=NM_U_$$VUID^NHINV(Y,120.83)
|
---|
| 761 | "RTN","NHINVART",50,0)
|
---|
| 762 | ; comments
|
---|
| 763 | "RTN","NHINVART",51,0)
|
---|
| 764 | S I=0 F S I=$O(NHY("C",I)) Q:I<1 D
|
---|
| 765 | "RTN","NHINVART",52,0)
|
---|
| 766 | . S X=$G(NHY("C",I)) K TXT
|
---|
| 767 | "RTN","NHINVART",53,0)
|
---|
| 768 | . S Y=$$VA200($P(X,U,3))_U_$P(X,U)
|
---|
| 769 | "RTN","NHINVART",54,0)
|
---|
| 770 | . S Y=Y_U_$S($L($P(X,U,2)):$E($P(X,U,2)),1:"E")
|
---|
| 771 | "RTN","NHINVART",55,0)
|
---|
| 772 | . S J=0 F S J=$O(NHY("C",I,J)) Q:J<1 S X=$G(NHY("C",I,J,0)),TXT(J)=X
|
---|
| 773 | "RTN","NHINVART",56,0)
|
---|
| 774 | . K X S X=$$STRING^NHINV(.TXT)
|
---|
| 775 | "RTN","NHINVART",57,0)
|
---|
| 776 | . S REAC("comment",I)=Y_U_X ;ien^name^date^type^text
|
---|
| 777 | "RTN","NHINVART",58,0)
|
---|
| 778 | ; drug info
|
---|
| 779 | "RTN","NHINVART",59,0)
|
---|
| 780 | I $D(NHY("I")) D
|
---|
| 781 | "RTN","NHINVART",60,0)
|
---|
| 782 | . N ROOT S ROOT=$$B^PSN50P41
|
---|
| 783 | "RTN","NHINVART",61,0)
|
---|
| 784 | . S I=0 F S I=$O(NHY("I",I)) Q:I<1 S X=$G(NHY("I",I)) D
|
---|
| 785 | "RTN","NHINVART",62,0)
|
---|
| 786 | .. N IEN S IEN=$O(@ROOT@(X,0))
|
---|
| 787 | "RTN","NHINVART",63,0)
|
---|
| 788 | .. S REAC("drugIngredient",I)=X_U_$$VUID^NHINV(IEN,50.416)
|
---|
| 789 | "RTN","NHINVART",64,0)
|
---|
| 790 | I $D(NHY("V")) D
|
---|
| 791 | "RTN","NHINVART",65,0)
|
---|
| 792 | . S I=0 F S I=$O(NHY("V",I)) Q:I<1 S X=$G(NHY("V",I)) D
|
---|
| 793 | "RTN","NHINVART",66,0)
|
---|
| 794 | .. D C^PSN50P65("",$P(X,U,2),"PSN")
|
---|
| 795 | "RTN","NHINVART",67,0)
|
---|
| 796 | .. N IEN S IEN=+$O(^TMP($J,"PSN","C",$P(X,U),0))
|
---|
| 797 | "RTN","NHINVART",68,0)
|
---|
| 798 | .. S REAC("drugClass",I)=$P(X,U,2)_U_$$VUID^NHINV(IEN,50.605)
|
---|
| 799 | "RTN","NHINVART",69,0)
|
---|
| 800 | I GMRA="" S REAC("removed")=1 ;entered in error
|
---|
| 801 | "RTN","NHINVART",70,0)
|
---|
| 802 | Q
|
---|
| 803 | "RTN","NHINVART",71,0)
|
---|
| 804 | ;
|
---|
| 805 | "RTN","NHINVART",72,0)
|
---|
| 806 | VA200(NAME) ; -- Return ien^name from #200
|
---|
| 807 | "RTN","NHINVART",73,0)
|
---|
| 808 | N Y S NAME=$G(NAME),Y="^"
|
---|
| 809 | "RTN","NHINVART",74,0)
|
---|
| 810 | I $L(NAME) S Y=+$O(^VA(200,"B",NAME,0))_U_NAME
|
---|
| 811 | "RTN","NHINVART",75,0)
|
---|
| 812 | Q Y
|
---|
| 813 | "RTN","NHINVART",76,0)
|
---|
| 814 | ;
|
---|
| 815 | "RTN","NHINVART",77,0)
|
---|
| 816 | DATE(X) ; -- Return internal form of date X
|
---|
| 817 | "RTN","NHINVART",78,0)
|
---|
| 818 | N %DT,Y
|
---|
| 819 | "RTN","NHINVART",79,0)
|
---|
| 820 | S %DT="TX" D ^%DT
|
---|
| 821 | "RTN","NHINVART",80,0)
|
---|
| 822 | Q Y
|
---|
| 823 | "RTN","NHINVART",81,0)
|
---|
| 824 | ;
|
---|
| 825 | "RTN","NHINVART",82,0)
|
---|
| 826 | DFO(X) ; -- Return 'DFO' string for mechanism name(s)
|
---|
| 827 | "RTN","NHINVART",83,0)
|
---|
| 828 | N I,P,Y S Y=""
|
---|
| 829 | "RTN","NHINVART",84,0)
|
---|
| 830 | F I=1:1:$L(X,",") S P=$P(X,",",I),Y=Y_$S($E(P)=" ":$E(P,2),1:$E(P))
|
---|
| 831 | "RTN","NHINVART",85,0)
|
---|
| 832 | S:Y="" Y=$G(X)
|
---|
| 833 | "RTN","NHINVART",86,0)
|
---|
| 834 | Q Y
|
---|
| 835 | "RTN","NHINVART",87,0)
|
---|
| 836 | ;
|
---|
| 837 | "RTN","NHINVART",88,0)
|
---|
| 838 | ; ------------ Return data to middle tier ------------
|
---|
| 839 | "RTN","NHINVART",89,0)
|
---|
| 840 | ;
|
---|
| 841 | "RTN","NHINVART",90,0)
|
---|
| 842 | XML(REAC) ; -- Return patient reaction as XML
|
---|
| 843 | "RTN","NHINVART",91,0)
|
---|
| 844 | ; as <element code='123' displayName='ABC' />
|
---|
| 845 | "RTN","NHINVART",92,0)
|
---|
| 846 | N ATT,X,Y,I,P,NM,TAG
|
---|
| 847 | "RTN","NHINVART",93,0)
|
---|
| 848 | D ADD("<allergy>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 849 | "RTN","NHINVART",94,0)
|
---|
| 850 | S ATT="" F S ATT=$O(REAC(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 851 | "RTN","NHINVART",95,0)
|
---|
| 852 | . I ATT="comment" D S Y="" Q
|
---|
| 853 | "RTN","NHINVART",96,0)
|
---|
| 854 | .. S I=0,Y="<comments>" D ADD(Y)
|
---|
| 855 | "RTN","NHINVART",97,0)
|
---|
| 856 | .. F S I=$O(REAC(ATT,I)) Q:I<1 S X=$G(REAC(ATT,I)) D
|
---|
| 857 | "RTN","NHINVART",98,0)
|
---|
| 858 | ... S Y="<comment id='"_I
|
---|
| 859 | "RTN","NHINVART",99,0)
|
---|
| 860 | ... S:$L($P(X,U,3)) Y=Y_"' entered='"_$P(X,U,3)
|
---|
| 861 | "RTN","NHINVART",100,0)
|
---|
| 862 | ... S:$L($P(X,U,2)) Y=Y_"' enteredBy='"_$$ESC^NHINV($P(X,U,2))
|
---|
| 863 | "RTN","NHINVART",101,0)
|
---|
| 864 | ... S:$L($P(X,U,4)) Y=Y_"' commentType='"_$P(X,U,4)
|
---|
| 865 | "RTN","NHINVART",102,0)
|
---|
| 866 | ... S:$L($P(X,U,5)) Y=Y_"' commentText='"_$$ESC^NHINV($P(X,U,5))
|
---|
| 867 | "RTN","NHINVART",103,0)
|
---|
| 868 | ... S Y=Y_"' />" D ADD(Y)
|
---|
| 869 | "RTN","NHINVART",104,0)
|
---|
| 870 | .. D ADD("</comments>")
|
---|
| 871 | "RTN","NHINVART",105,0)
|
---|
| 872 | . I $O(REAC(ATT,0)) D S Y="" Q
|
---|
| 873 | "RTN","NHINVART",106,0)
|
---|
| 874 | .. S NM=ATT_$S($E(ATT,$L(ATT))="s":"es",1:"s") D ADD("<"_NM_">")
|
---|
| 875 | "RTN","NHINVART",107,0)
|
---|
| 876 | .. S I=0 F S I=$O(REAC(ATT,I)) Q:I<1 D
|
---|
| 877 | "RTN","NHINVART",108,0)
|
---|
| 878 | ... S X=$G(REAC(ATT,I)),Y="<"_ATT_" "
|
---|
| 879 | "RTN","NHINVART",109,0)
|
---|
| 880 | ... F P=1:1 S TAG=$P("name^vuid^severity^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 881 | "RTN","NHINVART",110,0)
|
---|
| 882 | ... S Y=Y_"/>" D ADD(Y)
|
---|
| 883 | "RTN","NHINVART",111,0)
|
---|
| 884 | .. D ADD("</"_NM_">")
|
---|
| 885 | "RTN","NHINVART",112,0)
|
---|
| 886 | . S X=$G(REAC(ATT)),Y="" Q:'$L(X)
|
---|
| 887 | "RTN","NHINVART",113,0)
|
---|
| 888 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 889 | "RTN","NHINVART",114,0)
|
---|
| 890 | . I $L(X)>1 D S Y=""
|
---|
| 891 | "RTN","NHINVART",115,0)
|
---|
| 892 | .. S Y="<"_ATT_" "
|
---|
| 893 | "RTN","NHINVART",116,0)
|
---|
| 894 | .. F P=1:1 S TAG=$P("code^name^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 895 | "RTN","NHINVART",117,0)
|
---|
| 896 | .. S Y=Y_"/>" D ADD(Y)
|
---|
| 897 | "RTN","NHINVART",118,0)
|
---|
| 898 | D ADD("</allergy>")
|
---|
| 899 | "RTN","NHINVART",119,0)
|
---|
| 900 | Q
|
---|
| 901 | "RTN","NHINVART",120,0)
|
---|
| 902 | ;
|
---|
| 903 | "RTN","NHINVART",121,0)
|
---|
| 904 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 905 | "RTN","NHINVART",122,0)
|
---|
| 906 | S NHINI=$G(NHINI)+1
|
---|
| 907 | "RTN","NHINVART",123,0)
|
---|
| 908 | S @NHIN@(NHINI)=X
|
---|
| 909 | "RTN","NHINVART",124,0)
|
---|
| 910 | Q
|
---|
| 911 | "RTN","NHINVART",125,0)
|
---|
| 912 | ;
|
---|
| 913 | "RTN","NHINVART",126,0)
|
---|
| 914 | C32(REAC) ; -- convert iens to C32 codes
|
---|
| 915 | "RTN","NHINVART",127,0)
|
---|
| 916 | N X,Y,I
|
---|
| 917 | "RTN","NHINVART",128,0)
|
---|
| 918 | S X=$G(REAC("product")) I X S $P(REAC("product"),U)=$$VUID^NHINV(+X,120.82)
|
---|
| 919 | "RTN","NHINVART",129,0)
|
---|
| 920 | S X=$P($G(REAC("type")),U),Y=$P($G(REAC("mechanism")),U)
|
---|
| 921 | "RTN","NHINVART",130,0)
|
---|
| 922 | I $L(X) D S $P(REAC("type"),U)=I
|
---|
| 923 | "RTN","NHINVART",131,0)
|
---|
| 924 | . I Y="A" S I=$S(X["D":416098002,X["F":414285001,1:419199007) Q
|
---|
| 925 | "RTN","NHINVART",132,0)
|
---|
| 926 | . I Y="P" S I=$S(X["D":59037007,X["F":235719002,1:420134006) Q
|
---|
| 927 | "RTN","NHINVART",133,0)
|
---|
| 928 | . S I=$S(X["D":419511003,X["F":418471000,1:418038007)
|
---|
| 929 | "RTN","NHINVART",134,0)
|
---|
| 930 | S X=+$G(REAC("severity")) I X D
|
---|
| 931 | "RTN","NHINVART",135,0)
|
---|
| 932 | . S X=$S(X=1:255604002,X=2:6736007,X=3:24484000,1:X)
|
---|
| 933 | "RTN","NHINVART",136,0)
|
---|
| 934 | . S $P(REAC("severity"),U)=X
|
---|
| 935 | "RTN","NHINVART",137,0)
|
---|
| 936 | S I=0 F S I=$O(REAC("reaction",I)) Q:I<1 D
|
---|
| 937 | "RTN","NHINVART",138,0)
|
---|
| 938 | . S X=$G(REAC("reaction",I)) Q:'X
|
---|
| 939 | "RTN","NHINVART",139,0)
|
---|
| 940 | . S $P(REAC("reaction",I),U)=$$VUID^NHINV(+X,120.83)
|
---|
| 941 | "RTN","NHINVART",140,0)
|
---|
| 942 | S I=0 F S I=$O(REAC("drugClass",I)) Q:I<1 D
|
---|
| 943 | "RTN","NHINVART",141,0)
|
---|
| 944 | . S X=$G(REAC("drugClass",I)) Q:'X
|
---|
| 945 | "RTN","NHINVART",142,0)
|
---|
| 946 | . S $P(REAC("drugClass",I),U)=$$VUID^NHINV(+X,50.605)
|
---|
| 947 | "RTN","NHINVART",143,0)
|
---|
| 948 | S I=0 F S I=$O(REAC("drugIngredient",I)) Q:I<1 D
|
---|
| 949 | "RTN","NHINVART",144,0)
|
---|
| 950 | . S X=$G(REAC("drugIngredient",I)) Q:'X
|
---|
| 951 | "RTN","NHINVART",145,0)
|
---|
| 952 | . S $P(REAC("drugIngredient",I),U)=$$VUID^NHINV(+X,50.416)
|
---|
| 953 | "RTN","NHINVART",146,0)
|
---|
| 954 | Q
|
---|
| 955 | "RTN","NHINVIMM")
|
---|
| 956 | 0^14^B9313203^n/a
|
---|
| 957 | "RTN","NHINVIMM",1,0)
|
---|
| 958 | NHINVIMM ;SLC/MKB -- Immunizations extract
|
---|
| 959 | "RTN","NHINVIMM",2,0)
|
---|
| 960 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 961 | "RTN","NHINVIMM",3,0)
|
---|
| 962 | ;
|
---|
| 963 | "RTN","NHINVIMM",4,0)
|
---|
| 964 | ; External References DBIA#
|
---|
| 965 | "RTN","NHINVIMM",5,0)
|
---|
| 966 | ; ------------------- -----
|
---|
| 967 | "RTN","NHINVIMM",6,0)
|
---|
| 968 | ; ^DIC(4 10090
|
---|
| 969 | "RTN","NHINVIMM",7,0)
|
---|
| 970 | ; ^VA(200 10060
|
---|
| 971 | "RTN","NHINVIMM",8,0)
|
---|
| 972 | ; DIC 2051
|
---|
| 973 | "RTN","NHINVIMM",9,0)
|
---|
| 974 | ; DIQ 2056
|
---|
| 975 | "RTN","NHINVIMM",10,0)
|
---|
| 976 | ; PXRHS03,^TMP("PXI",$J) 1239
|
---|
| 977 | "RTN","NHINVIMM",11,0)
|
---|
| 978 | ; XUAF4 2171
|
---|
| 979 | "RTN","NHINVIMM",12,0)
|
---|
| 980 | ;
|
---|
| 981 | "RTN","NHINVIMM",13,0)
|
---|
| 982 | ; ------------ Get immunizations from VistA ------------
|
---|
| 983 | "RTN","NHINVIMM",14,0)
|
---|
| 984 | ;
|
---|
| 985 | "RTN","NHINVIMM",15,0)
|
---|
| 986 | EN(DFN,BEG,END,MAX,IFN) ; -- find patient's immunizations
|
---|
| 987 | "RTN","NHINVIMM",16,0)
|
---|
| 988 | N NHITM,NHICNT,NM,IDT,X
|
---|
| 989 | "RTN","NHINVIMM",17,0)
|
---|
| 990 | S DFN=+$G(DFN) Q:DFN<1 ;invalid patient
|
---|
| 991 | "RTN","NHINVIMM",18,0)
|
---|
| 992 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999),NHICNT=0
|
---|
| 993 | "RTN","NHINVIMM",19,0)
|
---|
| 994 | K ^TMP("PXI",$J) D IMMUN^PXRHS03(DFN)
|
---|
| 995 | "RTN","NHINVIMM",20,0)
|
---|
| 996 | ;
|
---|
| 997 | "RTN","NHINVIMM",21,0)
|
---|
| 998 | ; get one immunization
|
---|
| 999 | "RTN","NHINVIMM",22,0)
|
---|
| 1000 | I $G(IFN) D Q
|
---|
| 1001 | "RTN","NHINVIMM",23,0)
|
---|
| 1002 | . N DONE S DONE=0
|
---|
| 1003 | "RTN","NHINVIMM",24,0)
|
---|
| 1004 | . S NM="" F S NM=$O(^TMP("PXI",$J,NM)) Q:NM="" D Q:DONE
|
---|
| 1005 | "RTN","NHINVIMM",25,0)
|
---|
| 1006 | .. S IDT=0 F S IDT=$O(^TMP("PXI",$J,NM,IDT)) Q:IDT<1 I $D(^(IDT,IFN)) D Q
|
---|
| 1007 | "RTN","NHINVIMM",26,0)
|
---|
| 1008 | ... D EN1(.NHITM),XML(.NHITM)
|
---|
| 1009 | "RTN","NHINVIMM",27,0)
|
---|
| 1010 | ... S DONE=1
|
---|
| 1011 | "RTN","NHINVIMM",28,0)
|
---|
| 1012 | . K ^TMP("PXI",$J)
|
---|
| 1013 | "RTN","NHINVIMM",29,0)
|
---|
| 1014 | ;
|
---|
| 1015 | "RTN","NHINVIMM",30,0)
|
---|
| 1016 | ; get all immunizations
|
---|
| 1017 | "RTN","NHINVIMM",31,0)
|
---|
| 1018 | S X=BEG,BEG=9999999-END-.000001,END=9999999-X I $L(END,".")<2 S END=END_".2359"
|
---|
| 1019 | "RTN","NHINVIMM",32,0)
|
---|
| 1020 | S NM="" F S NM=$O(^TMP("PXI",$J,NM)) Q:NM="" D
|
---|
| 1021 | "RTN","NHINVIMM",33,0)
|
---|
| 1022 | . S IDT=BEG F S IDT=$O(^TMP("PXI",$J,NM,IDT)) Q:IDT<1!(IDT>END) D
|
---|
| 1023 | "RTN","NHINVIMM",34,0)
|
---|
| 1024 | .. S IFN=0 F S IFN=$O(^TMP("PXI",$J,NM,IDT,IFN)) Q:IFN<1 D Q:NHICNT'<MAX
|
---|
| 1025 | "RTN","NHINVIMM",35,0)
|
---|
| 1026 | ... K NHITM D EN1(.NHITM),XML(.NHITM)
|
---|
| 1027 | "RTN","NHINVIMM",36,0)
|
---|
| 1028 | ... S NHICNT=NHICNT+1
|
---|
| 1029 | "RTN","NHINVIMM",37,0)
|
---|
| 1030 | K ^TMP("PXI",$J)
|
---|
| 1031 | "RTN","NHINVIMM",38,0)
|
---|
| 1032 | Q
|
---|
| 1033 | "RTN","NHINVIMM",39,0)
|
---|
| 1034 | ;
|
---|
| 1035 | "RTN","NHINVIMM",40,0)
|
---|
| 1036 | EN1(IMM) ; -- return an immunization in IMM("attribute")=value
|
---|
| 1037 | "RTN","NHINVIMM",41,0)
|
---|
| 1038 | ; Expects ^TMP("PXI",$J,NM,IDT,IFN) from IMMUN^PXRHS03
|
---|
| 1039 | "RTN","NHINVIMM",42,0)
|
---|
| 1040 | N X0,X1,CPT,DA,X,Y K IMM
|
---|
| 1041 | "RTN","NHINVIMM",43,0)
|
---|
| 1042 | S X0=$G(^TMP("PXI",$J,NM,IDT,IFN,0)),X1=$G(^(1)),X=$G(^("COM"))
|
---|
| 1043 | "RTN","NHINVIMM",44,0)
|
---|
| 1044 | S:$L(X) IMM("comment")=X
|
---|
| 1045 | "RTN","NHINVIMM",45,0)
|
---|
| 1046 | S IMM("id")=IFN,IMM("name")=$P(X0,U)
|
---|
| 1047 | "RTN","NHINVIMM",46,0)
|
---|
| 1048 | S IMM("administered")=+$P(X0,U,3)
|
---|
| 1049 | "RTN","NHINVIMM",47,0)
|
---|
| 1050 | S IMM("series")=$P(X0,U,5)
|
---|
| 1051 | "RTN","NHINVIMM",48,0)
|
---|
| 1052 | S IMM("reaction")=$P(X0,U,6)
|
---|
| 1053 | "RTN","NHINVIMM",49,0)
|
---|
| 1054 | S IMM("contraindicated")=+$P(X0,U,7)
|
---|
| 1055 | "RTN","NHINVIMM",50,0)
|
---|
| 1056 | S IMM("location")=$P(X1,U)
|
---|
| 1057 | "RTN","NHINVIMM",51,0)
|
---|
| 1058 | S X=$P(X1,U,3) I $L(X) D
|
---|
| 1059 | "RTN","NHINVIMM",52,0)
|
---|
| 1060 | . S Y=$$LKUP^XUAF4(X) ;ien
|
---|
| 1061 | "RTN","NHINVIMM",53,0)
|
---|
| 1062 | . I Y<1 S Y=+$O(^DIC(4,"B",X,0)) ;dupl -> get 1st
|
---|
| 1063 | "RTN","NHINVIMM",54,0)
|
---|
| 1064 | . S IMM("facility")=$$STA^XUAF4(Y)_U_X
|
---|
| 1065 | "RTN","NHINVIMM",55,0)
|
---|
| 1066 | I '$D(IMM("facility")) S IMM("facility")=$$FAC^NHINV
|
---|
| 1067 | "RTN","NHINVIMM",56,0)
|
---|
| 1068 | S X=$P(X0,U,9) S:'$L(X) X=$P(X0,U,8)
|
---|
| 1069 | "RTN","NHINVIMM",57,0)
|
---|
| 1070 | I $L(X) S IMM("provider")=+$O(^VA(200,"B",X,0))_U_X
|
---|
| 1071 | "RTN","NHINVIMM",58,0)
|
---|
| 1072 | ;
|
---|
| 1073 | "RTN","NHINVIMM",59,0)
|
---|
| 1074 | S DA=+$$GET1^DIQ(9000010.11,IFN_",",.01,"I") Q:'DA
|
---|
| 1075 | "RTN","NHINVIMM",60,0)
|
---|
| 1076 | S X=+$$FIND1^DIC(811.1,,"QX",DA_";AUTTIMM(","B") I X>0 D
|
---|
| 1077 | "RTN","NHINVIMM",61,0)
|
---|
| 1078 | . S Y=$$GET1^DIQ(811.1,X_",",.02,"I") Q:Y<1
|
---|
| 1079 | "RTN","NHINVIMM",62,0)
|
---|
| 1080 | . S CPT=$G(@(U_$P(Y,";",2)_+Y_",0)"))
|
---|
| 1081 | "RTN","NHINVIMM",63,0)
|
---|
| 1082 | . S IMM("cpt")=$P(CPT,U,1,2)
|
---|
| 1083 | "RTN","NHINVIMM",64,0)
|
---|
| 1084 | Q
|
---|
| 1085 | "RTN","NHINVIMM",65,0)
|
---|
| 1086 | ;
|
---|
| 1087 | "RTN","NHINVIMM",66,0)
|
---|
| 1088 | ; ------------ Return data to middle tier ------------
|
---|
| 1089 | "RTN","NHINVIMM",67,0)
|
---|
| 1090 | ;
|
---|
| 1091 | "RTN","NHINVIMM",68,0)
|
---|
| 1092 | XML(IMM) ; -- Return immunizations as XML
|
---|
| 1093 | "RTN","NHINVIMM",69,0)
|
---|
| 1094 | N ATT,X,Y,I,P,NAMES,TAG
|
---|
| 1095 | "RTN","NHINVIMM",70,0)
|
---|
| 1096 | D ADD("<immunization>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 1097 | "RTN","NHINVIMM",71,0)
|
---|
| 1098 | S ATT="" F S ATT=$O(IMM(ATT)) Q:ATT="" D
|
---|
| 1099 | "RTN","NHINVIMM",72,0)
|
---|
| 1100 | . S X=$G(IMM(ATT)),Y="" Q:'$L(X)
|
---|
| 1101 | "RTN","NHINVIMM",73,0)
|
---|
| 1102 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" D ADD(Y) Q
|
---|
| 1103 | "RTN","NHINVIMM",74,0)
|
---|
| 1104 | . I $L(X)>1 D
|
---|
| 1105 | "RTN","NHINVIMM",75,0)
|
---|
| 1106 | .. S Y="<"_ATT_" "
|
---|
| 1107 | "RTN","NHINVIMM",76,0)
|
---|
| 1108 | .. F P=1:1 S TAG=$P("code^name^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 1109 | "RTN","NHINVIMM",77,0)
|
---|
| 1110 | .. S Y=Y_"/>" D ADD(Y)
|
---|
| 1111 | "RTN","NHINVIMM",78,0)
|
---|
| 1112 | D ADD("</immunization>")
|
---|
| 1113 | "RTN","NHINVIMM",79,0)
|
---|
| 1114 | Q
|
---|
| 1115 | "RTN","NHINVIMM",80,0)
|
---|
| 1116 | ;
|
---|
| 1117 | "RTN","NHINVIMM",81,0)
|
---|
| 1118 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 1119 | "RTN","NHINVIMM",82,0)
|
---|
| 1120 | S NHINI=$G(NHINI)+1
|
---|
| 1121 | "RTN","NHINVIMM",83,0)
|
---|
| 1122 | S @NHIN@(NHINI)=X
|
---|
| 1123 | "RTN","NHINVIMM",84,0)
|
---|
| 1124 | Q
|
---|
| 1125 | "RTN","NHINVIT")
|
---|
| 1126 | 0^4^B33591565^n/a
|
---|
| 1127 | "RTN","NHINVIT",1,0)
|
---|
| 1128 | NHINVIT ;SLC/MKB -- Vitals extract
|
---|
| 1129 | "RTN","NHINVIT",2,0)
|
---|
| 1130 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 1131 | "RTN","NHINVIT",3,0)
|
---|
| 1132 | ;
|
---|
| 1133 | "RTN","NHINVIT",4,0)
|
---|
| 1134 | ; External References DBIA#
|
---|
| 1135 | "RTN","NHINVIT",5,0)
|
---|
| 1136 | ; ------------------- -----
|
---|
| 1137 | "RTN","NHINVIT",6,0)
|
---|
| 1138 | ; ^SC 10040
|
---|
| 1139 | "RTN","NHINVIT",7,0)
|
---|
| 1140 | ; ^VA(200 10060
|
---|
| 1141 | "RTN","NHINVIT",8,0)
|
---|
| 1142 | ; DIC 2051
|
---|
| 1143 | "RTN","NHINVIT",9,0)
|
---|
| 1144 | ; DIQ 2056
|
---|
| 1145 | "RTN","NHINVIT",10,0)
|
---|
| 1146 | ; GMRVUT0,^UTILITY($J,"GMRVD") 1446
|
---|
| 1147 | "RTN","NHINVIT",11,0)
|
---|
| 1148 | ; GMVPXRM 3647
|
---|
| 1149 | "RTN","NHINVIT",12,0)
|
---|
| 1150 | ;
|
---|
| 1151 | "RTN","NHINVIT",13,0)
|
---|
| 1152 | ; ------------ Get vitals from VistA ------------
|
---|
| 1153 | "RTN","NHINVIT",14,0)
|
---|
| 1154 | ;
|
---|
| 1155 | "RTN","NHINVIT",15,0)
|
---|
| 1156 | EN(DFN,BEG,END,MAX,IFN) ; -- find patient's vitals
|
---|
| 1157 | "RTN","NHINVIT",16,0)
|
---|
| 1158 | N NHITM,NHIPRM,GMRVSTR,IDT,TYPE,VIT,CNT,X0,X,Y,I,N
|
---|
| 1159 | "RTN","NHINVIT",17,0)
|
---|
| 1160 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 1161 | "RTN","NHINVIT",18,0)
|
---|
| 1162 | ;
|
---|
| 1163 | "RTN","NHINVIT",19,0)
|
---|
| 1164 | ; get one measurement
|
---|
| 1165 | "RTN","NHINVIT",20,0)
|
---|
| 1166 | I $G(IFN) D EN1(IFN,.NHITM),XML(.NHITM) Q
|
---|
| 1167 | "RTN","NHINVIT",21,0)
|
---|
| 1168 | ;
|
---|
| 1169 | "RTN","NHINVIT",22,0)
|
---|
| 1170 | ; get all measurements
|
---|
| 1171 | "RTN","NHINVIT",23,0)
|
---|
| 1172 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 1173 | "RTN","NHINVIT",24,0)
|
---|
| 1174 | S GMRVSTR="BP;T;R;P;HT;WT;CVP;CG;PO2;PN",GMRVSTR(0)=BEG_U_END_U_MAX_"^1"
|
---|
| 1175 | "RTN","NHINVIT",25,0)
|
---|
| 1176 | K ^UTILITY($J,"GMRVD") D EN1^GMRVUT0
|
---|
| 1177 | "RTN","NHINVIT",26,0)
|
---|
| 1178 | S (IDT,CNT)=0 F S IDT=$O(^UTILITY($J,"GMRVD",IDT)) Q:IDT<1 D Q:CNT'<MAX
|
---|
| 1179 | "RTN","NHINVIT",27,0)
|
---|
| 1180 | . K VIT S VIT("taken")=9999999-IDT,CNT=CNT+1,N=0
|
---|
| 1181 | "RTN","NHINVIT",28,0)
|
---|
| 1182 | . S TYPE="" F S TYPE=$O(^UTILITY($J,"GMRVD",IDT,TYPE)) Q:TYPE="" D
|
---|
| 1183 | "RTN","NHINVIT",29,0)
|
---|
| 1184 | .. N NAME,VUID,RESULT,UNIT,MRES,MUNT,HIGH,LOW,QUAL
|
---|
| 1185 | "RTN","NHINVIT",30,0)
|
---|
| 1186 | .. S IFN=+$O(^UTILITY($J,"GMRVD",IDT,TYPE,0)),X0=$G(^(IFN))
|
---|
| 1187 | "RTN","NHINVIT",31,0)
|
---|
| 1188 | .. S X=+$P(X0,U,3),NAME=$$GET1^DIQ(120.5,IFN_",",.03)
|
---|
| 1189 | "RTN","NHINVIT",32,0)
|
---|
| 1190 | .. S VUID=$$VUID^NHINV(X,120.51),RESULT=$P(X0,U,8)
|
---|
| 1191 | "RTN","NHINVIT",33,0)
|
---|
| 1192 | .. S UNIT=$S(TYPE="T":"F",TYPE="HT":"in",TYPE="WT":"lb",TYPE="CVP":"cmH2O",TYPE="CG":"in",1:"")
|
---|
| 1193 | "RTN","NHINVIT",34,0)
|
---|
| 1194 | .. S (MRES,MUNT)="" I $L($P(X0,U,13)) D
|
---|
| 1195 | "RTN","NHINVIT",35,0)
|
---|
| 1196 | ... S X=$S(TYPE="T":"C",TYPE="HT":"cm",TYPE="WT":"kg",TYPE="CG":"cm",1:"")
|
---|
| 1197 | "RTN","NHINVIT",36,0)
|
---|
| 1198 | ... S MRES=$P(X0,U,13) S:$L(X) MUNT=X
|
---|
| 1199 | "RTN","NHINVIT",37,0)
|
---|
| 1200 | .. S X=$$RANGE(TYPE),(HIGH,LOW)="" I $L(X) S HIGH=$P(X,U),LOW=$P(X,U,2)
|
---|
| 1201 | "RTN","NHINVIT",38,0)
|
---|
| 1202 | .. S N=N+1,VIT("measurement",N)=IFN_U_VUID_U_NAME_U_RESULT_U_UNIT_U_MRES_U_MUNT_U_HIGH_U_LOW
|
---|
| 1203 | "RTN","NHINVIT",39,0)
|
---|
| 1204 | .. S QUAL=$P(X0,U,17) I $L(QUAL) F I=1:1:$L(QUAL,";") D
|
---|
| 1205 | "RTN","NHINVIT",40,0)
|
---|
| 1206 | ... S X=$P(QUAL,";",I),Y=$$FIND1^DIC(120.52,,"QX",X)
|
---|
| 1207 | "RTN","NHINVIT",41,0)
|
---|
| 1208 | ... I Y S VIT("measurement",N,"qualifier",I)=X_U_$$VUID^NHINV(Y,120.52)
|
---|
| 1209 | "RTN","NHINVIT",42,0)
|
---|
| 1210 | . S VIT("entered")=$P($G(X0),U,4) ;use last one
|
---|
| 1211 | "RTN","NHINVIT",43,0)
|
---|
| 1212 | . S X=+$P($G(X0),U,5) S:X VIT("location")=$$LOC(X)
|
---|
| 1213 | "RTN","NHINVIT",44,0)
|
---|
| 1214 | . S VIT("facility")=$$FAC^NHINV(X)
|
---|
| 1215 | "RTN","NHINVIT",45,0)
|
---|
| 1216 | . D XML(.VIT)
|
---|
| 1217 | "RTN","NHINVIT",46,0)
|
---|
| 1218 | K ^UTILITY($J,"GMRVD")
|
---|
| 1219 | "RTN","NHINVIT",47,0)
|
---|
| 1220 | Q
|
---|
| 1221 | "RTN","NHINVIT",48,0)
|
---|
| 1222 | ;
|
---|
| 1223 | "RTN","NHINVIT",49,0)
|
---|
| 1224 | EN1(ID,VIT) ; -- return a vital/measurement in VIT("attribute")
|
---|
| 1225 | "RTN","NHINVIT",50,0)
|
---|
| 1226 | K VIT S ID=+$G(ID) Q:ID<1 ;invalid ien
|
---|
| 1227 | "RTN","NHINVIT",51,0)
|
---|
| 1228 | N NHY,DFN,TYPE,X,Y,NAME,VUID,RESULT,UNIT,MRES,MUNT,HIGH,LOW,I
|
---|
| 1229 | "RTN","NHINVIT",52,0)
|
---|
| 1230 | D EN^GMVPXRM(.NHY,ID,"B")
|
---|
| 1231 | "RTN","NHINVIT",53,0)
|
---|
| 1232 | S DFN=+$G(NHY(2)) Q:DFN<1
|
---|
| 1233 | "RTN","NHINVIT",54,0)
|
---|
| 1234 | S TYPE=$$GET1^DIQ(120.51,+NHY(3)_",",1)
|
---|
| 1235 | "RTN","NHINVIT",55,0)
|
---|
| 1236 | S VIT("facility")=$$FAC^NHINV(+NHY(5)),VIT("location")=NHY(5)
|
---|
| 1237 | "RTN","NHINVIT",56,0)
|
---|
| 1238 | S NAME=$P(NHY(3),U,2),VUID=$$VUID^NHINV(+NHY(3),120.51)
|
---|
| 1239 | "RTN","NHINVIT",57,0)
|
---|
| 1240 | S X=$P(NHY(7),U,2),RESULT=X,(UNIT,MRES,MUNT)=""
|
---|
| 1241 | "RTN","NHINVIT",58,0)
|
---|
| 1242 | I TYPE="T" S UNIT="F",MUNT="C" S MRES=$J(X-32*5/9,0,1) ; EN1^GMRVUTL
|
---|
| 1243 | "RTN","NHINVIT",59,0)
|
---|
| 1244 | I TYPE="HT" S UNIT="in",MUNT="cm" S MRES=$J(2.54*X,0,2) ; EN2^GMRVUTL
|
---|
| 1245 | "RTN","NHINVIT",60,0)
|
---|
| 1246 | I TYPE="WT" S UNIT="lb",MUNT="kg" S MRES=$J(X/2.2,0,2) ; EN3^GMRVUTL
|
---|
| 1247 | "RTN","NHINVIT",61,0)
|
---|
| 1248 | I TYPE="CG" S UNIT="in",MUNT="cm" S MRES=$J(2.54*X,0,2)
|
---|
| 1249 | "RTN","NHINVIT",62,0)
|
---|
| 1250 | I TYPE="CVP" S UNIT="cmH2O"
|
---|
| 1251 | "RTN","NHINVIT",63,0)
|
---|
| 1252 | S VIT("taken")=+NHY(1),VIT("entered")=+NHY(4),(HIGH,LOW)=""
|
---|
| 1253 | "RTN","NHINVIT",64,0)
|
---|
| 1254 | S X=$$RANGE(TYPE) I $L(X) S HIGH=$P(X,U),LOW=$P(X,U,2)
|
---|
| 1255 | "RTN","NHINVIT",65,0)
|
---|
| 1256 | S VIT("measurement",1)=ID_U_VUID_U_NAME_U_RESULT_U_UNIT_U_MRES_U_MUNT_U_HIGH_U_LOW
|
---|
| 1257 | "RTN","NHINVIT",66,0)
|
---|
| 1258 | S I=0 F S I=$O(NHY(12,I)) Q:I<1 S X=$G(NHY(12,I)),VIT("measurement",1,"qualifier",I)=$P(X,U,2)_U_$$VUID^NHINV(+X,120.52)
|
---|
| 1259 | "RTN","NHINVIT",67,0)
|
---|
| 1260 | I $G(NHY(9)) D ;entered in error/reasons
|
---|
| 1261 | "RTN","NHINVIT",68,0)
|
---|
| 1262 | . S I=0 F S I=$O(NHY(11,I)) Q:I<1 S VIT("removed",I)=$P(NHY(11,I),U,2)
|
---|
| 1263 | "RTN","NHINVIT",69,0)
|
---|
| 1264 | Q
|
---|
| 1265 | "RTN","NHINVIT",70,0)
|
---|
| 1266 | ;
|
---|
| 1267 | "RTN","NHINVIT",71,0)
|
---|
| 1268 | USER(X) ; -- Return ien^name for person# X
|
---|
| 1269 | "RTN","NHINVIT",72,0)
|
---|
| 1270 | N Y S X=+$G(X)
|
---|
| 1271 | "RTN","NHINVIT",73,0)
|
---|
| 1272 | S Y=$S(X:X_U_$P($G(^VA(200,X,0)),U),1:"^")
|
---|
| 1273 | "RTN","NHINVIT",74,0)
|
---|
| 1274 | Q Y
|
---|
| 1275 | "RTN","NHINVIT",75,0)
|
---|
| 1276 | ;
|
---|
| 1277 | "RTN","NHINVIT",76,0)
|
---|
| 1278 | LOC(X) ; -- Return ien^name for hospital location X
|
---|
| 1279 | "RTN","NHINVIT",77,0)
|
---|
| 1280 | N Y S X=+$G(X)
|
---|
| 1281 | "RTN","NHINVIT",78,0)
|
---|
| 1282 | S Y=$S(X:X_U_$P($G(^SC(X,0)),U),1:"^")
|
---|
| 1283 | "RTN","NHINVIT",79,0)
|
---|
| 1284 | Q Y
|
---|
| 1285 | "RTN","NHINVIT",80,0)
|
---|
| 1286 | ;
|
---|
| 1287 | "RTN","NHINVIT",81,0)
|
---|
| 1288 | RANGE(TYPE) ; -- return high^low range of values for TYPE
|
---|
| 1289 | "RTN","NHINVIT",82,0)
|
---|
| 1290 | N Y S Y="" I '$D(NHIPRM) D ;get parameter values
|
---|
| 1291 | "RTN","NHINVIT",83,0)
|
---|
| 1292 | . N VAL D GETS^DIQ(120.57,"1,","5:7","","VAL")
|
---|
| 1293 | "RTN","NHINVIT",84,0)
|
---|
| 1294 | . M NHIPRM=VAL(120.57,"1,")
|
---|
| 1295 | "RTN","NHINVIT",85,0)
|
---|
| 1296 | I TYPE="T" S Y=$G(NHIPRM(5.1))_U_$G(NHIPRM(5.2))
|
---|
| 1297 | "RTN","NHINVIT",86,0)
|
---|
| 1298 | I TYPE="P" S Y=$G(NHIPRM(5.3))_U_$G(NHIPRM(5.4))
|
---|
| 1299 | "RTN","NHINVIT",87,0)
|
---|
| 1300 | I TYPE="R" S Y=$G(NHIPRM(5.5))_U_$G(NHIPRM(5.6))
|
---|
| 1301 | "RTN","NHINVIT",88,0)
|
---|
| 1302 | I TYPE="CVP" S Y=$G(NHIPRM(6.1))_U_$G(NHIPRM(6.2))
|
---|
| 1303 | "RTN","NHINVIT",89,0)
|
---|
| 1304 | I TYPE="PO2" S Y="100^"_$G(NHIPRM(6.3))
|
---|
| 1305 | "RTN","NHINVIT",90,0)
|
---|
| 1306 | I TYPE="BP" D
|
---|
| 1307 | "RTN","NHINVIT",91,0)
|
---|
| 1308 | . S Y=$G(NHIPRM(5.7))_"/"_$G(NHIPRM(5.71))_U
|
---|
| 1309 | "RTN","NHINVIT",92,0)
|
---|
| 1310 | . S Y=Y_$G(NHIPRM(5.8))_"/"_$G(NHIPRM(5.81))
|
---|
| 1311 | "RTN","NHINVIT",93,0)
|
---|
| 1312 | Q Y
|
---|
| 1313 | "RTN","NHINVIT",94,0)
|
---|
| 1314 | ;
|
---|
| 1315 | "RTN","NHINVIT",95,0)
|
---|
| 1316 | ; ------------ Return data to middle tier ------------
|
---|
| 1317 | "RTN","NHINVIT",96,0)
|
---|
| 1318 | ;
|
---|
| 1319 | "RTN","NHINVIT",97,0)
|
---|
| 1320 | NAME(X) ; -- Return name of measurement type X for XML element
|
---|
| 1321 | "RTN","NHINVIT",98,0)
|
---|
| 1322 | N Y S X=$G(X),Y=""
|
---|
| 1323 | "RTN","NHINVIT",99,0)
|
---|
| 1324 | S Y=$S(X="BP":"bloodPressure",X="T":"temperature",X="R":"respiration",X="P":"pulse",X="HT":"height",X="WT":"weight",X="CVP":"centralVenousPressure",X="CG":"circumferenceGirth",X="PO2":"pulseOximetry",X="PN":"pain",1:"")
|
---|
| 1325 | "RTN","NHINVIT",100,0)
|
---|
| 1326 | Q Y
|
---|
| 1327 | "RTN","NHINVIT",101,0)
|
---|
| 1328 | ;
|
---|
| 1329 | "RTN","NHINVIT",102,0)
|
---|
| 1330 | XML(VIT) ; -- Return vital measurement as XML in @NHIN@(#)
|
---|
| 1331 | "RTN","NHINVIT",103,0)
|
---|
| 1332 | N ATT,X,Y,I,J,P,NAMES,TAG
|
---|
| 1333 | "RTN","NHINVIT",104,0)
|
---|
| 1334 | D ADD("<vital>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 1335 | "RTN","NHINVIT",105,0)
|
---|
| 1336 | S ATT="" F S ATT=$O(VIT(ATT)) Q:ATT="" D
|
---|
| 1337 | "RTN","NHINVIT",106,0)
|
---|
| 1338 | . I ATT="measurement" D Q
|
---|
| 1339 | "RTN","NHINVIT",107,0)
|
---|
| 1340 | .. D ADD("<measurements>")
|
---|
| 1341 | "RTN","NHINVIT",108,0)
|
---|
| 1342 | .. S NAMES="id^vuid^name^value^units^metricValue^metricUnits^high^low^Z"
|
---|
| 1343 | "RTN","NHINVIT",109,0)
|
---|
| 1344 | .. S I=0 F S I=$O(VIT(ATT,I)) Q:I<1 D
|
---|
| 1345 | "RTN","NHINVIT",110,0)
|
---|
| 1346 | ... S X=$G(VIT(ATT,I)),Y="<"_ATT_" "
|
---|
| 1347 | "RTN","NHINVIT",111,0)
|
---|
| 1348 | ... F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 1349 | "RTN","NHINVIT",112,0)
|
---|
| 1350 | ... I '$D(VIT(ATT,I,"qualifier")) S Y=Y_"/>" D ADD(Y) Q
|
---|
| 1351 | "RTN","NHINVIT",113,0)
|
---|
| 1352 | ... S Y=Y_">" D ADD(Y),ADD("<qualifiers>")
|
---|
| 1353 | "RTN","NHINVIT",114,0)
|
---|
| 1354 | ... S J=0 F S J=$O(VIT(ATT,I,"qualifier",J)) Q:J<1 D
|
---|
| 1355 | "RTN","NHINVIT",115,0)
|
---|
| 1356 | .... S Y="<qualifier ",X=$G(VIT(ATT,I,"qualifier",J))
|
---|
| 1357 | "RTN","NHINVIT",116,0)
|
---|
| 1358 | .... F P=1:1 S TAG=$P("name^vuid^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 1359 | "RTN","NHINVIT",117,0)
|
---|
| 1360 | .... S Y=Y_"/>" D ADD(Y)
|
---|
| 1361 | "RTN","NHINVIT",118,0)
|
---|
| 1362 | ... D ADD("</qualifiers>"),ADD("</measurement>")
|
---|
| 1363 | "RTN","NHINVIT",119,0)
|
---|
| 1364 | .. D ADD("</measurements>")
|
---|
| 1365 | "RTN","NHINVIT",120,0)
|
---|
| 1366 | . I ATT="removed" D Q
|
---|
| 1367 | "RTN","NHINVIT",121,0)
|
---|
| 1368 | .. D ADD("<removed>")
|
---|
| 1369 | "RTN","NHINVIT",122,0)
|
---|
| 1370 | .. S I=0 F S I=$O(VIT(ATT,I)) Q:I<1 S Y="<reason value='"_$G(VIT(ATT,I))_"' />" D ADD(Y)
|
---|
| 1371 | "RTN","NHINVIT",123,0)
|
---|
| 1372 | .. D ADD("</removed>")
|
---|
| 1373 | "RTN","NHINVIT",124,0)
|
---|
| 1374 | . S X=$G(VIT(ATT)),Y="" Q:'$L(X)
|
---|
| 1375 | "RTN","NHINVIT",125,0)
|
---|
| 1376 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" D ADD(Y) Q
|
---|
| 1377 | "RTN","NHINVIT",126,0)
|
---|
| 1378 | . I $L(X)>1 D
|
---|
| 1379 | "RTN","NHINVIT",127,0)
|
---|
| 1380 | .. S Y="<"_ATT_" "
|
---|
| 1381 | "RTN","NHINVIT",128,0)
|
---|
| 1382 | .. F P=1:1 S TAG=$P("code^name^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 1383 | "RTN","NHINVIT",129,0)
|
---|
| 1384 | .. S Y=Y_"/>" D ADD(Y)
|
---|
| 1385 | "RTN","NHINVIT",130,0)
|
---|
| 1386 | D ADD("</vital>")
|
---|
| 1387 | "RTN","NHINVIT",131,0)
|
---|
| 1388 | Q
|
---|
| 1389 | "RTN","NHINVIT",132,0)
|
---|
| 1390 | ;
|
---|
| 1391 | "RTN","NHINVIT",133,0)
|
---|
| 1392 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 1393 | "RTN","NHINVIT",134,0)
|
---|
| 1394 | S NHINI=$G(NHINI)+1
|
---|
| 1395 | "RTN","NHINVIT",135,0)
|
---|
| 1396 | S @NHIN@(NHINI)=X
|
---|
| 1397 | "RTN","NHINVIT",136,0)
|
---|
| 1398 | Q
|
---|
| 1399 | "RTN","NHINVLR")
|
---|
| 1400 | 0^5^B25540846^n/a
|
---|
| 1401 | "RTN","NHINVLR",1,0)
|
---|
| 1402 | NHINVLR ;SLC/MKB -- Laboratory extract
|
---|
| 1403 | "RTN","NHINVLR",2,0)
|
---|
| 1404 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 1405 | "RTN","NHINVLR",3,0)
|
---|
| 1406 | ;
|
---|
| 1407 | "RTN","NHINVLR",4,0)
|
---|
| 1408 | ; External References DBIA#
|
---|
| 1409 | "RTN","NHINVLR",5,0)
|
---|
| 1410 | ; ------------------- -----
|
---|
| 1411 | "RTN","NHINVLR",6,0)
|
---|
| 1412 | ; ^DPT 10035
|
---|
| 1413 | "RTN","NHINVLR",7,0)
|
---|
| 1414 | ; ^LAB(60 10054
|
---|
| 1415 | "RTN","NHINVLR",8,0)
|
---|
| 1416 | ; ^LRO(69 2407
|
---|
| 1417 | "RTN","NHINVLR",9,0)
|
---|
| 1418 | ; ^LR 525
|
---|
| 1419 | "RTN","NHINVLR",10,0)
|
---|
| 1420 | ; DIC 2051
|
---|
| 1421 | "RTN","NHINVLR",11,0)
|
---|
| 1422 | ; DIQ 2056
|
---|
| 1423 | "RTN","NHINVLR",12,0)
|
---|
| 1424 | ; LR7OR1,^TMP("LRRR",$J) 2503
|
---|
| 1425 | "RTN","NHINVLR",13,0)
|
---|
| 1426 | ;
|
---|
| 1427 | "RTN","NHINVLR",14,0)
|
---|
| 1428 | ; ------------ Get results from VistA ------------
|
---|
| 1429 | "RTN","NHINVLR",15,0)
|
---|
| 1430 | ;
|
---|
| 1431 | "RTN","NHINVLR",16,0)
|
---|
| 1432 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's lab results
|
---|
| 1433 | "RTN","NHINVLR",17,0)
|
---|
| 1434 | N NHSUB,NHIDT,NHI,NHITM,LRDFN,SUB
|
---|
| 1435 | "RTN","NHINVLR",18,0)
|
---|
| 1436 | S DFN=+$G(DFN) Q:$G(DFN)<1
|
---|
| 1437 | "RTN","NHINVLR",19,0)
|
---|
| 1438 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 1439 | "RTN","NHINVLR",20,0)
|
---|
| 1440 | K ^TMP("LRRR",$J,DFN) S LRDFN=$G(^DPT(DFN,"LR")),NHSUB="CH"
|
---|
| 1441 | "RTN","NHINVLR",21,0)
|
---|
| 1442 | ;
|
---|
| 1443 | "RTN","NHINVLR",22,0)
|
---|
| 1444 | ; get result(s)
|
---|
| 1445 | "RTN","NHINVLR",23,0)
|
---|
| 1446 | I $L($G(ID)) D Q:NHI ;done
|
---|
| 1447 | "RTN","NHINVLR",24,0)
|
---|
| 1448 | . S NHSUB=$P(ID,";"),NHIDT=+$P(ID,";",2),(BEG,END)=9999999-NHIDT
|
---|
| 1449 | "RTN","NHINVLR",25,0)
|
---|
| 1450 | . S NHI=$P(ID,";",3) I NHI D ;skip loop - single result
|
---|
| 1451 | "RTN","NHINVLR",26,0)
|
---|
| 1452 | .. D RR^LR7OR1(DFN,,BEG,END,NHSUB)
|
---|
| 1453 | "RTN","NHINVLR",27,0)
|
---|
| 1454 | .. S SUB=$S("CH^MI"[NHSUB:NHSUB,1:"AP")_"(.NHITM)"
|
---|
| 1455 | "RTN","NHINVLR",28,0)
|
---|
| 1456 | .. D @SUB,XML(.NHITM)
|
---|
| 1457 | "RTN","NHINVLR",29,0)
|
---|
| 1458 | .. K ^TMP("LRRR",$J,DFN)
|
---|
| 1459 | "RTN","NHINVLR",30,0)
|
---|
| 1460 | ;
|
---|
| 1461 | "RTN","NHINVLR",31,0)
|
---|
| 1462 | D RR^LR7OR1(DFN,,BEG,END,NHSUB,,,MAX)
|
---|
| 1463 | "RTN","NHINVLR",32,0)
|
---|
| 1464 | S NHSUB="" F S NHSUB=$O(^TMP("LRRR",$J,DFN,NHSUB)) Q:NHSUB="" D
|
---|
| 1465 | "RTN","NHINVLR",33,0)
|
---|
| 1466 | . S NHIDT=0 F S NHIDT=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT)) Q:NHIDT<1 D
|
---|
| 1467 | "RTN","NHINVLR",34,0)
|
---|
| 1468 | .. S NHI=0 F S NHI=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT,NHI)) Q:NHI<1 D
|
---|
| 1469 | "RTN","NHINVLR",35,0)
|
---|
| 1470 | ... K NHITM S SUB=$S("CH^MI"[NHSUB:NHSUB,1:"AP")_"(.NHITM)"
|
---|
| 1471 | "RTN","NHINVLR",36,0)
|
---|
| 1472 | ... D @SUB,XML(.NHITM)
|
---|
| 1473 | "RTN","NHINVLR",37,0)
|
---|
| 1474 | K ^TMP("LRRR",$J,DFN)
|
---|
| 1475 | "RTN","NHINVLR",38,0)
|
---|
| 1476 | Q
|
---|
| 1477 | "RTN","NHINVLR",39,0)
|
---|
| 1478 | ;
|
---|
| 1479 | "RTN","NHINVLR",40,0)
|
---|
| 1480 | CH(LAB) ; -- return a Chemistry result in LAB("attribute")=value
|
---|
| 1481 | "RTN","NHINVLR",41,0)
|
---|
| 1482 | ; Expects ^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI),LRDFN
|
---|
| 1483 | "RTN","NHINVLR",42,0)
|
---|
| 1484 | N CDT,LR0,LRI,X0,X,LOINC,ORD,CMMT K LAB
|
---|
| 1485 | "RTN","NHINVLR",43,0)
|
---|
| 1486 | S LAB("id")="CH;"_NHIDT_";"_NHI,LAB("type")="CH"
|
---|
| 1487 | "RTN","NHINVLR",44,0)
|
---|
| 1488 | S CDT=9999999-NHIDT,LAB("collected")=CDT
|
---|
| 1489 | "RTN","NHINVLR",45,0)
|
---|
| 1490 | S LR0=$G(^LR(LRDFN,"CH",NHIDT,0)),LRI=$G(^(NHI))
|
---|
| 1491 | "RTN","NHINVLR",46,0)
|
---|
| 1492 | S LAB("status")="completed",LAB("resulted")=$P(LR0,U,3)
|
---|
| 1493 | "RTN","NHINVLR",47,0)
|
---|
| 1494 | S X0=$G(^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI))
|
---|
| 1495 | "RTN","NHINVLR",48,0)
|
---|
| 1496 | S LAB("test")=$P($G(^LAB(60,+X0,0)),U) ;$P(X0,U,10)?
|
---|
| 1497 | "RTN","NHINVLR",49,0)
|
---|
| 1498 | S:$L($P(X0,U,2)) LAB("result")=$P(X0,U,2)
|
---|
| 1499 | "RTN","NHINVLR",50,0)
|
---|
| 1500 | S:$L($P(X0,U,4)) LAB("units")=$P(X0,U,4)
|
---|
| 1501 | "RTN","NHINVLR",51,0)
|
---|
| 1502 | S:$L($P(X0,U,3)) LAB("interpretation")=$P(X0,U,3)
|
---|
| 1503 | "RTN","NHINVLR",52,0)
|
---|
| 1504 | S X=$P(X0,U,5) I $L(X),X["-" S LAB("low")=$P(X,"-"),LAB("high")=$P(X,"-",2)
|
---|
| 1505 | "RTN","NHINVLR",53,0)
|
---|
| 1506 | S LAB("localName")=$S($L($P(X0,U,15)):$P(X0,U,15),1:LAB("test"))
|
---|
| 1507 | "RTN","NHINVLR",54,0)
|
---|
| 1508 | S LAB("groupName")=$P(X0,U,16) ;accession#
|
---|
| 1509 | "RTN","NHINVLR",55,0)
|
---|
| 1510 | S X=$P($P(LRI,U,3),"!",3) S:X LOINC=$$GET1^DIQ(95.3,X_",",.01)
|
---|
| 1511 | "RTN","NHINVLR",56,0)
|
---|
| 1512 | S X=+$P(X0,U,19) I X D ;specimen
|
---|
| 1513 | "RTN","NHINVLR",57,0)
|
---|
| 1514 | . N VUID,IENS,NHY S VUID="",IENS=X_","
|
---|
| 1515 | "RTN","NHINVLR",58,0)
|
---|
| 1516 | . D GETS^DIQ(61,IENS,".01;2",,"NHY")
|
---|
| 1517 | "RTN","NHINVLR",59,0)
|
---|
| 1518 | . S LAB("specimen")=$G(NHY(61,IENS,2))_U_$G(NHY(61,IENS,.01)) ;SNOMED^name
|
---|
| 1519 | "RTN","NHINVLR",60,0)
|
---|
| 1520 | . S LAB("sample")=$$GET1^DIQ(61,X_",",4.1) ;name
|
---|
| 1521 | "RTN","NHINVLR",61,0)
|
---|
| 1522 | . ; LOINC=+$G(^LAB(60,+X0,1,X,95.3))
|
---|
| 1523 | "RTN","NHINVLR",62,0)
|
---|
| 1524 | . S:'$G(LOINC) LOINC=$$GET1^DIQ(60.01,X_","_+X0_",",95.3)
|
---|
| 1525 | "RTN","NHINVLR",63,0)
|
---|
| 1526 | . I LOINC S LAB("loinc")=LOINC,VUID=$$VUID^NHINV(+LOINC,95.3)
|
---|
| 1527 | "RTN","NHINVLR",64,0)
|
---|
| 1528 | . S:VUID LAB("vuid")=VUID
|
---|
| 1529 | "RTN","NHINVLR",65,0)
|
---|
| 1530 | S ORD=+$P(X0,U,17) S:ORD LAB("labOrderID")=ORD
|
---|
| 1531 | "RTN","NHINVLR",66,0)
|
---|
| 1532 | S X=$$ORDER(ORD,+X0) S:X LAB("orderID")=X
|
---|
| 1533 | "RTN","NHINVLR",67,0)
|
---|
| 1534 | S X=$P(LR0,U,14)
|
---|
| 1535 | "RTN","NHINVLR",68,0)
|
---|
| 1536 | S:X LAB("facility")=$$STA^XUAF4(X)_U_$P($$NS^XUAF4(X),U)
|
---|
| 1537 | "RTN","NHINVLR",69,0)
|
---|
| 1538 | I 'X S LAB("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 1539 | "RTN","NHINVLR",70,0)
|
---|
| 1540 | I $D(^TMP("LRRR",$J,DFN,"CH",NHIDT,"N")) M CMMT=^("N") S LAB("comment")=$$STRING^NHINV(.CMMT)
|
---|
| 1541 | "RTN","NHINVLR",71,0)
|
---|
| 1542 | Q
|
---|
| 1543 | "RTN","NHINVLR",72,0)
|
---|
| 1544 | ;
|
---|
| 1545 | "RTN","NHINVLR",73,0)
|
---|
| 1546 | ORDER(LABORD,TEST) ; -- return #100 order for Lab order# & Test
|
---|
| 1547 | "RTN","NHINVLR",74,0)
|
---|
| 1548 | N Y,D,S,T S Y=""
|
---|
| 1549 | "RTN","NHINVLR",75,0)
|
---|
| 1550 | S D=$O(^LRO(69,"C",LABORD,0)) I D D
|
---|
| 1551 | "RTN","NHINVLR",76,0)
|
---|
| 1552 | . S S=0 F S S=$O(^LRO(69,"C",LABORD,D,S)) Q:S<1 D
|
---|
| 1553 | "RTN","NHINVLR",77,0)
|
---|
| 1554 | .. S T=0 F S T=$O(^LRO(69,D,1,S,2,T)) Q:T<1 I +$G(^(T,0))=TEST S Y=+$P(^(0),U,7)
|
---|
| 1555 | "RTN","NHINVLR",78,0)
|
---|
| 1556 | Q Y
|
---|
| 1557 | "RTN","NHINVLR",79,0)
|
---|
| 1558 | ;
|
---|
| 1559 | "RTN","NHINVLR",80,0)
|
---|
| 1560 | MI(LAB) ; -- return a Microbiology result in LAB("attribute")=value
|
---|
| 1561 | "RTN","NHINVLR",81,0)
|
---|
| 1562 | ; Expects ^TMP("LRRR",$J,DFN,"MI",NHIDT,NHI),LRDFN
|
---|
| 1563 | "RTN","NHINVLR",82,0)
|
---|
| 1564 | N ID,CDT,X0,X,CMMT,LR0 K LAB
|
---|
| 1565 | "RTN","NHINVLR",83,0)
|
---|
| 1566 | S X0=$G(^TMP("LRRR",$J,DFN,"MI",NHIDT,NHI)) Q:$L($P(X0,U))'>1
|
---|
| 1567 | "RTN","NHINVLR",84,0)
|
---|
| 1568 | S LAB("id")="MI;"_NHIDT_"#"_NHI,LAB("status")="completed"
|
---|
| 1569 | "RTN","NHINVLR",85,0)
|
---|
| 1570 | S LAB("type")="MI",CDT=9999999-NHIDT,LAB("collected")=CDT
|
---|
| 1571 | "RTN","NHINVLR",86,0)
|
---|
| 1572 | S LR0=$G(^LR(LRDFN,"MI",NHIDT,0)),LAB("resulted")=$P(LR0,U,3)
|
---|
| 1573 | "RTN","NHINVLR",87,0)
|
---|
| 1574 | S:$L($P(X0,U,2)) LAB("result")=$P(X0,U,2)
|
---|
| 1575 | "RTN","NHINVLR",88,0)
|
---|
| 1576 | S:$L($P(X0,U,4)) LAB("units")=$P(X0,U,4)
|
---|
| 1577 | "RTN","NHINVLR",89,0)
|
---|
| 1578 | S:$L($P(X0,U,3)) LAB("interpretation")=$P(X0,U,3)
|
---|
| 1579 | "RTN","NHINVLR",90,0)
|
---|
| 1580 | S (LAB("test"),LAB("localName"))=$P(X0,U,15)
|
---|
| 1581 | "RTN","NHINVLR",91,0)
|
---|
| 1582 | S X=+$P(X0,U,19) I X D ;specimen
|
---|
| 1583 | "RTN","NHINVLR",92,0)
|
---|
| 1584 | . N IENS,NHY S IENS=X_","
|
---|
| 1585 | "RTN","NHINVLR",93,0)
|
---|
| 1586 | . D GETS^DIQ(61,IENS,".01;2",,"NHY")
|
---|
| 1587 | "RTN","NHINVLR",94,0)
|
---|
| 1588 | . S LAB("specimen")=$G(NHY(61,IENS,2))_U_$G(NHY(61,IENS,.01)) ;SNOMED^name
|
---|
| 1589 | "RTN","NHINVLR",95,0)
|
---|
| 1590 | . S LAB("sample")=$$GET1^DIQ(61,X_",",4.1) ;name
|
---|
| 1591 | "RTN","NHINVLR",96,0)
|
---|
| 1592 | S X=$P(LR0,U,14)
|
---|
| 1593 | "RTN","NHINVLR",97,0)
|
---|
| 1594 | S:X LAB("facility")=$$STA^XUAF4(X)_U_$P($$NS^XUAF4(X),U)
|
---|
| 1595 | "RTN","NHINVLR",98,0)
|
---|
| 1596 | I 'X S LAB("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 1597 | "RTN","NHINVLR",99,0)
|
---|
| 1598 | I $D(^TMP("LRRR",$J,DFN,"MI",NHIDT,"N")) M CMMT=^("N") S LAB("comment")=$$STRING^NHINV(.CMMT)
|
---|
| 1599 | "RTN","NHINVLR",100,0)
|
---|
| 1600 | Q
|
---|
| 1601 | "RTN","NHINVLR",101,0)
|
---|
| 1602 | ;
|
---|
| 1603 | "RTN","NHINVLR",102,0)
|
---|
| 1604 | AP(LAB) ; -- return a Pathology result in LAB("attribute")=value
|
---|
| 1605 | "RTN","NHINVLR",103,0)
|
---|
| 1606 | K LAB ;not implemented yet
|
---|
| 1607 | "RTN","NHINVLR",104,0)
|
---|
| 1608 | Q
|
---|
| 1609 | "RTN","NHINVLR",105,0)
|
---|
| 1610 | ;
|
---|
| 1611 | "RTN","NHINVLR",106,0)
|
---|
| 1612 | TYPE(X) ; -- Return name of lab section
|
---|
| 1613 | "RTN","NHINVLR",107,0)
|
---|
| 1614 | N NHIY,Y S Y=X
|
---|
| 1615 | "RTN","NHINVLR",108,0)
|
---|
| 1616 | D FIND^DIC(68,,.01,"PQX",X,,"B",,,"NHIY")
|
---|
| 1617 | "RTN","NHINVLR",109,0)
|
---|
| 1618 | S:$G(NHIY("DILIST",1,0)) Y=$P(NHIY("DILIST",1,0),U,2) ;name
|
---|
| 1619 | "RTN","NHINVLR",110,0)
|
---|
| 1620 | Q Y
|
---|
| 1621 | "RTN","NHINVLR",111,0)
|
---|
| 1622 | ;
|
---|
| 1623 | "RTN","NHINVLR",112,0)
|
---|
| 1624 | ; ------------ Return data to middle tier ------------
|
---|
| 1625 | "RTN","NHINVLR",113,0)
|
---|
| 1626 | ;
|
---|
| 1627 | "RTN","NHINVLR",114,0)
|
---|
| 1628 | XML(LAB) ; -- Return result as XML in @NHIN@(#)
|
---|
| 1629 | "RTN","NHINVLR",115,0)
|
---|
| 1630 | N ATT,X,Y,P,NAMES,TAG
|
---|
| 1631 | "RTN","NHINVLR",116,0)
|
---|
| 1632 | D ADD("<lab>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 1633 | "RTN","NHINVLR",117,0)
|
---|
| 1634 | S ATT="" F S ATT=$O(LAB(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 1635 | "RTN","NHINVLR",118,0)
|
---|
| 1636 | . S X=$G(LAB(ATT)),Y="" Q:'$L(X)
|
---|
| 1637 | "RTN","NHINVLR",119,0)
|
---|
| 1638 | . I ATT="comment" S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 1639 | "RTN","NHINVLR",120,0)
|
---|
| 1640 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 1641 | "RTN","NHINVLR",121,0)
|
---|
| 1642 | . I $L(X)>1 D S Y=""
|
---|
| 1643 | "RTN","NHINVLR",122,0)
|
---|
| 1644 | .. S Y="<"_ATT_" ",NAMES="code^name^Z"
|
---|
| 1645 | "RTN","NHINVLR",123,0)
|
---|
| 1646 | .. F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 1647 | "RTN","NHINVLR",124,0)
|
---|
| 1648 | .. S Y=Y_"/>" D ADD(Y)
|
---|
| 1649 | "RTN","NHINVLR",125,0)
|
---|
| 1650 | D ADD("</lab>")
|
---|
| 1651 | "RTN","NHINVLR",126,0)
|
---|
| 1652 | Q
|
---|
| 1653 | "RTN","NHINVLR",127,0)
|
---|
| 1654 | ;
|
---|
| 1655 | "RTN","NHINVLR",128,0)
|
---|
| 1656 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 1657 | "RTN","NHINVLR",129,0)
|
---|
| 1658 | S NHINI=$G(NHINI)+1
|
---|
| 1659 | "RTN","NHINVLR",130,0)
|
---|
| 1660 | S @NHIN@(NHINI)=X
|
---|
| 1661 | "RTN","NHINVLR",131,0)
|
---|
| 1662 | Q
|
---|
| 1663 | "RTN","NHINVLRA")
|
---|
| 1664 | 0^21^B45252098^n/a
|
---|
| 1665 | "RTN","NHINVLRA",1,0)
|
---|
| 1666 | NHINVLRA ;SLC/MKB -- Laboratory extract by accession
|
---|
| 1667 | "RTN","NHINVLRA",2,0)
|
---|
| 1668 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 1669 | "RTN","NHINVLRA",3,0)
|
---|
| 1670 | ;
|
---|
| 1671 | "RTN","NHINVLRA",4,0)
|
---|
| 1672 | ; External References DBIA#
|
---|
| 1673 | "RTN","NHINVLRA",5,0)
|
---|
| 1674 | ; ------------------- -----
|
---|
| 1675 | "RTN","NHINVLRA",6,0)
|
---|
| 1676 | ; ^DPT 10035
|
---|
| 1677 | "RTN","NHINVLRA",7,0)
|
---|
| 1678 | ; ^LAB(60 10054
|
---|
| 1679 | "RTN","NHINVLRA",8,0)
|
---|
| 1680 | ; ^LRO(69 2407
|
---|
| 1681 | "RTN","NHINVLRA",9,0)
|
---|
| 1682 | ; ^LR 525
|
---|
| 1683 | "RTN","NHINVLRA",10,0)
|
---|
| 1684 | ; ^VA(200 10060
|
---|
| 1685 | "RTN","NHINVLRA",11,0)
|
---|
| 1686 | ; DIC 2051
|
---|
| 1687 | "RTN","NHINVLRA",12,0)
|
---|
| 1688 | ; DIQ 2056
|
---|
| 1689 | "RTN","NHINVLRA",13,0)
|
---|
| 1690 | ; LR7OR1,^TMP("LRRR",$J) 2503
|
---|
| 1691 | "RTN","NHINVLRA",14,0)
|
---|
| 1692 | ; LR7OSUM,^TMP("LRC") 2766
|
---|
| 1693 | "RTN","NHINVLRA",15,0)
|
---|
| 1694 | ; PXAPI 1894
|
---|
| 1695 | "RTN","NHINVLRA",16,0)
|
---|
| 1696 | ; XUAF4 2171
|
---|
| 1697 | "RTN","NHINVLRA",17,0)
|
---|
| 1698 | ;
|
---|
| 1699 | "RTN","NHINVLRA",18,0)
|
---|
| 1700 | ; ------------ Get results from VistA ------------
|
---|
| 1701 | "RTN","NHINVLRA",19,0)
|
---|
| 1702 | ;
|
---|
| 1703 | "RTN","NHINVLRA",20,0)
|
---|
| 1704 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's lab results
|
---|
| 1705 | "RTN","NHINVLRA",21,0)
|
---|
| 1706 | N NHSUB,NHIDT,NHI,NHITM,LRDFN,LR0,ORD,X
|
---|
| 1707 | "RTN","NHINVLRA",22,0)
|
---|
| 1708 | S DFN=+$G(DFN) Q:$G(DFN)<1
|
---|
| 1709 | "RTN","NHINVLRA",23,0)
|
---|
| 1710 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 1711 | "RTN","NHINVLRA",24,0)
|
---|
| 1712 | S LRDFN=$G(^DPT(DFN,"LR")),NHSUB=""
|
---|
| 1713 | "RTN","NHINVLRA",25,0)
|
---|
| 1714 | K ^TMP("LRRR",$J,DFN)
|
---|
| 1715 | "RTN","NHINVLRA",26,0)
|
---|
| 1716 | ;
|
---|
| 1717 | "RTN","NHINVLRA",27,0)
|
---|
| 1718 | ; get result(s)
|
---|
| 1719 | "RTN","NHINVLRA",28,0)
|
---|
| 1720 | I $L($G(ID)) D ;reset search parameters
|
---|
| 1721 | "RTN","NHINVLRA",29,0)
|
---|
| 1722 | . S NHSUB=$P(ID,";"),NHIDT=+$P(ID,";",2)
|
---|
| 1723 | "RTN","NHINVLRA",30,0)
|
---|
| 1724 | . S:NHIDT (BEG,END)=9999999-NHIDT
|
---|
| 1725 | "RTN","NHINVLRA",31,0)
|
---|
| 1726 | ;
|
---|
| 1727 | "RTN","NHINVLRA",32,0)
|
---|
| 1728 | D RR^LR7OR1(DFN,,BEG,END,NHSUB,,,MAX)
|
---|
| 1729 | "RTN","NHINVLRA",33,0)
|
---|
| 1730 | S NHSUB="" F S NHSUB=$O(^TMP("LRRR",$J,DFN,NHSUB)) Q:NHSUB="" D
|
---|
| 1731 | "RTN","NHINVLRA",34,0)
|
---|
| 1732 | . S NHIDT=0 F S NHIDT=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT)) Q:NHIDT<1 I $O(^(NHIDT,0)) D
|
---|
| 1733 | "RTN","NHINVLRA",35,0)
|
---|
| 1734 | .. K NHITM,CMMT I "CH^MI"'[NHSUB D AP(.NHITM),XML(.NHITM) Q
|
---|
| 1735 | "RTN","NHINVLRA",36,0)
|
---|
| 1736 | .. S NHITM("type")=NHSUB,NHITM("id")=NHSUB_";"_NHIDT
|
---|
| 1737 | "RTN","NHINVLRA",37,0)
|
---|
| 1738 | .. S NHITM("collected")=9999999-NHIDT,NHITM("status")="completed"
|
---|
| 1739 | "RTN","NHINVLRA",38,0)
|
---|
| 1740 | .. S LR0=$G(^LR(LRDFN,NHSUB,NHIDT,0))
|
---|
| 1741 | "RTN","NHINVLRA",39,0)
|
---|
| 1742 | .. S NHITM("resulted")=$P(LR0,U,3),X=+$P(LR0,U,5) I X D
|
---|
| 1743 | "RTN","NHINVLRA",40,0)
|
---|
| 1744 | ... N IENS,NHY S IENS=X_","
|
---|
| 1745 | "RTN","NHINVLRA",41,0)
|
---|
| 1746 | ... D GETS^DIQ(61,IENS,".01:2",,"NHY")
|
---|
| 1747 | "RTN","NHINVLRA",42,0)
|
---|
| 1748 | ... S NHITM("specimen")=$G(NHY(61,IENS,2))_U_$G(NHY(61,IENS,.01)) ;SNOMED^name
|
---|
| 1749 | "RTN","NHINVLRA",43,0)
|
---|
| 1750 | ... S NHITM("sample")=$$GET1^DIQ(61,X_",",4.1) ;name
|
---|
| 1751 | "RTN","NHINVLRA",44,0)
|
---|
| 1752 | .. S NHITM("groupName")=$P(LR0,U,6),X=+$P(LR0,U,14)
|
---|
| 1753 | "RTN","NHINVLRA",45,0)
|
---|
| 1754 | .. S:X NHITM("facility")=$$STA^XUAF4(X)_U_$P($$NS^XUAF4(X),U)
|
---|
| 1755 | "RTN","NHINVLRA",46,0)
|
---|
| 1756 | .. I 'X S NHITM("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 1757 | "RTN","NHINVLRA",47,0)
|
---|
| 1758 | .. S:NHSUB="MI" NHITM("content")=$$TEXT(DFN,NHSUB,NHIDT)
|
---|
| 1759 | "RTN","NHINVLRA",48,0)
|
---|
| 1760 | .. S NHI=0 F S NHI=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT,NHI)) Q:NHI<1 D
|
---|
| 1761 | "RTN","NHINVLRA",49,0)
|
---|
| 1762 | ... S X=$S(NHSUB="MI":$$MI,1:$$CH)
|
---|
| 1763 | "RTN","NHINVLRA",50,0)
|
---|
| 1764 | ... S:$L(X) NHITM("lab",NHI)=X
|
---|
| 1765 | "RTN","NHINVLRA",51,0)
|
---|
| 1766 | ... S:$G(ORD) NHITM("labOrderID")=ORD
|
---|
| 1767 | "RTN","NHINVLRA",52,0)
|
---|
| 1768 | .. I $D(^TMP("LRRR",$J,DFN,NHSUB,NHIDT,"N")) M CMMT=^("N") S NHITM("comment")=$$STRING^NHINV(.CMMT)
|
---|
| 1769 | "RTN","NHINVLRA",53,0)
|
---|
| 1770 | .. D XML(.NHITM)
|
---|
| 1771 | "RTN","NHINVLRA",54,0)
|
---|
| 1772 | K ^TMP("LRRR",$J,DFN)
|
---|
| 1773 | "RTN","NHINVLRA",55,0)
|
---|
| 1774 | Q
|
---|
| 1775 | "RTN","NHINVLRA",56,0)
|
---|
| 1776 | ;
|
---|
| 1777 | "RTN","NHINVLRA",57,0)
|
---|
| 1778 | CH() ; -- return a Chemistry result as:
|
---|
| 1779 | "RTN","NHINVLRA",58,0)
|
---|
| 1780 | ; id^test^result^interpretation^units^low^high^loinc^vuid^order
|
---|
| 1781 | "RTN","NHINVLRA",59,0)
|
---|
| 1782 | ; Expects ^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI),LRDFN
|
---|
| 1783 | "RTN","NHINVLRA",60,0)
|
---|
| 1784 | N X,Y,X0,NODE,CMMT,LOINC
|
---|
| 1785 | "RTN","NHINVLRA",61,0)
|
---|
| 1786 | S X0=$G(^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI)),NODE=$G(^LR(LRDFN,"CH",NHIDT,NHI))
|
---|
| 1787 | "RTN","NHINVLRA",62,0)
|
---|
| 1788 | S X=$P($G(^LAB(60,+X0,0)),U)
|
---|
| 1789 | "RTN","NHINVLRA",63,0)
|
---|
| 1790 | S Y="CH;"_NHIDT_";"_NHI_U_X_U_$P(X0,U,2,4)
|
---|
| 1791 | "RTN","NHINVLRA",64,0)
|
---|
| 1792 | S X=$P(X0,U,5) I $L(X),X["-" S X=$TR(X,"- ","^"),$P(Y,U,6,7)=X
|
---|
| 1793 | "RTN","NHINVLRA",65,0)
|
---|
| 1794 | S X=$P($P(NODE,U,3),"!",3) S:X LOINC=$$GET1^DIQ(95.3,X_",",.01)
|
---|
| 1795 | "RTN","NHINVLRA",66,0)
|
---|
| 1796 | I '$G(LOINC) S X=+$P(X0,U,19) S:X LOINC=$$LOINC(+X0,X)
|
---|
| 1797 | "RTN","NHINVLRA",67,0)
|
---|
| 1798 | S $P(Y,U,8,9)=$G(LOINC)_U_$$VUID^NHINV(+LOINC,95.3)
|
---|
| 1799 | "RTN","NHINVLRA",68,0)
|
---|
| 1800 | S ORD=+$P(X0,U,17),X=$$ORDER(ORD,+X0) S:X $P(Y,U,10)=X
|
---|
| 1801 | "RTN","NHINVLRA",69,0)
|
---|
| 1802 | Q Y
|
---|
| 1803 | "RTN","NHINVLRA",70,0)
|
---|
| 1804 | ;
|
---|
| 1805 | "RTN","NHINVLRA",71,0)
|
---|
| 1806 | MI() ; -- return a Microbiology result as:
|
---|
| 1807 | "RTN","NHINVLRA",72,0)
|
---|
| 1808 | ; id^test^result^interpretation^units
|
---|
| 1809 | "RTN","NHINVLRA",73,0)
|
---|
| 1810 | ; Expects ^TMP("LRRR",$J,DFN,"MI",NHIDT,NHI)
|
---|
| 1811 | "RTN","NHINVLRA",74,0)
|
---|
| 1812 | N Y,X0
|
---|
| 1813 | "RTN","NHINVLRA",75,0)
|
---|
| 1814 | S X0=$G(^TMP("LRRR",$J,DFN,"MI",NHIDT,NHI)),Y=""
|
---|
| 1815 | "RTN","NHINVLRA",76,0)
|
---|
| 1816 | S:$L($P(X0,U))>1 Y="MI;"_NHIDT_";"_NHI_U_$P(X0,U,1,4)
|
---|
| 1817 | "RTN","NHINVLRA",77,0)
|
---|
| 1818 | Q Y
|
---|
| 1819 | "RTN","NHINVLRA",78,0)
|
---|
| 1820 | ;
|
---|
| 1821 | "RTN","NHINVLRA",79,0)
|
---|
| 1822 | AP(LAB) ; -- return a Pathology result in LAB("attribute")=value
|
---|
| 1823 | "RTN","NHINVLRA",80,0)
|
---|
| 1824 | N LR0,X,I,NODE
|
---|
| 1825 | "RTN","NHINVLRA",81,0)
|
---|
| 1826 | S LR0=$G(^LR(LRDFN,NHSUB,NHIDT,0))
|
---|
| 1827 | "RTN","NHINVLRA",82,0)
|
---|
| 1828 | S LAB("type")=NHSUB,LAB("id")=NHSUB_";"_NHIDT
|
---|
| 1829 | "RTN","NHINVLRA",83,0)
|
---|
| 1830 | S LAB("collected")=9999999-NHIDT,LAB("status")="completed"
|
---|
| 1831 | "RTN","NHINVLRA",84,0)
|
---|
| 1832 | S LAB("resulted")=$P(LR0,U,11),LAB("groupName")=$P(LR0,U,6)
|
---|
| 1833 | "RTN","NHINVLRA",85,0)
|
---|
| 1834 | S X="",I=0 F S I=$O(^LR(LRDFN,NHSUB,NHIDT,.1,I)) Q:I<1 S X=X_$S($L(X):", ",1:"")_$P($G(^(I,0)),U)
|
---|
| 1835 | "RTN","NHINVLRA",86,0)
|
---|
| 1836 | S:$L(X) LAB("specimen")=U_X
|
---|
| 1837 | "RTN","NHINVLRA",87,0)
|
---|
| 1838 | S LAB("facility")=$$FAC^NHINV
|
---|
| 1839 | "RTN","NHINVLRA",88,0)
|
---|
| 1840 | S NODE=$S(NHSUB="AU":$NA(^LR(LRDFN,101)),1:$NA(^LR(LRDFN,NHSUB,NHIDT,.05)))
|
---|
| 1841 | "RTN","NHINVLRA",89,0)
|
---|
| 1842 | S I=0 F S I=$O(@NODE@(I)) Q:I<1 S X=+$P($G(@NODE@(I,0)),U,2) I X D
|
---|
| 1843 | "RTN","NHINVLRA",90,0)
|
---|
| 1844 | . N LT,NT
|
---|
| 1845 | "RTN","NHINVLRA",91,0)
|
---|
| 1846 | . S LT=$$GET1^DIQ(8925,+X_",",.01) Q:$P(LT," ")="Addendum"
|
---|
| 1847 | "RTN","NHINVLRA",92,0)
|
---|
| 1848 | . S NT=$$GET1^DIQ(8925,+X_",",".01:1501")
|
---|
| 1849 | "RTN","NHINVLRA",93,0)
|
---|
| 1850 | . S LAB("document",I)=+X_U_LT_U_NT
|
---|
| 1851 | "RTN","NHINVLRA",94,0)
|
---|
| 1852 | I '$O(NHITM("document",0)) S NHITM("content")=$$TEXT(DFN,NHSUB,NHIDT)
|
---|
| 1853 | "RTN","NHINVLRA",95,0)
|
---|
| 1854 | Q
|
---|
| 1855 | "RTN","NHINVLRA",96,0)
|
---|
| 1856 | ;
|
---|
| 1857 | "RTN","NHINVLRA",97,0)
|
---|
| 1858 | LOINC(TEST,SPEC) ; -- Look up LOINC code, if not mapped
|
---|
| 1859 | "RTN","NHINVLRA",98,0)
|
---|
| 1860 | N Y,LAM,NHIN,IENS S Y=""
|
---|
| 1861 | "RTN","NHINVLRA",99,0)
|
---|
| 1862 | S TEST=+$G(TEST),SPEC=+$G(SPEC)
|
---|
| 1863 | "RTN","NHINVLRA",100,0)
|
---|
| 1864 | S LAM=$G(^LAB(60,TEST,64)),LAM=$S($P(LAM,U,2):$P(LAM,U,2),1:+LAM)
|
---|
| 1865 | "RTN","NHINVLRA",101,0)
|
---|
| 1866 | D GETS^DIQ(64.01,SPEC_","_LAM_",","30*",,"NHIN")
|
---|
| 1867 | "RTN","NHINVLRA",102,0)
|
---|
| 1868 | S IENS=$O(NHIN(64.02,"")) S:IENS Y=$G(NHIN(64.02,IENS,4))
|
---|
| 1869 | "RTN","NHINVLRA",103,0)
|
---|
| 1870 | S:'Y Y=$$GET1^DIQ(60.01,SPEC_","_TEST_",",95.3)
|
---|
| 1871 | "RTN","NHINVLRA",104,0)
|
---|
| 1872 | Q Y
|
---|
| 1873 | "RTN","NHINVLRA",105,0)
|
---|
| 1874 | ;
|
---|
| 1875 | "RTN","NHINVLRA",106,0)
|
---|
| 1876 | ORDER(LABORD,TEST) ; -- return #100 order for Lab order# & Test
|
---|
| 1877 | "RTN","NHINVLRA",107,0)
|
---|
| 1878 | N Y,D,S,T S Y=""
|
---|
| 1879 | "RTN","NHINVLRA",108,0)
|
---|
| 1880 | S D=$O(^LRO(69,"C",LABORD,0)) I D D
|
---|
| 1881 | "RTN","NHINVLRA",109,0)
|
---|
| 1882 | . S S=0 F S S=$O(^LRO(69,"C",LABORD,D,S)) Q:S<1 D
|
---|
| 1883 | "RTN","NHINVLRA",110,0)
|
---|
| 1884 | .. S T=0 F S T=$O(^LRO(69,D,1,S,2,T)) Q:T<1 I +$G(^(T,0))=TEST S Y=+$P(^(0),U,7)
|
---|
| 1885 | "RTN","NHINVLRA",111,0)
|
---|
| 1886 | Q Y
|
---|
| 1887 | "RTN","NHINVLRA",112,0)
|
---|
| 1888 | ;
|
---|
| 1889 | "RTN","NHINVLRA",113,0)
|
---|
| 1890 | NAME(X) ; -- Return name of subscript X
|
---|
| 1891 | "RTN","NHINVLRA",114,0)
|
---|
| 1892 | I X="AU" Q "AUTOPSY"
|
---|
| 1893 | "RTN","NHINVLRA",115,0)
|
---|
| 1894 | I X="BB" Q "BLOOD BANK"
|
---|
| 1895 | "RTN","NHINVLRA",116,0)
|
---|
| 1896 | I X="CH" Q "CHEM,HEM,TOX,RIA,SER,etc."
|
---|
| 1897 | "RTN","NHINVLRA",117,0)
|
---|
| 1898 | I X="CY" Q "CYTOLOGY"
|
---|
| 1899 | "RTN","NHINVLRA",118,0)
|
---|
| 1900 | I X="EM" Q "ELECTRON MICROSCOPY"
|
---|
| 1901 | "RTN","NHINVLRA",119,0)
|
---|
| 1902 | I X="MI" Q "MICROBIOLOGY"
|
---|
| 1903 | "RTN","NHINVLRA",120,0)
|
---|
| 1904 | I X="SP" Q "SURGICAL PATHOLOGY"
|
---|
| 1905 | "RTN","NHINVLRA",121,0)
|
---|
| 1906 | Q "ANATOMIC PATHOLOGY"
|
---|
| 1907 | "RTN","NHINVLRA",122,0)
|
---|
| 1908 | ;
|
---|
| 1909 | "RTN","NHINVLRA",123,0)
|
---|
| 1910 | RPT(DFN,ID,RPT) ; -- return report as a TIU document
|
---|
| 1911 | "RTN","NHINVLRA",124,0)
|
---|
| 1912 | S DFN=+$G(DFN),ID=$G(ID) Q:DFN<1 Q:'$L(ID)
|
---|
| 1913 | "RTN","NHINVLRA",125,0)
|
---|
| 1914 | N SUB,IDT,LRDFN,LR0,X
|
---|
| 1915 | "RTN","NHINVLRA",126,0)
|
---|
| 1916 | S SUB=$P(ID,";"),IDT=+$P(ID,";",2)
|
---|
| 1917 | "RTN","NHINVLRA",127,0)
|
---|
| 1918 | S LRDFN=$G(^DPT(DFN,"LR")),LR0=$G(^LR(LRDFN,SUB,IDT,0))
|
---|
| 1919 | "RTN","NHINVLRA",128,0)
|
---|
| 1920 | S RPT("id")=ID,RPT("referenceDateTime")=9999999-IDT
|
---|
| 1921 | "RTN","NHINVLRA",129,0)
|
---|
| 1922 | S RPT("localTitle")=$$NAME(SUB),RPT("status")="COMPLETED"
|
---|
| 1923 | "RTN","NHINVLRA",130,0)
|
---|
| 1924 | S X=+$P(LR0,U,14),RPT("facility")=$$FAC^NHINV(X)
|
---|
| 1925 | "RTN","NHINVLRA",131,0)
|
---|
| 1926 | S X=$P(LR0,U,13) I X["SC(" D
|
---|
| 1927 | "RTN","NHINVLRA",132,0)
|
---|
| 1928 | . N CDT,HLOC S HLOC=+X,CDT=9999999-IDT
|
---|
| 1929 | "RTN","NHINVLRA",133,0)
|
---|
| 1930 | . S X=$$GETENC^PXAPI(DFN,CDT,HLOC)
|
---|
| 1931 | "RTN","NHINVLRA",134,0)
|
---|
| 1932 | . S:X RPT("encounter")=+X
|
---|
| 1933 | "RTN","NHINVLRA",135,0)
|
---|
| 1934 | S X=+$P(LR0,U,4) S:X RPT("clinician",1)=X_U_$P($G(^VA(200,X,0)),U)
|
---|
| 1935 | "RTN","NHINVLRA",136,0)
|
---|
| 1936 | S RPT("content")=$$TEXT(DFN,SUB,IDT)
|
---|
| 1937 | "RTN","NHINVLRA",137,0)
|
---|
| 1938 | Q
|
---|
| 1939 | "RTN","NHINVLRA",138,0)
|
---|
| 1940 | ;
|
---|
| 1941 | "RTN","NHINVLRA",139,0)
|
---|
| 1942 | TEXT(DFN,SUB,IDT) ; -- return report text as a string
|
---|
| 1943 | "RTN","NHINVLRA",140,0)
|
---|
| 1944 | N LRDFN,DATE,NAME,NHS,NHY,I,X,Y
|
---|
| 1945 | "RTN","NHINVLRA",141,0)
|
---|
| 1946 | K ^TMP("LRC",$J),^TMP("LRH",$J),^TMP("LRT",$J)
|
---|
| 1947 | "RTN","NHINVLRA",142,0)
|
---|
| 1948 | S DATE=9999999-+$G(IDT),NAME=$$NAME(SUB),NHS(NAME)=""
|
---|
| 1949 | "RTN","NHINVLRA",143,0)
|
---|
| 1950 | D EN^LR7OSUM(.NHY,DFN,DATE,DATE,,,.NHS)
|
---|
| 1951 | "RTN","NHINVLRA",144,0)
|
---|
| 1952 | S I=+$G(^TMP("LRH",$J,NAME))+1,Y=$G(^TMP("LRC",$J,I,0)) ;LRH=header: Y=1st line
|
---|
| 1953 | "RTN","NHINVLRA",145,0)
|
---|
| 1954 | F S I=$O(^TMP("LRC",$J,I)) Q:I<1 S X=$G(^(I,0)) Q:X?1."=" S Y=Y_$C(13,10)_X
|
---|
| 1955 | "RTN","NHINVLRA",146,0)
|
---|
| 1956 | K ^TMP("LRC",$J),^TMP("LRH",$J),^TMP("LRT",$J)
|
---|
| 1957 | "RTN","NHINVLRA",147,0)
|
---|
| 1958 | Q Y
|
---|
| 1959 | "RTN","NHINVLRA",148,0)
|
---|
| 1960 | ;
|
---|
| 1961 | "RTN","NHINVLRA",149,0)
|
---|
| 1962 | ; ------------ Return data to middle tier ------------
|
---|
| 1963 | "RTN","NHINVLRA",150,0)
|
---|
| 1964 | ;
|
---|
| 1965 | "RTN","NHINVLRA",151,0)
|
---|
| 1966 | XML(LAB) ; -- Return result as XML in @NHIN@(#)
|
---|
| 1967 | "RTN","NHINVLRA",152,0)
|
---|
| 1968 | N ATT,X,Y,NAMES
|
---|
| 1969 | "RTN","NHINVLRA",153,0)
|
---|
| 1970 | D ADD("<accession>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 1971 | "RTN","NHINVLRA",154,0)
|
---|
| 1972 | S ATT="" F S ATT=$O(LAB(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 1973 | "RTN","NHINVLRA",155,0)
|
---|
| 1974 | . I $O(LAB(ATT,0)) D S Y="" Q
|
---|
| 1975 | "RTN","NHINVLRA",156,0)
|
---|
| 1976 | .. D ADD("<"_ATT_"s>")
|
---|
| 1977 | "RTN","NHINVLRA",157,0)
|
---|
| 1978 | .. S NAMES=$S(ATT="document":"id^localTitle^nationalTitle^Z",ATT="lab":"id^test^result^interpretation^units^low^high^loinc^vuid^order^Z",1:"code^name^Z")
|
---|
| 1979 | "RTN","NHINVLRA",158,0)
|
---|
| 1980 | .. S I=0 F S I=$O(LAB(ATT,I)) Q:I<1 D
|
---|
| 1981 | "RTN","NHINVLRA",159,0)
|
---|
| 1982 | ... S X=$G(LAB(ATT,I))
|
---|
| 1983 | "RTN","NHINVLRA",160,0)
|
---|
| 1984 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 1985 | "RTN","NHINVLRA",161,0)
|
---|
| 1986 | .. D ADD("</"_ATT_"s>")
|
---|
| 1987 | "RTN","NHINVLRA",162,0)
|
---|
| 1988 | . S X=$G(LAB(ATT)),Y="" Q:'$L(X)
|
---|
| 1989 | "RTN","NHINVLRA",163,0)
|
---|
| 1990 | . I ATT="comment" S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 1991 | "RTN","NHINVLRA",164,0)
|
---|
| 1992 | . I ATT="content" S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 1993 | "RTN","NHINVLRA",165,0)
|
---|
| 1994 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 1995 | "RTN","NHINVLRA",166,0)
|
---|
| 1996 | . I $L(X)>1 D S Y=""
|
---|
| 1997 | "RTN","NHINVLRA",167,0)
|
---|
| 1998 | .. S NAMES="code^name^Z"
|
---|
| 1999 | "RTN","NHINVLRA",168,0)
|
---|
| 2000 | .. S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2001 | "RTN","NHINVLRA",169,0)
|
---|
| 2002 | D ADD("</accession>")
|
---|
| 2003 | "RTN","NHINVLRA",170,0)
|
---|
| 2004 | Q
|
---|
| 2005 | "RTN","NHINVLRA",171,0)
|
---|
| 2006 | ;
|
---|
| 2007 | "RTN","NHINVLRA",172,0)
|
---|
| 2008 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 2009 | "RTN","NHINVLRA",173,0)
|
---|
| 2010 | N STR,P,TAG S STR=""
|
---|
| 2011 | "RTN","NHINVLRA",174,0)
|
---|
| 2012 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 2013 | "RTN","NHINVLRA",175,0)
|
---|
| 2014 | Q STR
|
---|
| 2015 | "RTN","NHINVLRA",176,0)
|
---|
| 2016 | ;
|
---|
| 2017 | "RTN","NHINVLRA",177,0)
|
---|
| 2018 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 2019 | "RTN","NHINVLRA",178,0)
|
---|
| 2020 | S NHINI=$G(NHINI)+1
|
---|
| 2021 | "RTN","NHINVLRA",179,0)
|
---|
| 2022 | S @NHIN@(NHINI)=X
|
---|
| 2023 | "RTN","NHINVLRA",180,0)
|
---|
| 2024 | Q
|
---|
| 2025 | "RTN","NHINVLRO")
|
---|
| 2026 | 0^22^B32647424^n/a
|
---|
| 2027 | "RTN","NHINVLRO",1,0)
|
---|
| 2028 | NHINVLRO ;SLC/MKB -- Laboratory extract by order/panel
|
---|
| 2029 | "RTN","NHINVLRO",2,0)
|
---|
| 2030 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 2031 | "RTN","NHINVLRO",3,0)
|
---|
| 2032 | ;
|
---|
| 2033 | "RTN","NHINVLRO",4,0)
|
---|
| 2034 | ; External References DBIA#
|
---|
| 2035 | "RTN","NHINVLRO",5,0)
|
---|
| 2036 | ; ------------------- -----
|
---|
| 2037 | "RTN","NHINVLRO",6,0)
|
---|
| 2038 | ; ^DPT 10035
|
---|
| 2039 | "RTN","NHINVLRO",7,0)
|
---|
| 2040 | ; ^LAB(60 67,91,10054
|
---|
| 2041 | "RTN","NHINVLRO",8,0)
|
---|
| 2042 | ; ^LRO(69 2407
|
---|
| 2043 | "RTN","NHINVLRO",9,0)
|
---|
| 2044 | ; ^LR 525
|
---|
| 2045 | "RTN","NHINVLRO",10,0)
|
---|
| 2046 | ; DIQ 2056
|
---|
| 2047 | "RTN","NHINVLRO",11,0)
|
---|
| 2048 | ; LR7OR1,^TMP("LRRR",$J) 2503
|
---|
| 2049 | "RTN","NHINVLRO",12,0)
|
---|
| 2050 | ; XUAF4 2171
|
---|
| 2051 | "RTN","NHINVLRO",13,0)
|
---|
| 2052 | ;
|
---|
| 2053 | "RTN","NHINVLRO",14,0)
|
---|
| 2054 | ; ------------ Get results from VistA ------------
|
---|
| 2055 | "RTN","NHINVLRO",15,0)
|
---|
| 2056 | ;
|
---|
| 2057 | "RTN","NHINVLRO",16,0)
|
---|
| 2058 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's lab results
|
---|
| 2059 | "RTN","NHINVLRO",17,0)
|
---|
| 2060 | N NHSUB,NHIDT,NHI,NHT,NHITM,CMMT,LRDFN,LR0,X
|
---|
| 2061 | "RTN","NHINVLRO",18,0)
|
---|
| 2062 | S DFN=+$G(DFN) Q:$G(DFN)<1
|
---|
| 2063 | "RTN","NHINVLRO",19,0)
|
---|
| 2064 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 2065 | "RTN","NHINVLRO",20,0)
|
---|
| 2066 | S LRDFN=$G(^DPT(DFN,"LR")),NHSUB="CH"
|
---|
| 2067 | "RTN","NHINVLRO",21,0)
|
---|
| 2068 | K ^TMP("LRRR",$J,DFN)
|
---|
| 2069 | "RTN","NHINVLRO",22,0)
|
---|
| 2070 | ;
|
---|
| 2071 | "RTN","NHINVLRO",23,0)
|
---|
| 2072 | ; get result(s)
|
---|
| 2073 | "RTN","NHINVLRO",24,0)
|
---|
| 2074 | I $G(ID) D RR^LR7OR1(DFN,ID)
|
---|
| 2075 | "RTN","NHINVLRO",25,0)
|
---|
| 2076 | I '$G(ID) D ;no id, or accession format (no lab order)
|
---|
| 2077 | "RTN","NHINVLRO",26,0)
|
---|
| 2078 | . S:$G(ID)'="" NHSUB=$P(ID,";"),(BEG,END)=9999999-$P(ID,";",2)
|
---|
| 2079 | "RTN","NHINVLRO",27,0)
|
---|
| 2080 | . D RR^LR7OR1(DFN,,BEG,END,NHSUB,,,MAX)
|
---|
| 2081 | "RTN","NHINVLRO",28,0)
|
---|
| 2082 | ;
|
---|
| 2083 | "RTN","NHINVLRO",29,0)
|
---|
| 2084 | S NHSUB="" F S NHSUB=$O(^TMP("LRRR",$J,DFN,NHSUB)) Q:NHSUB="" D
|
---|
| 2085 | "RTN","NHINVLRO",30,0)
|
---|
| 2086 | . S NHIDT=0 F S NHIDT=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT)) Q:NHIDT<1 I $O(^(NHIDT,0)) D
|
---|
| 2087 | "RTN","NHINVLRO",31,0)
|
---|
| 2088 | .. I "CH^MI"'[NHSUB Q
|
---|
| 2089 | "RTN","NHINVLRO",32,0)
|
---|
| 2090 | .. D SORT ;group accession by lab orders > NHLRO(panel,NHI)=data node
|
---|
| 2091 | "RTN","NHINVLRO",33,0)
|
---|
| 2092 | .. S NHT="" F S NHT=$O(NHLRO(NHT)) Q:NHT="" D
|
---|
| 2093 | "RTN","NHINVLRO",34,0)
|
---|
| 2094 | ... K NHITM,CMMT S X=$G(NHLRO(NHT))
|
---|
| 2095 | "RTN","NHINVLRO",35,0)
|
---|
| 2096 | ... I $G(ID),ID'=$P(X,U,3) Q ;single order only
|
---|
| 2097 | "RTN","NHINVLRO",36,0)
|
---|
| 2098 | ... S NHITM("id")=$P(X,U,3),NHITM("order")=$P(X,U,1,2)
|
---|
| 2099 | "RTN","NHINVLRO",37,0)
|
---|
| 2100 | ... S NHITM("type")=NHSUB,NHITM("status")="completed"
|
---|
| 2101 | "RTN","NHINVLRO",38,0)
|
---|
| 2102 | ... S NHITM("collected")=9999999-NHIDT
|
---|
| 2103 | "RTN","NHINVLRO",39,0)
|
---|
| 2104 | ... S LR0=$G(^LR(LRDFN,NHSUB,NHIDT,0))
|
---|
| 2105 | "RTN","NHINVLRO",40,0)
|
---|
| 2106 | ... S NHITM("resulted")=$P(LR0,U,3),X=+$P(LR0,U,5) I X D ;specimen
|
---|
| 2107 | "RTN","NHINVLRO",41,0)
|
---|
| 2108 | .... N IENS,NHY S IENS=X_","
|
---|
| 2109 | "RTN","NHINVLRO",42,0)
|
---|
| 2110 | .... D GETS^DIQ(61,IENS,".01:2",,"NHY")
|
---|
| 2111 | "RTN","NHINVLRO",43,0)
|
---|
| 2112 | .... S NHITM("specimen")=$G(NHY(61,IENS,2))_U_$G(NHY(61,IENS,.01)) ;SNOMED^name
|
---|
| 2113 | "RTN","NHINVLRO",44,0)
|
---|
| 2114 | .... S NHITM("sample")=$$GET1^DIQ(61,X_",",4.1) ;name
|
---|
| 2115 | "RTN","NHINVLRO",45,0)
|
---|
| 2116 | ... S NHITM("groupName")=$P(LR0,U,6),X=+$P(LR0,U,14)
|
---|
| 2117 | "RTN","NHINVLRO",46,0)
|
---|
| 2118 | ... S:X NHITM("facility")=$$STA^XUAF4(X)_U_$P($$NS^XUAF4(X),U)
|
---|
| 2119 | "RTN","NHINVLRO",47,0)
|
---|
| 2120 | ... I 'X S NHITM("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 2121 | "RTN","NHINVLRO",48,0)
|
---|
| 2122 | ... S NHI=0 F S NHI=$O(NHLRO(NHT,NHI)) Q:NHI<1 D
|
---|
| 2123 | "RTN","NHINVLRO",49,0)
|
---|
| 2124 | .... S X=$G(NHLRO(NHT,NHI))
|
---|
| 2125 | "RTN","NHINVLRO",50,0)
|
---|
| 2126 | .... S:NHSUB="CH" NHITM("value",NHI)=$$CH(X)
|
---|
| 2127 | "RTN","NHINVLRO",51,0)
|
---|
| 2128 | .... S:NHSUB="MI" NHITM("value",NHI)=$$MI(X)
|
---|
| 2129 | "RTN","NHINVLRO",52,0)
|
---|
| 2130 | ... I $D(^TMP("LRRR",$J,DFN,NHSUB,NHIDT,"N")) M CMMT=^("N") S NHITM("comment")=$$STRING^NHINV(.CMMT)
|
---|
| 2131 | "RTN","NHINVLRO",53,0)
|
---|
| 2132 | ... D XML(.NHITM)
|
---|
| 2133 | "RTN","NHINVLRO",54,0)
|
---|
| 2134 | K ^TMP("LRRR",$J,DFN)
|
---|
| 2135 | "RTN","NHINVLRO",55,0)
|
---|
| 2136 | Q
|
---|
| 2137 | "RTN","NHINVLRO",56,0)
|
---|
| 2138 | ;
|
---|
| 2139 | "RTN","NHINVLRO",57,0)
|
---|
| 2140 | SORT ; -- return NHLRO(PANEL) = CPRS order# ^ panel/test name ^ Lab Order string
|
---|
| 2141 | "RTN","NHINVLRO",58,0)
|
---|
| 2142 | ; NHLRO(PANEL,NHI) = result node
|
---|
| 2143 | "RTN","NHINVLRO",59,0)
|
---|
| 2144 | N X0,NUM,ORD,ODT,SN,T,T0,I,NHY,NHLRT K NHLRO
|
---|
| 2145 | "RTN","NHINVLRO",60,0)
|
---|
| 2146 | S NHI=$O(^TMP("LRRR",$J,DFN,NHSUB,NHIDT,0)),X0=$G(^(NHI)) ;first
|
---|
| 2147 | "RTN","NHINVLRO",61,0)
|
---|
| 2148 | S NUM=$P(X0,U,16),ORD=$P(X0,U,17),ODT=+$P(9999999-NHIDT,".")
|
---|
| 2149 | "RTN","NHINVLRO",62,0)
|
---|
| 2150 | ; - build NHLRT list of result nodes for each test/panel
|
---|
| 2151 | "RTN","NHINVLRO",63,0)
|
---|
| 2152 | I ORD S SN=0 F S SN=$O(^LRO(69,"C",ORD,ODT,SN)) Q:SN<1 D Q:$D(NHLRT)
|
---|
| 2153 | "RTN","NHINVLRO",64,0)
|
---|
| 2154 | . I $G(ID),$P(ID,";",3)'=SN Q
|
---|
| 2155 | "RTN","NHINVLRO",65,0)
|
---|
| 2156 | . S T=0 F S T=+$O(^LRO(69,ODT,1,SN,2,T)) Q:T<1 D
|
---|
| 2157 | "RTN","NHINVLRO",66,0)
|
---|
| 2158 | .. I $G(ID),T'=$P(ID,";",4) Q
|
---|
| 2159 | "RTN","NHINVLRO",67,0)
|
---|
| 2160 | .. S T0=$G(^LRO(69,ODT,1,SN,2,T,0))
|
---|
| 2161 | "RTN","NHINVLRO",68,0)
|
---|
| 2162 | .. ; is test/panel part of same accession?
|
---|
| 2163 | "RTN","NHINVLRO",69,0)
|
---|
| 2164 | .. Q:$P(T0,U,5)'=+$P(NUM," ",3)
|
---|
| 2165 | "RTN","NHINVLRO",70,0)
|
---|
| 2166 | .. Q:$$GET1^DIQ(68,$P(T0,U,4)_",",.09)'=$P(NUM," ")
|
---|
| 2167 | "RTN","NHINVLRO",71,0)
|
---|
| 2168 | .. ; expand panel into unit tests
|
---|
| 2169 | "RTN","NHINVLRO",72,0)
|
---|
| 2170 | .. K NHY D EXPAND(+T0,.NHY)
|
---|
| 2171 | "RTN","NHINVLRO",73,0)
|
---|
| 2172 | .. S I=0 F S I=$O(NHY(I)) Q:I<1 S NHLRT(I,+T0)="" ;NHLRT(test,panel)=""
|
---|
| 2173 | "RTN","NHINVLRO",74,0)
|
---|
| 2174 | .. S NHLRO(+T0)=$P(T0,U,7)_U_$P($G(^LAB(60,+T0,0)),U)_U_ORD_";"_ODT_";"_SN_";"_T
|
---|
| 2175 | "RTN","NHINVLRO",75,0)
|
---|
| 2176 | S:'$D(NHLRO) NHLRO(0)=$S(NHSUB="MI":"^MICROBIOLOGY^MI;",1:"^ACCESSION^CH;")_NHIDT ;no Lab Order
|
---|
| 2177 | "RTN","NHINVLRO",76,0)
|
---|
| 2178 | ; - build NHLRO(panel#,NHI) = ^TMP node
|
---|
| 2179 | "RTN","NHINVLRO",77,0)
|
---|
| 2180 | S NHI=0 F S NHI=$O(^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI)) Q:NHI<1 S X0=$G(^(NHI)) D
|
---|
| 2181 | "RTN","NHINVLRO",78,0)
|
---|
| 2182 | . I '$D(NHLRT(+X0)) S NHLRO(0,NHI)=X0 Q ;no Lab Order
|
---|
| 2183 | "RTN","NHINVLRO",79,0)
|
---|
| 2184 | . S T=0 F S T=$O(NHLRT(+X0,T)) Q:T<1 S NHLRO(T,NHI)=X0
|
---|
| 2185 | "RTN","NHINVLRO",80,0)
|
---|
| 2186 | Q
|
---|
| 2187 | "RTN","NHINVLRO",81,0)
|
---|
| 2188 | ;
|
---|
| 2189 | "RTN","NHINVLRO",82,0)
|
---|
| 2190 | EXPAND(TEST,ARAY) ;Expand a lab test panel [LR7OU1]
|
---|
| 2191 | "RTN","NHINVLRO",83,0)
|
---|
| 2192 | ;TEST=Test ptr to file 60
|
---|
| 2193 | "RTN","NHINVLRO",84,0)
|
---|
| 2194 | ;Expanded panel returned in ARAY(TEST)
|
---|
| 2195 | "RTN","NHINVLRO",85,0)
|
---|
| 2196 | N INARAY
|
---|
| 2197 | "RTN","NHINVLRO",86,0)
|
---|
| 2198 | D EX(TEST)
|
---|
| 2199 | "RTN","NHINVLRO",87,0)
|
---|
| 2200 | M ARAY=INARAY
|
---|
| 2201 | "RTN","NHINVLRO",88,0)
|
---|
| 2202 | Q
|
---|
| 2203 | "RTN","NHINVLRO",89,0)
|
---|
| 2204 | EX(TST) ;
|
---|
| 2205 | "RTN","NHINVLRO",90,0)
|
---|
| 2206 | N J,X,SUB
|
---|
| 2207 | "RTN","NHINVLRO",91,0)
|
---|
| 2208 | Q:'$D(^LAB(60,TST,0)) S SUB=$P(^(0),"^",5)
|
---|
| 2209 | "RTN","NHINVLRO",92,0)
|
---|
| 2210 | I $L(SUB) S:'$D(INARAY(+TST)) INARAY(+TST)="" Q
|
---|
| 2211 | "RTN","NHINVLRO",93,0)
|
---|
| 2212 | S J=0 F S J=$O(^LAB(60,+TST,2,J)) Q:J<1 S X=^(J,0) D EX(+X)
|
---|
| 2213 | "RTN","NHINVLRO",94,0)
|
---|
| 2214 | Q
|
---|
| 2215 | "RTN","NHINVLRO",95,0)
|
---|
| 2216 | ;
|
---|
| 2217 | "RTN","NHINVLRO",96,0)
|
---|
| 2218 | ACC(NUM,ODT,SN) ; -- Return 1 or 0, if Specimen entry matches accession
|
---|
| 2219 | "RTN","NHINVLRO",97,0)
|
---|
| 2220 | N T,T0,Y S Y=0
|
---|
| 2221 | "RTN","NHINVLRO",98,0)
|
---|
| 2222 | S T=+$O(^LRO(69,ODT,1,SN,2,0)),T0=$G(^(T,0))
|
---|
| 2223 | "RTN","NHINVLRO",99,0)
|
---|
| 2224 | I $P(T0,U,5)=+$P(NUM," ",3),$$GET1^DIQ(68,$P(T0,U,4)_",",.09)=$P(NUM," ") S Y=1
|
---|
| 2225 | "RTN","NHINVLRO",100,0)
|
---|
| 2226 | Q Y
|
---|
| 2227 | "RTN","NHINVLRO",101,0)
|
---|
| 2228 | ;
|
---|
| 2229 | "RTN","NHINVLRO",102,0)
|
---|
| 2230 | CH(X0) ; -- return a Chemistry result as:
|
---|
| 2231 | "RTN","NHINVLRO",103,0)
|
---|
| 2232 | ; id^test^result^interpretation^units^low^high^loinc^vuid
|
---|
| 2233 | "RTN","NHINVLRO",104,0)
|
---|
| 2234 | ; Expects X0=^TMP("LRRR",$J,DFN,"CH",NHIDT,NHI),LRDFN
|
---|
| 2235 | "RTN","NHINVLRO",105,0)
|
---|
| 2236 | N X,Y,NODE,LOINC
|
---|
| 2237 | "RTN","NHINVLRO",106,0)
|
---|
| 2238 | S NODE=$G(^LR(LRDFN,"CH",NHIDT,NHI))
|
---|
| 2239 | "RTN","NHINVLRO",107,0)
|
---|
| 2240 | S X=$P($G(^LAB(60,+X0,0)),U)
|
---|
| 2241 | "RTN","NHINVLRO",108,0)
|
---|
| 2242 | S Y="CH;"_NHIDT_";"_NHI_U_X_U_$P(X0,U,2,4)
|
---|
| 2243 | "RTN","NHINVLRO",109,0)
|
---|
| 2244 | S X=$P(X0,U,5) I $L(X),X["-" S X=$TR(X,"- ","^"),$P(Y,U,6,7)=X
|
---|
| 2245 | "RTN","NHINVLRO",110,0)
|
---|
| 2246 | S X=$P($P(NODE,U,3),"!",3) S:X LOINC=$$GET1^DIQ(95.3,X_",",.01)
|
---|
| 2247 | "RTN","NHINVLRO",111,0)
|
---|
| 2248 | I '$G(LOINC) S X=+$P(X0,U,19) S:X LOINC=$$LOINC(+X0,X)
|
---|
| 2249 | "RTN","NHINVLRO",112,0)
|
---|
| 2250 | S $P(Y,U,8,9)=$G(LOINC)_U_$$VUID^NHINV(+$G(LOINC),95.3)
|
---|
| 2251 | "RTN","NHINVLRO",113,0)
|
---|
| 2252 | Q Y
|
---|
| 2253 | "RTN","NHINVLRO",114,0)
|
---|
| 2254 | ;
|
---|
| 2255 | "RTN","NHINVLRO",115,0)
|
---|
| 2256 | LOINC(TEST,SPEC) ; -- Look up LOINC code, if not mapped
|
---|
| 2257 | "RTN","NHINVLRO",116,0)
|
---|
| 2258 | N Y,LAM,NHIN,IENS S Y=""
|
---|
| 2259 | "RTN","NHINVLRO",117,0)
|
---|
| 2260 | S TEST=+$G(TEST),SPEC=+$G(SPEC)
|
---|
| 2261 | "RTN","NHINVLRO",118,0)
|
---|
| 2262 | S LAM=$G(^LAB(60,TEST,64)),LAM=$S($P(LAM,U,2):$P(LAM,U,2),1:+LAM)
|
---|
| 2263 | "RTN","NHINVLRO",119,0)
|
---|
| 2264 | D GETS^DIQ(64.01,SPEC_","_LAM_",","30*",,"NHIN")
|
---|
| 2265 | "RTN","NHINVLRO",120,0)
|
---|
| 2266 | S IENS=$O(NHIN(64.02,"")) S:IENS Y=$G(NHIN(64.02,IENS,4))
|
---|
| 2267 | "RTN","NHINVLRO",121,0)
|
---|
| 2268 | S:'Y Y=$$GET1^DIQ(60.01,SPEC_","_TEST_",",95.3)
|
---|
| 2269 | "RTN","NHINVLRO",122,0)
|
---|
| 2270 | Q Y
|
---|
| 2271 | "RTN","NHINVLRO",123,0)
|
---|
| 2272 | ;
|
---|
| 2273 | "RTN","NHINVLRO",124,0)
|
---|
| 2274 | MI(X0) ; -- return a Microbiology result as:
|
---|
| 2275 | "RTN","NHINVLRO",125,0)
|
---|
| 2276 | ; id^test^result^interpretation^units
|
---|
| 2277 | "RTN","NHINVLRO",126,0)
|
---|
| 2278 | ; Expects X0=^TMP("LRRR",$J,DFN,"MI",NHIDT,NHI)
|
---|
| 2279 | "RTN","NHINVLRO",127,0)
|
---|
| 2280 | N Y S Y=""
|
---|
| 2281 | "RTN","NHINVLRO",128,0)
|
---|
| 2282 | S:$L($P(X0,U))>1 Y="MI;"_NHIDT_";"_NHI_U_$P(X0,U,1,4)
|
---|
| 2283 | "RTN","NHINVLRO",129,0)
|
---|
| 2284 | Q Y
|
---|
| 2285 | "RTN","NHINVLRO",130,0)
|
---|
| 2286 | ;
|
---|
| 2287 | "RTN","NHINVLRO",131,0)
|
---|
| 2288 | ; ------------ Return data to middle tier ------------
|
---|
| 2289 | "RTN","NHINVLRO",132,0)
|
---|
| 2290 | ;
|
---|
| 2291 | "RTN","NHINVLRO",133,0)
|
---|
| 2292 | XML(LAB) ; -- Return result as XML in @NHIN@(#)
|
---|
| 2293 | "RTN","NHINVLRO",134,0)
|
---|
| 2294 | N ATT,X,Y,I,J,P,NAMES,TAG
|
---|
| 2295 | "RTN","NHINVLRO",135,0)
|
---|
| 2296 | D ADD("<panel>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 2297 | "RTN","NHINVLRO",136,0)
|
---|
| 2298 | S ATT="" F S ATT=$O(LAB(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 2299 | "RTN","NHINVLRO",137,0)
|
---|
| 2300 | . I $O(LAB(ATT,0)) D S Y="" Q
|
---|
| 2301 | "RTN","NHINVLRO",138,0)
|
---|
| 2302 | .. D ADD("<"_ATT_"s>")
|
---|
| 2303 | "RTN","NHINVLRO",139,0)
|
---|
| 2304 | .. I ATT="value" S NAMES="id^test^result^interpretation^units^low^high^loinc^vuid^Z"
|
---|
| 2305 | "RTN","NHINVLRO",140,0)
|
---|
| 2306 | .. E S NAMES="code^name^Z"
|
---|
| 2307 | "RTN","NHINVLRO",141,0)
|
---|
| 2308 | .. S I=0 F S I=$O(LAB(ATT,I)) Q:I<1 D
|
---|
| 2309 | "RTN","NHINVLRO",142,0)
|
---|
| 2310 | ... S X=$G(LAB(ATT,I)),Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2311 | "RTN","NHINVLRO",143,0)
|
---|
| 2312 | .. D ADD("</"_ATT_"s>")
|
---|
| 2313 | "RTN","NHINVLRO",144,0)
|
---|
| 2314 | . S X=$G(LAB(ATT)),Y="" Q:'$L(X)
|
---|
| 2315 | "RTN","NHINVLRO",145,0)
|
---|
| 2316 | . I ATT="comment" S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 2317 | "RTN","NHINVLRO",146,0)
|
---|
| 2318 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 2319 | "RTN","NHINVLRO",147,0)
|
---|
| 2320 | . I $L(X)>1 S NAMES="code^name^Z",Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 2321 | "RTN","NHINVLRO",148,0)
|
---|
| 2322 | D ADD("</panel>")
|
---|
| 2323 | "RTN","NHINVLRO",149,0)
|
---|
| 2324 | Q
|
---|
| 2325 | "RTN","NHINVLRO",150,0)
|
---|
| 2326 | ;
|
---|
| 2327 | "RTN","NHINVLRO",151,0)
|
---|
| 2328 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 2329 | "RTN","NHINVLRO",152,0)
|
---|
| 2330 | N STR,P,TAG S STR=""
|
---|
| 2331 | "RTN","NHINVLRO",153,0)
|
---|
| 2332 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 2333 | "RTN","NHINVLRO",154,0)
|
---|
| 2334 | Q STR
|
---|
| 2335 | "RTN","NHINVLRO",155,0)
|
---|
| 2336 | ;
|
---|
| 2337 | "RTN","NHINVLRO",156,0)
|
---|
| 2338 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 2339 | "RTN","NHINVLRO",157,0)
|
---|
| 2340 | S NHINI=$G(NHINI)+1
|
---|
| 2341 | "RTN","NHINVLRO",158,0)
|
---|
| 2342 | S @NHIN@(NHINI)=X
|
---|
| 2343 | "RTN","NHINVLRO",159,0)
|
---|
| 2344 | Q
|
---|
| 2345 | "RTN","NHINVPL")
|
---|
| 2346 | 0^26^B19846807^n/a
|
---|
| 2347 | "RTN","NHINVPL",1,0)
|
---|
| 2348 | NHINVPL ;SLC/MKB -- Problem extract
|
---|
| 2349 | "RTN","NHINVPL",2,0)
|
---|
| 2350 | ;;1.0;NHIN;**1**;Dec 01, 2009;Build 11
|
---|
| 2351 | "RTN","NHINVPL",3,0)
|
---|
| 2352 | ;
|
---|
| 2353 | "RTN","NHINVPL",4,0)
|
---|
| 2354 | ; External References DBIA#
|
---|
| 2355 | "RTN","NHINVPL",5,0)
|
---|
| 2356 | ; ------------------- -----
|
---|
| 2357 | "RTN","NHINVPL",6,0)
|
---|
| 2358 | ; ^VA(200 10060
|
---|
| 2359 | "RTN","NHINVPL",7,0)
|
---|
| 2360 | ; %DT 10003
|
---|
| 2361 | "RTN","NHINVPL",8,0)
|
---|
| 2362 | ; DIQ 2056
|
---|
| 2363 | "RTN","NHINVPL",9,0)
|
---|
| 2364 | ; GMPLUTL2 2741
|
---|
| 2365 | "RTN","NHINVPL",10,0)
|
---|
| 2366 | ; XUAF4 2171
|
---|
| 2367 | "RTN","NHINVPL",11,0)
|
---|
| 2368 | ;
|
---|
| 2369 | "RTN","NHINVPL",12,0)
|
---|
| 2370 | ; ------------ Get problems from VistA ------------
|
---|
| 2371 | "RTN","NHINVPL",13,0)
|
---|
| 2372 | ;
|
---|
| 2373 | "RTN","NHINVPL",14,0)
|
---|
| 2374 | EN(DFN,BEG,END,MAX,IFN) ; -- find patient's problems
|
---|
| 2375 | "RTN","NHINVPL",15,0)
|
---|
| 2376 | N NHIPROB,NHI,NHITM,NHICNT,X
|
---|
| 2377 | "RTN","NHINVPL",16,0)
|
---|
| 2378 | ;
|
---|
| 2379 | "RTN","NHINVPL",17,0)
|
---|
| 2380 | ; get one problem
|
---|
| 2381 | "RTN","NHINVPL",18,0)
|
---|
| 2382 | I $G(IFN) D EN1(IFN,.NHITM),XML(.NHITM) Q
|
---|
| 2383 | "RTN","NHINVPL",19,0)
|
---|
| 2384 | ;
|
---|
| 2385 | "RTN","NHINVPL",20,0)
|
---|
| 2386 | ; get all patient problems
|
---|
| 2387 | "RTN","NHINVPL",21,0)
|
---|
| 2388 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 2389 | "RTN","NHINVPL",22,0)
|
---|
| 2390 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999),NHICNT=0
|
---|
| 2391 | "RTN","NHINVPL",23,0)
|
---|
| 2392 | D LIST^GMPLUTL2(.NHIPROB,DFN,"") ;all problems
|
---|
| 2393 | "RTN","NHINVPL",24,0)
|
---|
| 2394 | S NHI=0 F S NHI=$O(NHIPROB(NHI)) Q:(NHI<1)!(NHICNT'<MAX) D
|
---|
| 2395 | "RTN","NHINVPL",25,0)
|
---|
| 2396 | . S X=$P(NHIPROB(NHI),U,5) I X,(X<BEG)!(X>END) Q ;onset
|
---|
| 2397 | "RTN","NHINVPL",26,0)
|
---|
| 2398 | . S X=+NHIPROB(NHI) K NHITM ;ien
|
---|
| 2399 | "RTN","NHINVPL",27,0)
|
---|
| 2400 | . D EN1(X,.NHITM),XML(.NHITM)
|
---|
| 2401 | "RTN","NHINVPL",28,0)
|
---|
| 2402 | . S NHICNT=NHICNT+1
|
---|
| 2403 | "RTN","NHINVPL",29,0)
|
---|
| 2404 | Q
|
---|
| 2405 | "RTN","NHINVPL",30,0)
|
---|
| 2406 | ;
|
---|
| 2407 | "RTN","NHINVPL",31,0)
|
---|
| 2408 | EN1(ID,PROB) ; -- return a problem in PROB("attribute")=value
|
---|
| 2409 | "RTN","NHINVPL",32,0)
|
---|
| 2410 | N NHPL,X,I,J K PROB
|
---|
| 2411 | "RTN","NHINVPL",33,0)
|
---|
| 2412 | S ID=+$G(ID) Q:ID<1 ;invalid ien
|
---|
| 2413 | "RTN","NHINVPL",34,0)
|
---|
| 2414 | D DETAIL^GMPLUTL2(ID,.NHPL) Q:'$D(NHPL) ;doesn't exist
|
---|
| 2415 | "RTN","NHINVPL",35,0)
|
---|
| 2416 | S PROB("id")=ID ;,PROB("lexiconID")=+X1 ;SNOMED?
|
---|
| 2417 | "RTN","NHINVPL",36,0)
|
---|
| 2418 | S PROB("name")=$G(NHPL("NARRATIVE"))
|
---|
| 2419 | "RTN","NHINVPL",37,0)
|
---|
| 2420 | S X=$G(NHPL("MODIFIED")) S:$L(X) PROB("updated")=$$DATE(X)
|
---|
| 2421 | "RTN","NHINVPL",38,0)
|
---|
| 2422 | S PROB("icd")=$G(NHPL("DIAGNOSIS"))
|
---|
| 2423 | "RTN","NHINVPL",39,0)
|
---|
| 2424 | S X=$G(NHPL("STATUS")) S:$L(X) PROB("status")=$E(X)
|
---|
| 2425 | "RTN","NHINVPL",40,0)
|
---|
| 2426 | S X=$G(NHPL("HISTORY")) S:$L(X) PROB("history")=$E(X)
|
---|
| 2427 | "RTN","NHINVPL",41,0)
|
---|
| 2428 | S X=$G(NHPL("PRIORITY")) S:$L(X) PROB("acuity")=$E(X)
|
---|
| 2429 | "RTN","NHINVPL",42,0)
|
---|
| 2430 | S X=$G(NHPL("ONSET")) S:$L(X) PROB("onset")=$$DATE(X)
|
---|
| 2431 | "RTN","NHINVPL",43,0)
|
---|
| 2432 | S X=$$GET1^DIQ(9000011,ID_",",1.07,"I") S:X PROB("resolved")=X
|
---|
| 2433 | "RTN","NHINVPL",44,0)
|
---|
| 2434 | S X=$P($G(NHPL("ENTERED")),U) S:$L(X) PROB("entered")=$$DATE(X)
|
---|
| 2435 | "RTN","NHINVPL",45,0)
|
---|
| 2436 | S X=$$GET1^DIQ(9000011,ID_",",1.02,"I")
|
---|
| 2437 | "RTN","NHINVPL",46,0)
|
---|
| 2438 | S:X="P" PROB("unverified")=0,PROB("removed")=0
|
---|
| 2439 | "RTN","NHINVPL",47,0)
|
---|
| 2440 | S:X="T" PROB("unverified")=1,PROB("removed")=0
|
---|
| 2441 | "RTN","NHINVPL",48,0)
|
---|
| 2442 | S:X="H" PROB("unverified")=0,PROB("removed")=1
|
---|
| 2443 | "RTN","NHINVPL",49,0)
|
---|
| 2444 | S X=$G(NHPL("SC")),X=$S(X="YES":1,X="NO":0,1:"")
|
---|
| 2445 | "RTN","NHINVPL",50,0)
|
---|
| 2446 | S:$L(X) PROB("sc")=X I $G(NHPL("EXPOSURE")) D ;ao^rad^pgulf^hnc^mst^cv
|
---|
| 2447 | "RTN","NHINVPL",51,0)
|
---|
| 2448 | . S I=0 F S I=$O(NHPL("EXPOSURE",I)) Q:I<1 D
|
---|
| 2449 | "RTN","NHINVPL",52,0)
|
---|
| 2450 | .. S X=$G(NHPL("EXPOSURE",I))
|
---|
| 2451 | "RTN","NHINVPL",53,0)
|
---|
| 2452 | .. S PROB("exposure",I)=$$EXP(X)
|
---|
| 2453 | "RTN","NHINVPL",54,0)
|
---|
| 2454 | S X=$G(NHPL("PROVIDER")) S:$L(X) PROB("provider")=$$VA200(X)_U_X
|
---|
| 2455 | "RTN","NHINVPL",55,0)
|
---|
| 2456 | S X=$$GET1^DIQ(9000011,ID_",",1.06) S:$L(X) PROB("service")=X
|
---|
| 2457 | "RTN","NHINVPL",56,0)
|
---|
| 2458 | S X=$G(NHPL("CLINIC")) S:$L(X) PROB("location")=X
|
---|
| 2459 | "RTN","NHINVPL",57,0)
|
---|
| 2460 | S X=+$$GET1^DIQ(9000011,ID_",",.06,"I")
|
---|
| 2461 | "RTN","NHINVPL",58,0)
|
---|
| 2462 | S:X PROB("facility")=$$STA^XUAF4(X)_U_$P($$NS^XUAF4(X),U)
|
---|
| 2463 | "RTN","NHINVPL",59,0)
|
---|
| 2464 | I 'X S PROB("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 2465 | "RTN","NHINVPL",60,0)
|
---|
| 2466 | CMT ; comments
|
---|
| 2467 | "RTN","NHINVPL",61,0)
|
---|
| 2468 | Q:'$G(NHPL("COMMENT"))
|
---|
| 2469 | "RTN","NHINVPL",62,0)
|
---|
| 2470 | S I=0 F S I=$O(NHPL("COMMENT",I)) Q:I<1 D
|
---|
| 2471 | "RTN","NHINVPL",63,0)
|
---|
| 2472 | . S X=$G(NHPL("COMMENT",I))
|
---|
| 2473 | "RTN","NHINVPL",64,0)
|
---|
| 2474 | . S PROB("comment",I)=$$DATE($P(X,U))_U_$P(X,U,2,3)
|
---|
| 2475 | "RTN","NHINVPL",65,0)
|
---|
| 2476 | . ; = date ^ name of author ^ text
|
---|
| 2477 | "RTN","NHINVPL",66,0)
|
---|
| 2478 | Q
|
---|
| 2479 | "RTN","NHINVPL",67,0)
|
---|
| 2480 | ;
|
---|
| 2481 | "RTN","NHINVPL",68,0)
|
---|
| 2482 | DATE(X) ; -- Return internal form of date X
|
---|
| 2483 | "RTN","NHINVPL",69,0)
|
---|
| 2484 | N %DT,Y
|
---|
| 2485 | "RTN","NHINVPL",70,0)
|
---|
| 2486 | S %DT="" D ^%DT S:Y<1 Y=X
|
---|
| 2487 | "RTN","NHINVPL",71,0)
|
---|
| 2488 | Q Y
|
---|
| 2489 | "RTN","NHINVPL",72,0)
|
---|
| 2490 | ;
|
---|
| 2491 | "RTN","NHINVPL",73,0)
|
---|
| 2492 | VA200(X) ; -- Return ien of New Person X
|
---|
| 2493 | "RTN","NHINVPL",74,0)
|
---|
| 2494 | N Y S Y=$S($L($G(X)):+$O(^VA(200,"B",X,0)),1:"")
|
---|
| 2495 | "RTN","NHINVPL",75,0)
|
---|
| 2496 | Q Y
|
---|
| 2497 | "RTN","NHINVPL",76,0)
|
---|
| 2498 | ;
|
---|
| 2499 | "RTN","NHINVPL",77,0)
|
---|
| 2500 | EXP(X) ; -- Return code for exposure name X
|
---|
| 2501 | "RTN","NHINVPL",78,0)
|
---|
| 2502 | N Y S Y="",X=$E($G(X))
|
---|
| 2503 | "RTN","NHINVPL",79,0)
|
---|
| 2504 | I X="A" S Y="AO" ;agent orange
|
---|
| 2505 | "RTN","NHINVPL",80,0)
|
---|
| 2506 | I X="R" S Y="IR" ;ionizing radiation
|
---|
| 2507 | "RTN","NHINVPL",81,0)
|
---|
| 2508 | I X="E" S Y="PG" ;persian gulf
|
---|
| 2509 | "RTN","NHINVPL",82,0)
|
---|
| 2510 | I X="H" S Y="HNC" ;head/neck cancer
|
---|
| 2511 | "RTN","NHINVPL",83,0)
|
---|
| 2512 | I X="M" S Y="MST" ;military sexual trauma
|
---|
| 2513 | "RTN","NHINVPL",84,0)
|
---|
| 2514 | I X="C" S Y="CV" ;combat vet
|
---|
| 2515 | "RTN","NHINVPL",85,0)
|
---|
| 2516 | I X="S" S Y="SHAD"
|
---|
| 2517 | "RTN","NHINVPL",86,0)
|
---|
| 2518 | Q Y
|
---|
| 2519 | "RTN","NHINVPL",87,0)
|
---|
| 2520 | ;
|
---|
| 2521 | "RTN","NHINVPL",88,0)
|
---|
| 2522 | ; ------------ Return data to middle tier ------------
|
---|
| 2523 | "RTN","NHINVPL",89,0)
|
---|
| 2524 | ;
|
---|
| 2525 | "RTN","NHINVPL",90,0)
|
---|
| 2526 | XML(PROB) ; -- Return patient problem as XML in @NHIN@(I)
|
---|
| 2527 | "RTN","NHINVPL",91,0)
|
---|
| 2528 | N ATT,I,X,Y,P,TAG
|
---|
| 2529 | "RTN","NHINVPL",92,0)
|
---|
| 2530 | D ADD("<problem>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 2531 | "RTN","NHINVPL",93,0)
|
---|
| 2532 | S ATT="" F S ATT=$O(PROB(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 2533 | "RTN","NHINVPL",94,0)
|
---|
| 2534 | . I ATT="exposure" D S Y="" Q
|
---|
| 2535 | "RTN","NHINVPL",95,0)
|
---|
| 2536 | .. S Y="<exposures>" D ADD(Y)
|
---|
| 2537 | "RTN","NHINVPL",96,0)
|
---|
| 2538 | .. S I=0 F S I=$O(PROB(ATT,I)) Q:I<1 S X=$G(PROB(ATT,I)) S:$L(X) Y="<exposure value='"_X_"' />" D ADD(Y)
|
---|
| 2539 | "RTN","NHINVPL",97,0)
|
---|
| 2540 | .. D ADD("</exposures>")
|
---|
| 2541 | "RTN","NHINVPL",98,0)
|
---|
| 2542 | . I ATT="comment" D S Y="" Q
|
---|
| 2543 | "RTN","NHINVPL",99,0)
|
---|
| 2544 | .. D ADD("<comments>")
|
---|
| 2545 | "RTN","NHINVPL",100,0)
|
---|
| 2546 | .. S I=0 F S I=$O(PROB(ATT,I)) Q:I<1 S X=$G(PROB(ATT,I)) D
|
---|
| 2547 | "RTN","NHINVPL",101,0)
|
---|
| 2548 | ... S Y="<comment id='"_I
|
---|
| 2549 | "RTN","NHINVPL",102,0)
|
---|
| 2550 | ... S:$L($P(X,U,1)) Y=Y_"' entered='"_$P(X,U)
|
---|
| 2551 | "RTN","NHINVPL",103,0)
|
---|
| 2552 | ... S:$L($P(X,U,2)) Y=Y_"' enteredBy='"_$$ESC^NHINV($P(X,U,2))
|
---|
| 2553 | "RTN","NHINVPL",104,0)
|
---|
| 2554 | ... S:$L($P(X,U,3)) Y=Y_"' commentText='"_$$ESC^NHINV($P(X,U,3))
|
---|
| 2555 | "RTN","NHINVPL",105,0)
|
---|
| 2556 | ... S Y=Y_"' />" D ADD(Y)
|
---|
| 2557 | "RTN","NHINVPL",106,0)
|
---|
| 2558 | .. D ADD("</comments>")
|
---|
| 2559 | "RTN","NHINVPL",107,0)
|
---|
| 2560 | . S X=$G(PROB(ATT)),Y="" Q:'$L(X)
|
---|
| 2561 | "RTN","NHINVPL",108,0)
|
---|
| 2562 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 2563 | "RTN","NHINVPL",109,0)
|
---|
| 2564 | . I $L(X)>1 D S Y=""
|
---|
| 2565 | "RTN","NHINVPL",110,0)
|
---|
| 2566 | .. S Y="<"_ATT_" "
|
---|
| 2567 | "RTN","NHINVPL",111,0)
|
---|
| 2568 | .. F P=1:1 S TAG=$P("code^name^Z",U,P) Q:TAG="Z" I $L($P(X,U,P)) S Y=Y_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 2569 | "RTN","NHINVPL",112,0)
|
---|
| 2570 | .. S Y=Y_"/>" D ADD(Y)
|
---|
| 2571 | "RTN","NHINVPL",113,0)
|
---|
| 2572 | D ADD("</problem>")
|
---|
| 2573 | "RTN","NHINVPL",114,0)
|
---|
| 2574 | Q
|
---|
| 2575 | "RTN","NHINVPL",115,0)
|
---|
| 2576 | ;
|
---|
| 2577 | "RTN","NHINVPL",116,0)
|
---|
| 2578 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 2579 | "RTN","NHINVPL",117,0)
|
---|
| 2580 | S NHINI=$G(NHINI)+1
|
---|
| 2581 | "RTN","NHINVPL",118,0)
|
---|
| 2582 | S @NHIN@(NHINI)=X
|
---|
| 2583 | "RTN","NHINVPL",119,0)
|
---|
| 2584 | Q
|
---|
| 2585 | "RTN","NHINVPRC")
|
---|
| 2586 | 0^16^B6896734^n/a
|
---|
| 2587 | "RTN","NHINVPRC",1,0)
|
---|
| 2588 | NHINVPRC ;SLC/MKB -- Procedure extract
|
---|
| 2589 | "RTN","NHINVPRC",2,0)
|
---|
| 2590 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 2591 | "RTN","NHINVPRC",3,0)
|
---|
| 2592 | ;
|
---|
| 2593 | "RTN","NHINVPRC",4,0)
|
---|
| 2594 | ; External References DBIA#
|
---|
| 2595 | "RTN","NHINVPRC",5,0)
|
---|
| 2596 | ; ------------------- -----
|
---|
| 2597 | "RTN","NHINVPRC",6,0)
|
---|
| 2598 | ; RAO7PC1 2043
|
---|
| 2599 | "RTN","NHINVPRC",7,0)
|
---|
| 2600 | ; SROESTV 3533
|
---|
| 2601 | "RTN","NHINVPRC",8,0)
|
---|
| 2602 | ;
|
---|
| 2603 | "RTN","NHINVPRC",9,0)
|
---|
| 2604 | ; ------------ Get procedure(s) from VistA ------------
|
---|
| 2605 | "RTN","NHINVPRC",10,0)
|
---|
| 2606 | ;
|
---|
| 2607 | "RTN","NHINVPRC",11,0)
|
---|
| 2608 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's procedures
|
---|
| 2609 | "RTN","NHINVPRC",12,0)
|
---|
| 2610 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 2611 | "RTN","NHINVPRC",13,0)
|
---|
| 2612 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 2613 | "RTN","NHINVPRC",14,0)
|
---|
| 2614 | ;
|
---|
| 2615 | "RTN","NHINVPRC",15,0)
|
---|
| 2616 | N NHI,NHICNT,NHITM,NHY
|
---|
| 2617 | "RTN","NHINVPRC",16,0)
|
---|
| 2618 | ;
|
---|
| 2619 | "RTN","NHINVPRC",17,0)
|
---|
| 2620 | ; get one procedure
|
---|
| 2621 | "RTN","NHINVPRC",18,0)
|
---|
| 2622 | I $G(ID) D D:$D(NHITM) XML(.NHITM) Q
|
---|
| 2623 | "RTN","NHINVPRC",19,0)
|
---|
| 2624 | . I ID'["-" D EN1^NHINVSR(ID,.NHITM) Q
|
---|
| 2625 | "RTN","NHINVPRC",20,0)
|
---|
| 2626 | . S (BEG,END)=9999999.9999=+ID
|
---|
| 2627 | "RTN","NHINVPRC",21,0)
|
---|
| 2628 | . D EN1^RAO7PC1(DFN,BEG,END),EN1^NHINVRA(ID,.NHITM)
|
---|
| 2629 | "RTN","NHINVPRC",22,0)
|
---|
| 2630 | ;
|
---|
| 2631 | "RTN","NHINVPRC",23,0)
|
---|
| 2632 | ; get all surgeries
|
---|
| 2633 | "RTN","NHINVPRC",24,0)
|
---|
| 2634 | N SHOWADD S SHOWADD=1 ;to omit leading '+' with note titles
|
---|
| 2635 | "RTN","NHINVPRC",25,0)
|
---|
| 2636 | D LIST^SROESTV(.NHY,DFN,BEG,END,MAX,1)
|
---|
| 2637 | "RTN","NHINVPRC",26,0)
|
---|
| 2638 | S NHI=0 F S NHI=$O(@NHY@(NHI)) Q:NHI<1 D
|
---|
| 2639 | "RTN","NHINVPRC",27,0)
|
---|
| 2640 | . K NHITM D ONE^NHINVSR(NHI,.NHITM) Q:'$D(NHITM)
|
---|
| 2641 | "RTN","NHINVPRC",28,0)
|
---|
| 2642 | . ;Q:$G(NHITM("status"))'?1"COMP".E
|
---|
| 2643 | "RTN","NHINVPRC",29,0)
|
---|
| 2644 | . D XML(.NHITM)
|
---|
| 2645 | "RTN","NHINVPRC",30,0)
|
---|
| 2646 | K @NHY
|
---|
| 2647 | "RTN","NHINVPRC",31,0)
|
---|
| 2648 | ;
|
---|
| 2649 | "RTN","NHINVPRC",32,0)
|
---|
| 2650 | ; get all radiology exams
|
---|
| 2651 | "RTN","NHINVPRC",33,0)
|
---|
| 2652 | K ^TMP($J,"RAE1") D EN1^RAO7PC1(DFN,BEG,END,MAX)
|
---|
| 2653 | "RTN","NHINVPRC",34,0)
|
---|
| 2654 | S NHICNT=0,NHI=""
|
---|
| 2655 | "RTN","NHINVPRC",35,0)
|
---|
| 2656 | F S NHI=$O(^TMP($J,"RAE1",DFN,NHI)) Q:NHI="" D Q:NHICNT'<MAX ;I $P($P($G(^(NHI)),U,6),"~",2)?1"COMP".E
|
---|
| 2657 | "RTN","NHINVPRC",36,0)
|
---|
| 2658 | . K NHITM D EN1^NHINVRA(NHI,.NHITM) Q:'$D(NHITM)
|
---|
| 2659 | "RTN","NHINVPRC",37,0)
|
---|
| 2660 | . D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 2661 | "RTN","NHINVPRC",38,0)
|
---|
| 2662 | K ^TMP($J,"RAE1")
|
---|
| 2663 | "RTN","NHINVPRC",39,0)
|
---|
| 2664 | ;
|
---|
| 2665 | "RTN","NHINVPRC",40,0)
|
---|
| 2666 | ; Consults/ClinProc
|
---|
| 2667 | "RTN","NHINVPRC",41,0)
|
---|
| 2668 | ; V-files [CPT, Exam, Treatment, Patient ED]
|
---|
| 2669 | "RTN","NHINVPRC",42,0)
|
---|
| 2670 | ;
|
---|
| 2671 | "RTN","NHINVPRC",43,0)
|
---|
| 2672 | Q
|
---|
| 2673 | "RTN","NHINVPRC",44,0)
|
---|
| 2674 | ;
|
---|
| 2675 | "RTN","NHINVPRC",45,0)
|
---|
| 2676 | ; ------------ Return data to middle tier ------------
|
---|
| 2677 | "RTN","NHINVPRC",46,0)
|
---|
| 2678 | ;
|
---|
| 2679 | "RTN","NHINVPRC",47,0)
|
---|
| 2680 | XML(PRC) ; -- Return procedures as XML
|
---|
| 2681 | "RTN","NHINVPRC",48,0)
|
---|
| 2682 | N ATT,X,Y,I,NAMES
|
---|
| 2683 | "RTN","NHINVPRC",49,0)
|
---|
| 2684 | D ADD("<procedure>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 2685 | "RTN","NHINVPRC",50,0)
|
---|
| 2686 | S ATT="" F S ATT=$O(PRC(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 2687 | "RTN","NHINVPRC",51,0)
|
---|
| 2688 | . S NAMES=$S(ATT="document"!(ATT="opReport"):"id^localTitle^nationalTitle^status^Z",1:"code^name^Z")
|
---|
| 2689 | "RTN","NHINVPRC",52,0)
|
---|
| 2690 | . I $O(PRC(ATT,0)) D S Y="" Q ;multiples
|
---|
| 2691 | "RTN","NHINVPRC",53,0)
|
---|
| 2692 | .. D ADD("<"_ATT_"s>")
|
---|
| 2693 | "RTN","NHINVPRC",54,0)
|
---|
| 2694 | .. S I=0 F S I=$O(PRC(ATT,I)) Q:I<1 D
|
---|
| 2695 | "RTN","NHINVPRC",55,0)
|
---|
| 2696 | ... S X=$G(PRC(ATT,I))
|
---|
| 2697 | "RTN","NHINVPRC",56,0)
|
---|
| 2698 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2699 | "RTN","NHINVPRC",57,0)
|
---|
| 2700 | .. D ADD("</"_ATT_"s>")
|
---|
| 2701 | "RTN","NHINVPRC",58,0)
|
---|
| 2702 | . S X=$G(PRC(ATT)),Y="" Q:'$L(X)
|
---|
| 2703 | "RTN","NHINVPRC",59,0)
|
---|
| 2704 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 2705 | "RTN","NHINVPRC",60,0)
|
---|
| 2706 | . I $L(X)>1 S Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 2707 | "RTN","NHINVPRC",61,0)
|
---|
| 2708 | D ADD("</procedure>")
|
---|
| 2709 | "RTN","NHINVPRC",62,0)
|
---|
| 2710 | Q
|
---|
| 2711 | "RTN","NHINVPRC",63,0)
|
---|
| 2712 | ;
|
---|
| 2713 | "RTN","NHINVPRC",64,0)
|
---|
| 2714 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 2715 | "RTN","NHINVPRC",65,0)
|
---|
| 2716 | N STR,P,TAG S STR=""
|
---|
| 2717 | "RTN","NHINVPRC",66,0)
|
---|
| 2718 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 2719 | "RTN","NHINVPRC",67,0)
|
---|
| 2720 | Q STR
|
---|
| 2721 | "RTN","NHINVPRC",68,0)
|
---|
| 2722 | ;
|
---|
| 2723 | "RTN","NHINVPRC",69,0)
|
---|
| 2724 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 2725 | "RTN","NHINVPRC",70,0)
|
---|
| 2726 | S NHINI=$G(NHINI)+1
|
---|
| 2727 | "RTN","NHINVPRC",71,0)
|
---|
| 2728 | S @NHIN@(NHINI)=X
|
---|
| 2729 | "RTN","NHINVPRC",72,0)
|
---|
| 2730 | Q
|
---|
| 2731 | "RTN","NHINVPS")
|
---|
| 2732 | 0^27^B14129801^n/a
|
---|
| 2733 | "RTN","NHINVPS",1,0)
|
---|
| 2734 | NHINVPS ;SLC/MKB -- Pharmacy extract
|
---|
| 2735 | "RTN","NHINVPS",2,0)
|
---|
| 2736 | ;;1.0;NHIN;**1**;Dec 01, 2009;Build 11
|
---|
| 2737 | "RTN","NHINVPS",3,0)
|
---|
| 2738 | ;
|
---|
| 2739 | "RTN","NHINVPS",4,0)
|
---|
| 2740 | ; External References DBIA#
|
---|
| 2741 | "RTN","NHINVPS",5,0)
|
---|
| 2742 | ; ------------------- -----
|
---|
| 2743 | "RTN","NHINVPS",6,0)
|
---|
| 2744 | ; DIQ 2056
|
---|
| 2745 | "RTN","NHINVPS",7,0)
|
---|
| 2746 | ; PSOORRL,^TMP("PS",$J) 2400
|
---|
| 2747 | "RTN","NHINVPS",8,0)
|
---|
| 2748 | ; PSS50,^TMP($J 4483
|
---|
| 2749 | "RTN","NHINVPS",9,0)
|
---|
| 2750 | ;
|
---|
| 2751 | "RTN","NHINVPS",10,0)
|
---|
| 2752 | ; ------------ Get medications from VistA ------------
|
---|
| 2753 | "RTN","NHINVPS",11,0)
|
---|
| 2754 | ;
|
---|
| 2755 | "RTN","NHINVPS",12,0)
|
---|
| 2756 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's meds
|
---|
| 2757 | "RTN","NHINVPS",13,0)
|
---|
| 2758 | N PS0,NHI,NHITM,IV K ^TMP("PS",$J)
|
---|
| 2759 | "RTN","NHINVPS",14,0)
|
---|
| 2760 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 2761 | "RTN","NHINVPS",15,0)
|
---|
| 2762 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 2763 | "RTN","NHINVPS",16,0)
|
---|
| 2764 | ;
|
---|
| 2765 | "RTN","NHINVPS",17,0)
|
---|
| 2766 | ; get one med
|
---|
| 2767 | "RTN","NHINVPS",18,0)
|
---|
| 2768 | I $G(ID) D D:$D(NHITM)>9 XML(.NHITM) K ^TMP("PS",$J) Q
|
---|
| 2769 | "RTN","NHINVPS",19,0)
|
---|
| 2770 | . I ID["N" D NVA^NHINVPSO(ID,.NHITM) Q
|
---|
| 2771 | "RTN","NHINVPS",20,0)
|
---|
| 2772 | . I ID["O",(ID'["P")&(ID'["S") D RX^NHINVPSO(ID,.NHITM) Q
|
---|
| 2773 | "RTN","NHINVPS",21,0)
|
---|
| 2774 | . D OEL^PSOORRL(DFN,ID)
|
---|
| 2775 | "RTN","NHINVPS",22,0)
|
---|
| 2776 | . I ID["O",(ID["P")!(ID["S") D PEN1^NHINVPSO(ID,.NHITM) Q
|
---|
| 2777 | "RTN","NHINVPS",23,0)
|
---|
| 2778 | . S IV=$S(ID["V":1,$G(^TMP("PS",$J,"B",0)):1,1:0)
|
---|
| 2779 | "RTN","NHINVPS",24,0)
|
---|
| 2780 | . D @($S(IV:"IV1",1:"IN1")_"^NHINVPSI(ID,.NHITM)")
|
---|
| 2781 | "RTN","NHINVPS",25,0)
|
---|
| 2782 | ;
|
---|
| 2783 | "RTN","NHINVPS",26,0)
|
---|
| 2784 | ; get all meds
|
---|
| 2785 | "RTN","NHINVPS",27,0)
|
---|
| 2786 | D OCL^PSOORRL(DFN,BEG,END)
|
---|
| 2787 | "RTN","NHINVPS",28,0)
|
---|
| 2788 | S NHI=0 F S NHI=$O(^TMP("PS",$J,NHI)) Q:NHI<1!(NHI>MAX) S PS0=$G(^(NHI,0)) D I $D(NHITM)>9 D XML(.NHITM)
|
---|
| 2789 | "RTN","NHINVPS",29,0)
|
---|
| 2790 | . S ID=$P(PS0,U) K NHITM
|
---|
| 2791 | "RTN","NHINVPS",30,0)
|
---|
| 2792 | . I ID["N" D NVA^NHINVPSO(ID,.NHITM) Q
|
---|
| 2793 | "RTN","NHINVPS",31,0)
|
---|
| 2794 | . I ID["O" D RX^NHINVPSO(ID,.NHITM) Q
|
---|
| 2795 | "RTN","NHINVPS",32,0)
|
---|
| 2796 | . S IV=$S(ID["V":1,$G(^TMP("PS",$J,NHI,"B",0)):1,1:0)
|
---|
| 2797 | "RTN","NHINVPS",33,0)
|
---|
| 2798 | . D @($S(IV:"IV",1:"IN")_"^NHINVPSI(ID,.NHITM)")
|
---|
| 2799 | "RTN","NHINVPS",34,0)
|
---|
| 2800 | K ^TMP("PS",$J)
|
---|
| 2801 | "RTN","NHINVPS",35,0)
|
---|
| 2802 | Q
|
---|
| 2803 | "RTN","NHINVPS",36,0)
|
---|
| 2804 | ;
|
---|
| 2805 | "RTN","NHINVPS",37,0)
|
---|
| 2806 | NDF(DRUG,I) ; -- Set NDF data for dispense DRUG ien
|
---|
| 2807 | "RTN","NHINVPS",38,0)
|
---|
| 2808 | N VUID,X
|
---|
| 2809 | "RTN","NHINVPS",39,0)
|
---|
| 2810 | S DRUG=+$G(DRUG) Q:'DRUG
|
---|
| 2811 | "RTN","NHINVPS",40,0)
|
---|
| 2812 | D NDF^PSS50(DRUG,,,,,"NDF") S I=+$G(I)+1
|
---|
| 2813 | "RTN","NHINVPS",41,0)
|
---|
| 2814 | S MED("product",I)=DRUG_U_$G(^TMP($J,"NDF",DRUG,.01))_"^^D" ;Drug
|
---|
| 2815 | "RTN","NHINVPS",42,0)
|
---|
| 2816 | S X=$G(^TMP($J,"NDF",DRUG,20)),VUID=$$GET1^DIQ(50.6,+X_",",99.99)
|
---|
| 2817 | "RTN","NHINVPS",43,0)
|
---|
| 2818 | S MED("product",I,"G")=X_U_VUID ;VA Generic
|
---|
| 2819 | "RTN","NHINVPS",44,0)
|
---|
| 2820 | S X=$G(^TMP($J,"NDF",DRUG,22)),VUID=$$GET1^DIQ(50.68,+X_",",99.99)
|
---|
| 2821 | "RTN","NHINVPS",45,0)
|
---|
| 2822 | S MED("product",I,"P")=X_U_VUID ;VA Product
|
---|
| 2823 | "RTN","NHINVPS",46,0)
|
---|
| 2824 | S MED("product",I,"C")=$P($G(^TMP($J,"NDF",+DRUG,25)),U,3) ;display name
|
---|
| 2825 | "RTN","NHINVPS",47,0)
|
---|
| 2826 | K ^TMP($J,"NDF",DRUG)
|
---|
| 2827 | "RTN","NHINVPS",48,0)
|
---|
| 2828 | Q
|
---|
| 2829 | "RTN","NHINVPS",49,0)
|
---|
| 2830 | ;
|
---|
| 2831 | "RTN","NHINVPS",50,0)
|
---|
| 2832 | ; ------------ Return data to middle tier ------------
|
---|
| 2833 | "RTN","NHINVPS",51,0)
|
---|
| 2834 | ;
|
---|
| 2835 | "RTN","NHINVPS",52,0)
|
---|
| 2836 | XML(MED) ; -- Return patient meds as XML
|
---|
| 2837 | "RTN","NHINVPS",53,0)
|
---|
| 2838 | N ATT,X,Y,I,NAMES
|
---|
| 2839 | "RTN","NHINVPS",54,0)
|
---|
| 2840 | D ADD("<med>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 2841 | "RTN","NHINVPS",55,0)
|
---|
| 2842 | S ATT="" F S ATT=$O(MED(ATT)) Q:ATT="" D I $L(Y) D ADD(Y)
|
---|
| 2843 | "RTN","NHINVPS",56,0)
|
---|
| 2844 | . I $O(MED(ATT,0)) D S Y="" Q ;multiples
|
---|
| 2845 | "RTN","NHINVPS",57,0)
|
---|
| 2846 | .. D ADD("<"_ATT_"s>")
|
---|
| 2847 | "RTN","NHINVPS",58,0)
|
---|
| 2848 | .. S I=0 F S I=$O(MED(ATT,I)) Q:I<1 D
|
---|
| 2849 | "RTN","NHINVPS",59,0)
|
---|
| 2850 | ... S X=$G(MED(ATT,I)),NAMES=""
|
---|
| 2851 | "RTN","NHINVPS",60,0)
|
---|
| 2852 | ... I ATT="dose" S NAMES="dose^units^unitsPerDose^noun^route^schedule^duration^conjunction^doseStart^doseStop^Z"
|
---|
| 2853 | "RTN","NHINVPS",61,0)
|
---|
| 2854 | ... I ATT="fill" S NAMES="fillDate^fillRouting^releaseDate^fillQuantity^fillDaysSupply^partial^Z"
|
---|
| 2855 | "RTN","NHINVPS",62,0)
|
---|
| 2856 | ... I ATT="product" S NAMES="code^name^vuid^role^concentration^Z"
|
---|
| 2857 | "RTN","NHINVPS",63,0)
|
---|
| 2858 | ... S Y="<"_ATT_" "_$$LOOP_$S(ATT'="product":"/>",1:">") D ADD(Y)
|
---|
| 2859 | "RTN","NHINVPS",64,0)
|
---|
| 2860 | ... Q:ATT'="product"
|
---|
| 2861 | "RTN","NHINVPS",65,0)
|
---|
| 2862 | ... S X=$G(MED(ATT,I,"C")) I $L(X) S Y="<class "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2863 | "RTN","NHINVPS",66,0)
|
---|
| 2864 | ... S X=$G(MED(ATT,I,"G")) I $L(X) S Y="<vaGeneric "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2865 | "RTN","NHINVPS",67,0)
|
---|
| 2866 | ... S X=$G(MED(ATT,I,"P")) I $L(X) S Y="<vaProduct "_$$LOOP_"/>" D ADD(Y)
|
---|
| 2867 | "RTN","NHINVPS",68,0)
|
---|
| 2868 | ... D ADD("</product>")
|
---|
| 2869 | "RTN","NHINVPS",69,0)
|
---|
| 2870 | .. D ADD("</"_ATT_"s>")
|
---|
| 2871 | "RTN","NHINVPS",70,0)
|
---|
| 2872 | . S X=$G(MED(ATT)),Y="" Q:'$L(X)
|
---|
| 2873 | "RTN","NHINVPS",71,0)
|
---|
| 2874 | . I ATT="sig"!(ATT?1"ptIn"1.A) S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 2875 | "RTN","NHINVPS",72,0)
|
---|
| 2876 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 2877 | "RTN","NHINVPS",73,0)
|
---|
| 2878 | . I $L(X)>1 S NAMES="code^name^Z",Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 2879 | "RTN","NHINVPS",74,0)
|
---|
| 2880 | D ADD("</med>")
|
---|
| 2881 | "RTN","NHINVPS",75,0)
|
---|
| 2882 | Q
|
---|
| 2883 | "RTN","NHINVPS",76,0)
|
---|
| 2884 | ;
|
---|
| 2885 | "RTN","NHINVPS",77,0)
|
---|
| 2886 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 2887 | "RTN","NHINVPS",78,0)
|
---|
| 2888 | N STR,P,TAG S STR=""
|
---|
| 2889 | "RTN","NHINVPS",79,0)
|
---|
| 2890 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 2891 | "RTN","NHINVPS",80,0)
|
---|
| 2892 | Q STR
|
---|
| 2893 | "RTN","NHINVPS",81,0)
|
---|
| 2894 | ;
|
---|
| 2895 | "RTN","NHINVPS",82,0)
|
---|
| 2896 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 2897 | "RTN","NHINVPS",83,0)
|
---|
| 2898 | S NHINI=$G(NHINI)+1
|
---|
| 2899 | "RTN","NHINVPS",84,0)
|
---|
| 2900 | S @NHIN@(NHINI)=X
|
---|
| 2901 | "RTN","NHINVPS",85,0)
|
---|
| 2902 | Q
|
---|
| 2903 | "RTN","NHINVPSI")
|
---|
| 2904 | 0^24^B41411886^n/a
|
---|
| 2905 | "RTN","NHINVPSI",1,0)
|
---|
| 2906 | NHINVPSI ;SLC/MKB -- Inpatient Pharmacy extract
|
---|
| 2907 | "RTN","NHINVPSI",2,0)
|
---|
| 2908 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 2909 | "RTN","NHINVPSI",3,0)
|
---|
| 2910 | ;
|
---|
| 2911 | "RTN","NHINVPSI",4,0)
|
---|
| 2912 | ; External References DBIA#
|
---|
| 2913 | "RTN","NHINVPSI",5,0)
|
---|
| 2914 | ; ------------------- -----
|
---|
| 2915 | "RTN","NHINVPSI",6,0)
|
---|
| 2916 | ; ^SC 10040
|
---|
| 2917 | "RTN","NHINVPSI",7,0)
|
---|
| 2918 | ; DIQ 2056
|
---|
| 2919 | "RTN","NHINVPSI",8,0)
|
---|
| 2920 | ; ORX8 2467
|
---|
| 2921 | "RTN","NHINVPSI",9,0)
|
---|
| 2922 | ; PSOORRL,^TMP("PS",$J) 2400
|
---|
| 2923 | "RTN","NHINVPSI",10,0)
|
---|
| 2924 | ; PSS50P7 4662
|
---|
| 2925 | "RTN","NHINVPSI",11,0)
|
---|
| 2926 | ; XLFSTR 10104
|
---|
| 2927 | "RTN","NHINVPSI",12,0)
|
---|
| 2928 | ;
|
---|
| 2929 | "RTN","NHINVPSI",13,0)
|
---|
| 2930 | ; ------------ Get medications from VistA ------------
|
---|
| 2931 | "RTN","NHINVPSI",14,0)
|
---|
| 2932 | ;
|
---|
| 2933 | "RTN","NHINVPSI",15,0)
|
---|
| 2934 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's UD/IV meds
|
---|
| 2935 | "RTN","NHINVPSI",16,0)
|
---|
| 2936 | N PS0,NHI,NHITM,IV K ^TMP("PS",$J)
|
---|
| 2937 | "RTN","NHINVPSI",17,0)
|
---|
| 2938 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 2939 | "RTN","NHINVPSI",18,0)
|
---|
| 2940 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 2941 | "RTN","NHINVPSI",19,0)
|
---|
| 2942 | ;
|
---|
| 2943 | "RTN","NHINVPSI",20,0)
|
---|
| 2944 | ; get one med
|
---|
| 2945 | "RTN","NHINVPSI",21,0)
|
---|
| 2946 | I $G(ID) D Q
|
---|
| 2947 | "RTN","NHINVPSI",22,0)
|
---|
| 2948 | . Q:ID["N" Q:ID["O" ;inpatient only
|
---|
| 2949 | "RTN","NHINVPSI",23,0)
|
---|
| 2950 | . D OEL^PSOORRL(DFN,ID)
|
---|
| 2951 | "RTN","NHINVPSI",24,0)
|
---|
| 2952 | . S IV=$S(ID["V":1,$G(^TMP("PS",$J,"B",0)):1,1:0)
|
---|
| 2953 | "RTN","NHINVPSI",25,0)
|
---|
| 2954 | . D @($S(IV:"IV1",1:"IN1")_"(ID,.NHITM)")
|
---|
| 2955 | "RTN","NHINVPSI",26,0)
|
---|
| 2956 | . I $D(NHITM)>9 D XML^NHINVPS(.NHITM)
|
---|
| 2957 | "RTN","NHINVPSI",27,0)
|
---|
| 2958 | . K ^TMP("PS",$J)
|
---|
| 2959 | "RTN","NHINVPSI",28,0)
|
---|
| 2960 | ;
|
---|
| 2961 | "RTN","NHINVPSI",29,0)
|
---|
| 2962 | ; get all meds
|
---|
| 2963 | "RTN","NHINVPSI",30,0)
|
---|
| 2964 | D OCL^PSOORRL(DFN,BEG,END)
|
---|
| 2965 | "RTN","NHINVPSI",31,0)
|
---|
| 2966 | S NHI=0 F S NHI=$O(^TMP("PS",$J,NHI)) Q:NHI<1!(NHI>MAX) S PS0=$G(^(NHI,0)) D
|
---|
| 2967 | "RTN","NHINVPSI",32,0)
|
---|
| 2968 | . S ID=$P(PS0,U) K NHITM
|
---|
| 2969 | "RTN","NHINVPSI",33,0)
|
---|
| 2970 | . Q:ID["N" Q:ID["O" ;inpatient only
|
---|
| 2971 | "RTN","NHINVPSI",34,0)
|
---|
| 2972 | . S IV=$S(ID["V":1,$G(^TMP("PS",$J,NHI,"B",0)):1,1:0)
|
---|
| 2973 | "RTN","NHINVPSI",35,0)
|
---|
| 2974 | . D @($S(IV:"IV",1:"IN")_"(ID,.NHITM)")
|
---|
| 2975 | "RTN","NHINVPSI",36,0)
|
---|
| 2976 | . I $D(NHITM)>9 D XML^NHINVPS(.NHITM)
|
---|
| 2977 | "RTN","NHINVPSI",37,0)
|
---|
| 2978 | K ^TMP("PS",$J)
|
---|
| 2979 | "RTN","NHINVPSI",38,0)
|
---|
| 2980 | Q
|
---|
| 2981 | "RTN","NHINVPSI",39,0)
|
---|
| 2982 | ;
|
---|
| 2983 | "RTN","NHINVPSI",40,0)
|
---|
| 2984 | IN(ID,MED) ; -- return a medication in MED("attribute")=value
|
---|
| 2985 | "RTN","NHINVPSI",41,0)
|
---|
| 2986 | ; [expects PS0,OCL^PSOORRL data]
|
---|
| 2987 | "RTN","NHINVPSI",42,0)
|
---|
| 2988 | N X,PS,ORDER,DOSE,UNTS,RTE,SCH,OI,PSOI,LOC K MED
|
---|
| 2989 | "RTN","NHINVPSI",43,0)
|
---|
| 2990 | M PS=^TMP("PS",$J,NHI)
|
---|
| 2991 | "RTN","NHINVPSI",44,0)
|
---|
| 2992 | S MED("id")=ID,MED("vaType")="I"
|
---|
| 2993 | "RTN","NHINVPSI",45,0)
|
---|
| 2994 | S X=$P(PS0,U,15) S:X MED("start")=X
|
---|
| 2995 | "RTN","NHINVPSI",46,0)
|
---|
| 2996 | S X=$P(PS0,U,4) S:X MED("stop")=X
|
---|
| 2997 | "RTN","NHINVPSI",47,0)
|
---|
| 2998 | S MED("name")=$P(PS0,U,2),X=$P(PS0,U,9),MED("vaStatus")=X,X=$E(X,1,3)
|
---|
| 2999 | "RTN","NHINVPSI",48,0)
|
---|
| 3000 | S MED("status")=$S(X="DIS"!(X="PEN"):"not active",X="EXP"!(X="REN"):"historical",X="REI":"active",1:$$LOW^XLFSTR($P(PS0,U,9)))
|
---|
| 3001 | "RTN","NHINVPSI",49,0)
|
---|
| 3002 | S DOSE=$P(PS0,U,6) S:DOSE="" DOSE=$G(PS("SIG",1,0))
|
---|
| 3003 | "RTN","NHINVPSI",50,0)
|
---|
| 3004 | S RTE=$G(PS("MDR",1,0)),SCH=$P($G(PS("SCH",1,0)),U)
|
---|
| 3005 | "RTN","NHINVPSI",51,0)
|
---|
| 3006 | S MED("dose",1)=DOSE_"^^^^"_RTE_U_SCH
|
---|
| 3007 | "RTN","NHINVPSI",52,0)
|
---|
| 3008 | S MED("sig")="Give: "_DOSE_" "_RTE_" "_SCH I $G(PS("SIO",0)) D
|
---|
| 3009 | "RTN","NHINVPSI",53,0)
|
---|
| 3010 | . N SIO M SIO=PS("SIO")
|
---|
| 3011 | "RTN","NHINVPSI",54,0)
|
---|
| 3012 | . S MED("sig")=MED("sig")_$C(13,10)_$$STRING^NHINV(.SIO)
|
---|
| 3013 | "RTN","NHINVPSI",55,0)
|
---|
| 3014 | I $D(PS("P",0)) S MED("orderingProvider")=PS("P",0)
|
---|
| 3015 | "RTN","NHINVPSI",56,0)
|
---|
| 3016 | I $G(PS("CLINIC",0)) S MED("IMO")=1
|
---|
| 3017 | "RTN","NHINVPSI",57,0)
|
---|
| 3018 | S MED("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 3019 | "RTN","NHINVPSI",58,0)
|
---|
| 3020 | S ORDER=+$P(PS0,U,8) D:ORDER ORD
|
---|
| 3021 | "RTN","NHINVPSI",59,0)
|
---|
| 3022 | Q
|
---|
| 3023 | "RTN","NHINVPSI",60,0)
|
---|
| 3024 | ;
|
---|
| 3025 | "RTN","NHINVPSI",61,0)
|
---|
| 3026 | IN1(ID,MED) ; -- return a medication in MED("attribute")=value
|
---|
| 3027 | "RTN","NHINVPSI",62,0)
|
---|
| 3028 | ; [expects OEL^PSOORRL data]
|
---|
| 3029 | "RTN","NHINVPSI",63,0)
|
---|
| 3030 | N X,PS,PS0,ORDER,DOSE,UNTS,RTE,SCH,OI,PSOI,DRUG,LOC K MED
|
---|
| 3031 | "RTN","NHINVPSI",64,0)
|
---|
| 3032 | M PS=^TMP("PS",$J) S PS0=PS(0)
|
---|
| 3033 | "RTN","NHINVPSI",65,0)
|
---|
| 3034 | S MED("id")=ID,MED("vaType")="I"
|
---|
| 3035 | "RTN","NHINVPSI",66,0)
|
---|
| 3036 | S X=$P(PS0,U,5) S:X MED("start")=X
|
---|
| 3037 | "RTN","NHINVPSI",67,0)
|
---|
| 3038 | S X=$P(PS0,U,3) S:X MED("stop")=X
|
---|
| 3039 | "RTN","NHINVPSI",68,0)
|
---|
| 3040 | S MED("name")=$P(PS0,U),X=$P(PS0,U,6),MED("vaStatus")=X,X=$E(X,1,3)
|
---|
| 3041 | "RTN","NHINVPSI",69,0)
|
---|
| 3042 | S MED("status")=$S(X="DIS"!(X="PEN"):"not active",X="EXP"!(X="REN"):"historical",X="REI":"active",1:$$LOW^XLFSTR($P(PS0,U,9)))
|
---|
| 3043 | "RTN","NHINVPSI",70,0)
|
---|
| 3044 | S DOSE=$P(PS0,U,9) S:DOSE="" DOSE=$G(PS("SIG",1,0))
|
---|
| 3045 | "RTN","NHINVPSI",71,0)
|
---|
| 3046 | S RTE=$G(PS("MDR",1,0)),SCH=$P($G(PS("SCH",1,0)),U)
|
---|
| 3047 | "RTN","NHINVPSI",72,0)
|
---|
| 3048 | S MED("dose",1)=DOSE_"^^^^"_RTE_U_SCH
|
---|
| 3049 | "RTN","NHINVPSI",73,0)
|
---|
| 3050 | S MED("sig")="Give: "_DOSE_" "_RTE_" "_SCH I $G(PS("SIO",0)) D
|
---|
| 3051 | "RTN","NHINVPSI",74,0)
|
---|
| 3052 | . N SIO M SIO=PS("SIO")
|
---|
| 3053 | "RTN","NHINVPSI",75,0)
|
---|
| 3054 | . S MED("sig")=MED("sig")_$C(13,10)_$$STRING^NHINV(.SIO)
|
---|
| 3055 | "RTN","NHINVPSI",76,0)
|
---|
| 3056 | I $D(PS("P",0)) S MED("orderingProvider")=PS("P",0)
|
---|
| 3057 | "RTN","NHINVPSI",77,0)
|
---|
| 3058 | S MED("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 3059 | "RTN","NHINVPSI",78,0)
|
---|
| 3060 | S ORDER=+$P(PS0,U,11) D:ORDER ORD
|
---|
| 3061 | "RTN","NHINVPSI",79,0)
|
---|
| 3062 | I $D(^SC("AE",1,+$G(LOC))) S MED("IMO")=1
|
---|
| 3063 | "RTN","NHINVPSI",80,0)
|
---|
| 3064 | Q
|
---|
| 3065 | "RTN","NHINVPSI",81,0)
|
---|
| 3066 | ;
|
---|
| 3067 | "RTN","NHINVPSI",82,0)
|
---|
| 3068 | ORD ; get rest of inpatient data from ORDER
|
---|
| 3069 | "RTN","NHINVPSI",83,0)
|
---|
| 3070 | S OI=$$OI^ORX8(ORDER),PSOI=+$P(OI,U,3)
|
---|
| 3071 | "RTN","NHINVPSI",84,0)
|
---|
| 3072 | S MED("name")=$P(OI,U,2) I PSOI D
|
---|
| 3073 | "RTN","NHINVPSI",85,0)
|
---|
| 3074 | . D ZERO^PSS50P7(PSOI,,,"OI")
|
---|
| 3075 | "RTN","NHINVPSI",86,0)
|
---|
| 3076 | . S MED("form")=$P($G(^TMP($J,"OI",PSOI,.02)),U,2)
|
---|
| 3077 | "RTN","NHINVPSI",87,0)
|
---|
| 3078 | S X=$$VALUE^ORX8(ORDER,"DOSE"),DOSE=DOSE_"^^^"
|
---|
| 3079 | "RTN","NHINVPSI",88,0)
|
---|
| 3080 | S DRUG="" I X'="",X["&" D
|
---|
| 3081 | "RTN","NHINVPSI",89,0)
|
---|
| 3082 | . S DRUG=+$P(X,"&",6)
|
---|
| 3083 | "RTN","NHINVPSI",90,0)
|
---|
| 3084 | . S DOSE=$TR($P(X,"&",1,4),"&","^")
|
---|
| 3085 | "RTN","NHINVPSI",91,0)
|
---|
| 3086 | . S $P(MED("dose",1),U,1,4)=DOSE
|
---|
| 3087 | "RTN","NHINVPSI",92,0)
|
---|
| 3088 | S:'DRUG DRUG=+$$VALUE^ORX8(ORDER,"DRUG")
|
---|
| 3089 | "RTN","NHINVPSI",93,0)
|
---|
| 3090 | D:DRUG NDF^NHINVPS(DRUG)
|
---|
| 3091 | "RTN","NHINVPSI",94,0)
|
---|
| 3092 | K ^TMP($J,"OI")
|
---|
| 3093 | "RTN","NHINVPSI",95,0)
|
---|
| 3094 | ORDLOC ; enter here for just order# and location
|
---|
| 3095 | "RTN","NHINVPSI",96,0)
|
---|
| 3096 | S MED("orderID")=ORDER
|
---|
| 3097 | "RTN","NHINVPSI",97,0)
|
---|
| 3098 | S LOC=+$$GET1^DIQ(100,ORDER_",",6,"I") I LOC D
|
---|
| 3099 | "RTN","NHINVPSI",98,0)
|
---|
| 3100 | . S MED("location")=LOC_U_$P($G(^SC(LOC,0)),U)
|
---|
| 3101 | "RTN","NHINVPSI",99,0)
|
---|
| 3102 | . S MED("facility")=$$FAC^NHINV(LOC)
|
---|
| 3103 | "RTN","NHINVPSI",100,0)
|
---|
| 3104 | Q
|
---|
| 3105 | "RTN","NHINVPSI",101,0)
|
---|
| 3106 | ;
|
---|
| 3107 | "RTN","NHINVPSI",102,0)
|
---|
| 3108 | IV(ID,MED) ; -- return an infusion in MED("attribute")=value
|
---|
| 3109 | "RTN","NHINVPSI",103,0)
|
---|
| 3110 | ; [expects PS0,OCL^PSOORRL data]
|
---|
| 3111 | "RTN","NHINVPSI",104,0)
|
---|
| 3112 | N PS,X,ORDER,LOC K MED
|
---|
| 3113 | "RTN","NHINVPSI",105,0)
|
---|
| 3114 | M PS=^TMP("PS",$J,NHI)
|
---|
| 3115 | "RTN","NHINVPSI",106,0)
|
---|
| 3116 | S MED("id")=ID,MED("vaType")="V",MED("name")=$P(PS0,U,2)
|
---|
| 3117 | "RTN","NHINVPSI",107,0)
|
---|
| 3118 | S X=$P(PS0,U,15) S:X MED("start")=X
|
---|
| 3119 | "RTN","NHINVPSI",108,0)
|
---|
| 3120 | S X=$P(PS0,U,4) S:X MED("stop")=X
|
---|
| 3121 | "RTN","NHINVPSI",109,0)
|
---|
| 3122 | S MED("vaStatus")=$P(PS0,U,9),X=$E($P(PS0,U,9),1,3)
|
---|
| 3123 | "RTN","NHINVPSI",110,0)
|
---|
| 3124 | S MED("status")=$S(X="DIS"!(X="PEN"):"not active",X="EXP"!(X="PUR"):"historical",X="HOL":"hold",1:"active")
|
---|
| 3125 | "RTN","NHINVPSI",111,0)
|
---|
| 3126 | S MED("dose",1)="^^^^"_$G(PS("MDR",1,0))_U_$P($G(PS("SCH",1,0)),U)
|
---|
| 3127 | "RTN","NHINVPSI",112,0)
|
---|
| 3128 | S MED("rate")=$P(PS0,U,3) D IVP
|
---|
| 3129 | "RTN","NHINVPSI",113,0)
|
---|
| 3130 | S X=$G(PS("IVLIM",0)) S:$L(X) MED("ivLimit")=$$IVLIM(X)
|
---|
| 3131 | "RTN","NHINVPSI",114,0)
|
---|
| 3132 | I $G(PS("CLINIC",0)) S MED("IMO")=1
|
---|
| 3133 | "RTN","NHINVPSI",115,0)
|
---|
| 3134 | I $G(PS("P",0)) S MED("orderingProvider")=PS("P",0)
|
---|
| 3135 | "RTN","NHINVPSI",116,0)
|
---|
| 3136 | S MED("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 3137 | "RTN","NHINVPSI",117,0)
|
---|
| 3138 | S ORDER=+$P(PS0,U,8) D:ORDER ORDLOC
|
---|
| 3139 | "RTN","NHINVPSI",118,0)
|
---|
| 3140 | Q
|
---|
| 3141 | "RTN","NHINVPSI",119,0)
|
---|
| 3142 | ;
|
---|
| 3143 | "RTN","NHINVPSI",120,0)
|
---|
| 3144 | IV1(ID,MED) ; -- return an infusion in MED("attribute")=value
|
---|
| 3145 | "RTN","NHINVPSI",121,0)
|
---|
| 3146 | ; [expects OEL^PSOORRL data]
|
---|
| 3147 | "RTN","NHINVPSI",122,0)
|
---|
| 3148 | N PS,PS0,X,ORDER,LOC K MED
|
---|
| 3149 | "RTN","NHINVPSI",123,0)
|
---|
| 3150 | M PS=^TMP("PS",$J) S PS0=PS(0)
|
---|
| 3151 | "RTN","NHINVPSI",124,0)
|
---|
| 3152 | S MED("id")=ID,MED("vaType")="V",MED("name")=$P(PS0,U)
|
---|
| 3153 | "RTN","NHINVPSI",125,0)
|
---|
| 3154 | S X=$P(PS0,U,5) S:X MED("start")=X
|
---|
| 3155 | "RTN","NHINVPSI",126,0)
|
---|
| 3156 | S X=$P(PS0,U,3) S:X MED("stop")=X
|
---|
| 3157 | "RTN","NHINVPSI",127,0)
|
---|
| 3158 | S MED("vaStatus")=$P(PS0,U,6),X=$E($P(PS0,U,6),1,3)
|
---|
| 3159 | "RTN","NHINVPSI",128,0)
|
---|
| 3160 | S MED("status")=$S(X="DIS"!(X="PEN"):"not active",X="EXP"!(X="PUR"):"historical",X="HOL":"hold",1:"active")
|
---|
| 3161 | "RTN","NHINVPSI",129,0)
|
---|
| 3162 | S MED("dose",1)="^^^^"_$G(PS("MDR",1,0))_U_$P($G(PS("SCH",1,0)),U)
|
---|
| 3163 | "RTN","NHINVPSI",130,0)
|
---|
| 3164 | S MED("rate")=$P(PS0,U,2) D IVP
|
---|
| 3165 | "RTN","NHINVPSI",131,0)
|
---|
| 3166 | S X=$G(PS("IVLIM",0)) S:$L(X) MED("ivLimit")=$$IVLIM(X)
|
---|
| 3167 | "RTN","NHINVPSI",132,0)
|
---|
| 3168 | I $G(PS("P",0)) S MED("orderingProvider")=PS("P",0)
|
---|
| 3169 | "RTN","NHINVPSI",133,0)
|
---|
| 3170 | S MED("facility")=$$FAC^NHINV ;local stn#^name
|
---|
| 3171 | "RTN","NHINVPSI",134,0)
|
---|
| 3172 | S ORDER=+$P(PS0,U,11) D:ORDER ORDLOC
|
---|
| 3173 | "RTN","NHINVPSI",135,0)
|
---|
| 3174 | I $D(^SC("AE",1,+$G(LOC))) S MED("IMO")=1
|
---|
| 3175 | "RTN","NHINVPSI",136,0)
|
---|
| 3176 | Q
|
---|
| 3177 | "RTN","NHINVPSI",137,0)
|
---|
| 3178 | ;
|
---|
| 3179 | "RTN","NHINVPSI",138,0)
|
---|
| 3180 | IVP ; -- add IV products for ID,DFN
|
---|
| 3181 | "RTN","NHINVPSI",139,0)
|
---|
| 3182 | N I,N,FILE,IENS,NHIN,LIST,IEN,DRUG,STR
|
---|
| 3183 | "RTN","NHINVPSI",140,0)
|
---|
| 3184 | S FILE=$S(ID["P":53.157,1:55.02),N=0
|
---|
| 3185 | "RTN","NHINVPSI",141,0)
|
---|
| 3186 | S IENS=","_+ID_","_$S(ID["P":"",1:DFN_",")
|
---|
| 3187 | "RTN","NHINVPSI",142,0)
|
---|
| 3188 | F I=1:1 K NHIN D GETS^DIQ(FILE,I_IENS,"*","IE","NHIN") Q:'$D(NHIN) D
|
---|
| 3189 | "RTN","NHINVPSI",143,0)
|
---|
| 3190 | . K LIST M LIST=NHIN(FILE,I_IENS)
|
---|
| 3191 | "RTN","NHINVPSI",144,0)
|
---|
| 3192 | . S IEN=LIST(.01,"I"),DRUG=$$GET1^DIQ(52.6,IEN_",",1,"I")
|
---|
| 3193 | "RTN","NHINVPSI",145,0)
|
---|
| 3194 | . D:DRUG NDF^NHINVPS(DRUG,.N) S:'DRUG N=N+1
|
---|
| 3195 | "RTN","NHINVPSI",146,0)
|
---|
| 3196 | . S STR=$S(FILE=53.157:LIST(1,"E"),1:LIST(.02,"E"))
|
---|
| 3197 | "RTN","NHINVPSI",147,0)
|
---|
| 3198 | . S MED("product",N)=IEN_U_LIST(.01,"E")_"^^A^"_STR
|
---|
| 3199 | "RTN","NHINVPSI",148,0)
|
---|
| 3200 | S FILE=$S(ID["P":53.158,1:55.11)
|
---|
| 3201 | "RTN","NHINVPSI",149,0)
|
---|
| 3202 | F I=1:1 K NHIN D GETS^DIQ(FILE,I_IENS,"*","IE","NHIN") Q:'$D(NHIN) D
|
---|
| 3203 | "RTN","NHINVPSI",150,0)
|
---|
| 3204 | . K LIST M LIST=NHIN(FILE,I_IENS)
|
---|
| 3205 | "RTN","NHINVPSI",151,0)
|
---|
| 3206 | . S IEN=LIST(.01,"I"),DRUG=$$GET1^DIQ(52.7,IEN_",",1,"I")
|
---|
| 3207 | "RTN","NHINVPSI",152,0)
|
---|
| 3208 | . D:DRUG NDF^NHINVPS(DRUG,.N) S:'DRUG N=N+1
|
---|
| 3209 | "RTN","NHINVPSI",153,0)
|
---|
| 3210 | . S MED("product",N)=IEN_U_LIST(.01,"E")_"^^B^"_LIST(1,"E")
|
---|
| 3211 | "RTN","NHINVPSI",154,0)
|
---|
| 3212 | Q
|
---|
| 3213 | "RTN","NHINVPSI",155,0)
|
---|
| 3214 | ;
|
---|
| 3215 | "RTN","NHINVPSI",156,0)
|
---|
| 3216 | IVLIM(X) ; -- Return expanded version of IV Limit X
|
---|
| 3217 | "RTN","NHINVPSI",157,0)
|
---|
| 3218 | I '$L($G(X)) Q ""
|
---|
| 3219 | "RTN","NHINVPSI",158,0)
|
---|
| 3220 | N Y,VAL,UNT,I
|
---|
| 3221 | "RTN","NHINVPSI",159,0)
|
---|
| 3222 | S Y="",X=$$UP^XLFSTR(X)
|
---|
| 3223 | "RTN","NHINVPSI",160,0)
|
---|
| 3224 | I X?1"DOSES".E S X="A"_$P(X,"DOSES",2)
|
---|
| 3225 | "RTN","NHINVPSI",161,0)
|
---|
| 3226 | S UNT=$E(X),VAL=0 F I=2:1:$L(X) I $E(X,I) S VAL=$E(X,I,$L(X)) Q
|
---|
| 3227 | "RTN","NHINVPSI",162,0)
|
---|
| 3228 | I UNT="A" S Y=+VAL_$S(+VAL>1:" doses",1:" dose")
|
---|
| 3229 | "RTN","NHINVPSI",163,0)
|
---|
| 3230 | I UNT="D" S Y=+VAL_$S(+VAL>1:" days",1:" day")
|
---|
| 3231 | "RTN","NHINVPSI",164,0)
|
---|
| 3232 | I UNT="H" S Y=+VAL_$S(+VAL>1:" hours",1:" hour")
|
---|
| 3233 | "RTN","NHINVPSI",165,0)
|
---|
| 3234 | I UNT="C" S Y=+VAL_" CC"
|
---|
| 3235 | "RTN","NHINVPSI",166,0)
|
---|
| 3236 | I UNT="M" S Y=+VAL_" ml"
|
---|
| 3237 | "RTN","NHINVPSI",167,0)
|
---|
| 3238 | I UNT="L" S Y=+VAL_" L"
|
---|
| 3239 | "RTN","NHINVPSI",168,0)
|
---|
| 3240 | Q Y
|
---|
| 3241 | "RTN","NHINVPSO")
|
---|
| 3242 | 0^28^B65991145^n/a
|
---|
| 3243 | "RTN","NHINVPSO",1,0)
|
---|
| 3244 | NHINVPSO ;SLC/MKB -- Outpatient Pharmacy extract
|
---|
| 3245 | "RTN","NHINVPSO",2,0)
|
---|
| 3246 | ;;1.0;NHIN;**1**;Dec 01, 2009;Build 11
|
---|
| 3247 | "RTN","NHINVPSO",3,0)
|
---|
| 3248 | ;
|
---|
| 3249 | "RTN","NHINVPSO",4,0)
|
---|
| 3250 | ; External References DBIA#
|
---|
| 3251 | "RTN","NHINVPSO",5,0)
|
---|
| 3252 | ; ------------------- -----
|
---|
| 3253 | "RTN","NHINVPSO",6,0)
|
---|
| 3254 | ; ^SC 10040
|
---|
| 3255 | "RTN","NHINVPSO",7,0)
|
---|
| 3256 | ; ^VA(200) 10060
|
---|
| 3257 | "RTN","NHINVPSO",8,0)
|
---|
| 3258 | ; DIQ 2056
|
---|
| 3259 | "RTN","NHINVPSO",9,0)
|
---|
| 3260 | ; ORX8 2467
|
---|
| 3261 | "RTN","NHINVPSO",10,0)
|
---|
| 3262 | ; PSO5241 4821
|
---|
| 3263 | "RTN","NHINVPSO",11,0)
|
---|
| 3264 | ; PSOORDER,^TMP("PSOR",$J) 1878
|
---|
| 3265 | "RTN","NHINVPSO",12,0)
|
---|
| 3266 | ; PSOORRL,^TMP("PS",$J) 2400
|
---|
| 3267 | "RTN","NHINVPSO",13,0)
|
---|
| 3268 | ; PSS50P7 4662
|
---|
| 3269 | "RTN","NHINVPSO",14,0)
|
---|
| 3270 | ; PSS51P2 4548
|
---|
| 3271 | "RTN","NHINVPSO",15,0)
|
---|
| 3272 | ; XLFDT 10103
|
---|
| 3273 | "RTN","NHINVPSO",16,0)
|
---|
| 3274 | ;
|
---|
| 3275 | "RTN","NHINVPSO",17,0)
|
---|
| 3276 | ; ------------ Get medications from VistA ------------
|
---|
| 3277 | "RTN","NHINVPSO",18,0)
|
---|
| 3278 | ;
|
---|
| 3279 | "RTN","NHINVPSO",19,0)
|
---|
| 3280 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's meds
|
---|
| 3281 | "RTN","NHINVPSO",20,0)
|
---|
| 3282 | N PS0,NHI,NHITM K ^TMP("PS",$J)
|
---|
| 3283 | "RTN","NHINVPSO",21,0)
|
---|
| 3284 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 3285 | "RTN","NHINVPSO",22,0)
|
---|
| 3286 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 3287 | "RTN","NHINVPSO",23,0)
|
---|
| 3288 | ;
|
---|
| 3289 | "RTN","NHINVPSO",24,0)
|
---|
| 3290 | ; get one med
|
---|
| 3291 | "RTN","NHINVPSO",25,0)
|
---|
| 3292 | I $G(ID) D D:$D(NHITM)>9 XML^NHINVPS(.NHITM) Q
|
---|
| 3293 | "RTN","NHINVPSO",26,0)
|
---|
| 3294 | . Q:ID["I"
|
---|
| 3295 | "RTN","NHINVPSO",27,0)
|
---|
| 3296 | . I ID["N" D NVA(ID,.NHITM) Q
|
---|
| 3297 | "RTN","NHINVPSO",28,0)
|
---|
| 3298 | . I ID'["P",ID'["S" D RX(ID,.NHITM) Q
|
---|
| 3299 | "RTN","NHINVPSO",29,0)
|
---|
| 3300 | . D OEL^PSOORRL(DFN,ID),PEN1(ID,.NHITM)
|
---|
| 3301 | "RTN","NHINVPSO",30,0)
|
---|
| 3302 | . K ^TMP("PS",$J)
|
---|
| 3303 | "RTN","NHINVPSO",31,0)
|
---|
| 3304 | ;
|
---|
| 3305 | "RTN","NHINVPSO",32,0)
|
---|
| 3306 | ; get all meds
|
---|
| 3307 | "RTN","NHINVPSO",33,0)
|
---|
| 3308 | D OCL^PSOORRL(DFN,BEG,END)
|
---|
| 3309 | "RTN","NHINVPSO",34,0)
|
---|
| 3310 | S NHI=0 F S NHI=$O(^TMP("PS",$J,NHI)) Q:NHI<1!(NHI>MAX) S PS0=$G(^(NHI,0)) D I $D(NHITM)>9 D XML^NHINVPS(.NHITM)
|
---|
| 3311 | "RTN","NHINVPSO",35,0)
|
---|
| 3312 | . S ID=$P(PS0,U) K NHITM Q:ID["I"
|
---|
| 3313 | "RTN","NHINVPSO",36,0)
|
---|
| 3314 | . I ID["N" D NVA(ID,.NHITM) Q
|
---|
| 3315 | "RTN","NHINVPSO",37,0)
|
---|
| 3316 | . I ID["O" D RX(ID,.NHITM) Q
|
---|
| 3317 | "RTN","NHINVPSO",38,0)
|
---|
| 3318 | K ^TMP("PS",$J)
|
---|
| 3319 | "RTN","NHINVPSO",39,0)
|
---|
| 3320 | Q
|
---|
| 3321 | "RTN","NHINVPSO",40,0)
|
---|
| 3322 | ;
|
---|
| 3323 | "RTN","NHINVPSO",41,0)
|
---|
| 3324 | RX(ID,MED) ; -- return a prescription in MED("attribute")=value
|
---|
| 3325 | "RTN","NHINVPSO",42,0)
|
---|
| 3326 | I ID["P"!(ID["S") G PEND ;pending order
|
---|
| 3327 | "RTN","NHINVPSO",43,0)
|
---|
| 3328 | N RX0,RX1,DRUG,PSOI,X,I,START,STOP,ORIFN,FILL,RFD,PRV K MED
|
---|
| 3329 | "RTN","NHINVPSO",44,0)
|
---|
| 3330 | K ^TMP("PSOR",$J) D EN^PSOORDER(DFN,+ID)
|
---|
| 3331 | "RTN","NHINVPSO",45,0)
|
---|
| 3332 | S RX0=$G(^TMP("PSOR",$J,+ID,0)),RX1=$G(^(1)),DRUG=$G(^("DRUG",0))
|
---|
| 3333 | "RTN","NHINVPSO",46,0)
|
---|
| 3334 | S MED("id")=ID,MED("vaType")="O",MED("type")="Prescription"
|
---|
| 3335 | "RTN","NHINVPSO",47,0)
|
---|
| 3336 | S ORIFN=+$P(RX1,U,8) S:ORIFN MED("orderID")=ORIFN
|
---|
| 3337 | "RTN","NHINVPSO",48,0)
|
---|
| 3338 | S PSOI=$G(^TMP("PSOR",$J,+ID,"DRUGOI",0)) I PSOI D
|
---|
| 3339 | "RTN","NHINVPSO",49,0)
|
---|
| 3340 | . S MED("name")=$P(PSOI,";",2)
|
---|
| 3341 | "RTN","NHINVPSO",50,0)
|
---|
| 3342 | . D ZERO^PSS50P7(+PSOI,,,"OI")
|
---|
| 3343 | "RTN","NHINVPSO",51,0)
|
---|
| 3344 | . S MED("form")=$P($G(^TMP($J,"OI",+PSOI,.02)),U,2)
|
---|
| 3345 | "RTN","NHINVPSO",52,0)
|
---|
| 3346 | D:DRUG NDF^NHINVPS(+DRUG) ;add NDF data
|
---|
| 3347 | "RTN","NHINVPSO",53,0)
|
---|
| 3348 | S START=$P(RX0,U) S:START MED("start")=START
|
---|
| 3349 | "RTN","NHINVPSO",54,0)
|
---|
| 3350 | S STOP=$P(RX0,U,12) S:STOP MED("stop")=STOP ;_".2359"?
|
---|
| 3351 | "RTN","NHINVPSO",55,0)
|
---|
| 3352 | S X=$$GET1^DIQ(52,+ID_",",26,"I") S:X MED("expires")=X
|
---|
| 3353 | "RTN","NHINVPSO",56,0)
|
---|
| 3354 | S X=$P(RX0,U,17) S:X MED("ordered")=X
|
---|
| 3355 | "RTN","NHINVPSO",57,0)
|
---|
| 3356 | S MED("vaStatus")=$P($P(RX0,U,4),";",2),X=$P($P(RX0,U,4),";")
|
---|
| 3357 | "RTN","NHINVPSO",58,0)
|
---|
| 3358 | S MED("status")=$S(X="H":"hold",X="DC":"not active",X="D"!(X="E"):"historical",1:"active")
|
---|
| 3359 | "RTN","NHINVPSO",59,0)
|
---|
| 3360 | S MED("quantity")=$P(RX0,U,6),MED("daysSupply")=$P(RX0,U,7)
|
---|
| 3361 | "RTN","NHINVPSO",60,0)
|
---|
| 3362 | S MED("fillsAllowed")=$P(RX0,U,8),MED("fillsRemaining")=$P(RX0,U,9)
|
---|
| 3363 | "RTN","NHINVPSO",61,0)
|
---|
| 3364 | S MED("routing")=$P($P(RX1,U,6),";"),MED("prescription")=$P(RX0,U,5)
|
---|
| 3365 | "RTN","NHINVPSO",62,0)
|
---|
| 3366 | S MED("lastFilled")=$P(RX0,U,3) K FILL
|
---|
| 3367 | "RTN","NHINVPSO",63,0)
|
---|
| 3368 | S I=0 F S I=$O(^TMP("PSOR",$J,+ID,"REF",I)) Q:I<1 S X=$G(^(I,0)),FILL(+X)=X
|
---|
| 3369 | "RTN","NHINVPSO",64,0)
|
---|
| 3370 | S I=0 F S I=$O(^TMP("PSOR",$J,+ID,"RPAR",I)) Q:I<1 S X=$G(^(I,0)),$P(X,U,14)=1,FILL(+X)=X
|
---|
| 3371 | "RTN","NHINVPSO",65,0)
|
---|
| 3372 | S (I,RFD,PRV)=0 F S RFD=$O(FILL(RFD)) Q:RFD<1 S X=$G(FILL(RFD)) D ;sort 1st
|
---|
| 3373 | "RTN","NHINVPSO",66,0)
|
---|
| 3374 | . N MW,REL S I=I+1
|
---|
| 3375 | "RTN","NHINVPSO",67,0)
|
---|
| 3376 | . S MW=$P($P(X,U,10),";"),REL=$P($P(X,U,8),".")
|
---|
| 3377 | "RTN","NHINVPSO",68,0)
|
---|
| 3378 | . S MED("fill",I)=$P(RFD,".")_U_MW_U_REL_U_$P(X,U,4,5)_$S($P(X,U,14):"^1",1:"")
|
---|
| 3379 | "RTN","NHINVPSO",69,0)
|
---|
| 3380 | . S:$P(X,U,2) PRV=$P(X,U,2) ;save last provider
|
---|
| 3381 | "RTN","NHINVPSO",70,0)
|
---|
| 3382 | . ; fill comments?
|
---|
| 3383 | "RTN","NHINVPSO",71,0)
|
---|
| 3384 | S X=$S($P(RX0,U,11):$P(RX0,U,11),$P(RX0,U,10):$P(RX0,U,10),1:0)
|
---|
| 3385 | "RTN","NHINVPSO",72,0)
|
---|
| 3386 | S:X MED("fillCost")=X
|
---|
| 3387 | "RTN","NHINVPSO",73,0)
|
---|
| 3388 | S X=$G(^TMP("PSOR",$J,+ID,"SIG",1,0)),I=1
|
---|
| 3389 | "RTN","NHINVPSO",74,0)
|
---|
| 3390 | F S I=$O(^TMP("PSOR",$J,+ID,"SIG",I)) Q:I<1 S X=X_$G(^(I,0))
|
---|
| 3391 | "RTN","NHINVPSO",75,0)
|
---|
| 3392 | S MED("sig")=X
|
---|
| 3393 | "RTN","NHINVPSO",76,0)
|
---|
| 3394 | S X=$G(^TMP("PSOR",$J,+ID,"PI",1,0)),I=1
|
---|
| 3395 | "RTN","NHINVPSO",77,0)
|
---|
| 3396 | F S I=$O(^TMP("PSOR",$J,+ID,"PI",I)) Q:I<1 S X=X_$G(^(I,0))
|
---|
| 3397 | "RTN","NHINVPSO",78,0)
|
---|
| 3398 | S:$L(X) MED("ptInstructions")=X
|
---|
| 3399 | "RTN","NHINVPSO",79,0)
|
---|
| 3400 | S I=0 F S I=$O(^TMP("PSOR",$J,+ID,"MI",I)) Q:I<1 S X=$G(^(I,0)) D
|
---|
| 3401 | "RTN","NHINVPSO",80,0)
|
---|
| 3402 | . N UD,NOUN,DOSE,UNIT,RTE,SCH,DUR,CONJ,END
|
---|
| 3403 | "RTN","NHINVPSO",81,0)
|
---|
| 3404 | . S UD=$P(X,U,2),NOUN=$P(X,U,4)
|
---|
| 3405 | "RTN","NHINVPSO",82,0)
|
---|
| 3406 | . S DOSE=$P(X,U),UNIT=$P($P(X,U,3),";",2)
|
---|
| 3407 | "RTN","NHINVPSO",83,0)
|
---|
| 3408 | . S RTE=+$P(X,U,7) D ALL^PSS51P2(RTE,,,,"MR")
|
---|
| 3409 | "RTN","NHINVPSO",84,0)
|
---|
| 3410 | . S RTE=$G(^TMP($J,"MR",RTE,1))
|
---|
| 3411 | "RTN","NHINVPSO",85,0)
|
---|
| 3412 | . S DUR=$P(X,U,5),CONJ=$P(X,U,6),SCH=$P(X,U,8)
|
---|
| 3413 | "RTN","NHINVPSO",86,0)
|
---|
| 3414 | . S END=$S(DUR:$$STOP(START,DUR),1:STOP)
|
---|
| 3415 | "RTN","NHINVPSO",87,0)
|
---|
| 3416 | . S MED("dose",I)=DOSE_U_UNIT_U_UD_U_NOUN_U_RTE_U_SCH_U_DUR_U_CONJ_U_START_U_STOP
|
---|
| 3417 | "RTN","NHINVPSO",88,0)
|
---|
| 3418 | . I $E(CONJ)="T",DUR S START=END
|
---|
| 3419 | "RTN","NHINVPSO",89,0)
|
---|
| 3420 | S:RX1 X=$TR($P(RX1,U),";","^"),MED("orderingProvider")=X,MED("currentProvider")=X
|
---|
| 3421 | "RTN","NHINVPSO",90,0)
|
---|
| 3422 | S:$G(PRV) MED("currentProvider")=$TR(PRV,";","^")
|
---|
| 3423 | "RTN","NHINVPSO",91,0)
|
---|
| 3424 | S:$P(RX1,U,9) MED("pharmacist")=$TR($P(RX1,U,9),";","^")
|
---|
| 3425 | "RTN","NHINVPSO",92,0)
|
---|
| 3426 | S:$P(RX1,U,4) MED("location")=$TR($P(RX1,U,4),";","^")
|
---|
| 3427 | "RTN","NHINVPSO",93,0)
|
---|
| 3428 | S MED("facility")=$$FAC^NHINV(+$P(RX1,U,4))
|
---|
| 3429 | "RTN","NHINVPSO",94,0)
|
---|
| 3430 | K ^TMP("PSOR",$J),^TMP($J,"MR"),^TMP($J,"NDF"),^TMP($J,"OI")
|
---|
| 3431 | "RTN","NHINVPSO",95,0)
|
---|
| 3432 | Q
|
---|
| 3433 | "RTN","NHINVPSO",96,0)
|
---|
| 3434 | ;
|
---|
| 3435 | "RTN","NHINVPSO",97,0)
|
---|
| 3436 | PEND ; -- pending prescription
|
---|
| 3437 | "RTN","NHINVPSO",98,0)
|
---|
| 3438 | ; [expects PS0,OCL^PSOORRL data]
|
---|
| 3439 | "RTN","NHINVPSO",99,0)
|
---|
| 3440 | N I,X,NHIN K MED
|
---|
| 3441 | "RTN","NHINVPSO",100,0)
|
---|
| 3442 | S MED("id")=ID,MED("vaType")="O",MED("type")="Prescription"
|
---|
| 3443 | "RTN","NHINVPSO",101,0)
|
---|
| 3444 | S MED("vaStatus")=$P(PS0,U,9),MED("status")="not active"
|
---|
| 3445 | "RTN","NHINVPSO",102,0)
|
---|
| 3446 | S X=+$P(PS0,U,8) S:X MED("orderID")=X
|
---|
| 3447 | "RTN","NHINVPSO",103,0)
|
---|
| 3448 | S X=+$P(PS0,U,12) S:X MED("quantity")=X
|
---|
| 3449 | "RTN","NHINVPSO",104,0)
|
---|
| 3450 | D GETS^DIQ(52.41,+ID_",","101;13;19;15;5;1.1","I","NHIN")
|
---|
| 3451 | "RTN","NHINVPSO",105,0)
|
---|
| 3452 | S X=NHIN(52.41,+ID_",",101,"I") S:X MED("daysSupply")=X
|
---|
| 3453 | "RTN","NHINVPSO",106,0)
|
---|
| 3454 | S X=NHIN(52.41,+ID_",",13,"I") S:X MED("fillsAllowed")=X
|
---|
| 3455 | "RTN","NHINVPSO",107,0)
|
---|
| 3456 | S X=NHIN(52.41,+ID_",",19,"I") S:$L(X) MED("routing")=X
|
---|
| 3457 | "RTN","NHINVPSO",108,0)
|
---|
| 3458 | S X=NHIN(52.41,+ID_",",15,"I") S:X MED("ordered")=X
|
---|
| 3459 | "RTN","NHINVPSO",109,0)
|
---|
| 3460 | S X=NHIN(52.41,+ID_",",5,"I") S:X MED("orderingProvider")=X_U_$P($G(^VA(200,X,0)),U)
|
---|
| 3461 | "RTN","NHINVPSO",110,0)
|
---|
| 3462 | S X=NHIN(52.41,+ID_",",1.1,"I") S:X MED("location")=X_U_$P($G(^SC(X,0)),U)
|
---|
| 3463 | "RTN","NHINVPSO",111,0)
|
---|
| 3464 | S MED("facility")=$$FAC^NHINV(X)
|
---|
| 3465 | "RTN","NHINVPSO",112,0)
|
---|
| 3466 | S X=$G(^TMP("PS",$J,NHI,"SIG",1,0)),I=1
|
---|
| 3467 | "RTN","NHINVPSO",113,0)
|
---|
| 3468 | F S I=$O(^TMP("PS",$J,NHI,"SIG",I)) Q:I<1 S X=X_$C(13,10)_$G(^(I,0))
|
---|
| 3469 | "RTN","NHINVPSO",114,0)
|
---|
| 3470 | S MED("sig")=X
|
---|
| 3471 | "RTN","NHINVPSO",115,0)
|
---|
| 3472 | D PEN^PSO5241(DFN,"NHIN",+ID)
|
---|
| 3473 | "RTN","NHINVPSO",116,0)
|
---|
| 3474 | S X=$G(^TMP($J,"NHIN",DFN,+ID,8)) I X D ;Pharmacy OI
|
---|
| 3475 | "RTN","NHINVPSO",117,0)
|
---|
| 3476 | . S MED("name")=$P(X,U,2)_" "_$P(X,U,4),MED("form")=$P(X,U,4)
|
---|
| 3477 | "RTN","NHINVPSO",118,0)
|
---|
| 3478 | S X=$G(^TMP($J,"NHIN",DFN,+ID,11)) D:X NDF^NHINVPS(+X) ;Dispense Drug
|
---|
| 3479 | "RTN","NHINVPSO",119,0)
|
---|
| 3480 | D PDOSE K ^TMP($J,"NHIN")
|
---|
| 3481 | "RTN","NHINVPSO",120,0)
|
---|
| 3482 | Q
|
---|
| 3483 | "RTN","NHINVPSO",121,0)
|
---|
| 3484 | ;
|
---|
| 3485 | "RTN","NHINVPSO",122,0)
|
---|
| 3486 | PEN1(ID,MED) ; -- return a pending Rx in MED("attribute")=value
|
---|
| 3487 | "RTN","NHINVPSO",123,0)
|
---|
| 3488 | ; [expects OEL^PSOORRL data]
|
---|
| 3489 | "RTN","NHINVPSO",124,0)
|
---|
| 3490 | N PS,PS0,I,X,NHIN K MED
|
---|
| 3491 | "RTN","NHINVPSO",125,0)
|
---|
| 3492 | M PS=^TMP("PS",$J) S PS0=PS(0)
|
---|
| 3493 | "RTN","NHINVPSO",126,0)
|
---|
| 3494 | S MED("id")=ID,MED("vaType")="O",MED("type")="Prescription"
|
---|
| 3495 | "RTN","NHINVPSO",127,0)
|
---|
| 3496 | S MED("vaStatus")=$P(PS0,U,6),MED("status")="not active"
|
---|
| 3497 | "RTN","NHINVPSO",128,0)
|
---|
| 3498 | S X=+$P(PS0,U,11) S:X MED("orderID")=X
|
---|
| 3499 | "RTN","NHINVPSO",129,0)
|
---|
| 3500 | S X=+$P(PS0,U,8) S:X MED("quantity")=X
|
---|
| 3501 | "RTN","NHINVPSO",130,0)
|
---|
| 3502 | S X=+$P(PS0,U,4) S:X MED("fillsAllowed")=X
|
---|
| 3503 | "RTN","NHINVPSO",131,0)
|
---|
| 3504 | S X=+$P(PS0,U,5) S:X MED("ordered")=X
|
---|
| 3505 | "RTN","NHINVPSO",132,0)
|
---|
| 3506 | S X=$G(PS("DD",1,0)) D:X NDF^NHINVPS(+X) ;Dispense Drug
|
---|
| 3507 | "RTN","NHINVPSO",133,0)
|
---|
| 3508 | D GETS^DIQ(52.41,+ID_",","101;19;5;1.1","I","NHIN")
|
---|
| 3509 | "RTN","NHINVPSO",134,0)
|
---|
| 3510 | S X=NHIN(52.41,+ID_",",101,"I") S:X MED("daysSupply")=X
|
---|
| 3511 | "RTN","NHINVPSO",135,0)
|
---|
| 3512 | S X=NHIN(52.41,+ID_",",19,"I") S:$L(X) MED("routing")=X
|
---|
| 3513 | "RTN","NHINVPSO",136,0)
|
---|
| 3514 | S X=NHIN(52.41,+ID_",",5,"I") S:X MED("orderingProvider")=X_U_$P($G(^VA(200,X,0)),U)
|
---|
| 3515 | "RTN","NHINVPSO",137,0)
|
---|
| 3516 | S X=NHIN(52.41,+ID_",",1.1,"I") S:X MED("location")=X_U_$P($G(^SC(X,0)),U)
|
---|
| 3517 | "RTN","NHINVPSO",138,0)
|
---|
| 3518 | S MED("facility")=$$FAC^NHINV(X)
|
---|
| 3519 | "RTN","NHINVPSO",139,0)
|
---|
| 3520 | S X=$G(PS("SIG",1,0)),I=1
|
---|
| 3521 | "RTN","NHINVPSO",140,0)
|
---|
| 3522 | F S I=$O(PS("SIG",I)) Q:I<1 S X=X_$C(13,10)_$G(PS("SIG",I,0))
|
---|
| 3523 | "RTN","NHINVPSO",141,0)
|
---|
| 3524 | S MED("sig")=X
|
---|
| 3525 | "RTN","NHINVPSO",142,0)
|
---|
| 3526 | D PEN^PSO5241(DFN,"NHIN",+ID)
|
---|
| 3527 | "RTN","NHINVPSO",143,0)
|
---|
| 3528 | S X=$G(^TMP($J,"NHIN",DFN,+ID,8)) I X D ;Pharmacy OI
|
---|
| 3529 | "RTN","NHINVPSO",144,0)
|
---|
| 3530 | . S MED("name")=$P(X,U,2)_" "_$P(X,U,4),MED("form")=$P(X,U,4)
|
---|
| 3531 | "RTN","NHINVPSO",145,0)
|
---|
| 3532 | D PDOSE K ^TMP($J,"NHIN")
|
---|
| 3533 | "RTN","NHINVPSO",146,0)
|
---|
| 3534 | Q
|
---|
| 3535 | "RTN","NHINVPSO",147,0)
|
---|
| 3536 | ;
|
---|
| 3537 | "RTN","NHINVPSO",148,0)
|
---|
| 3538 | PDOSE ; Pending file doses
|
---|
| 3539 | "RTN","NHINVPSO",149,0)
|
---|
| 3540 | N QT,UNIT,UD,NOUN,DOSE,RTE,SCH,DUR,CONJ,BEG,END
|
---|
| 3541 | "RTN","NHINVPSO",150,0)
|
---|
| 3542 | F I=1:1 K NHIN D GETS^DIQ(52.413,I_","_+ID_",","*",,"NHIN") Q:'$D(NHIN) D
|
---|
| 3543 | "RTN","NHINVPSO",151,0)
|
---|
| 3544 | . K QT M QT=NHIN(52.413,I_","_+ID_",")
|
---|
| 3545 | "RTN","NHINVPSO",152,0)
|
---|
| 3546 | . S (UNIT,UD,NOUN)="",(DOSE,X)=QT(.01) I X["&" D
|
---|
| 3547 | "RTN","NHINVPSO",153,0)
|
---|
| 3548 | .. S DOSE=$P(X,"&"),UNIT=$P(X,"&",2)
|
---|
| 3549 | "RTN","NHINVPSO",154,0)
|
---|
| 3550 | .. S UD=$P(X,"&",3),NOUN=$P(X,"&",4)
|
---|
| 3551 | "RTN","NHINVPSO",155,0)
|
---|
| 3552 | . S SCH=QT(1),DUR=QT(2),CONJ=QT(6),BEG=QT(3),END=QT(4)
|
---|
| 3553 | "RTN","NHINVPSO",156,0)
|
---|
| 3554 | . S RTE=$$GET1^DIQ(52.413,I_","_+ID_",","10:1")
|
---|
| 3555 | "RTN","NHINVPSO",157,0)
|
---|
| 3556 | . S MED("dose",I)=DOSE_U_UNIT_U_UD_U_NOUN_U_RTE_U_SCH_U_DUR_U_CONJ_U_BEG_U_END
|
---|
| 3557 | "RTN","NHINVPSO",158,0)
|
---|
| 3558 | Q
|
---|
| 3559 | "RTN","NHINVPSO",159,0)
|
---|
| 3560 | ;
|
---|
| 3561 | "RTN","NHINVPSO",160,0)
|
---|
| 3562 | STOP(BEG,X) ; -- Return date after adding X to BEG
|
---|
| 3563 | "RTN","NHINVPSO",161,0)
|
---|
| 3564 | N D,H,M,S,UNT,Y
|
---|
| 3565 | "RTN","NHINVPSO",162,0)
|
---|
| 3566 | S Y=BEG,(D,H,M,S)=0,UNT=$P(X," ",2),X=+X
|
---|
| 3567 | "RTN","NHINVPSO",163,0)
|
---|
| 3568 | S:UNT?1"MON".E D=30*X
|
---|
| 3569 | "RTN","NHINVPSO",164,0)
|
---|
| 3570 | S:UNT?1"WEE".E D=7*X
|
---|
| 3571 | "RTN","NHINVPSO",165,0)
|
---|
| 3572 | S:UNT?1"DAY".E D=X
|
---|
| 3573 | "RTN","NHINVPSO",166,0)
|
---|
| 3574 | S:UNT?1"HOU".E H=X
|
---|
| 3575 | "RTN","NHINVPSO",167,0)
|
---|
| 3576 | S:UNT?1"MIN".E M=X
|
---|
| 3577 | "RTN","NHINVPSO",168,0)
|
---|
| 3578 | S:UNT?1"SEC".E S=X
|
---|
| 3579 | "RTN","NHINVPSO",169,0)
|
---|
| 3580 | S Y=$$FMADD^XLFDT(BEG,D,H,M,S)
|
---|
| 3581 | "RTN","NHINVPSO",170,0)
|
---|
| 3582 | Q Y
|
---|
| 3583 | "RTN","NHINVPSO",171,0)
|
---|
| 3584 | ;
|
---|
| 3585 | "RTN","NHINVPSO",172,0)
|
---|
| 3586 | NVA(ID,MED) ; -- return a non-VA med in MED("attribute")=value
|
---|
| 3587 | "RTN","NHINVPSO",173,0)
|
---|
| 3588 | N NVA,NHZ,ORIFN,DOSE,X K MED
|
---|
| 3589 | "RTN","NHINVPSO",174,0)
|
---|
| 3590 | D GETS^DIQ(55.05,+ID_","_DFN_",",".01:8;11:13","IE","NHZ")
|
---|
| 3591 | "RTN","NHINVPSO",175,0)
|
---|
| 3592 | M NVA=NHZ(55.05,+ID_","_DFN_",") K NHZ
|
---|
| 3593 | "RTN","NHINVPSO",176,0)
|
---|
| 3594 | S MED("id")=ID,MED("type")="OTC",MED("vaType")="N"
|
---|
| 3595 | "RTN","NHINVPSO",177,0)
|
---|
| 3596 | S ORIFN=+NVA(7,"I") S:ORIFN MED("orderID")=ORIFN
|
---|
| 3597 | "RTN","NHINVPSO",178,0)
|
---|
| 3598 | I NVA(.01,"I") D ;orderable item
|
---|
| 3599 | "RTN","NHINVPSO",179,0)
|
---|
| 3600 | . N FORM
|
---|
| 3601 | "RTN","NHINVPSO",180,0)
|
---|
| 3602 | . S X=NVA(.01,"I") D ZERO^PSS50P7(+X,,,"PSOI")
|
---|
| 3603 | "RTN","NHINVPSO",181,0)
|
---|
| 3604 | . S FORM=$P($G(^TMP($J,"PSOI",+X,.02)),U,2),MED("form")=FORM
|
---|
| 3605 | "RTN","NHINVPSO",182,0)
|
---|
| 3606 | . S MED("name")=NVA(.01,"E")_" "_FORM
|
---|
| 3607 | "RTN","NHINVPSO",183,0)
|
---|
| 3608 | S X=NVA(1,"I") D:X NDF^NHINVPS(+X) ;dispense drug
|
---|
| 3609 | "RTN","NHINVPSO",184,0)
|
---|
| 3610 | S MED("sig")=NVA(2,"E")_" BY "_NVA(3,"E")_" "_NVA(4,"E")
|
---|
| 3611 | "RTN","NHINVPSO",185,0)
|
---|
| 3612 | S X=NVA(2,"I"),NVA(2,"I")=+X_U_$P(X,+X,2) ;amt^unit
|
---|
| 3613 | "RTN","NHINVPSO",186,0)
|
---|
| 3614 | S DOSE=NVA(2,"I")_"^^" I ORIFN D ;reformat from order
|
---|
| 3615 | "RTN","NHINVPSO",187,0)
|
---|
| 3616 | . S X=$$VALUE^ORX8(ORIFN,"ROUTE") S:X NVA(3,"E")=$$GET1^DIQ(51.2,+X_",",1)
|
---|
| 3617 | "RTN","NHINVPSO",188,0)
|
---|
| 3618 | . S X=$$VALUE^ORX8(ORIFN,"SCHEDULE") S:$L(X) NVA(4,"E")=X
|
---|
| 3619 | "RTN","NHINVPSO",189,0)
|
---|
| 3620 | . S X=$$VALUE^ORX8(ORIFN,"DOSE"),DOSE=$TR($P(X,"&",1,4),"&","^")
|
---|
| 3621 | "RTN","NHINVPSO",190,0)
|
---|
| 3622 | S MED("dose",1)=DOSE_U_NVA(3,"E")_U_NVA(4,"E")
|
---|
| 3623 | "RTN","NHINVPSO",191,0)
|
---|
| 3624 | S:NVA(8,"I") MED("start")=NVA(8,"I")
|
---|
| 3625 | "RTN","NHINVPSO",192,0)
|
---|
| 3626 | S:NVA(6,"I") MED("stop")=NVA(6,"I")
|
---|
| 3627 | "RTN","NHINVPSO",193,0)
|
---|
| 3628 | S:NVA(11,"I") MED("ordered")=NVA(11,"I")
|
---|
| 3629 | "RTN","NHINVPSO",194,0)
|
---|
| 3630 | S MED("status")=$S($G(NVA(5,"E")):"not active",1:"active")
|
---|
| 3631 | "RTN","NHINVPSO",195,0)
|
---|
| 3632 | S:NVA(12,"I") MED("orderingProvider")=NVA(12,"I")_U_NVA(12,"E")
|
---|
| 3633 | "RTN","NHINVPSO",196,0)
|
---|
| 3634 | S:NVA(13,"I") MED("location")=NVA(13,"I")_U_NVA(13,"E")
|
---|
| 3635 | "RTN","NHINVPSO",197,0)
|
---|
| 3636 | S MED("facility")=$$FAC^NHINV(NVA(13,"I"))
|
---|
| 3637 | "RTN","NHINVPSO",198,0)
|
---|
| 3638 | K ^TMP($J,"PSOI"),^TMP($J,"NDF")
|
---|
| 3639 | "RTN","NHINVPSO",199,0)
|
---|
| 3640 | Q
|
---|
| 3641 | "RTN","NHINVPSO",200,0)
|
---|
| 3642 | ;
|
---|
| 3643 | "RTN","NHINVPSO",201,0)
|
---|
| 3644 | ACTIVE(X) ; -- return 1 or 0, if X is an active status
|
---|
| 3645 | "RTN","NHINVPSO",202,0)
|
---|
| 3646 | N Y S Y=1
|
---|
| 3647 | "RTN","NHINVPSO",203,0)
|
---|
| 3648 | I X="PURGE" S Y=0
|
---|
| 3649 | "RTN","NHINVPSO",204,0)
|
---|
| 3650 | I X="DELETED" S Y=0
|
---|
| 3651 | "RTN","NHINVPSO",205,0)
|
---|
| 3652 | I X="EXPIRED" S Y=0 ;keep, to renew?
|
---|
| 3653 | "RTN","NHINVPSO",206,0)
|
---|
| 3654 | I $P(X," ")="DISCONTINUED" S Y=0
|
---|
| 3655 | "RTN","NHINVPSO",207,0)
|
---|
| 3656 | Q Y
|
---|
| 3657 | "RTN","NHINVPT")
|
---|
| 3658 | 0^25^B59592091^n/a
|
---|
| 3659 | "RTN","NHINVPT",1,0)
|
---|
| 3660 | NHINVPT ;SLC/MKB -- Patient demographics extract
|
---|
| 3661 | "RTN","NHINVPT",2,0)
|
---|
| 3662 | ;;1.0;NHIN;**1**;Dec 01, 2009;Build 11
|
---|
| 3663 | "RTN","NHINVPT",3,0)
|
---|
| 3664 | ;
|
---|
| 3665 | "RTN","NHINVPT",4,0)
|
---|
| 3666 | ; External References DBIA#
|
---|
| 3667 | "RTN","NHINVPT",5,0)
|
---|
| 3668 | ; ------------------- -----
|
---|
| 3669 | "RTN","NHINVPT",6,0)
|
---|
| 3670 | ; ^DIC(42 10039
|
---|
| 3671 | "RTN","NHINVPT",7,0)
|
---|
| 3672 | ; ^DPT 10035
|
---|
| 3673 | "RTN","NHINVPT",8,0)
|
---|
| 3674 | ; DGCV 4156
|
---|
| 3675 | "RTN","NHINVPT",9,0)
|
---|
| 3676 | ; DGMSTAPI 2716
|
---|
| 3677 | "RTN","NHINVPT",10,0)
|
---|
| 3678 | ; DGNTAPI 3457
|
---|
| 3679 | "RTN","NHINVPT",11,0)
|
---|
| 3680 | ; DGPFAPI 3860
|
---|
| 3681 | "RTN","NHINVPT",12,0)
|
---|
| 3682 | ; DILFD 2055
|
---|
| 3683 | "RTN","NHINVPT",13,0)
|
---|
| 3684 | ; DIQ 2056
|
---|
| 3685 | "RTN","NHINVPT",14,0)
|
---|
| 3686 | ; MPIF001 2701
|
---|
| 3687 | "RTN","NHINVPT",15,0)
|
---|
| 3688 | ; SDUTL3 1252
|
---|
| 3689 | "RTN","NHINVPT",16,0)
|
---|
| 3690 | ; VADPT 10061
|
---|
| 3691 | "RTN","NHINVPT",17,0)
|
---|
| 3692 | ; VAFCTFU1 2990
|
---|
| 3693 | "RTN","NHINVPT",18,0)
|
---|
| 3694 | ; VASITE 10112
|
---|
| 3695 | "RTN","NHINVPT",19,0)
|
---|
| 3696 | ; XUAF4 2171
|
---|
| 3697 | "RTN","NHINVPT",20,0)
|
---|
| 3698 | ;
|
---|
| 3699 | "RTN","NHINVPT",21,0)
|
---|
| 3700 | ; ------------ Get data from VistA ------------
|
---|
| 3701 | "RTN","NHINVPT",22,0)
|
---|
| 3702 | ;
|
---|
| 3703 | "RTN","NHINVPT",23,0)
|
---|
| 3704 | EN(DFN,BEG,END,MAX,ID) ; -- find current patient demographics
|
---|
| 3705 | "RTN","NHINVPT",24,0)
|
---|
| 3706 | ; [BEG,END,MAX,ID not currently used]
|
---|
| 3707 | "RTN","NHINVPT",25,0)
|
---|
| 3708 | S DFN=+$G(DFN) Q:DFN<1 ;invalid patient
|
---|
| 3709 | "RTN","NHINVPT",26,0)
|
---|
| 3710 | N PAT,SYS S SYS=$$SITE^VASITE
|
---|
| 3711 | "RTN","NHINVPT",27,0)
|
---|
| 3712 | D DEM,SVC,PRF,ATC,SUPP,ALIAS,FAC
|
---|
| 3713 | "RTN","NHINVPT",28,0)
|
---|
| 3714 | I $D(PAT)>9 D XML(.PAT)
|
---|
| 3715 | "RTN","NHINVPT",29,0)
|
---|
| 3716 | Q
|
---|
| 3717 | "RTN","NHINVPT",30,0)
|
---|
| 3718 | ;
|
---|
| 3719 | "RTN","NHINVPT",31,0)
|
---|
| 3720 | DEM ;-demographic data
|
---|
| 3721 | "RTN","NHINVPT",32,0)
|
---|
| 3722 | N VADM,VA,VAERR,X
|
---|
| 3723 | "RTN","NHINVPT",33,0)
|
---|
| 3724 | S X=+$$GETICN^MPIF001(DFN) S:X>1 PAT("icn")=X
|
---|
| 3725 | "RTN","NHINVPT",34,0)
|
---|
| 3726 | D DEM^VADPT S X=VADM(1),PAT("fullName")=X
|
---|
| 3727 | "RTN","NHINVPT",35,0)
|
---|
| 3728 | S PAT("familyName")=$P(X,","),PAT("givenNames")=$P(X,",",2,99)
|
---|
| 3729 | "RTN","NHINVPT",36,0)
|
---|
| 3730 | S PAT("ssn")=$P(VADM(2),U),PAT("id")=DFN
|
---|
| 3731 | "RTN","NHINVPT",37,0)
|
---|
| 3732 | S:$D(VA("BID")) PAT("bid")=$E(X)_VA("BID")
|
---|
| 3733 | "RTN","NHINVPT",38,0)
|
---|
| 3734 | S PAT("dob")=+$P($P(VADM(3),U),".")
|
---|
| 3735 | "RTN","NHINVPT",39,0)
|
---|
| 3736 | S PAT("gender")=$P(VADM(5),U)
|
---|
| 3737 | "RTN","NHINVPT",40,0)
|
---|
| 3738 | S PAT("lrdfn")=+$G(^DPT(DFN,"LR"))
|
---|
| 3739 | "RTN","NHINVPT",41,0)
|
---|
| 3740 | S X=+$P($P(VADM(6),U),".") S:X PAT("died")=X
|
---|
| 3741 | "RTN","NHINVPT",42,0)
|
---|
| 3742 | S X=$$GET1^DIQ(38.1,DFN_",",2,"I") S:$L(X) PAT("sensitive")=X
|
---|
| 3743 | "RTN","NHINVPT",43,0)
|
---|
| 3744 | S X=+VADM(9) S:X PAT("religion")=X
|
---|
| 3745 | "RTN","NHINVPT",44,0)
|
---|
| 3746 | S X=$P(VADM(10),U,2) S:$L(X) PAT("maritalStatus")=$E(X)
|
---|
| 3747 | "RTN","NHINVPT",45,0)
|
---|
| 3748 | I VADM(11) D
|
---|
| 3749 | "RTN","NHINVPT",46,0)
|
---|
| 3750 | . N I S I=0
|
---|
| 3751 | "RTN","NHINVPT",47,0)
|
---|
| 3752 | . F S I=$O(VADM(11,I)) Q:I<1 S X=+VADM(11,I),PAT("ethnicity",X)=$$GET1^DIQ(10.2,X_",",4)
|
---|
| 3753 | "RTN","NHINVPT",48,0)
|
---|
| 3754 | I VADM(12) D
|
---|
| 3755 | "RTN","NHINVPT",49,0)
|
---|
| 3756 | . N I S I=0
|
---|
| 3757 | "RTN","NHINVPT",50,0)
|
---|
| 3758 | . F S I=$O(VADM(12,I)) Q:I<1 S X=+VADM(12,I),PAT("race",X)=$$GET1^DIQ(10,X_",",4)
|
---|
| 3759 | "RTN","NHINVPT",51,0)
|
---|
| 3760 | Q
|
---|
| 3761 | "RTN","NHINVPT",52,0)
|
---|
| 3762 | SVC ;-service data
|
---|
| 3763 | "RTN","NHINVPT",53,0)
|
---|
| 3764 | N VAEL,VASV,VAERR,X,Y,I,AO,IR,PGF,HNC,MST,CV
|
---|
| 3765 | "RTN","NHINVPT",54,0)
|
---|
| 3766 | D 7^VADPT
|
---|
| 3767 | "RTN","NHINVPT",55,0)
|
---|
| 3768 | S PAT("veteran")=VAEL(4)
|
---|
| 3769 | "RTN","NHINVPT",56,0)
|
---|
| 3770 | S PAT("sc")=+VAEL(3) S:VAEL(3) PAT("scPercent")=+$P(VAEL(3),U,2)
|
---|
| 3771 | "RTN","NHINVPT",57,0)
|
---|
| 3772 | ;
|
---|
| 3773 | "RTN","NHINVPT",58,0)
|
---|
| 3774 | ; exposures
|
---|
| 3775 | "RTN","NHINVPT",59,0)
|
---|
| 3776 | S AO=VASV(2),IR=VASV(3)
|
---|
| 3777 | "RTN","NHINVPT",60,0)
|
---|
| 3778 | S X=$P($G(^DPT(DFN,.322)),U,10),PGF=$S(X="Y":1,X="N":0,1:"")
|
---|
| 3779 | "RTN","NHINVPT",61,0)
|
---|
| 3780 | S X=$$GETCUR^DGNTAPI(DFN,"HNC"),X=+($G(HNC("STAT")))
|
---|
| 3781 | "RTN","NHINVPT",62,0)
|
---|
| 3782 | S HNC=$S(X=4:1,X=5:1,X=1:0,X=6:0,1:"")
|
---|
| 3783 | "RTN","NHINVPT",63,0)
|
---|
| 3784 | S X=$P($$GETSTAT^DGMSTAPI(DFN),U,2),MST=$S(X="Y":1,X="N":0,1:"")
|
---|
| 3785 | "RTN","NHINVPT",64,0)
|
---|
| 3786 | S X=$$CVEDT^DGCV(DFN),CV=$S(+X<0:"",+X=0:0,$P(X,U,3):1,1:0)
|
---|
| 3787 | "RTN","NHINVPT",65,0)
|
---|
| 3788 | S PAT("exposures")=AO_U_IR_U_PGF_U_HNC_U_MST_U_CV
|
---|
| 3789 | "RTN","NHINVPT",66,0)
|
---|
| 3790 | ;
|
---|
| 3791 | "RTN","NHINVPT",67,0)
|
---|
| 3792 | ; rated disabilities [see DGRPDB]
|
---|
| 3793 | "RTN","NHINVPT",68,0)
|
---|
| 3794 | S I=0 F S I=$O(^DPT(DFN,.372,I)) Q:I<1 D
|
---|
| 3795 | "RTN","NHINVPT",69,0)
|
---|
| 3796 | . N DIS S DIS=$G(^DPT(DFN,.372,I,0))
|
---|
| 3797 | "RTN","NHINVPT",70,0)
|
---|
| 3798 | . S Y=$$GET1^DIQ(31,+DIS_",",.01)
|
---|
| 3799 | "RTN","NHINVPT",71,0)
|
---|
| 3800 | . S PAT("disability",+DIS)=Y_U_$P(DIS,U,2,3) ;name^%^sc
|
---|
| 3801 | "RTN","NHINVPT",72,0)
|
---|
| 3802 | Q
|
---|
| 3803 | "RTN","NHINVPT",73,0)
|
---|
| 3804 | PRF ;-patient record flags
|
---|
| 3805 | "RTN","NHINVPT",74,0)
|
---|
| 3806 | N NHINPF,I,NAME,TEXT
|
---|
| 3807 | "RTN","NHINVPT",75,0)
|
---|
| 3808 | Q:'$$GETACT^DGPFAPI(DFN,"NHINPF")
|
---|
| 3809 | "RTN","NHINVPT",76,0)
|
---|
| 3810 | S I=0 F S I=$O(NHINPF(I)) Q:I<1 D
|
---|
| 3811 | "RTN","NHINVPT",77,0)
|
---|
| 3812 | . S NAME=$P(NHINPF(I,"FLAG"),U,2)
|
---|
| 3813 | "RTN","NHINVPT",78,0)
|
---|
| 3814 | . M TEXT=NHINPF(I,"NARR")
|
---|
| 3815 | "RTN","NHINVPT",79,0)
|
---|
| 3816 | . S PAT("flag",I)=NAME_U_$$STRING^NHINV(.TEXT)
|
---|
| 3817 | "RTN","NHINVPT",80,0)
|
---|
| 3818 | Q
|
---|
| 3819 | "RTN","NHINVPT",81,0)
|
---|
| 3820 | ATC ;-address & telecom
|
---|
| 3821 | "RTN","NHINVPT",82,0)
|
---|
| 3822 | N VAPA,I,X
|
---|
| 3823 | "RTN","NHINVPT",83,0)
|
---|
| 3824 | S VAPA("P")="" D ADD^VADPT ;permanent address
|
---|
| 3825 | "RTN","NHINVPT",84,0)
|
---|
| 3826 | S X="" F I=1:1:4 S X=X_VAPA(I)_U
|
---|
| 3827 | "RTN","NHINVPT",85,0)
|
---|
| 3828 | S X=X_$P(VAPA(5),U,2)_U_$P(VAPA(11),U,2)
|
---|
| 3829 | "RTN","NHINVPT",86,0)
|
---|
| 3830 | S PAT("address")=X ;street1^st2^st3^city^state^zip
|
---|
| 3831 | "RTN","NHINVPT",87,0)
|
---|
| 3832 | S X=VAPA(8)_U_$$GET1^DIQ(2,DFN_",",.134)_U_$$GET1^DIQ(2,DFN_",",.132)
|
---|
| 3833 | "RTN","NHINVPT",88,0)
|
---|
| 3834 | S PAT("telecom")=X ;home^cell^work phones
|
---|
| 3835 | "RTN","NHINVPT",89,0)
|
---|
| 3836 | Q
|
---|
| 3837 | "RTN","NHINVPT",90,0)
|
---|
| 3838 | SUPP ;-support contacts
|
---|
| 3839 | "RTN","NHINVPT",91,0)
|
---|
| 3840 | N VAOA,A,I,X,TYPE
|
---|
| 3841 | "RTN","NHINVPT",92,0)
|
---|
| 3842 | F A="",1 K VAOA D
|
---|
| 3843 | "RTN","NHINVPT",93,0)
|
---|
| 3844 | . S:A VAOA("A")=A D OAD^VADPT Q:'$L($G(VAOA(9)))
|
---|
| 3845 | "RTN","NHINVPT",94,0)
|
---|
| 3846 | . S TYPE=$S(A=1:"ECON",1:"NOK")
|
---|
| 3847 | "RTN","NHINVPT",95,0)
|
---|
| 3848 | . S PAT("support",TYPE)=VAOA(9)_U_VAOA(10) ;name^relationship
|
---|
| 3849 | "RTN","NHINVPT",96,0)
|
---|
| 3850 | . S X="" F I=1:1:4 S X=X_VAOA(I)_U
|
---|
| 3851 | "RTN","NHINVPT",97,0)
|
---|
| 3852 | . S X=X_$P(VAOA(5),U,2)_U_$P(VAOA(11),U,2)
|
---|
| 3853 | "RTN","NHINVPT",98,0)
|
---|
| 3854 | . S PAT("support",TYPE,"address")=X ;street1^st2^st3^city^state^zip
|
---|
| 3855 | "RTN","NHINVPT",99,0)
|
---|
| 3856 | . S I=$S(A=1:.33011,1:.21011),X=VAOA(8)_U_U_$$GET1^DIQ(2,DFN_",",I)
|
---|
| 3857 | "RTN","NHINVPT",100,0)
|
---|
| 3858 | . S PAT("support",TYPE,"telecom")=X ;home^cell^work phones
|
---|
| 3859 | "RTN","NHINVPT",101,0)
|
---|
| 3860 | Q
|
---|
| 3861 | "RTN","NHINVPT",102,0)
|
---|
| 3862 | ALIAS ;-other names used
|
---|
| 3863 | "RTN","NHINVPT",103,0)
|
---|
| 3864 | N I,X
|
---|
| 3865 | "RTN","NHINVPT",104,0)
|
---|
| 3866 | S I=0 F S I=$O(^DPT(DFN,.01,I)) Q:I<1 S X=$G(^(I,0)) D
|
---|
| 3867 | "RTN","NHINVPT",105,0)
|
---|
| 3868 | . S PAT("alias",I)=$P(X,U)
|
---|
| 3869 | "RTN","NHINVPT",106,0)
|
---|
| 3870 | Q
|
---|
| 3871 | "RTN","NHINVPT",107,0)
|
---|
| 3872 | FAC ;-treating facilities [see FACLIST^ORWCIRN]
|
---|
| 3873 | "RTN","NHINVPT",108,0)
|
---|
| 3874 | N IFN S DFN=+$G(DFN) Q:DFN<1
|
---|
| 3875 | "RTN","NHINVPT",109,0)
|
---|
| 3876 | N NHINY,HOME,I,X,IEN
|
---|
| 3877 | "RTN","NHINVPT",110,0)
|
---|
| 3878 | I $L($T(TFL^VAFCTFU1)) D TFL^VAFCTFU1(.NHINY,DFN)
|
---|
| 3879 | "RTN","NHINVPT",111,0)
|
---|
| 3880 | I $P($G(NHINY(1)),U)<0 D Q ;not setup
|
---|
| 3881 | "RTN","NHINVPT",112,0)
|
---|
| 3882 | . S X=$$SITE^VASITE,PAT("facility",+X)=$P(X,U,3)_U_$P(X,U,2)
|
---|
| 3883 | "RTN","NHINVPT",113,0)
|
---|
| 3884 | S HOME=+$P($G(^DPT(DFN,"MPI")),U,3) ;home facility
|
---|
| 3885 | "RTN","NHINVPT",114,0)
|
---|
| 3886 | S I=0 F S I=$O(NHINY(I)) Q:I<1 D
|
---|
| 3887 | "RTN","NHINVPT",115,0)
|
---|
| 3888 | . S X=NHINY(I) Q:$P(X,U)="" ;unknown
|
---|
| 3889 | "RTN","NHINVPT",116,0)
|
---|
| 3890 | . S IEN=+$$IEN^XUAF4($P(X,U))
|
---|
| 3891 | "RTN","NHINVPT",117,0)
|
---|
| 3892 | . I +X=776!(+X=200) S $P(X,U,2)="DEPT. OF DEFENSE"
|
---|
| 3893 | "RTN","NHINVPT",118,0)
|
---|
| 3894 | . S PAT("facility",IEN)=$P(X,U,1,3) ;stn# ^ name ^ last date
|
---|
| 3895 | "RTN","NHINVPT",119,0)
|
---|
| 3896 | . I IEN=HOME S $P(PAT("facility",IEN),U,4)=1
|
---|
| 3897 | "RTN","NHINVPT",120,0)
|
---|
| 3898 | Q
|
---|
| 3899 | "RTN","NHINVPT",121,0)
|
---|
| 3900 | ;
|
---|
| 3901 | "RTN","NHINVPT",122,0)
|
---|
| 3902 | INPT ;-current inpt status data
|
---|
| 3903 | "RTN","NHINVPT",123,0)
|
---|
| 3904 | N ADM,X
|
---|
| 3905 | "RTN","NHINVPT",124,0)
|
---|
| 3906 | S ADM=+$G(^DPT(DFN,.105)) I ADM D
|
---|
| 3907 | "RTN","NHINVPT",125,0)
|
---|
| 3908 | . N VAIN,VAERR,HLOC,SVC
|
---|
| 3909 | "RTN","NHINVPT",126,0)
|
---|
| 3910 | . D INP^VADPT S PAT("admitted")=ADM_U_+VAIN(7)
|
---|
| 3911 | "RTN","NHINVPT",127,0)
|
---|
| 3912 | . S PAT("ward")=VAIN(4),PAT("roomBed")=VAIN(5)
|
---|
| 3913 | "RTN","NHINVPT",128,0)
|
---|
| 3914 | . S HLOC=+$G(^DIC(42,+VAIN(4),44)),SVC=$P($G(^(0)),U,3)
|
---|
| 3915 | "RTN","NHINVPT",129,0)
|
---|
| 3916 | . S PAT("location")=HLOC_U_$P(VAIN(4),U,2)
|
---|
| 3917 | "RTN","NHINVPT",130,0)
|
---|
| 3918 | . S:$L(SVC) PAT("locSvc")=SVC_U_$$EXTERNAL^DILFD(42,.03,,SVC)
|
---|
| 3919 | "RTN","NHINVPT",131,0)
|
---|
| 3920 | . S PAT("specialty")=VAIN(3)
|
---|
| 3921 | "RTN","NHINVPT",132,0)
|
---|
| 3922 | . S PAT("attending")=VAIN(11)
|
---|
| 3923 | "RTN","NHINVPT",133,0)
|
---|
| 3924 | . S X=$$FAC^NHINV(HLOC),PAT("site")=X
|
---|
| 3925 | "RTN","NHINVPT",134,0)
|
---|
| 3926 | S PAT("inpatient")=$S(ADM:"true",1:"false")
|
---|
| 3927 | "RTN","NHINVPT",135,0)
|
---|
| 3928 | S X=$$OUTPTPR^SDUTL3(DFN) S:X PAT("pcProvider")=X
|
---|
| 3929 | "RTN","NHINVPT",136,0)
|
---|
| 3930 | S X=$$OUTPTTM^SDUTL3(DFN) S:X PAT("pcTeam")=X
|
---|
| 3931 | "RTN","NHINVPT",137,0)
|
---|
| 3932 | Q
|
---|
| 3933 | "RTN","NHINVPT",138,0)
|
---|
| 3934 | ;
|
---|
| 3935 | "RTN","NHINVPT",139,0)
|
---|
| 3936 | ; ------------ Return data to middle tier ------------
|
---|
| 3937 | "RTN","NHINVPT",140,0)
|
---|
| 3938 | ;
|
---|
| 3939 | "RTN","NHINVPT",141,0)
|
---|
| 3940 | XML(ITEM) ; -- Return patient data as XML in @NHIN@(n)
|
---|
| 3941 | "RTN","NHINVPT",142,0)
|
---|
| 3942 | ; as <element code='123' displayName='ABC' />
|
---|
| 3943 | "RTN","NHINVPT",143,0)
|
---|
| 3944 | N ATT,X,Y,I,ID
|
---|
| 3945 | "RTN","NHINVPT",144,0)
|
---|
| 3946 | D ADD("<patient>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 3947 | "RTN","NHINVPT",145,0)
|
---|
| 3948 | S ATT="" F S ATT=$O(ITEM(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 3949 | "RTN","NHINVPT",146,0)
|
---|
| 3950 | . I ATT="exposures" D:X["1" S Y="" Q
|
---|
| 3951 | "RTN","NHINVPT",147,0)
|
---|
| 3952 | .. S I=0,Y="<exposures>" D ADD(Y)
|
---|
| 3953 | "RTN","NHINVPT",148,0)
|
---|
| 3954 | .. F ID="AO","IR","PG","HNC","MST","CV" S I=I+1 I $P(X,U,I) S Y="<exposure value='"_ID_"' />" D ADD(Y)
|
---|
| 3955 | "RTN","NHINVPT",149,0)
|
---|
| 3956 | .. D ADD("</exposures>")
|
---|
| 3957 | "RTN","NHINVPT",150,0)
|
---|
| 3958 | . I $L($O(ITEM(ATT,""))) D Q ;multiples
|
---|
| 3959 | "RTN","NHINVPT",151,0)
|
---|
| 3960 | .. S ID=$S($E(ATT,$L(ATT))="s":ATT_"es",$E(ATT,$L(ATT))="y":$E(ATT,1,$L(ATT)-1)_"ies",1:ATT_"s")
|
---|
| 3961 | "RTN","NHINVPT",152,0)
|
---|
| 3962 | .. D ADD("<"_ID_">")
|
---|
| 3963 | "RTN","NHINVPT",153,0)
|
---|
| 3964 | .. S I="" F S I=$O(ITEM(ATT,I)) Q:I="" D D:$L(Y) ADD(Y)
|
---|
| 3965 | "RTN","NHINVPT",154,0)
|
---|
| 3966 | ... S X=ITEM(ATT,I),Y="<"_ATT_" "
|
---|
| 3967 | "RTN","NHINVPT",155,0)
|
---|
| 3968 | ... I ATT="support" D S Y="" Q
|
---|
| 3969 | "RTN","NHINVPT",156,0)
|
---|
| 3970 | .... S Y=Y_"contactType='"_I_"' name='"_$$ESC^NHINV($P(X,U))_$S($L($P(X,U,2)):"' relationship='"_$$ESC^NHINV($P(X,U,2)),1:"")_"' >" D ADD(Y)
|
---|
| 3971 | "RTN","NHINVPT",157,0)
|
---|
| 3972 | .... S X=$G(ITEM(ATT,I,"address")) I $L(X) D ADDR(X)
|
---|
| 3973 | "RTN","NHINVPT",158,0)
|
---|
| 3974 | .... S X=$G(ITEM(ATT,I,"telecom")) I $L(X) D PHONE(X)
|
---|
| 3975 | "RTN","NHINVPT",159,0)
|
---|
| 3976 | .... D ADD("</support>")
|
---|
| 3977 | "RTN","NHINVPT",160,0)
|
---|
| 3978 | ... I ATT="alias" S Y=Y_"fullName='"_$$ESC^NHINV(X)_$S(X[",":"' familyName='"_$$ESC^NHINV($P(X,","))_"' givenNames='"_$$ESC^NHINV($P(X,",",2,99)),1:"")_"' />" Q
|
---|
| 3979 | "RTN","NHINVPT",161,0)
|
---|
| 3980 | ... I ATT="flag" S Y=Y_"name='"_$$ESC^NHINV($P(X,U))_"' text='"_$$ESC^NHINV($P(X,U,2))_"' />" Q
|
---|
| 3981 | "RTN","NHINVPT",162,0)
|
---|
| 3982 | ... I ATT="facility" S Y=Y_"code='"_$P(X,U)_"' name='"_$$ESC^NHINV($P(X,U,2))_$S($P(X,U,3):"' latestDate='"_$P($P(X,U,3),"."),1:"")_$S($P(X,U,4):"' homeSite='1",1:"")_"' />" Q
|
---|
| 3983 | "RTN","NHINVPT",163,0)
|
---|
| 3984 | ... I ATT="disability" S Y=Y_"vaCode='"_I_"' printName='"_$$ESC^NHINV($P(X,U))_$S($P(X,U,2):"' sc='"_$P(X,U,2)_"' scPercent='"_$P(X,U,3),1:"")_"' />" Q
|
---|
| 3985 | "RTN","NHINVPT",164,0)
|
---|
| 3986 | ... S Y=Y_"value='"_$$ESC^NHINV(ITEM(ATT,I))_"' />"
|
---|
| 3987 | "RTN","NHINVPT",165,0)
|
---|
| 3988 | .. D ADD("</"_ID_">") S Y=""
|
---|
| 3989 | "RTN","NHINVPT",166,0)
|
---|
| 3990 | . S X=$G(ITEM(ATT)),Y="" Q:'$L(X)
|
---|
| 3991 | "RTN","NHINVPT",167,0)
|
---|
| 3992 | . I ATT="address" D ADDR(X) S Y="" Q
|
---|
| 3993 | "RTN","NHINVPT",168,0)
|
---|
| 3994 | . I ATT="telecom" D PHONE(X) S Y="" Q
|
---|
| 3995 | "RTN","NHINVPT",169,0)
|
---|
| 3996 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 3997 | "RTN","NHINVPT",170,0)
|
---|
| 3998 | . S Y="<"_ATT_" code='"_$P(X,U)_"' name='"_$$ESC^NHINV($P(X,U,2))_"' />"
|
---|
| 3999 | "RTN","NHINVPT",171,0)
|
---|
| 4000 | D ADD("</patient>")
|
---|
| 4001 | "RTN","NHINVPT",172,0)
|
---|
| 4002 | Q
|
---|
| 4003 | "RTN","NHINVPT",173,0)
|
---|
| 4004 | ;
|
---|
| 4005 | "RTN","NHINVPT",174,0)
|
---|
| 4006 | ADDR(X) ; -- XML address node from X=street1^st2^st3^city^state^zip
|
---|
| 4007 | "RTN","NHINVPT",175,0)
|
---|
| 4008 | N I,Y Q:$L(X)'>5 ;no data
|
---|
| 4009 | "RTN","NHINVPT",176,0)
|
---|
| 4010 | S Y="<address"
|
---|
| 4011 | "RTN","NHINVPT",177,0)
|
---|
| 4012 | F I=1,2,3 I $L($P(X,U,I)) S Y=Y_" streetLine"_I_"='"_$$ESC^NHINV($P(X,U,I))_"'"
|
---|
| 4013 | "RTN","NHINVPT",178,0)
|
---|
| 4014 | I $L($P(X,U,4)) S Y=Y_" city='"_$$ESC^NHINV($P(X,U,4))_"'"
|
---|
| 4015 | "RTN","NHINVPT",179,0)
|
---|
| 4016 | I $L($P(X,U,5)) S Y=Y_" stateProvince='"_$P(X,U,5)_"'"
|
---|
| 4017 | "RTN","NHINVPT",180,0)
|
---|
| 4018 | I $L($P(X,U,6)) S Y=Y_" postalCode='"_$P(X,U,6)_"'"
|
---|
| 4019 | "RTN","NHINVPT",181,0)
|
---|
| 4020 | S Y=Y_" />" D ADD(Y)
|
---|
| 4021 | "RTN","NHINVPT",182,0)
|
---|
| 4022 | Q
|
---|
| 4023 | "RTN","NHINVPT",183,0)
|
---|
| 4024 | ;
|
---|
| 4025 | "RTN","NHINVPT",184,0)
|
---|
| 4026 | PHONE(X) ; -- XML telecom node from X=home^cell^work numbers
|
---|
| 4027 | "RTN","NHINVPT",185,0)
|
---|
| 4028 | N I,Y Q:$L(X)'>2 ;no data
|
---|
| 4029 | "RTN","NHINVPT",186,0)
|
---|
| 4030 | D ADD("<telecomList>")
|
---|
| 4031 | "RTN","NHINVPT",187,0)
|
---|
| 4032 | I $L($P(X,U,1)) S Y="<telecom usageType='H' value='"_$P(X,U,1)_"' />" D ADD(Y)
|
---|
| 4033 | "RTN","NHINVPT",188,0)
|
---|
| 4034 | I $L($P(X,U,2)) S Y="<telecom usageType='MC' value='"_$P(X,U,2)_"' />" D ADD(Y)
|
---|
| 4035 | "RTN","NHINVPT",189,0)
|
---|
| 4036 | I $L($P(X,U,3)) S Y="<telecom usageType='WP' value='"_$P(X,U,3)_"' />" D ADD(Y)
|
---|
| 4037 | "RTN","NHINVPT",190,0)
|
---|
| 4038 | D ADD("</telecomList>")
|
---|
| 4039 | "RTN","NHINVPT",191,0)
|
---|
| 4040 | Q
|
---|
| 4041 | "RTN","NHINVPT",192,0)
|
---|
| 4042 | ;
|
---|
| 4043 | "RTN","NHINVPT",193,0)
|
---|
| 4044 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 4045 | "RTN","NHINVPT",194,0)
|
---|
| 4046 | S NHINI=$G(NHINI)+1
|
---|
| 4047 | "RTN","NHINVPT",195,0)
|
---|
| 4048 | S @NHIN@(NHINI)=X
|
---|
| 4049 | "RTN","NHINVPT",196,0)
|
---|
| 4050 | Q
|
---|
| 4051 | "RTN","NHINVRA")
|
---|
| 4052 | 0^11^B18363736^n/a
|
---|
| 4053 | "RTN","NHINVRA",1,0)
|
---|
| 4054 | NHINVRA ;SLC/MKB -- Radiology extract
|
---|
| 4055 | "RTN","NHINVRA",2,0)
|
---|
| 4056 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 4057 | "RTN","NHINVRA",3,0)
|
---|
| 4058 | ;
|
---|
| 4059 | "RTN","NHINVRA",4,0)
|
---|
| 4060 | ; External References DBIA#
|
---|
| 4061 | "RTN","NHINVRA",5,0)
|
---|
| 4062 | ; ------------------- -----
|
---|
| 4063 | "RTN","NHINVRA",6,0)
|
---|
| 4064 | ; ^SC( 10040
|
---|
| 4065 | "RTN","NHINVRA",7,0)
|
---|
| 4066 | ; ^VA(200 10060
|
---|
| 4067 | "RTN","NHINVRA",8,0)
|
---|
| 4068 | ; DIQ 2056
|
---|
| 4069 | "RTN","NHINVRA",9,0)
|
---|
| 4070 | ; ICPTCOD 1995
|
---|
| 4071 | "RTN","NHINVRA",10,0)
|
---|
| 4072 | ; RAO7PC1 2043
|
---|
| 4073 | "RTN","NHINVRA",11,0)
|
---|
| 4074 | ; RAO7PC3 2877
|
---|
| 4075 | "RTN","NHINVRA",12,0)
|
---|
| 4076 | ;
|
---|
| 4077 | "RTN","NHINVRA",13,0)
|
---|
| 4078 | ; ------------ Get exam(s) from VistA ------------
|
---|
| 4079 | "RTN","NHINVRA",14,0)
|
---|
| 4080 | ;
|
---|
| 4081 | "RTN","NHINVRA",15,0)
|
---|
| 4082 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's radiology exams
|
---|
| 4083 | "RTN","NHINVRA",16,0)
|
---|
| 4084 | N NHITM,NHICNT,NHXID
|
---|
| 4085 | "RTN","NHINVRA",17,0)
|
---|
| 4086 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 4087 | "RTN","NHINVRA",18,0)
|
---|
| 4088 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 4089 | "RTN","NHINVRA",19,0)
|
---|
| 4090 | K ^TMP($J,"RAE1") D EN1^RAO7PC1(DFN,BEG,END,MAX)
|
---|
| 4091 | "RTN","NHINVRA",20,0)
|
---|
| 4092 | ;
|
---|
| 4093 | "RTN","NHINVRA",21,0)
|
---|
| 4094 | ; get exam(s)
|
---|
| 4095 | "RTN","NHINVRA",22,0)
|
---|
| 4096 | I $G(ID) D EN1(ID,.NHITM),XML(.NHITM) Q
|
---|
| 4097 | "RTN","NHINVRA",23,0)
|
---|
| 4098 | ;
|
---|
| 4099 | "RTN","NHINVRA",24,0)
|
---|
| 4100 | ; get all exams
|
---|
| 4101 | "RTN","NHINVRA",25,0)
|
---|
| 4102 | S NHICNT=0,NHXID=""
|
---|
| 4103 | "RTN","NHINVRA",26,0)
|
---|
| 4104 | F S NHXID=$O(^TMP($J,"RAE1",DFN,NHXID)) Q:NHXID="" D Q:NHICNT'<MAX
|
---|
| 4105 | "RTN","NHINVRA",27,0)
|
---|
| 4106 | . K NHITM D EN1(NHXID,.NHITM) Q:'$D(NHITM)
|
---|
| 4107 | "RTN","NHINVRA",28,0)
|
---|
| 4108 | . D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 4109 | "RTN","NHINVRA",29,0)
|
---|
| 4110 | K ^TMP($J,"RAE1")
|
---|
| 4111 | "RTN","NHINVRA",30,0)
|
---|
| 4112 | Q
|
---|
| 4113 | "RTN","NHINVRA",31,0)
|
---|
| 4114 | ;
|
---|
| 4115 | "RTN","NHINVRA",32,0)
|
---|
| 4116 | EN1(ID,EXM) ; -- return an exam in EXM("attribute")=value
|
---|
| 4117 | "RTN","NHINVRA",33,0)
|
---|
| 4118 | ; Expects ^TMP($J,"RAE1",DFN,ID) from EN1^RAO7PC1
|
---|
| 4119 | "RTN","NHINVRA",34,0)
|
---|
| 4120 | N VPRN,VPR,X0,DATE,LOC,X,Y,IENS,NHMOD K EXM
|
---|
| 4121 | "RTN","NHINVRA",35,0)
|
---|
| 4122 | S X0=$G(^TMP($J,"RAE1",DFN,ID))
|
---|
| 4123 | "RTN","NHINVRA",36,0)
|
---|
| 4124 | S EXM("id")=ID,EXM("name")=$P(X0,U),EXM("case")=$P(X0,U,2)
|
---|
| 4125 | "RTN","NHINVRA",37,0)
|
---|
| 4126 | S DATE=9999999.9999-+ID,EXM("dateTime")=DATE
|
---|
| 4127 | "RTN","NHINVRA",38,0)
|
---|
| 4128 | I $P(X0,U,5) S EXM("document",1)=ID_U_$P(X0,U)_"^^"_$P(X0,U,3) ;id^localTitle^^status, if rpt exists
|
---|
| 4129 | "RTN","NHINVRA",39,0)
|
---|
| 4130 | S:$L($P(X0,U,6)) EXM("status")=$P($P(X0,U,6),"~",2)
|
---|
| 4131 | "RTN","NHINVRA",40,0)
|
---|
| 4132 | S X=$P(X0,U,7),LOC="" I $L(X) D
|
---|
| 4133 | "RTN","NHINVRA",41,0)
|
---|
| 4134 | . S LOC=+$O(^SC("B",X,0)),EXM("location")=LOC_U_X
|
---|
| 4135 | "RTN","NHINVRA",42,0)
|
---|
| 4136 | S EXM("facility")=$$FAC^NHINV(LOC)
|
---|
| 4137 | "RTN","NHINVRA",43,0)
|
---|
| 4138 | I $L($P(X0,U,8)) S X=$TR($P(X0,U,8),"~","^"),EXM("imagingType")=X
|
---|
| 4139 | "RTN","NHINVRA",44,0)
|
---|
| 4140 | S IENS=$P(ID,"-",2)_","_+ID_","_DFN_","
|
---|
| 4141 | "RTN","NHINVRA",45,0)
|
---|
| 4142 | S X=$P(X0,U,10) I X D
|
---|
| 4143 | "RTN","NHINVRA",46,0)
|
---|
| 4144 | . S EXM("type")=$$CPT(X)
|
---|
| 4145 | "RTN","NHINVRA",47,0)
|
---|
| 4146 | . I $D(^TMP($J,"RAE1",DFN,ID,"CMOD")) M EXM("modifier")=^("CMOD")
|
---|
| 4147 | "RTN","NHINVRA",48,0)
|
---|
| 4148 | S EXM("hasImages")=$S($P(X0,U,12)="Y":1,1:0)
|
---|
| 4149 | "RTN","NHINVRA",49,0)
|
---|
| 4150 | I $P(X0,U,4)="Y"!($P(X0,U,9)="Y") S EXM("interpretation")="ABNORMAL"
|
---|
| 4151 | "RTN","NHINVRA",50,0)
|
---|
| 4152 | S EXM("encounter")=$$GET1^DIQ(70.03,IENS,27,"I")
|
---|
| 4153 | "RTN","NHINVRA",51,0)
|
---|
| 4154 | S X=$$GET1^DIQ(70.03,IENS,15,"I") ;S:'X X=$$GET1^DIQ(70.03,IENS,12,"I")
|
---|
| 4155 | "RTN","NHINVRA",52,0)
|
---|
| 4156 | I X S EXM("provider")=X_U_$P($G(^VA(200,X,0)),U)
|
---|
| 4157 | "RTN","NHINVRA",53,0)
|
---|
| 4158 | S EXM("category")="RA"
|
---|
| 4159 | "RTN","NHINVRA",54,0)
|
---|
| 4160 | Q
|
---|
| 4161 | "RTN","NHINVRA",55,0)
|
---|
| 4162 | ;
|
---|
| 4163 | "RTN","NHINVRA",56,0)
|
---|
| 4164 | CPT(IEN) ; -- return code^description for CPT code, or "^" if error
|
---|
| 4165 | "RTN","NHINVRA",57,0)
|
---|
| 4166 | N X0,NHX,N,I,X,Y S IEN=+$G(IEN)
|
---|
| 4167 | "RTN","NHINVRA",58,0)
|
---|
| 4168 | S X0=$$CPT^ICPTCOD(IEN) I X0<0 Q "^"
|
---|
| 4169 | "RTN","NHINVRA",59,0)
|
---|
| 4170 | S Y=$P(X0,U,2,3) ;CPT Code^Short Name
|
---|
| 4171 | "RTN","NHINVRA",60,0)
|
---|
| 4172 | S N=$$CPTD^ICPTCOD($P(Y,U),"NHX") ;CPT Description
|
---|
| 4173 | "RTN","NHINVRA",61,0)
|
---|
| 4174 | I N>0,$L($G(NHX(1))) D
|
---|
| 4175 | "RTN","NHINVRA",62,0)
|
---|
| 4176 | . S X=$G(NHX(1)),I=1
|
---|
| 4177 | "RTN","NHINVRA",63,0)
|
---|
| 4178 | . F S I=$O(NHX(I)) Q:I<1 Q:NHX(I)=" " S X=X_" "_NHX(I)
|
---|
| 4179 | "RTN","NHINVRA",64,0)
|
---|
| 4180 | . S $P(Y,U,2)=X
|
---|
| 4181 | "RTN","NHINVRA",65,0)
|
---|
| 4182 | Q Y
|
---|
| 4183 | "RTN","NHINVRA",66,0)
|
---|
| 4184 | ;
|
---|
| 4185 | "RTN","NHINVRA",67,0)
|
---|
| 4186 | RPT(DFN,ID,RPT) ; -- return report as a TIU document
|
---|
| 4187 | "RTN","NHINVRA",68,0)
|
---|
| 4188 | S DFN=+$G(DFN),ID=$G(ID) Q:DFN<1 Q:ID<1
|
---|
| 4189 | "RTN","NHINVRA",69,0)
|
---|
| 4190 | N EXAM,CASE,PROC,X0,I,X,Y,IENS
|
---|
| 4191 | "RTN","NHINVRA",70,0)
|
---|
| 4192 | S EXAM=DFN_U_$TR(ID,"-","^") D
|
---|
| 4193 | "RTN","NHINVRA",71,0)
|
---|
| 4194 | . N DFN D EN3^RAO7PC3(EXAM)
|
---|
| 4195 | "RTN","NHINVRA",72,0)
|
---|
| 4196 | S CASE=$O(^TMP($J,"RAE3",DFN,0)),PROC=$O(^(CASE,"")),X0=$G(^(PROC))
|
---|
| 4197 | "RTN","NHINVRA",73,0)
|
---|
| 4198 | S I=$O(^TMP($J,"RAE3",DFN,CASE,PROC,0)),Y=$G(^(I))
|
---|
| 4199 | "RTN","NHINVRA",74,0)
|
---|
| 4200 | F S I=$O(^TMP($J,"RAE3",DFN,CASE,PROC,I)) Q:I<1 S X=^(I),Y=Y_$C(13,10)_X
|
---|
| 4201 | "RTN","NHINVRA",75,0)
|
---|
| 4202 | S RPT("id")=ID,RPT("content")=Y
|
---|
| 4203 | "RTN","NHINVRA",76,0)
|
---|
| 4204 | S X=9999999.9999-(+ID),RPT("referenceDateTime")=X
|
---|
| 4205 | "RTN","NHINVRA",77,0)
|
---|
| 4206 | S RPT("localTitle")=PROC,RPT("status")=$P(X0,U)
|
---|
| 4207 | "RTN","NHINVRA",78,0)
|
---|
| 4208 | S IENS=+ID_","_DFN_",",X=$$GET1^DIQ(70.02,IENS,4,"I")
|
---|
| 4209 | "RTN","NHINVRA",79,0)
|
---|
| 4210 | S RPT("facility")=$$FAC^NHINV(X)
|
---|
| 4211 | "RTN","NHINVRA",80,0)
|
---|
| 4212 | S IENS=$P(ID,"-",2)_","_IENS
|
---|
| 4213 | "RTN","NHINVRA",81,0)
|
---|
| 4214 | S RPT("encounter")=$$GET1^DIQ(70.03,IENS,27,"I")
|
---|
| 4215 | "RTN","NHINVRA",82,0)
|
---|
| 4216 | S X=$$GET1^DIQ(70.03,IENS,15,"I") S:'X X=$$GET1^DIQ(70.03,IENS,12,"I")
|
---|
| 4217 | "RTN","NHINVRA",83,0)
|
---|
| 4218 | I X S RPT("clinician",1)=X_U_$P($G(^VA(200,X,0)),U)
|
---|
| 4219 | "RTN","NHINVRA",84,0)
|
---|
| 4220 | K ^TMP($J,"RAE3",DFN)
|
---|
| 4221 | "RTN","NHINVRA",85,0)
|
---|
| 4222 | Q
|
---|
| 4223 | "RTN","NHINVRA",86,0)
|
---|
| 4224 | ;
|
---|
| 4225 | "RTN","NHINVRA",87,0)
|
---|
| 4226 | ; ------------ Return data to middle tier ------------
|
---|
| 4227 | "RTN","NHINVRA",88,0)
|
---|
| 4228 | ;
|
---|
| 4229 | "RTN","NHINVRA",89,0)
|
---|
| 4230 | XML(EXM) ; -- Return exams as XML
|
---|
| 4231 | "RTN","NHINVRA",90,0)
|
---|
| 4232 | N ATT,X,Y,NAMES
|
---|
| 4233 | "RTN","NHINVRA",91,0)
|
---|
| 4234 | D ADD("<radiology>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 4235 | "RTN","NHINVRA",92,0)
|
---|
| 4236 | S ATT="" F S ATT=$O(EXM(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 4237 | "RTN","NHINVRA",93,0)
|
---|
| 4238 | . S NAMES=$S(ATT="document":"id^localTitle^nationalTitle^status^Z",1:"code^name^Z")
|
---|
| 4239 | "RTN","NHINVRA",94,0)
|
---|
| 4240 | . I $O(EXM(ATT,0)) D S Y="" Q ;multiples
|
---|
| 4241 | "RTN","NHINVRA",95,0)
|
---|
| 4242 | .. D ADD("<"_ATT_"s>")
|
---|
| 4243 | "RTN","NHINVRA",96,0)
|
---|
| 4244 | .. S I=0 F S I=$O(EXM(ATT,I)) Q:I<1 D
|
---|
| 4245 | "RTN","NHINVRA",97,0)
|
---|
| 4246 | ... S X=$G(EXM(ATT,I))
|
---|
| 4247 | "RTN","NHINVRA",98,0)
|
---|
| 4248 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 4249 | "RTN","NHINVRA",99,0)
|
---|
| 4250 | .. D ADD("</"_ATT_"s>")
|
---|
| 4251 | "RTN","NHINVRA",100,0)
|
---|
| 4252 | . S X=$G(EXM(ATT)),Y="" Q:'$L(X)
|
---|
| 4253 | "RTN","NHINVRA",101,0)
|
---|
| 4254 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 4255 | "RTN","NHINVRA",102,0)
|
---|
| 4256 | . I $L(X)>1 S Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 4257 | "RTN","NHINVRA",103,0)
|
---|
| 4258 | D ADD("</radiology>")
|
---|
| 4259 | "RTN","NHINVRA",104,0)
|
---|
| 4260 | Q
|
---|
| 4261 | "RTN","NHINVRA",105,0)
|
---|
| 4262 | ;
|
---|
| 4263 | "RTN","NHINVRA",106,0)
|
---|
| 4264 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 4265 | "RTN","NHINVRA",107,0)
|
---|
| 4266 | N STR,P,TAG S STR=""
|
---|
| 4267 | "RTN","NHINVRA",108,0)
|
---|
| 4268 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 4269 | "RTN","NHINVRA",109,0)
|
---|
| 4270 | Q STR
|
---|
| 4271 | "RTN","NHINVRA",110,0)
|
---|
| 4272 | ;
|
---|
| 4273 | "RTN","NHINVRA",111,0)
|
---|
| 4274 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 4275 | "RTN","NHINVRA",112,0)
|
---|
| 4276 | S NHINI=$G(NHINI)+1
|
---|
| 4277 | "RTN","NHINVRA",113,0)
|
---|
| 4278 | S @NHIN@(NHINI)=X
|
---|
| 4279 | "RTN","NHINVRA",114,0)
|
---|
| 4280 | Q
|
---|
| 4281 | "RTN","NHINVSIT")
|
---|
| 4282 | 0^15^B60599762^n/a
|
---|
| 4283 | "RTN","NHINVSIT",1,0)
|
---|
| 4284 | NHINVSIT ;SLC/MKB -- Visit/Encounter extract
|
---|
| 4285 | "RTN","NHINVSIT",2,0)
|
---|
| 4286 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 4287 | "RTN","NHINVSIT",3,0)
|
---|
| 4288 | ;
|
---|
| 4289 | "RTN","NHINVSIT",4,0)
|
---|
| 4290 | ; External References DBIA#
|
---|
| 4291 | "RTN","NHINVSIT",5,0)
|
---|
| 4292 | ; ------------------- -----
|
---|
| 4293 | "RTN","NHINVSIT",6,0)
|
---|
| 4294 | ; ^AUPNVSIT 2028
|
---|
| 4295 | "RTN","NHINVSIT",7,0)
|
---|
| 4296 | ; ^DIC(40.7 557
|
---|
| 4297 | "RTN","NHINVSIT",8,0)
|
---|
| 4298 | ; ^DIC(42 10039
|
---|
| 4299 | "RTN","NHINVSIT",9,0)
|
---|
| 4300 | ; ^SC 10040
|
---|
| 4301 | "RTN","NHINVSIT",10,0)
|
---|
| 4302 | ; ^SCE 2065
|
---|
| 4303 | "RTN","NHINVSIT",11,0)
|
---|
| 4304 | ; ^VA(200 10060
|
---|
| 4305 | "RTN","NHINVSIT",12,0)
|
---|
| 4306 | ; DIC 2051
|
---|
| 4307 | "RTN","NHINVSIT",13,0)
|
---|
| 4308 | ; DIQ 2056
|
---|
| 4309 | "RTN","NHINVSIT",14,0)
|
---|
| 4310 | ; ICDCODE 3990
|
---|
| 4311 | "RTN","NHINVSIT",15,0)
|
---|
| 4312 | ; ICPTCOD 1995
|
---|
| 4313 | "RTN","NHINVSIT",16,0)
|
---|
| 4314 | ; PXAPI,^TMP("PXKENC",$J 1894,1895
|
---|
| 4315 | "RTN","NHINVSIT",17,0)
|
---|
| 4316 | ; VADPT 10061
|
---|
| 4317 | "RTN","NHINVSIT",18,0)
|
---|
| 4318 | ; XUAF4 2171
|
---|
| 4319 | "RTN","NHINVSIT",19,0)
|
---|
| 4320 | ;
|
---|
| 4321 | "RTN","NHINVSIT",20,0)
|
---|
| 4322 | ; ------------ Get encounter(s) from VistA ------------
|
---|
| 4323 | "RTN","NHINVSIT",21,0)
|
---|
| 4324 | ;
|
---|
| 4325 | "RTN","NHINVSIT",22,0)
|
---|
| 4326 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's visits and appointments
|
---|
| 4327 | "RTN","NHINVSIT",23,0)
|
---|
| 4328 | N NHICNT,NHITM,NHDT,NHLOC,NHDA
|
---|
| 4329 | "RTN","NHINVSIT",24,0)
|
---|
| 4330 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 4331 | "RTN","NHINVSIT",25,0)
|
---|
| 4332 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 4333 | "RTN","NHINVSIT",26,0)
|
---|
| 4334 | ;
|
---|
| 4335 | "RTN","NHINVSIT",27,0)
|
---|
| 4336 | ; get one visit
|
---|
| 4337 | "RTN","NHINVSIT",28,0)
|
---|
| 4338 | I $G(ID) D EN1(ID,.NHITM),XML(.NHITM) Q
|
---|
| 4339 | "RTN","NHINVSIT",29,0)
|
---|
| 4340 | ;
|
---|
| 4341 | "RTN","NHINVSIT",30,0)
|
---|
| 4342 | ; -- get all visits
|
---|
| 4343 | "RTN","NHINVSIT",31,0)
|
---|
| 4344 | I END,END'["." S END=END_".24" ;assume end of day
|
---|
| 4345 | "RTN","NHINVSIT",32,0)
|
---|
| 4346 | S NHICNT=0
|
---|
| 4347 | "RTN","NHINVSIT",33,0)
|
---|
| 4348 | ;F S IDX=$Q(@IDX,-1) Q:DFN'=$P(IDX,",",2) Q:$P(IDX,",",3)<BEG I $P(IDX,",",5)["P" D
|
---|
| 4349 | "RTN","NHINVSIT",34,0)
|
---|
| 4350 | S NHDT=END F S NHDT=$O(^AUPNVSIT("AET",DFN,NHDT),-1) Q:NHDT<BEG D Q:NHICNT'<MAX
|
---|
| 4351 | "RTN","NHINVSIT",35,0)
|
---|
| 4352 | . S NHLOC=0 F S NHLOC=$O(^AUPNVSIT("AET",DFN,NHDT,NHLOC)) Q:NHLOC<1 D
|
---|
| 4353 | "RTN","NHINVSIT",36,0)
|
---|
| 4354 | .. S NHDA=0 F S NHDA=$O(^AUPNVSIT("AET",DFN,NHDT,NHLOC,"P",NHDA)) Q:NHDA<1 D
|
---|
| 4355 | "RTN","NHINVSIT",37,0)
|
---|
| 4356 | ... K NHITM D EN1(NHDA,.NHITM) Q:'$D(NHITM)
|
---|
| 4357 | "RTN","NHINVSIT",38,0)
|
---|
| 4358 | ... D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 4359 | "RTN","NHINVSIT",39,0)
|
---|
| 4360 | Q
|
---|
| 4361 | "RTN","NHINVSIT",40,0)
|
---|
| 4362 | ;
|
---|
| 4363 | "RTN","NHINVSIT",41,0)
|
---|
| 4364 | ENAA(DFN,BEG,END,MAX,ID) ; -- find patient's visits and appointments [AA]
|
---|
| 4365 | "RTN","NHINVSIT",42,0)
|
---|
| 4366 | N IDT,DA,NHICNT,NHITM
|
---|
| 4367 | "RTN","NHINVSIT",43,0)
|
---|
| 4368 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 4369 | "RTN","NHINVSIT",44,0)
|
---|
| 4370 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 4371 | "RTN","NHINVSIT",45,0)
|
---|
| 4372 | I $G(ID) D EN1(ID,.NHITM),XML(.NHITM) Q ;one visit
|
---|
| 4373 | "RTN","NHINVSIT",46,0)
|
---|
| 4374 | D IDT S NHICNT=0
|
---|
| 4375 | "RTN","NHINVSIT",47,0)
|
---|
| 4376 | S IDT=BEG F S IDT=$O(^AUPNVSIT("AA",DFN,IDT)) Q:IDT<1!(IDT>END) D Q:NHICNT'<MAX
|
---|
| 4377 | "RTN","NHINVSIT",48,0)
|
---|
| 4378 | . S DA=0 F S DA=$O(^AUPNVSIT("AA",DFN,IDT,DA)) Q:DA<1 D
|
---|
| 4379 | "RTN","NHINVSIT",49,0)
|
---|
| 4380 | .. K NHITM D EN1(DA,.NHITM) Q:'$D(NHITM)
|
---|
| 4381 | "RTN","NHINVSIT",50,0)
|
---|
| 4382 | .. D XML(.NHITM) S NHICNT=NHICNT+1
|
---|
| 4383 | "RTN","NHINVSIT",51,0)
|
---|
| 4384 | Q
|
---|
| 4385 | "RTN","NHINVSIT",52,0)
|
---|
| 4386 | IDT ; -- invert BEG and END dates for visit format:
|
---|
| 4387 | "RTN","NHINVSIT",53,0)
|
---|
| 4388 | ; IDT=(9999999-$P(VDT,"."))_"."_$P(VDT,".",2)
|
---|
| 4389 | "RTN","NHINVSIT",54,0)
|
---|
| 4390 | N X S X=BEG
|
---|
| 4391 | "RTN","NHINVSIT",55,0)
|
---|
| 4392 | S BEG=(9999999-$P(END,"."))
|
---|
| 4393 | "RTN","NHINVSIT",56,0)
|
---|
| 4394 | S END=(9999999-$P(X,"."))_".2359"
|
---|
| 4395 | "RTN","NHINVSIT",57,0)
|
---|
| 4396 | Q
|
---|
| 4397 | "RTN","NHINVSIT",58,0)
|
---|
| 4398 | ;
|
---|
| 4399 | "RTN","NHINVSIT",59,0)
|
---|
| 4400 | EN1(IEN,VST) ; -- return a visit in VST("attribute")=value
|
---|
| 4401 | "RTN","NHINVSIT",60,0)
|
---|
| 4402 | N X0,X15,X,FAC,LOC,CATG,INPT,DA
|
---|
| 4403 | "RTN","NHINVSIT",61,0)
|
---|
| 4404 | S IEN=+$G(IEN) Q:IEN<1 ;invalid ien
|
---|
| 4405 | "RTN","NHINVSIT",62,0)
|
---|
| 4406 | D ENCEVENT^PXAPI(IEN)
|
---|
| 4407 | "RTN","NHINVSIT",63,0)
|
---|
| 4408 | S X0=$G(^TMP("PXKENC",$J,IEN,"VST",IEN,0)),X15=$G(^(150))
|
---|
| 4409 | "RTN","NHINVSIT",64,0)
|
---|
| 4410 | Q:$P(X15,U,3)'="P" Q:$P(X0,U,7)="E" ;want primary, not historical
|
---|
| 4411 | "RTN","NHINVSIT",65,0)
|
---|
| 4412 | I $P(X0,U,7)="H" D ADM(IEN,+X0,.VST) Q
|
---|
| 4413 | "RTN","NHINVSIT",66,0)
|
---|
| 4414 | S VST("id")=IEN,VST("dateTime")=+X0
|
---|
| 4415 | "RTN","NHINVSIT",67,0)
|
---|
| 4416 | S FAC=+$P(X0,U,6),CATG=$P(X0,U,7),LOC=+$P(X0,U,22)
|
---|
| 4417 | "RTN","NHINVSIT",68,0)
|
---|
| 4418 | S:FAC VST("facility")=$$STA^XUAF4(FAC)_U_$P($$NS^XUAF4(FAC),U)
|
---|
| 4419 | "RTN","NHINVSIT",69,0)
|
---|
| 4420 | S VST("serviceCategory")=CATG_U_$$CATG(CATG)
|
---|
| 4421 | "RTN","NHINVSIT",70,0)
|
---|
| 4422 | S VST("visitString")=LOC_";"_+X0_";"_CATG
|
---|
| 4423 | "RTN","NHINVSIT",71,0)
|
---|
| 4424 | S INPT=$P(X15,U,2) S:INPT="" INPT=$S("H^I^R^D"[CATG:1,1:0)
|
---|
| 4425 | "RTN","NHINVSIT",72,0)
|
---|
| 4426 | S X=$$CPT(IEN) S:X VST("type")=$P($$CPT^ICPTCOD(X),U,2,3)
|
---|
| 4427 | "RTN","NHINVSIT",73,0)
|
---|
| 4428 | I 'X S VST("type")=U_$S('INPT&LOC:$P($G(^SC(LOC,0)),U)_" VISIT",1:$$CATG(CATG))
|
---|
| 4429 | "RTN","NHINVSIT",74,0)
|
---|
| 4430 | S VST("patientClass")=$S(INPT:"IMP",1:"AMB")
|
---|
| 4431 | "RTN","NHINVSIT",75,0)
|
---|
| 4432 | S X=$P(X0,U,8) S:X VST("stopCode")=$$AMIS(X) I LOC D
|
---|
| 4433 | "RTN","NHINVSIT",76,0)
|
---|
| 4434 | . N L0 S L0=$G(^SC(LOC,0))
|
---|
| 4435 | "RTN","NHINVSIT",77,0)
|
---|
| 4436 | . I 'X S VST("stopCode")=$$AMIS($P(L0,U,7))
|
---|
| 4437 | "RTN","NHINVSIT",78,0)
|
---|
| 4438 | . S VST("location")=$P(L0,U),VST("service")=$$SERV($P(L0,U,20))
|
---|
| 4439 | "RTN","NHINVSIT",79,0)
|
---|
| 4440 | . S X=$P(L0,U,18) S:X VST("creditStopCode")=$$AMIS(X)
|
---|
| 4441 | "RTN","NHINVSIT",80,0)
|
---|
| 4442 | . S:'FAC VST("facility")=$$FAC^NHINV(LOC)
|
---|
| 4443 | "RTN","NHINVSIT",81,0)
|
---|
| 4444 | S VST("reason")=$$POV(IEN)
|
---|
| 4445 | "RTN","NHINVSIT",82,0)
|
---|
| 4446 | ; provider(s)
|
---|
| 4447 | "RTN","NHINVSIT",83,0)
|
---|
| 4448 | S DA=0 F S DA=$O(^TMP("PXKENC",$J,IEN,"PRV",DA)) Q:DA<1 S X0=$G(^(DA,0)) D
|
---|
| 4449 | "RTN","NHINVSIT",84,0)
|
---|
| 4450 | . S VST("provider",DA)=+X0_U_$P($G(^VA(200,+X0,0)),U)_$S($P(X0,U,4)="P":"^P^1",1:"^S^")
|
---|
| 4451 | "RTN","NHINVSIT",85,0)
|
---|
| 4452 | ; note(s)
|
---|
| 4453 | "RTN","NHINVSIT",86,0)
|
---|
| 4454 | D TIU(IEN)
|
---|
| 4455 | "RTN","NHINVSIT",87,0)
|
---|
| 4456 | K ^TMP("PXKENC",$J,IEN)
|
---|
| 4457 | "RTN","NHINVSIT",88,0)
|
---|
| 4458 | Q
|
---|
| 4459 | "RTN","NHINVSIT",89,0)
|
---|
| 4460 | ;
|
---|
| 4461 | "RTN","NHINVSIT",90,0)
|
---|
| 4462 | TIU(VISIT) ; -- add notes to VST("document")
|
---|
| 4463 | "RTN","NHINVSIT",91,0)
|
---|
| 4464 | N X,Y,I,NHIN,LT,NT,DA,CNT
|
---|
| 4465 | "RTN","NHINVSIT",92,0)
|
---|
| 4466 | D FIND^DIC(8925,,.01,"QX",+$G(VISIT),,"V",,,"NHIN")
|
---|
| 4467 | "RTN","NHINVSIT",93,0)
|
---|
| 4468 | S Y="",(I,CNT)=0
|
---|
| 4469 | "RTN","NHINVSIT",94,0)
|
---|
| 4470 | F S I=$O(NHIN("DILIST",1,I)) Q:I<1 D
|
---|
| 4471 | "RTN","NHINVSIT",95,0)
|
---|
| 4472 | . S LT=$G(NHIN("DILIST","ID",I,.01)) Q:$P(LT," ")="Addendum"
|
---|
| 4473 | "RTN","NHINVSIT",96,0)
|
---|
| 4474 | . S DA=$G(NHIN("DILIST",2,I))
|
---|
| 4475 | "RTN","NHINVSIT",97,0)
|
---|
| 4476 | . S NT=$$GET1^DIQ(8925,+DA_",",".01:1501")
|
---|
| 4477 | "RTN","NHINVSIT",98,0)
|
---|
| 4478 | . S CNT=CNT+1,VST("document",CNT)=DA_U_LT_U_NT
|
---|
| 4479 | "RTN","NHINVSIT",99,0)
|
---|
| 4480 | Q
|
---|
| 4481 | "RTN","NHINVSIT",100,0)
|
---|
| 4482 | ;
|
---|
| 4483 | "RTN","NHINVSIT",101,0)
|
---|
| 4484 | POV(VISIT) ; -- return the primary Purpose of Visit as ICD^ProviderNarrative
|
---|
| 4485 | "RTN","NHINVSIT",102,0)
|
---|
| 4486 | N DA,Y,X,X0,ICD S Y=""
|
---|
| 4487 | "RTN","NHINVSIT",103,0)
|
---|
| 4488 | S DA=0 F S DA=$O(^TMP("PXKENC",$J,VISIT,"POV",DA)) Q:DA<1 S X0=$G(^(DA,0)) I $P(X0,U,12)="P" D Q:$L(Y)
|
---|
| 4489 | "RTN","NHINVSIT",104,0)
|
---|
| 4490 | . S X=+$P(X0,U,4),ICD=$$ICD(+X0)
|
---|
| 4491 | "RTN","NHINVSIT",105,0)
|
---|
| 4492 | . S Y=ICD_U_$$GET1^DIQ(9999999.27,X_",",.01)
|
---|
| 4493 | "RTN","NHINVSIT",106,0)
|
---|
| 4494 | Q Y
|
---|
| 4495 | "RTN","NHINVSIT",107,0)
|
---|
| 4496 | ;
|
---|
| 4497 | "RTN","NHINVSIT",108,0)
|
---|
| 4498 | ICD(IEN) ; -- return code^description for ICD code, or "^" if error
|
---|
| 4499 | "RTN","NHINVSIT",109,0)
|
---|
| 4500 | N X0,NHX,N,I,X,Y S IEN=+$G(IEN)
|
---|
| 4501 | "RTN","NHINVSIT",110,0)
|
---|
| 4502 | S X0=$$ICDDX^ICDCODE(IEN) I X0<0 Q "^"
|
---|
| 4503 | "RTN","NHINVSIT",111,0)
|
---|
| 4504 | S Y=$P(X0,U,2)_U_$P(X0,U,4) ;ICD Code^Dx name
|
---|
| 4505 | "RTN","NHINVSIT",112,0)
|
---|
| 4506 | S N=$$ICDD^ICDCODE($P(Y,U),"NHX") ;ICD Description
|
---|
| 4507 | "RTN","NHINVSIT",113,0)
|
---|
| 4508 | I N>0,$L($G(NHX(1))) S $P(Y,U,2)=NHX(1)
|
---|
| 4509 | "RTN","NHINVSIT",114,0)
|
---|
| 4510 | Q Y
|
---|
| 4511 | "RTN","NHINVSIT",115,0)
|
---|
| 4512 | ;
|
---|
| 4513 | "RTN","NHINVSIT",116,0)
|
---|
| 4514 | CPT(VISIT) ; -- Return CPT code of encounter type
|
---|
| 4515 | "RTN","NHINVSIT",117,0)
|
---|
| 4516 | N DA,Y,X,X0 S Y=""
|
---|
| 4517 | "RTN","NHINVSIT",118,0)
|
---|
| 4518 | S DA=0 F S DA=$O(^TMP("PXKENC",$J,VISIT,"CPT",DA)) Q:DA<1 S X0=$G(^(DA,0)) D Q:$L(Y)
|
---|
| 4519 | "RTN","NHINVSIT",119,0)
|
---|
| 4520 | . S X=$P(X0,U) I X?1"992"2N S Y=X Q
|
---|
| 4521 | "RTN","NHINVSIT",120,0)
|
---|
| 4522 | Q Y
|
---|
| 4523 | "RTN","NHINVSIT",121,0)
|
---|
| 4524 | ;
|
---|
| 4525 | "RTN","NHINVSIT",122,0)
|
---|
| 4526 | AMIS(X) ; -- return the AMIS code^name of Credit Stop X
|
---|
| 4527 | "RTN","NHINVSIT",123,0)
|
---|
| 4528 | N Y S Y=""
|
---|
| 4529 | "RTN","NHINVSIT",124,0)
|
---|
| 4530 | S X0=$G(^DIC(40.7,+$G(X),0)) S:$L(X0) Y=$P(X0,U,2)_U_$P(X0,U)
|
---|
| 4531 | "RTN","NHINVSIT",125,0)
|
---|
| 4532 | Q Y
|
---|
| 4533 | "RTN","NHINVSIT",126,0)
|
---|
| 4534 | ;
|
---|
| 4535 | "RTN","NHINVSIT",127,0)
|
---|
| 4536 | CATG(X) ; -- Return name of visit Service Category code X
|
---|
| 4537 | "RTN","NHINVSIT",128,0)
|
---|
| 4538 | N Y S Y=""
|
---|
| 4539 | "RTN","NHINVSIT",129,0)
|
---|
| 4540 | I X="A" S Y="AMBULATORY"
|
---|
| 4541 | "RTN","NHINVSIT",130,0)
|
---|
| 4542 | I X="H" S Y="HOSPITALIZATION"
|
---|
| 4543 | "RTN","NHINVSIT",131,0)
|
---|
| 4544 | I X="I" S Y="IN HOSPITAL"
|
---|
| 4545 | "RTN","NHINVSIT",132,0)
|
---|
| 4546 | I X="C" S Y="CHART REVIEW"
|
---|
| 4547 | "RTN","NHINVSIT",133,0)
|
---|
| 4548 | I X="T" S Y="TELECOMMUNICATIONS"
|
---|
| 4549 | "RTN","NHINVSIT",134,0)
|
---|
| 4550 | I X="N" S Y="NOT FOUND"
|
---|
| 4551 | "RTN","NHINVSIT",135,0)
|
---|
| 4552 | I X="S" S Y="DAY SURGERY"
|
---|
| 4553 | "RTN","NHINVSIT",136,0)
|
---|
| 4554 | I X="O" S Y="OBSERVATION"
|
---|
| 4555 | "RTN","NHINVSIT",137,0)
|
---|
| 4556 | I X="E" S Y="EVENT (HISTORICAL)"
|
---|
| 4557 | "RTN","NHINVSIT",138,0)
|
---|
| 4558 | I X="R" S Y="NURSING HOME"
|
---|
| 4559 | "RTN","NHINVSIT",139,0)
|
---|
| 4560 | I X="D" S Y="DAILY HOSPITALIZATION DATA"
|
---|
| 4561 | "RTN","NHINVSIT",140,0)
|
---|
| 4562 | I X="X" S Y="ANCILLARY PACKAGE DAILY DATA"
|
---|
| 4563 | "RTN","NHINVSIT",141,0)
|
---|
| 4564 | Q Y
|
---|
| 4565 | "RTN","NHINVSIT",142,0)
|
---|
| 4566 | ;
|
---|
| 4567 | "RTN","NHINVSIT",143,0)
|
---|
| 4568 | SERV(FTS) ; -- Return #42.4 Service for a Facility Treating Specialty
|
---|
| 4569 | "RTN","NHINVSIT",144,0)
|
---|
| 4570 | N Y S Y="",FTS=+$G(FTS)
|
---|
| 4571 | "RTN","NHINVSIT",145,0)
|
---|
| 4572 | S Y=$$GET1^DIQ(45.7,FTS_",","1:3","E")
|
---|
| 4573 | "RTN","NHINVSIT",146,0)
|
---|
| 4574 | Q Y
|
---|
| 4575 | "RTN","NHINVSIT",147,0)
|
---|
| 4576 | ;
|
---|
| 4577 | "RTN","NHINVSIT",148,0)
|
---|
| 4578 | ADM(IEN,DATE,ADM) ; -- return an admission in ADM("attribute")=value
|
---|
| 4579 | "RTN","NHINVSIT",149,0)
|
---|
| 4580 | N VAIP,VAERR,HLOC,ICD,I K ADM
|
---|
| 4581 | "RTN","NHINVSIT",150,0)
|
---|
| 4582 | S IEN=+$G(IEN),DATE=+$G(DATE) Q:IEN<1 Q:DATE<1 ;invalid
|
---|
| 4583 | "RTN","NHINVSIT",151,0)
|
---|
| 4584 | S VAIP("D")=DATE D IN5^VADPT Q:'$G(VAIP(1)) ;deleted
|
---|
| 4585 | "RTN","NHINVSIT",152,0)
|
---|
| 4586 | S ADM("id")=IEN,ADM("patientClass")="IMP"
|
---|
| 4587 | "RTN","NHINVSIT",153,0)
|
---|
| 4588 | ; ADM("admitType")=$P($G(VAIP(4)),U,2)
|
---|
| 4589 | "RTN","NHINVSIT",154,0)
|
---|
| 4590 | S DATE=+$G(VAIP(3)),(ADM("dateTime"),ADM("arrivalDateTime"))=DATE,I=0
|
---|
| 4591 | "RTN","NHINVSIT",155,0)
|
---|
| 4592 | S:$G(VAIP(7)) I=I+1,ADM("provider",I)=VAIP(7)_"^P^1" ;primary
|
---|
| 4593 | "RTN","NHINVSIT",156,0)
|
---|
| 4594 | S:$G(VAIP(18)) I=I+1,ADM("provider",I)=VAIP(18)_"^A" ;attending
|
---|
| 4595 | "RTN","NHINVSIT",157,0)
|
---|
| 4596 | S ADM("specialty")=$P($G(VAIP(8)),U,2)
|
---|
| 4597 | "RTN","NHINVSIT",158,0)
|
---|
| 4598 | S X=$$SERV(+$G(VAIP(8))),ADM("service")=X
|
---|
| 4599 | "RTN","NHINVSIT",159,0)
|
---|
| 4600 | S X=$$POV(IEN) S:X ADM("reason")=X_U_$G(VAIP(9)) I 'X D
|
---|
| 4601 | "RTN","NHINVSIT",160,0)
|
---|
| 4602 | . S X=$$GET1^DIQ(405,+VAIP(1)_",",".16:79","I") ;Mvt>PTF>ICD ien
|
---|
| 4603 | "RTN","NHINVSIT",161,0)
|
---|
| 4604 | . I 'X S ADM("reason")=U_U_$G(VAIP(9)) Q ;Dx text
|
---|
| 4605 | "RTN","NHINVSIT",162,0)
|
---|
| 4606 | . S ICD=$$ICD(X),ADM("reason")=ICD_U_$G(VAIP(9))
|
---|
| 4607 | "RTN","NHINVSIT",163,0)
|
---|
| 4608 | S HLOC=+$G(^DIC(42,+$G(VAIP(5)),44))
|
---|
| 4609 | "RTN","NHINVSIT",164,0)
|
---|
| 4610 | S:HLOC ADM("location")=$P($G(^SC(HLOC,0)),U)
|
---|
| 4611 | "RTN","NHINVSIT",165,0)
|
---|
| 4612 | S ADM("facility")=$$FAC^NHINV(+HLOC),ADM("roomBed")=$P(VAIP(6),U,2)
|
---|
| 4613 | "RTN","NHINVSIT",166,0)
|
---|
| 4614 | S ADM("serviceCategory")="H^HOSPITALIZATION"
|
---|
| 4615 | "RTN","NHINVSIT",167,0)
|
---|
| 4616 | S X=$$CPT(IEN),ADM("type")=$S(X:$P($$CPT^ICPTCOD(X),U,2,3),1:U_$$CATG("H"))
|
---|
| 4617 | "RTN","NHINVSIT",168,0)
|
---|
| 4618 | I $G(VAIP(17)) D
|
---|
| 4619 | "RTN","NHINVSIT",169,0)
|
---|
| 4620 | . S ADM("departureDateTime")=+$G(VAIP(17,1))
|
---|
| 4621 | "RTN","NHINVSIT",170,0)
|
---|
| 4622 | . ; ADM("disposition")=$G(VAIP(17,3)) ;Discharge Mvt Type
|
---|
| 4623 | "RTN","NHINVSIT",171,0)
|
---|
| 4624 | S ADM("visitString")=HLOC_";"_DATE_";H"
|
---|
| 4625 | "RTN","NHINVSIT",172,0)
|
---|
| 4626 | Q
|
---|
| 4627 | "RTN","NHINVSIT",173,0)
|
---|
| 4628 | ;
|
---|
| 4629 | "RTN","NHINVSIT",174,0)
|
---|
| 4630 | ENC(IEN,ENC) ; -- return an encounter in ENC("attribute")=value
|
---|
| 4631 | "RTN","NHINVSIT",175,0)
|
---|
| 4632 | N X0,DATE,HLOC,TYPE,STS,X,Y K ENC
|
---|
| 4633 | "RTN","NHINVSIT",176,0)
|
---|
| 4634 | S IEN=+$G(IEN) Q:IEN<1 ;invalid ien
|
---|
| 4635 | "RTN","NHINVSIT",177,0)
|
---|
| 4636 | S ENC("id")="E"_IEN,X0=$G(^SCE(IEN,0))
|
---|
| 4637 | "RTN","NHINVSIT",178,0)
|
---|
| 4638 | S DATE=+X0,ENC("dateTime")=DATE
|
---|
| 4639 | "RTN","NHINVSIT",179,0)
|
---|
| 4640 | S HLOC=+$P(X0,U,4) I HLOC D
|
---|
| 4641 | "RTN","NHINVSIT",180,0)
|
---|
| 4642 | . S HLOC=HLOC_U_$P($G(^SC(HLOC,0)),U)
|
---|
| 4643 | "RTN","NHINVSIT",181,0)
|
---|
| 4644 | . S ENC("location")=$P(HLOC,U,2)
|
---|
| 4645 | "RTN","NHINVSIT",182,0)
|
---|
| 4646 | . S X=$$GET1^DIQ(44,+HLOC_",",9.5,"I")
|
---|
| 4647 | "RTN","NHINVSIT",183,0)
|
---|
| 4648 | . I X S ENC("service")=$$SERV(X)
|
---|
| 4649 | "RTN","NHINVSIT",184,0)
|
---|
| 4650 | S ENC("facility")=$$FAC^NHINV(+HLOC)
|
---|
| 4651 | "RTN","NHINVSIT",185,0)
|
---|
| 4652 | S STS=$$GET1^DIQ(409.68,IEN_",",.12,"E")
|
---|
| 4653 | "RTN","NHINVSIT",186,0)
|
---|
| 4654 | S X=$S(STS?1"INP".E:"IMP",1:"AMB"),ENC("patientClass")=X,TYPE=$E(X)
|
---|
| 4655 | "RTN","NHINVSIT",187,0)
|
---|
| 4656 | S ENC("type")=U_$S(HLOC:$P(HLOC,U,2)_" VISIT",1:$$CATG(TYPE))
|
---|
| 4657 | "RTN","NHINVSIT",188,0)
|
---|
| 4658 | S ENC("serviceCategory")=TYPE_U_$$CATG(TYPE)
|
---|
| 4659 | "RTN","NHINVSIT",189,0)
|
---|
| 4660 | S ENC("visitString")=+HLOC_";"_DATE_";"_TYPE
|
---|
| 4661 | "RTN","NHINVSIT",190,0)
|
---|
| 4662 | Q
|
---|
| 4663 | "RTN","NHINVSIT",191,0)
|
---|
| 4664 | ;
|
---|
| 4665 | "RTN","NHINVSIT",192,0)
|
---|
| 4666 | ; ------------ Return data to middle tier ------------
|
---|
| 4667 | "RTN","NHINVSIT",193,0)
|
---|
| 4668 | ;
|
---|
| 4669 | "RTN","NHINVSIT",194,0)
|
---|
| 4670 | XML(VISIT) ; -- Return patient visit as XML
|
---|
| 4671 | "RTN","NHINVSIT",195,0)
|
---|
| 4672 | N ATT,X,Y,NAMES
|
---|
| 4673 | "RTN","NHINVSIT",196,0)
|
---|
| 4674 | D ADD("<visit>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 4675 | "RTN","NHINVSIT",197,0)
|
---|
| 4676 | S ATT="" F S ATT=$O(VISIT(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 4677 | "RTN","NHINVSIT",198,0)
|
---|
| 4678 | . I $O(VISIT(ATT,0)) D S Y="" Q ;multiples
|
---|
| 4679 | "RTN","NHINVSIT",199,0)
|
---|
| 4680 | .. D ADD("<"_ATT_"s>")
|
---|
| 4681 | "RTN","NHINVSIT",200,0)
|
---|
| 4682 | .. S I=0 F S I=$O(VISIT(ATT,I)) Q:I<1 D
|
---|
| 4683 | "RTN","NHINVSIT",201,0)
|
---|
| 4684 | ... S X=$G(VISIT(ATT,I)),NAMES=""
|
---|
| 4685 | "RTN","NHINVSIT",202,0)
|
---|
| 4686 | ... I ATT="document" S NAMES="id^localTitle^nationalTitle^Z"
|
---|
| 4687 | "RTN","NHINVSIT",203,0)
|
---|
| 4688 | ... I ATT="provider" S NAMES="code^name^role^primary^Z"
|
---|
| 4689 | "RTN","NHINVSIT",204,0)
|
---|
| 4690 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 4691 | "RTN","NHINVSIT",205,0)
|
---|
| 4692 | .. D ADD("</"_ATT_"s>")
|
---|
| 4693 | "RTN","NHINVSIT",206,0)
|
---|
| 4694 | . S X=$G(VISIT(ATT)),Y="" Q:'$L(X)
|
---|
| 4695 | "RTN","NHINVSIT",207,0)
|
---|
| 4696 | . S NAMES="code^name^"_$S(ATT="reason":"narrative^",1:"")_"Z"
|
---|
| 4697 | "RTN","NHINVSIT",208,0)
|
---|
| 4698 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 4699 | "RTN","NHINVSIT",209,0)
|
---|
| 4700 | . I $L(X)>1 S Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 4701 | "RTN","NHINVSIT",210,0)
|
---|
| 4702 | D ADD("</visit>")
|
---|
| 4703 | "RTN","NHINVSIT",211,0)
|
---|
| 4704 | Q
|
---|
| 4705 | "RTN","NHINVSIT",212,0)
|
---|
| 4706 | ;
|
---|
| 4707 | "RTN","NHINVSIT",213,0)
|
---|
| 4708 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 4709 | "RTN","NHINVSIT",214,0)
|
---|
| 4710 | N STR,P,TAG S STR=""
|
---|
| 4711 | "RTN","NHINVSIT",215,0)
|
---|
| 4712 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 4713 | "RTN","NHINVSIT",216,0)
|
---|
| 4714 | Q STR
|
---|
| 4715 | "RTN","NHINVSIT",217,0)
|
---|
| 4716 | ;
|
---|
| 4717 | "RTN","NHINVSIT",218,0)
|
---|
| 4718 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 4719 | "RTN","NHINVSIT",219,0)
|
---|
| 4720 | S NHINI=$G(NHINI)+1
|
---|
| 4721 | "RTN","NHINVSIT",220,0)
|
---|
| 4722 | S @NHIN@(NHINI)=X
|
---|
| 4723 | "RTN","NHINVSIT",221,0)
|
---|
| 4724 | Q
|
---|
| 4725 | "RTN","NHINVSR")
|
---|
| 4726 | 0^12^B25931760^n/a
|
---|
| 4727 | "RTN","NHINVSR",1,0)
|
---|
| 4728 | NHINVSR ;SLC/MKB -- Surgical Procedures
|
---|
| 4729 | "RTN","NHINVSR",2,0)
|
---|
| 4730 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 4731 | "RTN","NHINVSR",3,0)
|
---|
| 4732 | ;
|
---|
| 4733 | "RTN","NHINVSR",4,0)
|
---|
| 4734 | ; External References DBIA#
|
---|
| 4735 | "RTN","NHINVSR",5,0)
|
---|
| 4736 | ; ------------------- -----
|
---|
| 4737 | "RTN","NHINVSR",6,0)
|
---|
| 4738 | ; DIQ 2056
|
---|
| 4739 | "RTN","NHINVSR",7,0)
|
---|
| 4740 | ; STATUS^GMTSROB 3969
|
---|
| 4741 | "RTN","NHINVSR",8,0)
|
---|
| 4742 | ; ICPTCOD 1995
|
---|
| 4743 | "RTN","NHINVSR",9,0)
|
---|
| 4744 | ; ICPTMOD 1996
|
---|
| 4745 | "RTN","NHINVSR",10,0)
|
---|
| 4746 | ; SROESTV 3533
|
---|
| 4747 | "RTN","NHINVSR",11,0)
|
---|
| 4748 | ; TIUSRVR1 2944
|
---|
| 4749 | "RTN","NHINVSR",12,0)
|
---|
| 4750 | ;
|
---|
| 4751 | "RTN","NHINVSR",13,0)
|
---|
| 4752 | ; ------------ Get surgery(ies) from VistA ------------
|
---|
| 4753 | "RTN","NHINVSR",14,0)
|
---|
| 4754 | ;
|
---|
| 4755 | "RTN","NHINVSR",15,0)
|
---|
| 4756 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's surgeries
|
---|
| 4757 | "RTN","NHINVSR",16,0)
|
---|
| 4758 | N NHI,NHICNT,NHITM,NHY
|
---|
| 4759 | "RTN","NHINVSR",17,0)
|
---|
| 4760 | S DFN=+$G(DFN) Q:DFN<1
|
---|
| 4761 | "RTN","NHINVSR",18,0)
|
---|
| 4762 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 4763 | "RTN","NHINVSR",19,0)
|
---|
| 4764 | ;
|
---|
| 4765 | "RTN","NHINVSR",20,0)
|
---|
| 4766 | ; get one surgery
|
---|
| 4767 | "RTN","NHINVSR",21,0)
|
---|
| 4768 | I $G(ID) D EN1(ID,.NHITM),XML(.NHITM) Q
|
---|
| 4769 | "RTN","NHINVSR",22,0)
|
---|
| 4770 | ;
|
---|
| 4771 | "RTN","NHINVSR",23,0)
|
---|
| 4772 | ; get all surgeries
|
---|
| 4773 | "RTN","NHINVSR",24,0)
|
---|
| 4774 | Q:'$L($T(LIST^SROESTV))
|
---|
| 4775 | "RTN","NHINVSR",25,0)
|
---|
| 4776 | N SHOWADD S SHOWADD=1 ;to omit leading '+' with note titles
|
---|
| 4777 | "RTN","NHINVSR",26,0)
|
---|
| 4778 | D LIST^SROESTV(.NHY,DFN,BEG,END,MAX,1)
|
---|
| 4779 | "RTN","NHINVSR",27,0)
|
---|
| 4780 | S NHI=0 F S NHI=$O(@NHY@(NHI)) Q:NHI<1 D
|
---|
| 4781 | "RTN","NHINVSR",28,0)
|
---|
| 4782 | . K NHITM D ONE(NHI,.NHITM)
|
---|
| 4783 | "RTN","NHINVSR",29,0)
|
---|
| 4784 | . I $D(NHITM) D XML(.NHITM)
|
---|
| 4785 | "RTN","NHINVSR",30,0)
|
---|
| 4786 | K @NHY
|
---|
| 4787 | "RTN","NHINVSR",31,0)
|
---|
| 4788 | Q
|
---|
| 4789 | "RTN","NHINVSR",32,0)
|
---|
| 4790 | ;
|
---|
| 4791 | "RTN","NHINVSR",33,0)
|
---|
| 4792 | ONE(NUM,SURG) ; -- return a surgery in SURG("attribute")=value
|
---|
| 4793 | "RTN","NHINVSR",34,0)
|
---|
| 4794 | ; Expects DFN, @NHY@(NUM) from LIST^SROESTV
|
---|
| 4795 | "RTN","NHINVSR",35,0)
|
---|
| 4796 | N IEN,NHX,X,Y,I,NHMOD,NHOTH
|
---|
| 4797 | "RTN","NHINVSR",36,0)
|
---|
| 4798 | S NHX=$G(@NHY@(NUM))
|
---|
| 4799 | "RTN","NHINVSR",37,0)
|
---|
| 4800 | S IEN=+$P(NHX,U) Q:IEN<1 K SURG
|
---|
| 4801 | "RTN","NHINVSR",38,0)
|
---|
| 4802 | S SURG("id")=IEN,SURG("name")=$P(NHX,U,2)
|
---|
| 4803 | "RTN","NHINVSR",39,0)
|
---|
| 4804 | S SURG("dateTime")=$P(NHX,U,3)
|
---|
| 4805 | "RTN","NHINVSR",40,0)
|
---|
| 4806 | S X=$P(NHX,U,4) S:X SURG("provider")=$TR(X,";","^")
|
---|
| 4807 | "RTN","NHINVSR",41,0)
|
---|
| 4808 | S SURG("status")=$$STATUS(IEN,$P(NHX,U,3))
|
---|
| 4809 | "RTN","NHINVSR",42,0)
|
---|
| 4810 | S X=$$GET1^DIQ(130,IEN_",",50,"I"),SURG("facility")=$$FAC^NHINV(X)
|
---|
| 4811 | "RTN","NHINVSR",43,0)
|
---|
| 4812 | S SURG("encounter")=$$GET1^DIQ(130,IEN_",",.015,"I")
|
---|
| 4813 | "RTN","NHINVSR",44,0)
|
---|
| 4814 | S X=$$GET1^DIQ(130,IEN_",",27,"I") I X D
|
---|
| 4815 | "RTN","NHINVSR",45,0)
|
---|
| 4816 | . S SURG("type")=$$CPT(X)
|
---|
| 4817 | "RTN","NHINVSR",46,0)
|
---|
| 4818 | . D GETS^DIQ(130,IEN_",","28*","I","NHMOD") ;CPT modifiers
|
---|
| 4819 | "RTN","NHINVSR",47,0)
|
---|
| 4820 | . S I="" F S I=$O(NHMOD(130.028,I)) Q:I="" D
|
---|
| 4821 | "RTN","NHINVSR",48,0)
|
---|
| 4822 | .. S X=+$G(NHMOD(130.028,I,.01,"I")),Y=$$MOD^ICPTMOD(X,"I")
|
---|
| 4823 | "RTN","NHINVSR",49,0)
|
---|
| 4824 | .. S SURG("modifier",+I)=$P(Y,U,2,3)
|
---|
| 4825 | "RTN","NHINVSR",50,0)
|
---|
| 4826 | D GETS^DIQ(130,IEN_",",".42*","I","NHOTH") ;other procedures
|
---|
| 4827 | "RTN","NHINVSR",51,0)
|
---|
| 4828 | S I="" F S I=$O(NHOTH(130.16,I)) Q:I="" D
|
---|
| 4829 | "RTN","NHINVSR",52,0)
|
---|
| 4830 | . S X=+$G(NHOTH(130.16,I,3,"I")) Q:'X
|
---|
| 4831 | "RTN","NHINVSR",53,0)
|
---|
| 4832 | . S SURG("otherProcedure",+I)=$$CPT(X)
|
---|
| 4833 | "RTN","NHINVSR",54,0)
|
---|
| 4834 | S I=0 F S I=$O(@NHY@(NUM,I)) Q:I<1 S X=$G(@NHY@(NUM,I)) I X D
|
---|
| 4835 | "RTN","NHINVSR",55,0)
|
---|
| 4836 | . N LT,NT S LT=$P(X,U,2) Q:$P(LT," ")="Addendum"
|
---|
| 4837 | "RTN","NHINVSR",56,0)
|
---|
| 4838 | . S NT=$$GET1^DIQ(8925,+X_",",".01:1501")
|
---|
| 4839 | "RTN","NHINVSR",57,0)
|
---|
| 4840 | . S SURG("document",I)=+X_U_LT_U_NT
|
---|
| 4841 | "RTN","NHINVSR",58,0)
|
---|
| 4842 | . I LT["OPERATION REPORT"!(LT["PROCEDURE REPORT") S SURG("opReport")=+X_U_LT_U_NT
|
---|
| 4843 | "RTN","NHINVSR",59,0)
|
---|
| 4844 | S SURG("category")="SR"
|
---|
| 4845 | "RTN","NHINVSR",60,0)
|
---|
| 4846 | Q
|
---|
| 4847 | "RTN","NHINVSR",61,0)
|
---|
| 4848 | ;
|
---|
| 4849 | "RTN","NHINVSR",62,0)
|
---|
| 4850 | EN1(IEN,SURG) ; -- return a surgery in SURG("attribute")=value
|
---|
| 4851 | "RTN","NHINVSR",63,0)
|
---|
| 4852 | N NHX,NHY,X,Y,I,NHMOD,NHOTH,SHOWADD
|
---|
| 4853 | "RTN","NHINVSR",64,0)
|
---|
| 4854 | S SHOWADD=1 ;to omit leading '+' with note titles
|
---|
| 4855 | "RTN","NHINVSR",65,0)
|
---|
| 4856 | D ONE^SROESTV("NHY",IEN) S NHX=$G(NHY(IEN)) Q:NHX=""
|
---|
| 4857 | "RTN","NHINVSR",66,0)
|
---|
| 4858 | S SURG("id")=IEN,SURG("name")=$P(NHX,U,2),SURG("dateTime")=$P(NHX,U,3)
|
---|
| 4859 | "RTN","NHINVSR",67,0)
|
---|
| 4860 | S X=$P(NHX,U,4) S:X SURG("provider")=$TR(X,";","^")
|
---|
| 4861 | "RTN","NHINVSR",68,0)
|
---|
| 4862 | S SURG("status")=$$STATUS(IEN,$P(NHX,U,3))
|
---|
| 4863 | "RTN","NHINVSR",69,0)
|
---|
| 4864 | S X=$$GET1^DIQ(130,IEN_",",50,"I"),SURG("facility")=$$FAC^NHINV(X)
|
---|
| 4865 | "RTN","NHINVSR",70,0)
|
---|
| 4866 | S SURG("encounter")=$$GET1^DIQ(130,IEN_",",.015,"I")
|
---|
| 4867 | "RTN","NHINVSR",71,0)
|
---|
| 4868 | S X=$$GET1^DIQ(130,IEN_",",27,"I") I X D
|
---|
| 4869 | "RTN","NHINVSR",72,0)
|
---|
| 4870 | . S SURG("type")=$$CPT(X)
|
---|
| 4871 | "RTN","NHINVSR",73,0)
|
---|
| 4872 | . D GETS^DIQ(130,IEN_",","28*","I","NHMOD") ;CPT modifiers
|
---|
| 4873 | "RTN","NHINVSR",74,0)
|
---|
| 4874 | . S I="" F S I=$O(NHMOD(130.028,I)) Q:I="" D
|
---|
| 4875 | "RTN","NHINVSR",75,0)
|
---|
| 4876 | .. S X=+$G(NHMOD(130.028,I,.01,"I")),Y=$$MOD^ICPTMOD(X,"I")
|
---|
| 4877 | "RTN","NHINVSR",76,0)
|
---|
| 4878 | .. S SURG("modifier",+I)=$P(Y,U,2,3)
|
---|
| 4879 | "RTN","NHINVSR",77,0)
|
---|
| 4880 | D GETS^DIQ(130,"28,",".42*","I","NHOTH") ;other procedures
|
---|
| 4881 | "RTN","NHINVSR",78,0)
|
---|
| 4882 | S I="" F S I=$O(NHOTH(130.16,I)) Q:I="" D
|
---|
| 4883 | "RTN","NHINVSR",79,0)
|
---|
| 4884 | . S X=+$G(NHOTH(130.16,I,3,"I")) Q:'X
|
---|
| 4885 | "RTN","NHINVSR",80,0)
|
---|
| 4886 | . S SURG("otherProcedure",+I)=$$CPT(X)
|
---|
| 4887 | "RTN","NHINVSR",81,0)
|
---|
| 4888 | S I=0 F S I=$O(NHY(IEN,I)) Q:I<1 S X=$G(NHY(IEN,I)) I X D
|
---|
| 4889 | "RTN","NHINVSR",82,0)
|
---|
| 4890 | . N LT,NT S LT=$P(X,U,2) Q:$P(LT," ")="Addendum"
|
---|
| 4891 | "RTN","NHINVSR",83,0)
|
---|
| 4892 | . S NT=$$GET1^DIQ(8925,+X_",",".01:1501")
|
---|
| 4893 | "RTN","NHINVSR",84,0)
|
---|
| 4894 | . S SURG("document",I)=+X_U_LT_U_NT
|
---|
| 4895 | "RTN","NHINVSR",85,0)
|
---|
| 4896 | . I LT["OPERATION REPORT"!(LT["PROCEDURE REPORT") S SURG("opReport")=+X_U_LT_U_NT
|
---|
| 4897 | "RTN","NHINVSR",86,0)
|
---|
| 4898 | S SURG("category")="SR"
|
---|
| 4899 | "RTN","NHINVSR",87,0)
|
---|
| 4900 | Q
|
---|
| 4901 | "RTN","NHINVSR",88,0)
|
---|
| 4902 | ;
|
---|
| 4903 | "RTN","NHINVSR",89,0)
|
---|
| 4904 | CPT(IEN) ; -- return code^description for CPT code, or "^" if error
|
---|
| 4905 | "RTN","NHINVSR",90,0)
|
---|
| 4906 | N X0,NHX,N,I,X,Y S IEN=+$G(IEN)
|
---|
| 4907 | "RTN","NHINVSR",91,0)
|
---|
| 4908 | S X0=$$CPT^ICPTCOD(IEN) I X0<0 Q "^"
|
---|
| 4909 | "RTN","NHINVSR",92,0)
|
---|
| 4910 | S Y=$P(X0,U,2,3) ;CPT Code^Short Name
|
---|
| 4911 | "RTN","NHINVSR",93,0)
|
---|
| 4912 | S N=$$CPTD^ICPTCOD($P(Y,U),"NHX") ;CPT Description
|
---|
| 4913 | "RTN","NHINVSR",94,0)
|
---|
| 4914 | I N>0,$L($G(NHX(1))) D
|
---|
| 4915 | "RTN","NHINVSR",95,0)
|
---|
| 4916 | . S X=$G(NHX(1)),I=1
|
---|
| 4917 | "RTN","NHINVSR",96,0)
|
---|
| 4918 | . F S I=$O(NHX(I)) Q:I<1 Q:NHX(I)=" " S X=X_" "_NHX(I)
|
---|
| 4919 | "RTN","NHINVSR",97,0)
|
---|
| 4920 | . S $P(Y,U,2)=X
|
---|
| 4921 | "RTN","NHINVSR",98,0)
|
---|
| 4922 | Q Y
|
---|
| 4923 | "RTN","NHINVSR",99,0)
|
---|
| 4924 | ;
|
---|
| 4925 | "RTN","NHINVSR",100,0)
|
---|
| 4926 | STATUS(GMN,GMDT) ; -- get current STATUS of request
|
---|
| 4927 | "RTN","NHINVSR",101,0)
|
---|
| 4928 | N STATUS S STATUS="UNKNOWN"
|
---|
| 4929 | "RTN","NHINVSR",102,0)
|
---|
| 4930 | I $G(GMN),$G(GMDT) D STATUS^GMTSROB
|
---|
| 4931 | "RTN","NHINVSR",103,0)
|
---|
| 4932 | I $E(STATUS)="(" S STATUS=$P($P(STATUS,"(",2),")")
|
---|
| 4933 | "RTN","NHINVSR",104,0)
|
---|
| 4934 | Q STATUS
|
---|
| 4935 | "RTN","NHINVSR",105,0)
|
---|
| 4936 | ;
|
---|
| 4937 | "RTN","NHINVSR",106,0)
|
---|
| 4938 | ; ------------ Return data to middle tier ------------
|
---|
| 4939 | "RTN","NHINVSR",107,0)
|
---|
| 4940 | ;
|
---|
| 4941 | "RTN","NHINVSR",108,0)
|
---|
| 4942 | XML(SURG) ; -- Return surgery as XML
|
---|
| 4943 | "RTN","NHINVSR",109,0)
|
---|
| 4944 | N ATT,X,Y,NAMES
|
---|
| 4945 | "RTN","NHINVSR",110,0)
|
---|
| 4946 | D ADD("<surgery>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 4947 | "RTN","NHINVSR",111,0)
|
---|
| 4948 | S ATT="" F S ATT=$O(SURG(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 4949 | "RTN","NHINVSR",112,0)
|
---|
| 4950 | . I $O(SURG(ATT,0)) D S Y="" Q ;multiples
|
---|
| 4951 | "RTN","NHINVSR",113,0)
|
---|
| 4952 | .. D ADD("<"_ATT_"s>")
|
---|
| 4953 | "RTN","NHINVSR",114,0)
|
---|
| 4954 | .. S I=0 F S I=$O(SURG(ATT,I)) Q:I<1 D
|
---|
| 4955 | "RTN","NHINVSR",115,0)
|
---|
| 4956 | ... S X=$G(SURG(ATT,I)),NAMES=""
|
---|
| 4957 | "RTN","NHINVSR",116,0)
|
---|
| 4958 | ... S NAMES=$S(ATT="document":"id^localTitle^nationalTitle^Z",1:"code^name^Z")
|
---|
| 4959 | "RTN","NHINVSR",117,0)
|
---|
| 4960 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 4961 | "RTN","NHINVSR",118,0)
|
---|
| 4962 | .. D ADD("</"_ATT_"s>")
|
---|
| 4963 | "RTN","NHINVSR",119,0)
|
---|
| 4964 | . S X=$G(SURG(ATT)),Y="" Q:'$L(X)
|
---|
| 4965 | "RTN","NHINVSR",120,0)
|
---|
| 4966 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 4967 | "RTN","NHINVSR",121,0)
|
---|
| 4968 | . S NAMES=$S(ATT="opReport":"id^localTitle^nationalTitle^Z",1:"code^name^Z")
|
---|
| 4969 | "RTN","NHINVSR",122,0)
|
---|
| 4970 | . I $L(X)>1 S Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 4971 | "RTN","NHINVSR",123,0)
|
---|
| 4972 | D ADD("</surgery>")
|
---|
| 4973 | "RTN","NHINVSR",124,0)
|
---|
| 4974 | Q
|
---|
| 4975 | "RTN","NHINVSR",125,0)
|
---|
| 4976 | ;
|
---|
| 4977 | "RTN","NHINVSR",126,0)
|
---|
| 4978 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 4979 | "RTN","NHINVSR",127,0)
|
---|
| 4980 | N STR,P,TAG S STR=""
|
---|
| 4981 | "RTN","NHINVSR",128,0)
|
---|
| 4982 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 4983 | "RTN","NHINVSR",129,0)
|
---|
| 4984 | Q STR
|
---|
| 4985 | "RTN","NHINVSR",130,0)
|
---|
| 4986 | ;
|
---|
| 4987 | "RTN","NHINVSR",131,0)
|
---|
| 4988 | ADD(X) ; -- Add a line @NHIN@(n)=X
|
---|
| 4989 | "RTN","NHINVSR",132,0)
|
---|
| 4990 | S NHINI=$G(NHINI)+1
|
---|
| 4991 | "RTN","NHINVSR",133,0)
|
---|
| 4992 | S @NHIN@(NHINI)=X
|
---|
| 4993 | "RTN","NHINVSR",134,0)
|
---|
| 4994 | Q
|
---|
| 4995 | "RTN","NHINVSR",135,0)
|
---|
| 4996 | ;
|
---|
| 4997 | "RTN","NHINVSR",136,0)
|
---|
| 4998 | RPT(NHY,ID) ; -- Return report in NHY(n)
|
---|
| 4999 | "RTN","NHINVSR",137,0)
|
---|
| 5000 | S ID=+$G(ID) Q:ID<1
|
---|
| 5001 | "RTN","NHINVSR",138,0)
|
---|
| 5002 | D TGET^TIUSRVR1(.NHY,ID)
|
---|
| 5003 | "RTN","NHINVSR",139,0)
|
---|
| 5004 | Q
|
---|
| 5005 | "RTN","NHINVTIU")
|
---|
| 5006 | 0^13^B18326219^n/a
|
---|
| 5007 | "RTN","NHINVTIU",1,0)
|
---|
| 5008 | NHINVTIU ;SLC/MKB -- TIU extract
|
---|
| 5009 | "RTN","NHINVTIU",2,0)
|
---|
| 5010 | ;;1.0;NHIN;**1**;Oct 25, 2010;Build 11
|
---|
| 5011 | "RTN","NHINVTIU",3,0)
|
---|
| 5012 | ;
|
---|
| 5013 | "RTN","NHINVTIU",4,0)
|
---|
| 5014 | ; External References DBIA#
|
---|
| 5015 | "RTN","NHINVTIU",5,0)
|
---|
| 5016 | ; ------------------- -----
|
---|
| 5017 | "RTN","NHINVTIU",6,0)
|
---|
| 5018 | ; ^SC( 10040
|
---|
| 5019 | "RTN","NHINVTIU",7,0)
|
---|
| 5020 | ; ^VA(200 10060
|
---|
| 5021 | "RTN","NHINVTIU",8,0)
|
---|
| 5022 | ; DIQ 2056
|
---|
| 5023 | "RTN","NHINVTIU",9,0)
|
---|
| 5024 | ; TIUSRVLO 2834,2865
|
---|
| 5025 | "RTN","NHINVTIU",10,0)
|
---|
| 5026 | ; TIUSRVR1 2944
|
---|
| 5027 | "RTN","NHINVTIU",11,0)
|
---|
| 5028 | ;
|
---|
| 5029 | "RTN","NHINVTIU",12,0)
|
---|
| 5030 | ; ------------ Get documents from VistA ------------
|
---|
| 5031 | "RTN","NHINVTIU",13,0)
|
---|
| 5032 | ;
|
---|
| 5033 | "RTN","NHINVTIU",14,0)
|
---|
| 5034 | EN(DFN,BEG,END,MAX,ID) ; -- find patient's documents
|
---|
| 5035 | "RTN","NHINVTIU",15,0)
|
---|
| 5036 | N NHITM,NHI,NHX,NHY,NHDAD
|
---|
| 5037 | "RTN","NHINVTIU",16,0)
|
---|
| 5038 | S DFN=+$G(DFN) Q:$G(DFN)<1
|
---|
| 5039 | "RTN","NHINVTIU",17,0)
|
---|
| 5040 | S BEG=$G(BEG,1410101),END=$G(END,9999998),MAX=$G(MAX,999999)
|
---|
| 5041 | "RTN","NHINVTIU",18,0)
|
---|
| 5042 | ;
|
---|
| 5043 | "RTN","NHINVTIU",19,0)
|
---|
| 5044 | ; get one document
|
---|
| 5045 | "RTN","NHINVTIU",20,0)
|
---|
| 5046 | I $L($G(ID)),ID[";" D RPT^NHINVLRA(DFN,ID,.NHITM),XML(.NHITM) Q ;Lab
|
---|
| 5047 | "RTN","NHINVTIU",21,0)
|
---|
| 5048 | I $G(ID),ID["-" D RPT^NHINVRA(DFN,ID,.NHITM),XML(.NHITM) Q ;Radiology
|
---|
| 5049 | "RTN","NHINVTIU",22,0)
|
---|
| 5050 | I $G(ID) D Q
|
---|
| 5051 | "RTN","NHINVTIU",23,0)
|
---|
| 5052 | . N SHOWADD S SHOWADD=1
|
---|
| 5053 | "RTN","NHINVTIU",24,0)
|
---|
| 5054 | . S NHX=ID_U_$$RESOLVE^TIUSRVLO(ID)
|
---|
| 5055 | "RTN","NHINVTIU",25,0)
|
---|
| 5056 | . D EN1(ID,.NHITM),XML(.NHITM)
|
---|
| 5057 | "RTN","NHINVTIU",26,0)
|
---|
| 5058 | ;
|
---|
| 5059 | "RTN","NHINVTIU",27,0)
|
---|
| 5060 | ; get all documents via
|
---|
| 5061 | "RTN","NHINVTIU",28,0)
|
---|
| 5062 | D CONTEXT^TIUSRVLO(.NHY,3,1,DFN,BEG,END,,MAX,,1)
|
---|
| 5063 | "RTN","NHINVTIU",29,0)
|
---|
| 5064 | S NHI=0 F S NHI=$O(@NHY@(NHI)) Q:NHI<1 D
|
---|
| 5065 | "RTN","NHINVTIU",30,0)
|
---|
| 5066 | . S NHX=$G(@NHY@(NHI)),IFN=+NHX
|
---|
| 5067 | "RTN","NHINVTIU",31,0)
|
---|
| 5068 | . K NHITM D EN1(IFN,.NHITM)
|
---|
| 5069 | "RTN","NHINVTIU",32,0)
|
---|
| 5070 | . D:$D(NHITM) XML(.NHITM)
|
---|
| 5071 | "RTN","NHINVTIU",33,0)
|
---|
| 5072 | Q
|
---|
| 5073 | "RTN","NHINVTIU",34,0)
|
---|
| 5074 | ;
|
---|
| 5075 | "RTN","NHINVTIU",35,0)
|
---|
| 5076 | EN1(IEN,DOC) ; -- return a document in DOC("attribute")=value
|
---|
| 5077 | "RTN","NHINVTIU",36,0)
|
---|
| 5078 | ; Expects DFN, NHX=IEN ^ $$RESOLVE^TIUSRVLO(IEN)
|
---|
| 5079 | "RTN","NHINVTIU",37,0)
|
---|
| 5080 | N X,NAME,NHINX,ES,I K DOC
|
---|
| 5081 | "RTN","NHINVTIU",38,0)
|
---|
| 5082 | S IEN=+$G(IEN) Q:IEN<1 ;invalid ien
|
---|
| 5083 | "RTN","NHINVTIU",39,0)
|
---|
| 5084 | Q:"UNKNOWN"[$P($G(NHX),U,2) ;null or invalid
|
---|
| 5085 | "RTN","NHINVTIU",40,0)
|
---|
| 5086 | S DOC("id")=IEN,NAME=$P(NHX,U,2),DOC("localTitle")=NAME
|
---|
| 5087 | "RTN","NHINVTIU",41,0)
|
---|
| 5088 | I $P(NHX,U,14),$P(NAME," ")="Addendum" D Q
|
---|
| 5089 | "RTN","NHINVTIU",42,0)
|
---|
| 5090 | . N DATE,PARENT K DOC
|
---|
| 5091 | "RTN","NHINVTIU",43,0)
|
---|
| 5092 | . S DATE=$P(NHX,U,3),PARENT=$P(NHX,U,14)
|
---|
| 5093 | "RTN","NHINVTIU",44,0)
|
---|
| 5094 | . I DATE,PARENT>1 S NHDAD(PARENT,DATE)=NHX
|
---|
| 5095 | "RTN","NHINVTIU",45,0)
|
---|
| 5096 | S X=$$GET1^DIQ(8925,IEN_",",".01:1501") S:$L(X) DOC("nationalTitle")=X
|
---|
| 5097 | "RTN","NHINVTIU",46,0)
|
---|
| 5098 | S X=$$GET1^DIQ(8925,IEN_",",".01:1501:99.99") S:$L(X) DOC("nationalTitleCode")=X
|
---|
| 5099 | "RTN","NHINVTIU",47,0)
|
---|
| 5100 | S X=$$GET1^DIQ(8925,IEN_",",.04) S:$L(X) DOC("documentClass")=X
|
---|
| 5101 | "RTN","NHINVTIU",48,0)
|
---|
| 5102 | S DOC("referenceDateTime")=$P(NHX,U,3)
|
---|
| 5103 | "RTN","NHINVTIU",49,0)
|
---|
| 5104 | S X=$P(NHX,U,6) D ;S:$L(X) DOC("location")=X
|
---|
| 5105 | "RTN","NHINVTIU",50,0)
|
---|
| 5106 | . N LOC S LOC=$S($L(X):+$O(^SC("B",X,0)),1:0)
|
---|
| 5107 | "RTN","NHINVTIU",51,0)
|
---|
| 5108 | . S DOC("facility")=$$FAC^NHINV(LOC)
|
---|
| 5109 | "RTN","NHINVTIU",52,0)
|
---|
| 5110 | S X=$P(NHX,U,7) S:$L(X) DOC("status")=X
|
---|
| 5111 | "RTN","NHINVTIU",53,0)
|
---|
| 5112 | S:$L($P(NHX,U,12)) DOC("subject")=$P(NHX,U,12)
|
---|
| 5113 | "RTN","NHINVTIU",54,0)
|
---|
| 5114 | ; X=$S($P(NHX,U,13)[">":"C",$P(NHX,U,13)["<":"I",1:"") ;componentType
|
---|
| 5115 | "RTN","NHINVTIU",55,0)
|
---|
| 5116 | S DOC("encounter")=$$GET1^DIQ(8925,IEN_",",.03,"I") ;$$VSTR(IEN)
|
---|
| 5117 | "RTN","NHINVTIU",56,0)
|
---|
| 5118 | S DOC("content")=$$TEXT(IEN)
|
---|
| 5119 | "RTN","NHINVTIU",57,0)
|
---|
| 5120 | ; providers &/or signatures
|
---|
| 5121 | "RTN","NHINVTIU",58,0)
|
---|
| 5122 | S X=$P(NHX,U,5),I=0 S:X I=I+1,DOC("clinician",I)=+X_U_$P(X,";",3)_"^A" ;author
|
---|
| 5123 | "RTN","NHINVTIU",59,0)
|
---|
| 5124 | D GETS^DIQ(8925,IEN_",","1501;1502;1507;1508","IE","NHINX")
|
---|
| 5125 | "RTN","NHINVTIU",60,0)
|
---|
| 5126 | M ES=NHINX(8925,IEN_",") I ES(1501,"I") D
|
---|
| 5127 | "RTN","NHINVTIU",61,0)
|
---|
| 5128 | . S I=I+1
|
---|
| 5129 | "RTN","NHINVTIU",62,0)
|
---|
| 5130 | . S DOC("clinician",I)=ES(1502,"I")_U_ES(1502,"E")_"^S^"_ES(1501,"I")_U_$$SIG(ES(1502,"I"))
|
---|
| 5131 | "RTN","NHINVTIU",63,0)
|
---|
| 5132 | I ES(1507,"I") D ; cosigner
|
---|
| 5133 | "RTN","NHINVTIU",64,0)
|
---|
| 5134 | . S I=I+1
|
---|
| 5135 | "RTN","NHINVTIU",65,0)
|
---|
| 5136 | . S DOC("clinician",I)=ES(1508,"I")_U_ES(1508,"E")_"^C^"_ES(1507,"I")_U_$$SIG(ES(1508,"I"))
|
---|
| 5137 | "RTN","NHINVTIU",66,0)
|
---|
| 5138 | Q
|
---|
| 5139 | "RTN","NHINVTIU",67,0)
|
---|
| 5140 | ;
|
---|
| 5141 | "RTN","NHINVTIU",68,0)
|
---|
| 5142 | VSTR(DA) ; -- get visit string for document DA
|
---|
| 5143 | "RTN","NHINVTIU",69,0)
|
---|
| 5144 | ; Expects DFN, NHX = IEN ^ $$RESOLVE^TIUSRVLO(IEN)
|
---|
| 5145 | "RTN","NHINVTIU",70,0)
|
---|
| 5146 | N VDT,VTYP,VLOC,Y
|
---|
| 5147 | "RTN","NHINVTIU",71,0)
|
---|
| 5148 | S VDT=$P($P(NHX,U,8),";",2)
|
---|
| 5149 | "RTN","NHINVTIU",72,0)
|
---|
| 5150 | S VTYP=$$GET1^DIQ(8925,DA_",",.13)
|
---|
| 5151 | "RTN","NHINVTIU",73,0)
|
---|
| 5152 | S VLOC=$$GET1^DIQ(8925,DA_",",1211,"I")
|
---|
| 5153 | "RTN","NHINVTIU",74,0)
|
---|
| 5154 | S Y=VLOC_";"_VDT_";"_VTYP
|
---|
| 5155 | "RTN","NHINVTIU",75,0)
|
---|
| 5156 | Q Y
|
---|
| 5157 | "RTN","NHINVTIU",76,0)
|
---|
| 5158 | ;
|
---|
| 5159 | "RTN","NHINVTIU",77,0)
|
---|
| 5160 | SIG(X) ; -- Return Signature Block Name_Title
|
---|
| 5161 | "RTN","NHINVTIU",78,0)
|
---|
| 5162 | N X20,Y S X20=$G(^VA(200,+$G(X),20))
|
---|
| 5163 | "RTN","NHINVTIU",79,0)
|
---|
| 5164 | S Y=$P(X20,U,2)_" "_$P(X20,U,3)
|
---|
| 5165 | "RTN","NHINVTIU",80,0)
|
---|
| 5166 | Q Y
|
---|
| 5167 | "RTN","NHINVTIU",81,0)
|
---|
| 5168 | ;
|
---|
| 5169 | "RTN","NHINVTIU",82,0)
|
---|
| 5170 | RPT(NHY,IFN) ; -- Return text of document in @NHY@(n)
|
---|
| 5171 | "RTN","NHINVTIU",83,0)
|
---|
| 5172 | D TGET^TIUSRVR1(.NHY,IFN)
|
---|
| 5173 | "RTN","NHINVTIU",84,0)
|
---|
| 5174 | Q
|
---|
| 5175 | "RTN","NHINVTIU",85,0)
|
---|
| 5176 | ;
|
---|
| 5177 | "RTN","NHINVTIU",86,0)
|
---|
| 5178 | TEXT(IFN) ; -- Return document IFN as a text string
|
---|
| 5179 | "RTN","NHINVTIU",87,0)
|
---|
| 5180 | N I,Y,NHY S IFN=+$G(IFN),Y=""
|
---|
| 5181 | "RTN","NHINVTIU",88,0)
|
---|
| 5182 | I IFN D
|
---|
| 5183 | "RTN","NHINVTIU",89,0)
|
---|
| 5184 | . D TGET^TIUSRVR1(.NHY,IFN)
|
---|
| 5185 | "RTN","NHINVTIU",90,0)
|
---|
| 5186 | . S I=0 F S I=$O(@NHY@(I)) Q:I<1 S Y=Y_$S($L(Y):$C(13,10),1:"")_@NHY@(I)
|
---|
| 5187 | "RTN","NHINVTIU",91,0)
|
---|
| 5188 | Q Y
|
---|
| 5189 | "RTN","NHINVTIU",92,0)
|
---|
| 5190 | ;
|
---|
| 5191 | "RTN","NHINVTIU",93,0)
|
---|
| 5192 | ; ------------ Return data to middle tier ------------
|
---|
| 5193 | "RTN","NHINVTIU",94,0)
|
---|
| 5194 | ;
|
---|
| 5195 | "RTN","NHINVTIU",95,0)
|
---|
| 5196 | XML(DOC) ; -- Return patient documents as XML
|
---|
| 5197 | "RTN","NHINVTIU",96,0)
|
---|
| 5198 | N ATT,X,Y,NAMES,TYPE
|
---|
| 5199 | "RTN","NHINVTIU",97,0)
|
---|
| 5200 | D ADD("<document>") S NHINTOTL=$G(NHINTOTL)+1
|
---|
| 5201 | "RTN","NHINVTIU",98,0)
|
---|
| 5202 | S ATT="" F S ATT=$O(DOC(ATT)) Q:ATT="" D D:$L(Y) ADD(Y)
|
---|
| 5203 | "RTN","NHINVTIU",99,0)
|
---|
| 5204 | . I $O(DOC(ATT,0)) D S Y="" Q ;multiples
|
---|
| 5205 | "RTN","NHINVTIU",100,0)
|
---|
| 5206 | .. D ADD("<"_ATT_"s>")
|
---|
| 5207 | "RTN","NHINVTIU",101,0)
|
---|
| 5208 | .. S I=0 F S I=$O(DOC(ATT,I)) Q:I<1 D
|
---|
| 5209 | "RTN","NHINVTIU",102,0)
|
---|
| 5210 | ... S X=$G(DOC(ATT,I)),NAMES=""
|
---|
| 5211 | "RTN","NHINVTIU",103,0)
|
---|
| 5212 | ... I ATT="clinician" S NAMES="code^name^role^dateTime^signature^Z"
|
---|
| 5213 | "RTN","NHINVTIU",104,0)
|
---|
| 5214 | ... S Y="<"_ATT_" "_$$LOOP_"/>" D ADD(Y)
|
---|
| 5215 | "RTN","NHINVTIU",105,0)
|
---|
| 5216 | .. D ADD("</"_ATT_"s>")
|
---|
| 5217 | "RTN","NHINVTIU",106,0)
|
---|
| 5218 | . S X=$G(DOC(ATT)),Y="" Q:'$L(X)
|
---|
| 5219 | "RTN","NHINVTIU",107,0)
|
---|
| 5220 | . I ATT="content" S Y="<"_ATT_" xml:space='preserve'>"_$$ESC^NHINV(X)_"</"_ATT_">" Q
|
---|
| 5221 | "RTN","NHINVTIU",108,0)
|
---|
| 5222 | . I X'["^" S Y="<"_ATT_" value='"_$$ESC^NHINV(X)_"' />" Q
|
---|
| 5223 | "RTN","NHINVTIU",109,0)
|
---|
| 5224 | . I $L(X)>1 S NAMES="code^name^Z",Y="<"_ATT_" "_$$LOOP_"/>"
|
---|
| 5225 | "RTN","NHINVTIU",110,0)
|
---|
| 5226 | D ADD("</document>")
|
---|
| 5227 | "RTN","NHINVTIU",111,0)
|
---|
| 5228 | Q
|
---|
| 5229 | "RTN","NHINVTIU",112,0)
|
---|
| 5230 | ;
|
---|
| 5231 | "RTN","NHINVTIU",113,0)
|
---|
| 5232 | LOOP() ; -- build sub-items string from NAMES and X
|
---|
| 5233 | "RTN","NHINVTIU",114,0)
|
---|
| 5234 | N STR,P,TAG S STR=""
|
---|
| 5235 | "RTN","NHINVTIU",115,0)
|
---|
| 5236 | F P=1:1 S TAG=$P(NAMES,U,P) Q:TAG="Z" I $L($P(X,U,P)) S STR=STR_TAG_"='"_$$ESC^NHINV($P(X,U,P))_"' "
|
---|
| 5237 | "RTN","NHINVTIU",116,0)
|
---|
| 5238 | Q STR
|
---|
| 5239 | "RTN","NHINVTIU",117,0)
|
---|
| 5240 | ;
|
---|
| 5241 | "RTN","NHINVTIU",118,0)
|
---|
| 5242 | ADD(X) ; Add a line @NHIN@(n)=X
|
---|
| 5243 | "RTN","NHINVTIU",119,0)
|
---|
| 5244 | S NHINI=$G(NHINI)+1
|
---|
| 5245 | "RTN","NHINVTIU",120,0)
|
---|
| 5246 | S @NHIN@(NHINI)=X
|
---|
| 5247 | "RTN","NHINVTIU",121,0)
|
---|
| 5248 | Q
|
---|
| 5249 | "VER")
|
---|
| 5250 | 8.0^22.0
|
---|
| 5251 | "BLD",7816,6)
|
---|
| 5252 | ^1
|
---|
| 5253 | **END**
|
---|
| 5254 | **END**
|
---|