VistA-WorldVistAEHR/r/IMAGING-MAG-ZMAG/MAG7RSO.m

51 lines
2.4 KiB
Mathematica

MAG7RSO ;WOIFO/PMK,MLH - copy radiology message from HLSDATA to ^MAGDHL7 - update diag codes in OBX segs ; 07 Jul 2003 12:30 PM
;;3.0;IMAGING;**11**;14-April-2004
;; +---------------------------------------------------------------+
;; | Property of the US Government. |
;; | No permission to copy or redistribute this software is given. |
;; | Use of unreleased versions of this software requires the user |
;; | to execute a written test agreement with the VistA Imaging |
;; | Development Office of the Department of Veterans Affairs, |
;; | telephone (301) 734-0100. |
;; | |
;; | The Food and Drug Administration classifies this software as |
;; | a medical device. As such, it may not be changed in any way. |
;; | Modifications to this software may result in an adulterated |
;; | medical device under 21CFR820, the use of which is considered |
;; | to be a violation of US Federal Statutes. |
;; +---------------------------------------------------------------+
;;
;
OBXUPD ; SUBROUTINE - called by ADDDTA^MAGDHL7
; Update OBX diagnosis code info on radiology ORU messages.
; DICOM requires a numeric code in its triplet.
;
N IXOBX ; ---------------- index to OBX segments in MAG7WRK array
N DIAGCSTR ; ------------- diagnostic code string
N TESTSTR ; -------------- substring to test with
N TESTIX ; --------------- index of entries to test against
N DIAGCIX ; -------------- diagnostic code index in 78.3
;
; Look for DIAGNOSTIC CODE in each OBX segment. When that string is found,
; try to pick up the numeric diagnosis code from the Radiology DIAGNOSTIC
; CODES File (#78.3).
S IXOBX=""
F S IXOBX=$O(MAG7WRK("B","OBX",IXOBX)) Q:'IXOBX D
. I $G(MAG7WRK(IXOBX,3,1,2,1))="DIAGNOSTIC CODE",$G(MAG7WRK(IXOBX,2,1,1,1))="ST" D
. . S DIAGCSTR=$G(MAG7WRK(IXOBX,5,1,1,1))
. . K DIAGCIX
. . I DIAGCSTR]"" D
. . . S TESTSTR=$E(DIAGCSTR,1,30),TESTIX=""
. . . F S TESTIX=$O(^RA(78.3,"B",TESTSTR,TESTIX)) Q:'TESTIX D Q:$G(DIAGCIX)
. . . . I $P($G(^RA(78.3,TESTIX,0)),U)=DIAGCSTR S DIAGCIX=TESTIX
. . . . Q
. . . Q
. . I '$G(DIAGCIX) S DIAGCIX=9999 ; 'no code found' flag
. . S MAG7WRK(IXOBX,2,1,1,1)="CE"
. . S MAG7WRK(IXOBX,5,1,1,1)=DIAGCIX
. . S MAG7WRK(IXOBX,5,1,2,1)=DIAGCSTR
. . S MAG7WRK(IXOBX,5,1,3,1)="VISTA78.3"
. . Q
. Q
Q