source: FOIAVistA/trunk/r/AUTOMATED_LAB_INSTRUMENTS-LA/LA7VOBX2.m@ 1783

Last change on this file since 1783 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.0 KB
Line 
1LA7VOBX2 ;DALOI/JMC - LAB OBX Segment message builder (AP subscripts) cont'd ; 05/26/00
2 ;;5.2;AUTOMATED LAB INSTRUMENTS;**46,64**;Sep 27, 1994
3 ;
4AP ; Build OBX segments for resultss that are anatomic/surgical pathology subscripts
5 ; Called by LA7VOBX
6 ;
7 N LA7953,LA7ACODE,LA7CODE,LA7DIV,LA7IENS,LA7OBX5,LA7OBX5M,LA7SUB,LA7SUBFL,LA7VP,LA7WP,LA7X,LA7Y
8 ;
9 S (LA7953,LA7DIV,LA7VP)=""
10 ;
11 ; Surgical pathology subscript
12 I LRSS="SP" S LA7SUBFL=63.08
13 ;
14 ; Cytology subscript
15 I LRSS="CY" S LA7SUBFL=63.09
16 ;
17 ; Electron microscopy subscript
18 I LRSS="EM" S LA7SUBFL=63.02
19 ;
20 S LA7IENS=""
21 F I=3:-1:1 I $P(LRIDT,",",I) S LRIDT(I)=$P(LRIDT,",",I),LA7IENS=LA7IENS_LRIDT(I)_","
22 S LA7IENS=LA7IENS_LRDFN_","
23 S LRIDT=$P(LRIDT,",")
24 S LA7SUB(0)=$G(^LR(LRDFN,LRSS,LRIDT,0))
25 ;
26 ; Get default codes
27 S LA7CODE=$$DEFCODE^LA7VHLU5(LRSS,LRSB,"","")
28 ;
29 ; Initialize OBX segment
30 S LA7OBX(0)="OBX"
31 ;
32 ; Value type
33 S LA7X=LA7SUBFL,LA7Y=LRSB
34 I LRSS="SP" D
35 . I LRSB=1.2 S LA7X=63.817,LA7Y=1
36 . I LRSB="10,1.5" S LA7X=63.82,LA7Y=.01
37 . I LRSB="10,2" S LA7X=63.12,LA7Y=2
38 . I LRSB="10,5" S LA7X=63.819,LA7Y=1
39 S LA7OBX(2)=$$OBX2^LA7VOBX(LA7X,LA7Y)
40 ;
41 ; Observation identifier
42 S LA7OBX(3)=$$OBX3^LA7VOBX($P(LA7CODE,"!",2),$P(LA7CODE,"!",3),"",LA7FS,LA7ECH)
43 ;
44 ; Observation sub-ID
45 ; Create sub-ID for supplementary reports and special studies
46 I LRSS="SP" D SUBID
47 ;
48 ; Build result field
49 I LRSB=.012 D
50 . N LA7I,LA7X,LA7Y
51 . S LA7I=0
52 . F S LA7I=$O(^LR(LRDFN,LRSS,LRIDT,.1,LA7I)) Q:'LA7I D
53 . . S LA7X=$G(^LR(LRDFN,LRSS,LRIDT,.1,LA7I,0))
54 . . S LA7Y(LA7I)=$P(LA7X,"^")
55 . S LA7OBX(5)=$$OBX5R^LA7VOBX(.LA7Y,LA7OBX(2),LA7FS,LA7ECH)
56 ;
57 I LRSB'=.012 D
58 . I LRSS="SP",$P(LRSB,",")=10,LRSB'="10,5" Q
59 . I LA7NVAF=1 D DOD Q
60 . I LRSS="SP",LRSB=1.2 N LRSB S LA7SUBFL=63.817,LRSB=1
61 . I LRSS="SP",LRSB="10,5" N LRSB S LA7SUBFL=63.819,LRSB=1
62 . D OBX5M^LA7VOBX(LA7SUBFL,LA7IENS,LRSB,.LA7WP,LA7FS,LA7ECH)
63 . D BUILDSEG^LA7VHLU(.LA7WP,.LA7OBX5M,"")
64 . M LA7OBX(5)=LA7OBX5M
65 ;
66 I LRSS="SP",$P(LRSB,",")=10 D
67 . N LA7VAL,X
68 . I LRSB=10 D
69 . . S LA7VAL=$$GET1^DIQ(63.12,LA7IENS,.01)
70 . . S X=$$GET1^DIQ(63.12,LA7IENS,".01:2")
71 . . I $L(X) S LA7VAL=$S($E(X,1,2)="T-":"",1:"T-")_X_"^"_LA7VAL_"^SNM"
72 . . S LA7OBX(5)=$$OBX5^LA7VOBX(LA7VAL,LA7OBX(2),LA7FS,LA7ECH)
73 . I LRSB="10,2" D
74 . . S LA7VAL=$$GET1^DIQ(63.12,LA7IENS,2)
75 . . S LA7OBX(5)=$$OBX5^LA7VOBX(LA7VAL,LA7OBX(2),LA7FS,LA7ECH)
76 . . S LA7OBX(6)=$$OBX6^LA7VOBX("g","",LA7FS,LA7ECH)
77 ;
78 ; Don't build this segment if no results/value to send
79 I $G(LA7OBX(5,0))="",$G(LA7OBX(5))="" Q
80 ;
81 ; Build sequence id
82 S LA7OBX(1)=$$OBX1^LA7VOBX(.LA7OBXSN)
83 ;
84 ; "P"artial, "F"inal , "A"mended results
85 ; If not release date then pending
86 I '$P(LA7SUB(0),"^",11) S LA7OBX(11)="P"
87 ;
88 ; If release date then check for changes
89 I $P(LA7SUB(0),"^",11) D
90 . I $P(LA7SUB(0),"^",15) S LA7OBX(11)="C"
91 . E S LA7OBX(11)="F"
92 ;
93 I $P(LA7SUB(0),"^",13),$$DIV4^XUSER(.LA7DIV,$P(LA7SUB(0),"^",2)) S LA7DIV=$O(LA7DIV(0))
94 ;
95 ; Facility that performed the testing
96 S LA7OBX(15)=$$OBX15^LA7VOBX(LA7DIV,LA7FS,LA7ECH)
97 ;
98 ; Person that verified the test
99 S LA7VP=$P(LA7SUB(0),"^",13)
100 I LA7VP S LA7OBX(16)=$$OBX16^LA7VOBX(LA7VP,LA7DIV,LA7FS,LA7ECH)
101 ;
102 D BUILDSEG^LA7VHLU(.LA7OBX,.LA7ARRAY,LA7FS)
103 ;
104 Q
105 ;
106 ;
107SUBID ; Build sub-id for "SP" subscript
108 ; Used to identify supplementary reports, specimens and related special
109 ; studies performed on thoese specimens.
110 ;
111 N LA7SUBID
112 ;
113 S LA7SUBID=""
114 ;
115 ; Sub-id's for supplementary reports
116 I LRSB=1.2 S LA7SUBID="1."_$P(LA7IENS,",")
117 ;
118 ; Sub-id's for specimens and special studies
119 I LRSB=10!(LRSB="10,2") S LA7SUBID="10."_$P(LA7IENS,",")
120 I LRSB="10,1.5"!(LRSB="10,5") S LA7SUBID="10."_$P(LA7IENS,",",2)_"."_$P(LA7IENS,",")
121 ;
122 I $L(LA7SUBID) S LA7OBX(4)=$$OBX4^LA7VOBX(LA7SUBID,LA7FS,LA7ECH)
123 ;
124 Q
125 ;
126 ;
127DOD ; Build OBX segment's to special DoD specifications.
128 ; Send word-processing fields as series of OBX's for DoD.
129 ; DoD cannot handle formatted text (FT) data type.
130 ;
131 S LA7OBX(2)="ST"
132 S LA7VAL=$G(^LR(LRDFN,LRSS,$P(LA7IDT,","),LA7SB,$P(LA7IDT,",",2),0))
133 I LA7VAL="" S LA7VAL=" "
134 S LA7OBX(5)=$$OBX5^LA7VOBX(LA7VAL,LA7OBX(2),LA7FS,LA7ECH)
135 Q
Note: See TracBrowser for help on using the repository browser.