LA7UTL02 ;VA/HOIFO/BH - Cytopathology Query Utility ; 17-Oct-2014 09:22 ; MKK
;;5.2;AUTOMATED LAB INSTRUMENTS;**1027,1032,1034**;NOV 01, 1997;Build 88
;
;;VA LR Patch(s): 69
;
CYPATH(LRDFN,IEN,RET,ERR) ; Returns data for a Cytopathology Encounter
;
; Input:
;
; LRDFN - Patient Lab DFN (Required)
; IEN - IEN of CY entry (Required)
; RET - Array reference for passing back data (Required)
; ERR - Error array to pass back (Not required)
;
; Output:
;
; '0' - If the API encountered an Error along with @ERR array
;
; '1' - if the API ran successfully and the following data if it exists
;
; Visit Date field .01 and Accession Number field .06 of file 63.09.
; @RET("DEMO",ien of visit)=Visit Date^Accession Number
;
; Specimen field .01 of sub file 63.902.
; @RET("SPEC",ien of Specimen entry)=Specimen Data
;
; Clinical History field .01 of sub file 63.913.
; @RET("CHIS",ien of the Clinical History entry)=Clinical His.
;
; Pre Operative Diagnosis field .01 of sub file 63.914.
; @RET@("PREDX",ien of the Pre. Op. Diagnosis entry)=Pre Op Diag.
;
; Operative Diagnosis field .01 of sub file 63.905.
; @RET@("OPERDX",ien of the Op. Diagnosis entry)=Op Diag.
;
; Post Opertive Diagnosis field .01 of sub file 63.906.
; @RET@("POSTDX,ien of the Post. Op Diagnosis entry)=Pst. Op Diag.
;
; Cytopathology Diagnosis field .01 of sub file 63.903.
; @RET@("CYTODX",ien of the Cytopathology Diagnosis entry)=Cyto Dx
;
; Microscopic Examination field .01 of sub file 63.911.
; @RET@("MICRO",ien of the Microscopic Examination entry)=Micro. Exam
;
; ICD field .01 of sub file 63.901.
; @RET@("ICD9",ien of Cyto ien entry)=ICD9 (external)
;
; ---------------------------------------------------------------------
;
K @RET
K @ERR
I $G(LRDFN)="" D Q 0
. I $G(ERR)'="" S @ERR@("-1")="No Lab DFN." Q
;
I $G(IEN)="" D Q 0
. I $G(ERR)'="" S @ERR@("-1")="No Cytopathology record IEN." Q
;
I $G(RET)="" D Q 0
. I $G(ERR)'="" S @ERR@("-1")="No results array reference passed." Q
;
N QUIT
D DEMO
I 'QUIT D SPECIMEN
I 'QUIT D HISTORY
I 'QUIT D PDIAG
I 'QUIT D OPDIAG
I 'QUIT D POSTDIAG
I 'QUIT D CYTOPATH
I 'QUIT D MICRO
I 'QUIT D ICD
I QUIT Q 0
Q 1
;
;
DEMO ; Get basic demographics
N VDATE S QUIT=0
S VDATE=$$GET1^DIQ(63.09,IEN_","_LRDFN,.01,"I")
I VDATE=""!($G(DIERR)) S QUIT=1 Q
S ANUM=$$GET1^DIQ(63.09,IEN_","_LRDFN,.06,"I")
I $G(DIERR) S QUIT=1 Q
S @RET@("DEMO",IEN)=VDATE_"^"_ANUM
Q
;
;
SPECIMEN ;
N SPIENS,SPIEN,SPECIMEN S SPIEN="0"
F S SPIEN=$O(^LR(LRDFN,"CY",IEN,.1,SPIEN)) Q:'SPIEN!(QUIT) D
. Q:QUIT
. S SPIENS=SPIEN_","_IEN_","_LRDFN_","
. S SPECIMEN=$$GET1^DIQ(63.902,SPIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Specimen data)."
. . S QUIT=1
. I SPECIMEN="" Q
. S @RET@("SPEC",SPIEN)=SPECIMEN
Q
;
;
HISTORY N CHIENS,CHIEN,HISTORY S CHIEN="0"
F S CHIEN=$O(^LR(LRDFN,"CY",IEN,.2,CHIEN)) Q:'CHIEN!(QUIT) D
. Q:QUIT
. S CHIENS=CHIEN_","_IEN_","_LRDFN_","
. S HISTORY=$$GET1^DIQ(63.913,CHIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Clinical History data)."
. . S QUIT=1
. I HISTORY="" Q
. S @RET@("CHIS",CHIEN)=HISTORY
Q
;
PDIAG N PDIENS,PDIEN,PREOPDX S PDIEN="0"
F S PDIEN=$O(^LR(LRDFN,"CY",IEN,.3,PDIEN)) Q:'PDIEN!(QUIT) D
. Q:QUIT
. S PDIENS=PDIEN_","_IEN_","_LRDFN_","
. S PREOPDX=$$GET1^DIQ(63.914,PDIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Pre Operative Diagnosis data)."
. . S QUIT=1
. I PREOPDX="" Q
. S @RET@("PREDX",PDIEN)=PREOPDX
Q
;
;
OPDIAG N ODIENS,ODIEN,OPERDX S ODIEN="0"
F S ODIEN=$O(^LR(LRDFN,"CY",IEN,.4,ODIEN)) Q:'ODIEN!(QUIT) D
. Q:QUIT
. S ODIENS=ODIEN_","_IEN_","_LRDFN_","
. S OPERDX=$$GET1^DIQ(63.905,ODIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Operative Diagnosis data)."
. . S QUIT=1
. I OPERDX="" Q
. S @RET@("OPERDX",ODIEN)=OPERDX
Q
;
;
POSTDIAG ;
N PSDIENS,PSDIEN,POSTDX S PSDIEN="0"
F S PSDIEN=$O(^LR(LRDFN,"CY",IEN,.5,PSDIEN)) Q:'PSDIEN!(QUIT) D
. Q:QUIT
. S PSDIENS=PSDIEN_","_IEN_","_LRDFN_","
. S POSTDX=$$GET1^DIQ(63.906,PSDIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Post Operative Diagnosis data)."
. . S QUIT=1
. I POSTDX="" Q
. S @RET@("POSTDX",PSDIEN)=POSTDX
Q
;
CYTOPATH ; - Cyto Pathology
N CYIENS,CYIEN,CYTODX S CYIEN="0"
F S CYIEN=$O(^LR(LRDFN,"CY",IEN,1.4,CYIEN)) Q:'CYIEN!(QUIT) D
. Q:QUIT
. S CYIENS=CYIEN_","_IEN_","_LRDFN_","
. S CYTODX=$$GET1^DIQ(63.903,CYIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Cytopathology diagnosis data)."
. . S QUIT=1
. I CYTODX="" Q
. S @RET@("CYTODX",CYIEN)=CYTODX
Q
;
MICRO ; - Microscopic Exam
N MICIENS,MICEXAM,MICIEN S MICIEN="0"
F S MICIEN=$O(^LR(LRDFN,"CY",IEN,1.1,MICIEN)) Q:'MICIEN!(QUIT) D
. Q:QUIT
. S MICIENS=MICIEN_","_IEN_","_LRDFN_","
. S MICEXAM=$$GET1^DIQ(63.911,MICIENS,.01,"I")
. I $G(DIERR) D Q
. . K @RET
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (Cytopathology Microscopic Examination)"
. . S QUIT=1
. I MICEXAM="" Q
. S @RET@("MICRO",MICIEN)=MICEXAM
Q
;
;
ICD ; - Get ICD Data
N ICDIENS,ICDIEN,ICD9 S ICDIEN="0"
F S ICDIEN=$O(^LR(LRDFN,"CY",IEN,3,ICDIEN)) Q:'ICDIEN!(QUIT) D
. Q:QUIT
. S ICDIENS=ICDIEN_","_IEN_","_LRDFN_","
. S ICD9=$$GET1^DIQ(63.901,ICDIENS,.01,"E")
. I $G(DIERR) D Q
. . K @RET
. . ; I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (ICD9 data)."
. . I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (ICD data)." ; IHS/MSC/MKK - LR*5.2*1034
. . S QUIT=1
. I ICD9="" Q
. S @RET@("ICD9",ICDIEN)=ICD9
Q
;
LA7UTL02 ;VA/HOIFO/BH - Cytopathology Query Utility ; 17-Oct-2014 09:22 ; MKK
+1 ;;5.2;AUTOMATED LAB INSTRUMENTS;**1027,1032,1034**;NOV 01, 1997;Build 88
+2 ;
+3 ;;VA LR Patch(s): 69
+4 ;
CYPATH(LRDFN,IEN,RET,ERR) ; Returns data for a Cytopathology Encounter
+1 ;
+2 ; Input:
+3 ;
+4 ; LRDFN - Patient Lab DFN (Required)
+5 ; IEN - IEN of CY entry (Required)
+6 ; RET - Array reference for passing back data (Required)
+7 ; ERR - Error array to pass back (Not required)
+8 ;
+9 ; Output:
+10 ;
+11 ; '0' - If the API encountered an Error along with @ERR array
+12 ;
+13 ; '1' - if the API ran successfully and the following data if it exists
+14 ;
+15 ; Visit Date field .01 and Accession Number field .06 of file 63.09.
+16 ; @RET("DEMO",ien of visit)=Visit Date^Accession Number
+17 ;
+18 ; Specimen field .01 of sub file 63.902.
+19 ; @RET("SPEC",ien of Specimen entry)=Specimen Data
+20 ;
+21 ; Clinical History field .01 of sub file 63.913.
+22 ; @RET("CHIS",ien of the Clinical History entry)=Clinical His.
+23 ;
+24 ; Pre Operative Diagnosis field .01 of sub file 63.914.
+25 ; @RET@("PREDX",ien of the Pre. Op. Diagnosis entry)=Pre Op Diag.
+26 ;
+27 ; Operative Diagnosis field .01 of sub file 63.905.
+28 ; @RET@("OPERDX",ien of the Op. Diagnosis entry)=Op Diag.
+29 ;
+30 ; Post Opertive Diagnosis field .01 of sub file 63.906.
+31 ; @RET@("POSTDX,ien of the Post. Op Diagnosis entry)=Pst. Op Diag.
+32 ;
+33 ; Cytopathology Diagnosis field .01 of sub file 63.903.
+34 ; @RET@("CYTODX",ien of the Cytopathology Diagnosis entry)=Cyto Dx
+35 ;
+36 ; Microscopic Examination field .01 of sub file 63.911.
+37 ; @RET@("MICRO",ien of the Microscopic Examination entry)=Micro. Exam
+38 ;
+39 ; ICD field .01 of sub file 63.901.
+40 ; @RET@("ICD9",ien of Cyto ien entry)=ICD9 (external)
+41 ;
+42 ; ---------------------------------------------------------------------
+43 ;
+44 KILL @RET
+45 KILL @ERR
+46 IF $GET(LRDFN)=""
Begin DoDot:1
+47 IF $GET(ERR)'=""
SET @ERR@("-1")="No Lab DFN."
QUIT
End DoDot:1
QUIT 0
+48 ;
+49 IF $GET(IEN)=""
Begin DoDot:1
+50 IF $GET(ERR)'=""
SET @ERR@("-1")="No Cytopathology record IEN."
QUIT
End DoDot:1
QUIT 0
+51 ;
+52 IF $GET(RET)=""
Begin DoDot:1
+53 IF $GET(ERR)'=""
SET @ERR@("-1")="No results array reference passed."
QUIT
End DoDot:1
QUIT 0
+54 ;
+55 NEW QUIT
+56 DO DEMO
+57 IF 'QUIT
DO SPECIMEN
+58 IF 'QUIT
DO HISTORY
+59 IF 'QUIT
DO PDIAG
+60 IF 'QUIT
DO OPDIAG
+61 IF 'QUIT
DO POSTDIAG
+62 IF 'QUIT
DO CYTOPATH
+63 IF 'QUIT
DO MICRO
+64 IF 'QUIT
DO ICD
+65 IF QUIT
QUIT 0
+66 QUIT 1
+67 ;
+68 ;
DEMO ; Get basic demographics
+1 NEW VDATE
SET QUIT=0
+2 SET VDATE=$$GET1^DIQ(63.09,IEN_","_LRDFN,.01,"I")
+3 IF VDATE=""!($GET(DIERR))
SET QUIT=1
QUIT
+4 SET ANUM=$$GET1^DIQ(63.09,IEN_","_LRDFN,.06,"I")
+5 IF $GET(DIERR)
SET QUIT=1
QUIT
+6 SET @RET@("DEMO",IEN)=VDATE_"^"_ANUM
+7 QUIT
+8 ;
+9 ;
SPECIMEN ;
+1 NEW SPIENS,SPIEN,SPECIMEN
SET SPIEN="0"
+2 FOR
SET SPIEN=$ORDER(^LR(LRDFN,"CY",IEN,.1,SPIEN))
IF 'SPIEN!(QUIT)
QUIT
Begin DoDot:1
+3 IF QUIT
QUIT
+4 SET SPIENS=SPIEN_","_IEN_","_LRDFN_","
+5 SET SPECIMEN=$$GET1^DIQ(63.902,SPIENS,.01,"I")
+6 IF $GET(DIERR)
Begin DoDot:2
+7 KILL @RET
+8 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Specimen data)."
+9 SET QUIT=1
End DoDot:2
QUIT
+10 IF SPECIMEN=""
QUIT
+11 SET @RET@("SPEC",SPIEN)=SPECIMEN
End DoDot:1
+12 QUIT
+13 ;
+14 ;
HISTORY NEW CHIENS,CHIEN,HISTORY
SET CHIEN="0"
+1 FOR
SET CHIEN=$ORDER(^LR(LRDFN,"CY",IEN,.2,CHIEN))
IF 'CHIEN!(QUIT)
QUIT
Begin DoDot:1
+2 IF QUIT
QUIT
+3 SET CHIENS=CHIEN_","_IEN_","_LRDFN_","
+4 SET HISTORY=$$GET1^DIQ(63.913,CHIENS,.01,"I")
+5 IF $GET(DIERR)
Begin DoDot:2
+6 KILL @RET
+7 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Clinical History data)."
+8 SET QUIT=1
End DoDot:2
QUIT
+9 IF HISTORY=""
QUIT
+10 SET @RET@("CHIS",CHIEN)=HISTORY
End DoDot:1
+11 QUIT
+12 ;
PDIAG NEW PDIENS,PDIEN,PREOPDX
SET PDIEN="0"
+1 FOR
SET PDIEN=$ORDER(^LR(LRDFN,"CY",IEN,.3,PDIEN))
IF 'PDIEN!(QUIT)
QUIT
Begin DoDot:1
+2 IF QUIT
QUIT
+3 SET PDIENS=PDIEN_","_IEN_","_LRDFN_","
+4 SET PREOPDX=$$GET1^DIQ(63.914,PDIENS,.01,"I")
+5 IF $GET(DIERR)
Begin DoDot:2
+6 KILL @RET
+7 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Pre Operative Diagnosis data)."
+8 SET QUIT=1
End DoDot:2
QUIT
+9 IF PREOPDX=""
QUIT
+10 SET @RET@("PREDX",PDIEN)=PREOPDX
End DoDot:1
+11 QUIT
+12 ;
+13 ;
OPDIAG NEW ODIENS,ODIEN,OPERDX
SET ODIEN="0"
+1 FOR
SET ODIEN=$ORDER(^LR(LRDFN,"CY",IEN,.4,ODIEN))
IF 'ODIEN!(QUIT)
QUIT
Begin DoDot:1
+2 IF QUIT
QUIT
+3 SET ODIENS=ODIEN_","_IEN_","_LRDFN_","
+4 SET OPERDX=$$GET1^DIQ(63.905,ODIENS,.01,"I")
+5 IF $GET(DIERR)
Begin DoDot:2
+6 KILL @RET
+7 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Operative Diagnosis data)."
+8 SET QUIT=1
End DoDot:2
QUIT
+9 IF OPERDX=""
QUIT
+10 SET @RET@("OPERDX",ODIEN)=OPERDX
End DoDot:1
+11 QUIT
+12 ;
+13 ;
POSTDIAG ;
+1 NEW PSDIENS,PSDIEN,POSTDX
SET PSDIEN="0"
+2 FOR
SET PSDIEN=$ORDER(^LR(LRDFN,"CY",IEN,.5,PSDIEN))
IF 'PSDIEN!(QUIT)
QUIT
Begin DoDot:1
+3 IF QUIT
QUIT
+4 SET PSDIENS=PSDIEN_","_IEN_","_LRDFN_","
+5 SET POSTDX=$$GET1^DIQ(63.906,PSDIENS,.01,"I")
+6 IF $GET(DIERR)
Begin DoDot:2
+7 KILL @RET
+8 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Post Operative Diagnosis data)."
+9 SET QUIT=1
End DoDot:2
QUIT
+10 IF POSTDX=""
QUIT
+11 SET @RET@("POSTDX",PSDIEN)=POSTDX
End DoDot:1
+12 QUIT
+13 ;
CYTOPATH ; - Cyto Pathology
+1 NEW CYIENS,CYIEN,CYTODX
SET CYIEN="0"
+2 FOR
SET CYIEN=$ORDER(^LR(LRDFN,"CY",IEN,1.4,CYIEN))
IF 'CYIEN!(QUIT)
QUIT
Begin DoDot:1
+3 IF QUIT
QUIT
+4 SET CYIENS=CYIEN_","_IEN_","_LRDFN_","
+5 SET CYTODX=$$GET1^DIQ(63.903,CYIENS,.01,"I")
+6 IF $GET(DIERR)
Begin DoDot:2
+7 KILL @RET
+8 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Cytopathology diagnosis data)."
+9 SET QUIT=1
End DoDot:2
QUIT
+10 IF CYTODX=""
QUIT
+11 SET @RET@("CYTODX",CYIEN)=CYTODX
End DoDot:1
+12 QUIT
+13 ;
MICRO ; - Microscopic Exam
+1 NEW MICIENS,MICEXAM,MICIEN
SET MICIEN="0"
+2 FOR
SET MICIEN=$ORDER(^LR(LRDFN,"CY",IEN,1.1,MICIEN))
IF 'MICIEN!(QUIT)
QUIT
Begin DoDot:1
+3 IF QUIT
QUIT
+4 SET MICIENS=MICIEN_","_IEN_","_LRDFN_","
+5 SET MICEXAM=$$GET1^DIQ(63.911,MICIENS,.01,"I")
+6 IF $GET(DIERR)
Begin DoDot:2
+7 KILL @RET
+8 IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (Cytopathology Microscopic Examination)"
+9 SET QUIT=1
End DoDot:2
QUIT
+10 IF MICEXAM=""
QUIT
+11 SET @RET@("MICRO",MICIEN)=MICEXAM
End DoDot:1
+12 QUIT
+13 ;
+14 ;
ICD ; - Get ICD Data
+1 NEW ICDIENS,ICDIEN,ICD9
SET ICDIEN="0"
+2 FOR
SET ICDIEN=$ORDER(^LR(LRDFN,"CY",IEN,3,ICDIEN))
IF 'ICDIEN!(QUIT)
QUIT
Begin DoDot:1
+3 IF QUIT
QUIT
+4 SET ICDIENS=ICDIEN_","_IEN_","_LRDFN_","
+5 SET ICD9=$$GET1^DIQ(63.901,ICDIENS,.01,"E")
+6 IF $GET(DIERR)
Begin DoDot:2
+7 KILL @RET
+8 ; I $G(ERR)'="" S @ERR@("-1")="Fileman Error within GET1 call (ICD9 data)."
+9 ; IHS/MSC/MKK - LR*5.2*1034
IF $GET(ERR)'=""
SET @ERR@("-1")="Fileman Error within GET1 call (ICD data)."
+10 SET QUIT=1
End DoDot:2
QUIT
+11 IF ICD9=""
QUIT
+12 SET @RET@("ICD9",ICDIEN)=ICD9
End DoDot:1
+13 QUIT
+14 ;