Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: LA7UTL1C

LA7UTL1C.m

Go to the documentation of this file.
  1. LA7UTL1C ;VA/HOIFO/BH - Microbiology Query Utility ;JUL 06, 2010 3:14 PM
  1. ;;5.2;AUTOMATED LAB INSTRUMENTS;**69,1027**;NOV 01, 1997
  1. ;
  1. ;
  1. MI(LRDFN,LRIDT,LAARRAY) ; Get Microbiology data
  1. ; Get top node data
  1. ;
  1. N LACOMIEN,LAGETIEN,LAGSIEN,LAIEN,LAORGIEN,LAPARIEN,LAPRIEN,LAREMIEN,LASCCOM,LASCIEN,LAFIXANT,LAFCOM,LAFUNIEN,LAMBIEN,LAMBCOM,LAFIXMB,LAMBFLD,LAMBFLD1,LACNT1,LAMBRES,LAVIEN
  1. N LAGETS,LAGETIEN,LAMFLD,LAANTIEN,LACMANTI,LABSPIEN,LAPSPIEN,LAMSPIEN,LAVRRIEN
  1. ;
  1. S LAIEN=LRIDT_","_LRDFN
  1. K LARET,LAERR
  1. D GETS^DIQ(63.05,LAIEN,".01;.05;.055;.06;11.51;11.57;11.58;22:23;24;25;.99","IE","LARET","LAERR")
  1. I $D(LAERR("DIERR")) K LAERR Q
  1. M @LAARRAY=LARET
  1. K LARET,LAERR
  1. ;
  1. ; Get Bact RPT Remark
  1. S LAREMIEN=0
  1. F S LAREMIEN=$O(^LR(LRDFN,"MI",LRIDT,4,LAREMIEN)) Q:'LAREMIEN D
  1. . S LAGETIEN=LAREMIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.33,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; Get Gram Stain
  1. S LAGSIEN=0
  1. F S LAGSIEN=$O(^LR(LRDFN,"MI",LRIDT,2,LAGSIEN)) Q:'LAGSIEN D
  1. . S LAGETIEN=LAGSIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.29,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; Get Organism data
  1. S LAORGIEN=0
  1. F S LAORGIEN=$O(^LR(LRDFN,"MI",LRIDT,3,LAORGIEN)) Q:'LAORGIEN D
  1. . S LAGETIEN=LAORGIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.3,LAGETIEN,".01;1","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. . S LACOMIEN=0
  1. . F S LACOMIEN=$O(^LR(LRDFN,"MI",LRIDT,3,LAORGIEN,1,LACOMIEN)) Q:'LACOMIEN D
  1. . . S LAGETIEN=LACOMIEN_","_LAORGIEN_","_LRIDT_","_LRDFN
  1. . . K LARET,LAERR
  1. . . D GETS^DIQ(63.31,LAGETIEN,".01","IE","LARET","LAERR")
  1. . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . M @LAARRAY=LARET
  1. . . K LARET,LAERR
  1. . ;
  1. . ;
  1. . S LAFIXANT=2
  1. . F S LAFIXANT=$O(^LR(LRDFN,"MI",LRIDT,3,LAORGIEN,LAFIXANT)) Q:'LAFIXANT!(LAFIXANT'<3) D
  1. . . Q:$E(LAFIXANT,1,4)'="2.00"
  1. . . S LAGETIEN=LAORGIEN_","_LRIDT_","_LRDFN
  1. . . I $L(LAFIXANT)<7 D
  1. . . . S LAMFLD=$$DECODE^LA7UTL1B(LAFIXANT)
  1. . . . I LAMFLD="" Q
  1. . . . N LACNT1,LACNT,LAVAL,LA7ARR1,LAMFLD2,LAIN,LAMFLD3,LAMFLD4
  1. . . . F LACNT=2,3,4 D
  1. . . . . S LAVAL=$P(LAMFLD,U,LACNT)
  1. . . . . S LAIN="LAMFLD"_LACNT
  1. . . . . S @LAIN=$P(LAVAL,"~")
  1. . . . . S LA7ARR1(@LAIN)=$P(LAVAL,"~",2)
  1. . . . . ;
  1. . . . K LARET,LAERR
  1. . . . D GETS^DIQ(63.3,LAGETIEN,LAMFLD2_";"_LAMFLD3_";"_LAMFLD4,"IE","LARET","LAERR")
  1. . . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . . S LACNT1=0
  1. . . . S LAGETIEN=LAGETIEN_","
  1. . . . F S LACNT1=$O(LA7ARR1(LACNT1)) Q:'LACNT1 D
  1. . . . . N LARES
  1. . . . . S LARES=$G(LARET(63.3,LAGETIEN,LACNT1,"I"))
  1. . . . . I LARES="" K LARET(63.3,LAGETIEN,LACNT1) Q
  1. . . . . S LARET(63.3,LAGETIEN,LACNT1,"I")=LA7ARR1(LACNT1)_U_LARES
  1. . . . M @LAARRAY=LARET
  1. . . . ;
  1. . . . ;
  1. . . I $L(LAFIXANT)>6 D
  1. . . . N LACNT2,LANAME,LATEST,LARET,LAERR,LARES
  1. . . . D FIELD^DID(63.3,LAFIXANT,"","LABEL","LATEST")
  1. . . . I '$D(LATEST("LABEL")) Q
  1. . . . S LANAME=LATEST("LABEL")
  1. . . . ;
  1. . . . D GETS^DIQ(63.3,LAGETIEN,LAFIXANT_";"_LAFIXANT_"1;"_LAFIXANT_"2","IE","LARET","LAERR")
  1. . . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . . S LAGETIEN=LAGETIEN_","
  1. . . . S LARES=$G(LARET(63.3,LAGETIEN,LAFIXANT,"I"))
  1. . . . S:LARES'="" LARET(63.3,LAGETIEN,LAFIXANT,"I")=LANAME_U_LARES
  1. . . . I LARES="" K LARET(63.3,LAGETIEN,LAFIXANT)
  1. . . . F LACNT2=1,2 D
  1. . . . . K LATEST
  1. . . . . D FIELD^DID(63.3,LAFIXANT_LACNT2,"","LABEL","LATEST")
  1. . . . . I '$D(LATEST("LABEL")) Q
  1. . . . . S LANAME=LATEST("LABEL")
  1. . . . . S LARES=$G(LARET(63.3,LAGETIEN,LAFIXANT_LACNT2,"I"))
  1. . . . . I LARES="" K LARET(63.3,LAGETIEN,LAFIXANT_LACNT2) Q
  1. . . . . S LARET(63.3,LAGETIEN,LAFIXANT_LACNT2,"I")=LANAME_U_LARES
  1. . . . M @LAARRAY=LARET
  1. . ;
  1. . S LACMANTI=0
  1. . F S LACMANTI=$O(^LR(LRDFN,"MI",LRIDT,3,LAORGIEN,3,LACMANTI)) Q:'LACMANTI D
  1. . . S LAANTIEN=LACMANTI_","_LAORGIEN_","_LRIDT_","_LRDFN
  1. . . K LARET,LAERR
  1. . . D GETS^DIQ(63.32,LAANTIEN,".01;1;2","IE","LARET","LAERR")
  1. . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . M @LAARRAY=LARET
  1. . . K LARET,LAERR
  1. ;
  1. ;
  1. ; Get Parasite data
  1. S LAPARIEN=0
  1. F S LAPARIEN=$O(^LR(LRDFN,"MI",LRIDT,6,LAPARIEN)) Q:'LAPARIEN D
  1. . S LAGETIEN=LAPARIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.34,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. . ; - Get stage code data
  1. . S LASCIEN=0
  1. . F S LASCIEN=$O(^LR(LRDFN,"MI",LRIDT,6,LAPARIEN,1,LASCIEN)) Q:'LASCIEN D
  1. . . S LAGETIEN=LASCIEN_","_LAPARIEN_","_LRIDT_","_LRDFN
  1. . . K LARET,LAERR
  1. . . D GETS^DIQ(63.35,LAGETIEN,".01;1","IE","LARET","LAERR")
  1. . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . M @LAARRAY=LARET
  1. . . K LARET,LAERR
  1. . . ; - Get stage code comments
  1. . . S LASCCOM=0
  1. . . F S LASCCOM=$O(^LR(LRDFN,"MI",LRIDT,6,LAPARIEN,1,LASCIEN,1,LASCCOM)) Q:'LASCCOM D
  1. . . . S LAGETIEN=LASCCOM_","_LASCIEN_","_LAPARIEN_","_LRIDT_","_LRDFN
  1. . . . K LARET,LAERR
  1. . . . D GETS^DIQ(63.351,LAGETIEN,".01","IE","LARET","LAERR")
  1. . . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . . M @LAARRAY=LARET
  1. . . . K LARET,LAERR
  1. ;
  1. ; - Get Parasite Remarks
  1. S LAPRIEN=0
  1. F S LAPRIEN=$O(^LR(LRDFN,"MI",LRIDT,7,LAPRIEN)) Q:'LAPRIEN D
  1. . S LAGETIEN=LAPRIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.36,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; ---Fungus Yeast
  1. S LAFUNIEN=0
  1. F S LAFUNIEN=$O(^LR(LRDFN,"MI",LRIDT,9,LAFUNIEN)) Q:'LAFUNIEN D
  1. . S LAGETIEN=LAFUNIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.37,LAGETIEN,".01;1","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. . S LAFCOM=0
  1. . F S LAFCOM=$O(^LR(LRDFN,"MI",LRIDT,9,LAFUNIEN,1,LAFCOM)) Q:'LAFCOM D
  1. . . S LAGETIEN=LAFCOM_","_LAFUNIEN_","_LRIDT_","_LRDFN
  1. . . K LARET,LAERR
  1. . . D GETS^DIQ(63.372,LAGETIEN,".01","IE","LARET","LAERR")
  1. . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . M @LAARRAY=LARET
  1. . . K LARET,LAERR
  1. ;
  1. ; ---Mycobacteruim
  1. ;
  1. S LAMBIEN=0
  1. F S LAMBIEN=$O(^LR(LRDFN,"MI",LRIDT,12,LAMBIEN)) Q:'LAMBIEN D
  1. . S LAGETIEN=LAMBIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.39,LAGETIEN,".01;1","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. . S LAMBCOM=0
  1. . F S LAMBCOM=$O(^LR(LRDFN,"MI",LRIDT,12,LAMBIEN,1,LAMBCOM)) Q:'LAMBCOM D
  1. . . S LAGETIEN=LAMBCOM_","_LAMBIEN_","_LRIDT_","_LRDFN
  1. . . K LARET,LAERR
  1. . . D GETS^DIQ(63.4,LAGETIEN,".01","IE","LARET","LAERR")
  1. . . I $D(LAERR("DIERR")) K LAERR Q
  1. . . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. . S LAFIXMB=2
  1. . S LAGETIEN=LAMBIEN_","_LRIDT_","_LRDFN
  1. . F S LAFIXMB=$O(^LR(LRDFN,"MI",LRIDT,12,LAMBIEN,LAFIXMB)) Q:'LAFIXMB!(LAFIXMB'<3) D
  1. . . Q:$E(LAFIXMB,1,4)'="2.00"
  1. . . I $L(LAFIXMB)<7 D
  1. . . . S LAMBFLD=$P($$DECODEMB^LA7UTL1B(LAFIXMB),U,2)
  1. . . . I LAMBFLD="" Q
  1. . . . S LAMBFLD1=$P(LAMBFLD,"~",2)
  1. . . . S LAMBFLD=$P(LAMBFLD,"~",1)
  1. . . . K LARET,LAERR
  1. . . . D GETS^DIQ(63.39,LAGETIEN,LAMBFLD,"IE","LARET","LAERR")
  1. . . . ;
  1. . . . I $D(LAERR("DIERR"))!('$D(LARET)) K LARET,LAERR Q
  1. . . . ;
  1. . . . S LAGETS=LAGETIEN_","
  1. . . . S LAMBRES=$G(LARET(63.39,LAGETS,LAMBFLD,"I"))
  1. . . . I LAMBRES="" K LARET(63.39,LAGETS,LAMBFLD) Q
  1. . . . S LARET(63.39,LAGETS,LAMBFLD,"I")=LAMBFLD1_U_LAMBRES
  1. . . . M @LAARRAY=LARET
  1. . . . ;
  1. . . . ;
  1. . . I $L(LAFIXMB)>6 D
  1. . . . N LANAME,LATEST,LARET,LAERR,LAMBRES
  1. . . . D FIELD^DID(63.39,LAFIXMB,"","LABEL","LATEST")
  1. . . . I '$D(LATEST("LABEL")) Q
  1. . . . S LANAME=LATEST("LABEL")
  1. . . . K LARET,LAERR
  1. . . . D GETS^DIQ(63.39,LAGETIEN,LAFIXMB,"IE","LARET","LAERR")
  1. . . . ;
  1. . . . I $D(LAERR("DIERR"))!('$D(LARET)) K LAERR Q
  1. . . . S LAGETS=LAGETIEN_","
  1. . . . S LAMBRES=$G(LARET(63.39,LAGETS,LAFIXMB,"I"))
  1. . . . I LAMBRES="" K LARET(63.39,LAGETS,LAFIXMB) Q
  1. . . . S:LAMBRES'="" LARET(63.39,LAGETS,LAFIXMB,"I")=LANAME_U_LAMBRES
  1. . . . M @LAARRAY=LARET
  1. ;
  1. ; ---Virus
  1. ;
  1. S LAVIEN=0
  1. F S LAVIEN=$O(^LR(LRDFN,"MI",LRIDT,17,LAVIEN)) Q:'LAVIEN D
  1. . S LAGETIEN=LAVIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.43,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; ---Parasitology Smear/Prep
  1. ;
  1. S LAPSPIEN=0
  1. F S LAPSPIEN=$O(^LR(LRDFN,"MI",LRIDT,24,LAPSPIEN)) Q:'LAPSPIEN D
  1. . S LAGETIEN=LAPSPIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.341,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; ---Bacteriology Smear/Prep
  1. ;
  1. S LABSPIEN=0
  1. F S LABSPIEN=$O(^LR(LRDFN,"MI",LRIDT,25,LABSPIEN)) Q:'LABSPIEN D
  1. . S LAGETIEN=LABSPIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.291,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; ---Mycology Smear/Prep
  1. ;
  1. S LAMSPIEN=0
  1. F S LAMSPIEN=$O(^LR(LRDFN,"MI",LRIDT,15,LAMSPIEN)) Q:'LAMSPIEN D
  1. . S LAGETIEN=LAMSPIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.371,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. ; ---Virology RPT
  1. ;
  1. S LAVRRIEN=0
  1. F S LAVRRIEN=$O(^LR(LRDFN,"MI",LRIDT,18,LAVRRIEN)) Q:'LAVRRIEN D
  1. . S LAGETIEN=LAVRRIEN_","_LRIDT_","_LRDFN
  1. . K LARET,LAERR
  1. . D GETS^DIQ(63.44,LAGETIEN,".01","IE","LARET","LAERR")
  1. . I $D(LAERR("DIERR")) K LAERR Q
  1. . M @LAARRAY=LARET
  1. . K LARET,LAERR
  1. ;
  1. Q
  1. ;