source: FOIAVistA/tag/r/IMAGING-MAG-ZMAG/MAGGTLB1.m@ 628

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

initial load of FOIAVistA 6/30/08 version

File size: 5.9 KB
Line 
1MAGGTLB1 ;WOIFO/LB - RPC routine for Imaging Lab Interface ; [ 06/20/2001 08:56 ]
2 ;;3.0;IMAGING;**59**;Nov 27, 2007;Build 20
3 ;;Per VHA Directive 2004-038, this routine should not be modified.
4 ;; +---------------------------------------------------------------+
5 ;; | Property of the US Government. |
6 ;; | No permission to copy or redistribute this software is given. |
7 ;; | Use of unreleased versions of this software requires the user |
8 ;; | to execute a written test agreement with the VistA Imaging |
9 ;; | Development Office of the Department of Veterans Affairs, |
10 ;; | telephone (301) 734-0100. |
11 ;; | The Food and Drug Administration classifies this software as |
12 ;; | a medical device. As such, it may not be changed in any way. |
13 ;; | Modifications to this software may result in an adulterated |
14 ;; | medical device under 21CFR820, the use of which is considered |
15 ;; | to be a violation of US Federal Statutes. |
16 ;; +---------------------------------------------------------------+
17 ;;
18 Q
19 ;This routine is called from the Laboratory Image capture window.
20 ;After an image is captured and an entry is created in file 2005,
21 ;this routine will be called to set the imaging pointers in the
22 ;corresponding Lab subfile (Autopsy/ Organism, Surgical Path, EM,
23 ;or Cytology) and update the imaging file with the corresponding
24 ;Lab pointers.
25FILE(MAGRY,IMIEN,DATA) ;RPC Call to file pointers in Lab and Image files.
26 ;IMIEN - ^MAG(2005,IMIEN image captured.
27 ;DATA - piece 1 = stain piece 2 = micro obj
28 ; 3 = Pt name 4 = ssn
29 ; 5 = date/time 6 = acc#
30 ; 7 = Pathologist 8 = specimen desc.
31 ; 9 = lab section 10 = dfn
32 ; 11 = lrdfn 12 = lri
33 ; 13 = spec ien 14 = field#
34 ; 15 = global root e.g. ^LR(1,"SP",7069758,1,1
35 ;DATA is the result of START^MAGGTLB (the specimen variable during the
36 ;image capture window).
37 ;Will return a single value on filing success.
38 ;
39 IF $$NEWERR^%ZTER N $ETRAP,$ESTACK S $ETRAP="D ERR^MAGGTERR"
40 E S X="ERR^MAGGTERR",@^%ZOSF("TRAP")
41 ;
42 N ANUM,DA,DA1,DAS,DFN,DIERR,FIELD,I,IMOBJ,LABD,LABFDA,LABIEN,LABIENS
43 N LRDFN,LRI,MAGFDA,MAGIEN,MAGNODE,OUT,SECT,SECTLTR,SPEC,SPECD
44 N SSUBFILE,SSUBFL,STAIN,SUBFILE,X,Y
45 S MAGRY="0^Started filing",MAGIEN=IMIEN
46 S SECT=$P(DATA,"^",9),DFN=$P(DATA,"^",10),LRDFN=$P(DATA,"^",11)
47 S LRI=$P(DATA,"^",12)
48 S SPEC=$P(DATA,"^",13),FIELD=$P(DATA,"^",14)
49 S MAGNODE="^"_$P(DATA,"^",15,99),ANUM=$P(DATA,"^",6)
50 S SPECD=$P(DATA,"^",8),STAIN=$P(DATA,"^",1),IMOBJ=$P(DATA,"^",2)
51 I SECT["~" S SECT=$P(SECT,"~",1)
52 ;Check for valid image
53 I '$D(^MAG(2005,MAGIEN,0)) D Q
54 . S Y(0)="0^Image entry does not exist."
55 ;Check for valid image patient entry.
56 I $P(^MAG(2005,MAGIEN,0),"^",7)'=DFN D Q
57 . S MAGRY="0^Image patient does not match Lab patient."
58 ;Check if parent file and corresponding fields are filed in file 2005.
59 I $D(^MAG(2005,MAGIEN,2)) S X=^MAG(2005,MAGIEN,2) D Q:OUT
60 . S OUT=0
61 . I $P(X,"^",6),$P(X,"^",7),$P(X,"^",8) S OUT=1
62 . I OUT S MAGRY="0^Report already exist for this image."
63 ;Check the Lab entries...do they still exists.
64 S MAGNODE=MAGNODE_",0)"
65 I '$D(@MAGNODE) S MAGRY="0^Specimen no longer in Lab file." Q
66 ;Everything seem okay lets file image pointer in lab file.
67 S SECTLTR=$S(SECT=63:"AY",SECT=63.2:"AY",1:$P(^MAG(2005.03,SECT,0),"^",2))
68 ;Lab nodes; AY, SP, EM or CY.
69 ;
70LAB2 ;updating files using silent Fileman DB calls.
71 N MAGERR,MAGLVL
72 S SUBFILE=$S(SECT=63:63.2,1:SECT)
73 S MAGRY="0^Lab's Imaging subfile doesn't exisit." ;default
74 ;Laboratory's Autopsy subfile has two imaging fields (2005 & 2005.1)
75 ; and file 2005.03 does not reflect this.
76 D FIELD^DID(SUBFILE,FIELD,"","SPECIFIER","MAGLVL","MAGERR")
77 I $D(MAGERR("DIERR")) Q
78 I '$D(MAGLVL("SPECIFIER")) Q
79 S SSUBFL=$G(MAGLVL("SPECIFIER")) ;Lab's Imaging subfile
80 I SSUBFL="" Q
81 ;Image sub-subfile.
82 S SSUBFILE="" F I=1:1:$L(SSUBFL) D
83 . I $E(SSUBFL,I)?1N!($E(SSUBFL,I)?1".") S SSUBFILE=SSUBFILE_$E(SSUBFL,I)
84 . ;Leave off the alpha characters
85 S DA1=$S(SECTLTR="AY":SPEC,1:LRI) ;Autopsy is by specimen not date/time
86 S DAS="+3,"_DA1_","_LRDFN_","
87 ;Sets the iens e.g. da,da(1),da(2). The +3 can be any #; it is the
88 ;subscript of the return variable LABIENS.
89 ;Returns IEN for that subfile & use of +3 is because it's 2 levels down.
90 S LABFDA(SSUBFILE,DAS,.01)=MAGIEN,LABIENS=""
91 D UPDATE^DIE("S","LABFDA","LABIENS")
92 I $D(DIERR) S MAGRY="O^Unsuccessful Lab updating." Q
93 I '$D(LABIENS(3)) S MAGRY="0^Unsuccessful Lab updating" Q
94 S DA=$G(LABIENS(3))
95 I 'DA!('$D(^LR(LRDFN,SECTLTR,DA1,FIELD,DA,0))) D Q
96 . S MAGRY="0^Unsuccessful Lab updating"
97IMAGE2 ;
98 S MAGIEN=MAGIEN_",",LABIEN=DA,LABD=DA1 K DA,DA1
99 ; The following fields are saved in the ADDIMAGE Call.
100 ; 50 =ANUM ;ACCESSION NUMBER FIELD
101 ; 51 =SPECD ;SPECIMEN DESCRIPTION FIELD
102 ; 52 =SPEC ;SPECIMEN DO
103 ; 53 =STAIN ;Histology stain
104 ; 54 =IMOBJ ;MICROSCOPE OBJECTIVE
105 N DIK
106 S MAGFDA(2005,MAGIEN,16)=SECT ;LAB SECTION
107 S MAGFDA(2005,MAGIEN,17)=LRDFN ;PARENT FILE DO VALUE
108 S MAGFDA(2005,MAGIEN,18)=LABIEN ;LAB BACKWARD IMAGE POINTER
109 S MAGFDA(2005,MAGIEN,63)=LABD ;If AUTOPSY, it's specimen else date/time
110 S I=0 F I=$O(MAGFDA(2005,MAGIEN,I)) Q:'I D
111 . D UPDATE^DIE("S","MAGFDA","")
112 I $D(DIERR) S I=0 F S I=$O(MAGFDA(2005,MAGIEN,I)) Q:'I D
113 . S MAGFDA(2005,MAGIEN,I)="" D UPDATE^DIE("","MAGFDA","")
114 I $D(DIERR),$D(^LR(LRDFN,SECTLTR,DA1,FIELD,LABIEN,0)),$G(^LR(LRDFN,SECTLTR,DA1,FIELD,LABIEN,0))=MAGIEN D
115 . S DA(2)=LRDFN,DA(1)=DA1,DA=LABIEN
116 . S DIK="^LR("_LRDFN_","""_SECTLTR_""","_DA1_","_FIELD_","
117 . D ^DIK ;Remove imaging pointers from lab subfile.
118 I $D(DIERR) S MAGRY="0^Unsuccessful both files not updated." K DIERR Q
119 S MAGRY="1^Success in filing both parent & image files." K DIERR
120 D LINKDT^MAGGTU6(.X,+MAGIEN)
121 Q
Note: See TracBrowser for help on using the repository browser.