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

LRPXAPPU.m

Go to the documentation of this file.
LRPXAPPU ;VA/SLC/STAFF - Test Lab APIs Utilities ; 17-Oct-2014 09:22 ; MKK
 ;;5.2;LAB SERVICE;**1030,1034**;NOV 01, 1997;Build 88
 ;;5.2;LAB SERVICE;**295**;Sep 27, 1994;Build 5
 ;
 ; This routine is used along with LRPXAPP for testing Lab APIs.
 ;
DISPLAY ; from LRPXAPP
 ; displays results stored in a TMP global
 N NUM,NUM1
 W ! S NUM=""
 F  S NUM=$O(^TMP("LRPXAPP",$J,NUM)) Q:NUM=""  D
 . I $D(^TMP("LRPXAPP",$J,NUM))#2 W !,^(NUM) Q
 . S NUM1=""
 . F  S NUM1=$O(^TMP("LRPXAPP",$J,NUM,NUM1)) Q:NUM1=""  W !,NUM,",",NUM1
 K ^TMP("LRPXAPP",$J)
 Q
 ;
GETTYPE(TYPE,ERR) ; from LRPXAPP
 ; asks for type of data (C, M, A), returned as TYPE
 N DIR,DIRUT,DTOUT,X,Y K DIR
 S ERR=0,TYPE=""
 S DIR(0)="SAO^C:CHEMISTRY;M:MICROBIOLOGY;A:ANATOMIC PATHOLOGY"
 S DIR("A")="Type of data -- C M A : "
 S DIR("B")="C"
 D ^DIR K DIR
 I Y[U!$D(DTOUT) S ERR=1 Q
 S TYPE=Y
 W !
 Q
 ;
GETPT(DFN,ERR) ; from LRPXAPP
 ; asks for a patient, returns DFN
 N DIC,X,Y K DIC,Y
 S ERR=0
 S DIC=2,DIC(0)="AEMOQZ"
 D ^DIC I Y<1 S ERR=-1
 S DFN=+Y
 W !
 Q
 ;
GETCOND(COND,TYPE,ERR) ; from LRPXAPI6,LRPXAPP
 ; asks for a conditional expression, returned as COND
 N DIR,DIRUT,DTOUT,X,Y K DIR
 S TYPE=$G(TYPE,"C")
 S ERR=0,COND=""
 S DIR(0)="FAO^^I '$$CONDOK^LRPXAPIU(X,TYPE) K X"
 S DIR("A")="Condition: "
 D ^DIR K DIR
 I Y[U!$D(DTOUT) S ERR=1 Q
 S COND=Y
 W !
 Q
 ;
GETDATE(FROM,TO,ERR) ; from LRPXAPP
 ; asks for a date range
 ; FROM return as oldest date selection, TO as most recent
 N DIR,DIRUT,DTOUT,X,Y K DIR
 S (FROM,TO,ERR)=0
 S DIR(0)="DAO^2900101:DT:EX"
 S DIR("A")="From: "
 D ^DIR K DIR
 I Y[U!$D(DTOUT) S ERR=1 Q
 I '$L(Y) S (FROM,TO)="" Q
 S FROM=Y
 ;
 N DIR,X,Y K DIR
 S DIR(0)="DAO^2900101:DT:EX"
 S DIR("A")="To: "
 D ^DIR K DIR
 I $D(DIRUT) S FROM=0,ERR=-1 Q
 S TO=Y D DATES^LRPXAPIU(.FROM,.TO)
 W !
 Q
 ;
GETTEST(TEST,TYPE,ERR) ; from LRPXAPP
 ; asks for a lab test, returned as TEST
 N DIC,X,Y K DIC
 S ERR=0
 S DIC=60,DIC(0)="AEMOQ"
 S TYPE=$G(TYPE,"C") D
 . I TYPE="C" S DIC("S")="I $P(^(0),U,4)=""CH"""
 . I TYPE="M" S DIC("S")="I $P(^(0),U,4)=""MI"""
 . I TYPE="A" S DIC("S")="I ""CYEMSPAU""[$P(^(0),U,4),$L($P(^(0),U,4))"
 D ^DIC I Y<1 S ERR=-1
 S TEST=+Y
 W !
 Q
 ;
GETAP(CODE,ERR) ; from LRPXAPP
 ; asks for an AP item, returned as CODE
 N FILE,DIC,DIR,DIRUT,DTOUT,X,Y K DIC,DIR
 S ERR=0,CODE=""
 S DIR(0)="SA^S:SPEC;T:TEST;O:ORGAN;D:DISEASE;M:MORPH;E:ETIOLOGY;F:FUNC;P:PROC;I:ICD"
 S DIR("A")="Type of code -- S T O D M E F P I: "
 D ^DIR K DIR
 I Y[U!$D(DTOUT) S ERR=1 Q
 S FILE=Y
 I FILE="S" D  Q  ; specimen is free text
 . N DIR,DIRUT,DTOUT,X,Y K DIR
 . S DIR(0)="FAO^^"
 . S DIR("A")="Specimen (free text): "
 . D ^DIR K DIR
 . I Y[U!$D(DTOUT) S ERR=1 Q
 . S CODE="A;S;1."_$$UP^XLFSTR(Y)
 D  I Y<1!$D(DTOUT) S ERR=1 Q
 . S DIC(0)="AEMOQ"
 . I FILE="T" D GETTEST(.Y,"A",.ERR) Q
 . I FILE="O" S DIC=61 D ^DIC Q
 . I FILE="D" S DIC=61.4 D ^DIC Q
 . I FILE="M" S DIC=61.1 D ^DIC Q
 . I FILE="E" S DIC=61.2 D ^DIC Q
 . I FILE="F" S DIC=61.3 D ^DIC Q
 . I FILE="P" S DIC=61.5 D ^DIC Q
 . I FILE="I" S DIC=80 D ^DIC Q
 S CODE="A;"_FILE_";"_+Y
 W !
 Q
 ;
GETMICRO(CODE,ERR) ; from LRPXAPP
 ; asks for a Micro item, returned as CODE
 N FILE,DIC,DIR,DIRUT,DTOUT,X,Y K DIC,DIR
 S ERR=0,CODE=""
 S DIR(0)="SA^S:SPEC;T:TEST;O:ORGANISM;A:ANTIMICROBIAL;M:MYCOBACTERIA DRUG"
 S DIR("A")="Type of code -- S T O A M : "
 D ^DIR K DIR
 I Y[U!$D(DTOUT) S ERR=1 Q
 S FILE=Y
 S DIC(0)="AEMOQ"
 D  I Y<1!$D(DTOUT) S ERR=1 Q
 . I FILE="T" D GETTEST(.Y,"M",.ERR) Q
 . I FILE="S" S DIC=61 D ^DIC Q
 . I FILE="O" S DIC=61.2 D ^DIC Q
 . I FILE="A" S DIC=62.06 D ^DIC Q
 . I FILE="M" D  Q
 .. S DIC="^DD(63.39," D ^DIC ; dbia 999
 .. I '$$TBDN^LRPXAPIU(+Y) S Y=-1 Q
 S CODE="M;"_FILE_";"_+Y
 W !
 Q