| 1 | MAGGTLB ;WOIFO/LB - RPC call for Laboratory/Imaging interface ; [ 11/24/2004 04:06 ] | 
|---|
| 2 | ;;3.0;IMAGING;**48**;Jan 11, 2005 | 
|---|
| 3 | ;; +---------------------------------------------------------------+ | 
|---|
| 4 | ;; | Property of the US Government.                                | | 
|---|
| 5 | ;; | No permission to copy or redistribute this software is given. | | 
|---|
| 6 | ;; | Use of unreleased versions of this software requires the user | | 
|---|
| 7 | ;; | to execute a written test agreement with the VistA Imaging    | | 
|---|
| 8 | ;; | Development Office of the Department of Veterans Affairs,     | | 
|---|
| 9 | ;; | telephone (301) 734-0100.                                     | | 
|---|
| 10 | ;; |                                                               | | 
|---|
| 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 | ;The line tag SECT is used for selection of the Laboratory section. | 
|---|
| 21 | ;The line tag STAIN is used for selection of Histological stain. | 
|---|
| 22 | ;The line tag MICRO is used for selection of Microscopic Objective. | 
|---|
| 23 | ;The line tag START is used for selection of the specimen that the image | 
|---|
| 24 | ;relates to. This line tag will require a lab section (Autopsy/ | 
|---|
| 25 | ;Gross, Autopsy/Microscopic, EM, Surgical Path, or Cytology), | 
|---|
| 26 | ;the Accession year, and either an Accession # or Autopsy #.  Based on | 
|---|
| 27 | ;this information it will return an array of specimens for selection. | 
|---|
| 28 | ; | 
|---|
| 29 | START(MAGRY,SECT,YR,ACNUM,XXX) ;RPC Call to Return a list of specimens | 
|---|
| 30 | ;  -Removed DFN (XXX) -no longer being used for lookup | 
|---|
| 31 | ;SECT = Lab entry from 2005.03 | 
|---|
| 32 | ;YR = 4 digits of year (1700-2000's) | 
|---|
| 33 | ;ACNUM = Accession number or autopsy number | 
|---|
| 34 | ;Returns an array of specimens for the year_accession#. | 
|---|
| 35 | ;MAGRY(#)=Piece 1 = Pt Name            piece 2 = Ssn | 
|---|
| 36 | ;               3 = Date/Time                4 = Accn # | 
|---|
| 37 | ;               5 = Pathologist              6 = Specimen | 
|---|
| 38 | ;               7 = Ien for file 2005.03     8 = Dfn | 
|---|
| 39 | ;               9 = Lrdfn                   10 = Ien for date/time | 
|---|
| 40 | ;              11 = Ien specimen            12 = Lab section subfile | 
|---|
| 41 | ;                                                 imaging field number | 
|---|
| 42 | ;              13 = LR global being referenced | 
|---|
| 43 | ;the MAGRY(0)=0 or # lines in array^status (success or no success) | 
|---|
| 44 | ;the MAGRY(1)=titles for the grid array | 
|---|
| 45 | N Y,YEAR | 
|---|
| 46 | IF $$NEWERR^%ZTER N $ETRAP,$ESTACK S $ETRAP="D ERRA^MAGGTERR" | 
|---|
| 47 | E  S X="ERRA^MAGGTERR",@^%ZOSF("TRAP") | 
|---|
| 48 | S MAGRY(0)="0^No Data",DATA=0 | 
|---|
| 49 | S MAGRY(1)="Name^SSN^Date/Time^Acc #^Pathologist^Specimen" | 
|---|
| 50 | N CNT,NUM,DATE,ANUM,NUM,DATA,LRDFN,LRI,LINE,MAGI,DATE,PATH,SPEC,MAGABV | 
|---|
| 51 | N MAGNODE,MAGSSN,PAT,MAGSECT,FILE,DATA,MAGDFN,MAGNM,MAGX,X0 | 
|---|
| 52 | S DATA=0 | 
|---|
| 53 | S LINE=2 | 
|---|
| 54 | S MAGRY(0)="0^No specimen information found, please enter via DHCP Lab application" | 
|---|
| 55 | I '$G(SECT)!('$G(ACNUM))!($L(YR)'=4) D  Q | 
|---|
| 56 | . S MAGRY(0)="0^Incorrect variables sent" | 
|---|
| 57 | S MAGABV=$P(SECT,"~",2),SECT=$P(SECT,"~") | 
|---|
| 58 | Q:'$D(^MAG(2005.03,SECT,0)) | 
|---|
| 59 | S MAGSECT=$P(^MAG(2005.03,SECT,0),"^"),MAGI=$E($P(^(0),"^",2),1) | 
|---|
| 60 | S MAGNODE=$S(MAGI="S":"SP",MAGI="E":"EM",MAGI="C":"CY",1:"AU") | 
|---|
| 61 | S MAGX="A"_MAGNODE_"A" | 
|---|
| 62 | ;Xref to search accession year and accession/autopsy #. | 
|---|
| 63 | I YR<1700 S MAGRY(0)="0^=Invalid year provided" Q | 
|---|
| 64 | S YEAR=YR,YR=YEAR-1700 | 
|---|
| 65 | ;2001-1700 =301 Fileman internal & YR2K compliance | 
|---|
| 66 | ;Checked with Lab developers, still setting 3digit year in xref | 
|---|
| 67 | ;S YR=$S(YR>1999:3_$E(YR,3,4),1:2_$E(YR,3,4))  ;CODE FOR YRS >1999 | 
|---|
| 68 | ;Checking MUMPs x-ref which can not be done via FM DB silent calls. | 
|---|
| 69 | I '$D(^LR(MAGX,YR,MAGABV,ACNUM)) D  Q | 
|---|
| 70 | . S MAGRY(0)="0^Accession number "_MAGABV_" "_YEAR_" "_ACNUM_" is invalid" | 
|---|
| 71 | . ;No data for the year accession # | 
|---|
| 72 | S LRDFN=$O(^LR(MAGX,YR,MAGABV,ACNUM,0)),LRI=$O(^(LRDFN,0)) | 
|---|
| 73 | S MAGDFN=$P(^LR(LRDFN,0),"^",3),FILE=$P(^LR(LRDFN,0),"^",2) | 
|---|
| 74 | I FILE=2 S X=^DPT(MAGDFN,0),MAGNM=$P(X,"^"),MAGSSN=$P(X,"^",9) ;Patient file | 
|---|
| 75 | I FILE[67 D  Q:MAGNM="" | 
|---|
| 76 | . D GETS^DIQ(67,MAGDFN,".01;.09","E",MAGZZ,MAGERR) | 
|---|
| 77 | . I $D(MAGERR("DIERR")) S MAGRY(0)="0^Patient lookup failed" Q | 
|---|
| 78 | . S MAGNM=$G(MAGZZ(67,MAGDFN_",",".01","E")) | 
|---|
| 79 | . S MAGSSN=$G(MAGZZ(67,MAGDFN_",",".09","E")) | 
|---|
| 80 | I "ASCE"'[MAGI Q   ;Not a valid lab section (Autopsy,Surgical Path, Cytology or EM) | 
|---|
| 81 | S MAGNODE=$S(MAGI="S":"SP",MAGI="E":"EM",MAGI="C":"CY",1:"AY") | 
|---|
| 82 | G:MAGNODE="AY" AUTOPSY    ;Need this because 2005.03 does not reference the right node. | 
|---|
| 83 | Q:'$D(^LR(LRDFN,MAGNODE,LRI,0)) | 
|---|
| 84 | S X0=^LR(LRDFN,MAGNODE,LRI,0),PATH=$P(X0,"^",2),NUM=$P(X0,"^",6) | 
|---|
| 85 | S DATE=$P(X0,"^",1),ANUM=NUM | 
|---|
| 86 | LOOK ; | 
|---|
| 87 | S PATH=$S('PATH:"UNKNOWN",1:$$GET1^DIQ(200,PATH_",",.01)) | 
|---|
| 88 | S YEAR=$E(DATE,1,3)+1700     ;4 digit year | 
|---|
| 89 | ; YR2K Compliance 301+1700=2001 | 
|---|
| 90 | S DATE=$E(DATE,4,5)_"/"_$E(DATE,6,7)_"/"_YEAR | 
|---|
| 91 | S X=0 F  S X=$O(^LR(LRDFN,MAGNODE,LRI,.1,X)) Q:'X  D | 
|---|
| 92 | . S SPEC=$P($G(^LR(LRDFN,MAGNODE,LRI,.1,X,0)),"^") | 
|---|
| 93 | . S MAGRY(LINE)=MAGNM_"^"_MAGSSN_"^"_DATE_"^"_ANUM_"^"_PATH_"^"_SPEC_"^"_SECT_"^"_MAGDFN_"^"_LRDFN_"^"_LRI_"^"_X_"^"_"2005"_"^"_"LR("_LRDFN_","""_MAGNODE_""","_LRI_",.1,"_X | 
|---|
| 94 | . S DATA=1,LINE=LINE+1 | 
|---|
| 95 | I DATA S MAGRY(0)=(LINE-2)_"^"_"DATA FOUND" | 
|---|
| 96 | Q | 
|---|
| 97 | AUTOPSY ; | 
|---|
| 98 | N MAGERR,MAGRYLN,MAGZZ,XX | 
|---|
| 99 | S (MAGERR,MAGZZ)="" | 
|---|
| 100 | S X0=^LR(LRDFN,"AU"),DATE=$P(X0,"^"),NUM=$P(X0,"^",6) | 
|---|
| 101 | S PATH=$P(X0,"^",7),ANUM=NUM | 
|---|
| 102 | S PATH=$S('PATH:"UNKNOWN",1:$$GET1^DIQ(200,PATH_",",.01)) | 
|---|
| 103 | ;  DATE in line below, was DATA ( DATA was a misprint ) GEK | 
|---|
| 104 | S YEAR=$E(DATE,1,3)+1700   ;4 digit year | 
|---|
| 105 | ; YR2K compliance 301+1700= 2001 | 
|---|
| 106 | S DATE=$E(DATE,4,5)_"/"_$E(DATE,6,7)_"/"_YEAR | 
|---|
| 107 | S XX=0 F  S XX=$O(^LR(LRDFN,MAGNODE,XX)) Q:'XX  D | 
|---|
| 108 | . Q:'$D(^LR(LRDFN,MAGNODE,XX,0)) | 
|---|
| 109 | . S SPEC=$P(^LR(LRDFN,MAGNODE,XX,0),"^") | 
|---|
| 110 | . D GETS^DIQ(61,SPEC,".01","E","MAGZZ","MAGERR") | 
|---|
| 111 | . S SPEC=$S($D(MAGERR("DIERR")):"UNKNOWN",1:$G(MAGZZ(61,SPEC_",",".01","E"))) | 
|---|
| 112 | . S MAGRYLN="" | 
|---|
| 113 | . S MAGRYLN=MAGNM_"^"_MAGSSN_"^"_DATE_"^"_ANUM_"^"_PATH_"^"_SPEC | 
|---|
| 114 | . S MAGRYLN=MAGRYLN_"^"_SECT_"^"_MAGDFN_"^"_LRDFN_"^^"_XX | 
|---|
| 115 | . S MAGRYLN=MAGRYLN_"^"_$S(MAGSECT["GROSS":2005,1:2005.1) | 
|---|
| 116 | . S MAGRYLN=MAGRYLN_"^"_"LR("_LRDFN_","""_MAGNODE_""","_XX | 
|---|
| 117 | . S MAGRY(LINE)=MAGRYLN | 
|---|
| 118 | . S DATA=1,LINE=LINE+1 | 
|---|
| 119 | I DATA S MAGRY(0)=(LINE-2)_"^"_"DATA FOUND" | 
|---|
| 120 | I 'DATA S MAGRY(0)="0^No organ/tissue defined for this autopsy." | 
|---|
| 121 | ;If MAGSECT[ "GROSS" then the field # is 2005 for subfile 63.2 | 
|---|
| 122 | ;else the field # is 2005.1 for the same subfile (AUTOPSY ORGAN/TISSUE). | 
|---|
| 123 | Q | 
|---|
| 124 | STAIN(MAGRY) ;RPC Call to return array of entries from | 
|---|
| 125 | ;       file 2005.4, Image Histological Stain. | 
|---|
| 126 | ; | 
|---|
| 127 | S MAGRY(0)="0^No Entries found for file 2005.4" | 
|---|
| 128 | Q:'$D(^MAG(2005.4,0))    ;Imaging file not defined. | 
|---|
| 129 | N ENTRY,CNT,DATA,BLANK | 
|---|
| 130 | S ENTRY=0,CNT=1,DATA=0,$P(BLANK," ",30)=" " | 
|---|
| 131 | F  S ENTRY=$O(^MAG(2005.4,ENTRY)) Q:'ENTRY  D | 
|---|
| 132 | . Q:'$D(^MAG(2005.4,ENTRY,0))  S X=$P(^MAG(2005.4,ENTRY,0),"^") | 
|---|
| 133 | . S MAGRY(CNT)=X_BLANK_"^"_X,CNT=CNT+1,DATA=1 | 
|---|
| 134 | I DATA S MAGRY(0)="1^DATA FOUND"_U_(CNT-1) | 
|---|
| 135 | Q | 
|---|
| 136 | MICRO(MAGRY) ;RPC Call to Return array of entries from | 
|---|
| 137 | ;        file 2005.41, Microscopic Objective | 
|---|
| 138 | S MAGRY(0)="0^No entries found for file 2005.41" | 
|---|
| 139 | Q:'$D(^MAG(2005.41,0))    ;Imaging file not defined. | 
|---|
| 140 | N ENTRY,CNT,DATA,BLANK | 
|---|
| 141 | S ENTRY=0,CNT=1,DATA=0,$P(BLANK," ",30)=" " | 
|---|
| 142 | F  S ENTRY=$O(^MAG(2005.41,ENTRY)) Q:'ENTRY  D | 
|---|
| 143 | . Q:'$D(^MAG(2005.41,ENTRY,0))  S X=$P(^MAG(2005.41,ENTRY,0),"^") | 
|---|
| 144 | . S MAGRY(CNT)=X_BLANK_"^"_X,CNT=CNT+1,DATA=1 | 
|---|
| 145 | I DATA S MAGRY(0)="1^DATA FOUND"_"^"_(CNT-1) | 
|---|
| 146 | Q | 
|---|
| 147 | SECT(MAGRY) ;RPC Call to Build Pathology selection | 
|---|
| 148 | ;       from file 68 accordingly to user's division | 
|---|
| 149 | ;MAGRY - Returns array of lab section name, section abbreviation | 
|---|
| 150 | ;        used in defining the accession number & xref lookup, | 
|---|
| 151 | ;        as well as the IEN in Imaging Parent file. | 
|---|
| 152 | N Y,A,B,BLANK,MAGABV,MAGERR,MAGIEN,MAGNM,MAGNNM,MAGSEC,MAGTYPE,DATA | 
|---|
| 153 | IF $$NEWERR^%ZTER N $ETRAP,$ESTACK S $ETRAP="D ERRA^MAGGTERR" | 
|---|
| 154 | E  S X="ERRA^MAGGTERR",@^%ZOSF("TRAP") | 
|---|
| 155 | S MAGRY(0)="0^No entries found^0" | 
|---|
| 156 | S MAGSEC="SPCYEMAU",(A,B)=0,$P(BLANK," ",30)="" D CK Q:MAGERR | 
|---|
| 157 | F  S A=$O(^LRO(68,A)) Q:'A  D | 
|---|
| 158 | . I MAGSEC[$P($G(^LRO(68,A,0)),"^",2),$P(^LRO(68,A,0),"^",2)]"""",$G(^LRO(68,A,3,+DUZ(2),0)) D | 
|---|
| 159 | . . S MAGABV=$P(^LRO(68,A,0),"^",11) Q:MAGABV=""   ;No abbreviation defined | 
|---|
| 160 | . . S MAGTYPE=$P(^LRO(68,A,0),"^",2),MAGNM=$P(^LRO(68,A,0),"^") | 
|---|
| 161 | . . Q:MAGSEC'[MAGTYPE  D PARENT    ;Must be pathology section. | 
|---|
| 162 | . . S B=B+1,DATA=1,MAGRY(B)=MAGNM_BLANK_"^"_MAGIEN_"~"_MAGABV | 
|---|
| 163 | I '$D(DATA) S MAGRY(0)="0^No entries found for your division^0" Q | 
|---|
| 164 | I DATA S B=B+1,MAGRY(0)="1^Entries found^"_B | 
|---|
| 165 | Q | 
|---|
| 166 | CK ;Check for valid division. | 
|---|
| 167 | S MAGERR=1 | 
|---|
| 168 | N MAGSITE,MAGER | 
|---|
| 169 | S MAGSITE=+DUZ(2) | 
|---|
| 170 | I 'MAGSITE D  Q | 
|---|
| 171 | . S MAGRY(0)="0^You don't have a division setup." | 
|---|
| 172 | ;  gek/ change : ..."A",MAGSITE...  to  ..."","`"_MAGSITE... | 
|---|
| 173 | I '$$FIND1^DIC(4,"","","`"_MAGSITE,"","","MAGER") D  Q | 
|---|
| 174 | . S MAGRY(0)="0^No division name found." | 
|---|
| 175 | S MAGERR=0 | 
|---|
| 176 | Q | 
|---|
| 177 | PARENT ;Set the corresponding parent file/subfile in ^MAG(2005.03,62:64. | 
|---|
| 178 | S MAGIEN=$S(MAGTYPE="SP":63.08,MAGTYPE="EM":63.02,MAGTYPE="CY":63.09,1:63.2) | 
|---|
| 179 | I MAGTYPE="AU" S MAGIEN=63.2,MAGNNM=MAGNM_" (GROSS)",B=B+1,MAGRY(B)=MAGNNM_BLANK_"^"_MAGIEN_"~"_MAGABV,MAGNNM="",MAGIEN=63,MAGNM=MAGNM_" (MICROSCOPIC)" | 
|---|
| 180 | ;Autopsy selection will have two selection (GROSS or MICROSCOPIC) and the parent file ^MAG(2005.03 has two entries (63 & 63.2). | 
|---|
| 181 | Q | 
|---|