APCLD8TL ; IHS/CMI/LAB - DISPLAY IND LISTS ;
;;2.0;IHS PCC SUITE;;MAY 14, 2009
;; ;
EP(APCLTAXI) ;EP - CALLED FROM OPTION
D EN
Q
EOJ ;EP
D EN^XBVK("APCL")
Q
;; ;
EN ;EP -- main entry point for
D EN^VALM("APCLD8 TAXONOMY EDIT")
D CLEAR^VALM1
D FULL^VALM1
W:$D(IOF) @IOF
D EOJ
Q
;
HDR ; -- header code
S VALMHDR(1)="Updating the "_APCLTAXN_" taxonomy"
Q
;
INIT ; -- init variables and list array
I APCLTAXT="L" D LAB Q
K APCLLAB S APCLHIGH="",C=0
S APCLX=0 F S APCLX=$O(^ATXAX(APCLTAXI,21,APCLX)) Q:APCLX'=+APCLX D
.S C=C+1
.S APCLLABI=$P(^ATXAX(APCLTAXI,21,APCLX,0),U)
.S APCLLAB(C,0)=C_") "_$$VAL^XBDIQ1($P(^ATXAX(APCLTAXI,0),U,15),APCLLABI,.01)
.S APCLLAB("IDX",C,C)=APCLLABI
.Q
S (VALMCNT,APCLHIGH)=C
Q
LAB ;
K APCLLAB S APCLHIGH="",C=0
S APCLX=0 F S APCLX=$O(^ATXLAB(APCLTAXI,21,APCLX)) Q:APCLX'=+APCLX D
.S C=C+1
.S APCLLABI=$P(^ATXLAB(APCLTAXI,21,APCLX,0),U)
.S APCLLAB(C,0)=C_") "_$P($G(^LAB(60,APCLLABI,0)),U)
.S APCLLAB("IDX",C,C)=APCLLABI
.Q
S (VALMCNT,APCLHIGH)=C
Q
;
HELP ; -- help code
S X="?" D DISP^XQORM1 W !!
Q
;
EXIT ; -- exit code
Q
;
EXPND ; -- expand code
Q
;
BACK ;go back to listman
D TERM^VALM0
S VALMBCK="R"
D INIT
D HDR
K DIR
K X,Y,Z,I
Q
;
REM ;
W ! K DIR
S DIR(0)="NO^1:"_APCLHIGH,DIR("A")="Remove Which Item"
D ^DIR K DIR S:$D(DUOUT) DIRUT=1
I Y="" W !,"No item selected." G REMX
I $D(DIRUT) W !,"No item selected." G REMX
S APCLLABI=APCLLAB("IDX",Y,Y)
;sure
I APCLTAXT="L" K DIR S DIR(0)="Y",DIR("A")="Are you sure you want to remove the "_$P(^LAB(60,APCLLABI,0),U)_" lab test",DIR("B")="N" KILL DA D ^DIR KILL DIR
I APCLTAXT="T" K DIR S DIR(0)="Y",DIR("A")="Are you sure you want to remove the "_$$VAL^XBDIQ1($P(^ATXAX(APCLTAXI,0),U,15),APCLLABI,.01)_" "_$$VAL^XBDIQ1(9002226,APCLTAXI,.15),DIR("B")="N" KILL DA D ^DIR KILL DIR
I 'Y G REM
I $D(DIRUT) G REMX
D ^XBFMK
I APCLTAXT="L" S DA(1)=APCLTAXI,DA=$O(^ATXLAB(APCLTAXI,21,"B",APCLLABI,0)),DIE="^ATXLAB("_APCLTAXI_",21,",DR=".01///@" D ^DIE
I APCLTAXT="T" S DA(1)=APCLTAXI,DA=$O(^ATXAX(APCLTAXI,21,"B",APCLLABI,0)),DIE="^ATXAX("_APCLTAXI_",21,",DR=".01///@" D ^DIE
REMX ;
D ^XBFMK
D BACK
Q
ADD ;EP - add an item to the selected list - called from a protocol
D FULL^VALM1
W !
I APCLTAXT="L" D LABADD G ADDX
K DIC
S DIC(0)="AEMQ",DIC=$P(^ATXAX(APCLTAXI,0),U,15) D ^DIC
I Y=-1 G ADDX
I $D(^ATXAX(APCLTAXI,21,"B",+Y)) W !!,"That item is already in the taxonomy." H 2 G ADD
S DA=APCLTAXI
S (X,APCLTXLI)=+Y
S APCLFILE=$P(^ATXAX(APCLTAXI,0),U,15)
S DA(1)=APCLTAXI
S DIC="^ATXAX("_DA_",21,"
S DIC(0)="L",DIC("DR")=".02////"_APCLTXLI K DD,DO
S:'$D(^ATXAX(DA,21,0)) ^ATXAX(DA,21,0)="^9002226.02101A"
D FILE^DICN
I '$D(^ATXAX(APCLTAXI,21,"B",APCLTXLI)) W !!,"adding ITEM failed." H 2 G ADD
G ADDX
LABADD ;
K DIC
S DIC(0)="AEMQ",DIC="^LAB(60,",DIC("A")="Which LAB Test: " D ^DIC
I Y=-1 G ADDX
S APCLTXLI=+Y
I '$P(^ATXLAB(APCLTAXI,0),U,11),$O(^LAB(60,APCLTXLI,2,0)) S APCLYN="" D G:'APCLYN ADDX
.W !!,"This lab test, ",$P(^LAB(60,APCLTXLI,0),U),", is a panel test and the"
.W !,"taxonomy ",$P(^ATXLAB(APCLTAXI,0),U)," should not contain panel tests.",!
.S DIR(0)="Y",DIR("A")="Do you still want to add this lab test to this taxonomy",DIR("B")="N" KILL DA D ^DIR KILL DIR
.Q:$D(DIRUT)
.S APCLYN=Y
I $D(^ATXLAB(APCLTAXI,21,"B",+Y)) W !!,"Lab test ",$P(^LAB(60,+Y,0),U)," is already in the taxonomy." H 2 G ADD
S DA=APCLTAXI
S X=APCLTXLI
S DA(1)=APCLTAXI
S DIC="^ATXLAB("_DA_",21,"
S DIC(0)="L" K DD,DO
S:'$D(^ATXLAB(DA,21,0)) ^ATXLAB(DA,21,0)="^9002228.02101PA"
D FILE^DICN
I '$D(^ATXLAB(APCLTAXI,21,"B",APCLTXLI)) W !!,"adding lab test failed." H 2 G ADD
ADDX ;
K DIC,DA,DR,APCLTXLI,DD,DO,APCLFILE
D BACK
Q
APCLD8TL ; IHS/CMI/LAB - DISPLAY IND LISTS ;
+1 ;;2.0;IHS PCC SUITE;;MAY 14, 2009
+2 ;; ;
EP(APCLTAXI) ;EP - CALLED FROM OPTION
+1 DO EN
+2 QUIT
EOJ ;EP
+1 DO EN^XBVK("APCL")
+2 QUIT
+3 ;; ;
EN ;EP -- main entry point for
+1 DO EN^VALM("APCLD8 TAXONOMY EDIT")
+2 DO CLEAR^VALM1
+3 DO FULL^VALM1
+4 IF $DATA(IOF)
WRITE @IOF
+5 DO EOJ
+6 QUIT
+7 ;
HDR ; -- header code
+1 SET VALMHDR(1)="Updating the "_APCLTAXN_" taxonomy"
+2 QUIT
+3 ;
INIT ; -- init variables and list array
+1 IF APCLTAXT="L"
DO LAB
QUIT
+2 KILL APCLLAB
SET APCLHIGH=""
SET C=0
+3 SET APCLX=0
FOR
SET APCLX=$ORDER(^ATXAX(APCLTAXI,21,APCLX))
IF APCLX'=+APCLX
QUIT
Begin DoDot:1
+4 SET C=C+1
+5 SET APCLLABI=$PIECE(^ATXAX(APCLTAXI,21,APCLX,0),U)
+6 SET APCLLAB(C,0)=C_") "_$$VAL^XBDIQ1($PIECE(^ATXAX(APCLTAXI,0),U,15),APCLLABI,.01)
+7 SET APCLLAB("IDX",C,C)=APCLLABI
+8 QUIT
End DoDot:1
+9 SET (VALMCNT,APCLHIGH)=C
+10 QUIT
LAB ;
+1 KILL APCLLAB
SET APCLHIGH=""
SET C=0
+2 SET APCLX=0
FOR
SET APCLX=$ORDER(^ATXLAB(APCLTAXI,21,APCLX))
IF APCLX'=+APCLX
QUIT
Begin DoDot:1
+3 SET C=C+1
+4 SET APCLLABI=$PIECE(^ATXLAB(APCLTAXI,21,APCLX,0),U)
+5 SET APCLLAB(C,0)=C_") "_$PIECE($GET(^LAB(60,APCLLABI,0)),U)
+6 SET APCLLAB("IDX",C,C)=APCLLABI
+7 QUIT
End DoDot:1
+8 SET (VALMCNT,APCLHIGH)=C
+9 QUIT
+10 ;
HELP ; -- help code
+1 SET X="?"
DO DISP^XQORM1
WRITE !!
+2 QUIT
+3 ;
EXIT ; -- exit code
+1 QUIT
+2 ;
EXPND ; -- expand code
+1 QUIT
+2 ;
BACK ;go back to listman
+1 DO TERM^VALM0
+2 SET VALMBCK="R"
+3 DO INIT
+4 DO HDR
+5 KILL DIR
+6 KILL X,Y,Z,I
+7 QUIT
+8 ;
REM ;
+1 WRITE !
KILL DIR
+2 SET DIR(0)="NO^1:"_APCLHIGH
SET DIR("A")="Remove Which Item"
+3 DO ^DIR
KILL DIR
IF $DATA(DUOUT)
SET DIRUT=1
+4 IF Y=""
WRITE !,"No item selected."
GOTO REMX
+5 IF $DATA(DIRUT)
WRITE !,"No item selected."
GOTO REMX
+6 SET APCLLABI=APCLLAB("IDX",Y,Y)
+7 ;sure
+8 IF APCLTAXT="L"
KILL DIR
SET DIR(0)="Y"
SET DIR("A")="Are you sure you want to remove the "_$PIECE(^LAB(60,APCLLABI,0),U)_" lab test"
SET DIR("B")="N"
KILL DA
DO ^DIR
KILL DIR
+9 IF APCLTAXT="T"
KILL DIR
SET DIR(0)="Y"
SET DIR("A")="Are you sure you want to remove the "_$$VAL^XBDIQ1($PIECE(^ATXAX(APCLTAXI,0),U,15),APCLLABI,.01)_" "_$$VAL^XBDIQ1(9002226,APCLTAXI,.15)
SET DIR("B")="N"
KILL DA
DO ^DIR
KILL DIR
+10 IF 'Y
GOTO REM
+11 IF $DATA(DIRUT)
GOTO REMX
+12 DO ^XBFMK
+13 IF APCLTAXT="L"
SET DA(1)=APCLTAXI
SET DA=$ORDER(^ATXLAB(APCLTAXI,21,"B",APCLLABI,0))
SET DIE="^ATXLAB("_APCLTAXI_",21,"
SET DR=".01///@"
DO ^DIE
+14 IF APCLTAXT="T"
SET DA(1)=APCLTAXI
SET DA=$ORDER(^ATXAX(APCLTAXI,21,"B",APCLLABI,0))
SET DIE="^ATXAX("_APCLTAXI_",21,"
SET DR=".01///@"
DO ^DIE
REMX ;
+1 DO ^XBFMK
+2 DO BACK
+3 QUIT
ADD ;EP - add an item to the selected list - called from a protocol
+1 DO FULL^VALM1
+2 WRITE !
+3 IF APCLTAXT="L"
DO LABADD
GOTO ADDX
+4 KILL DIC
+5 SET DIC(0)="AEMQ"
SET DIC=$PIECE(^ATXAX(APCLTAXI,0),U,15)
DO ^DIC
+6 IF Y=-1
GOTO ADDX
+7 IF $DATA(^ATXAX(APCLTAXI,21,"B",+Y))
WRITE !!,"That item is already in the taxonomy."
HANG 2
GOTO ADD
+8 SET DA=APCLTAXI
+9 SET (X,APCLTXLI)=+Y
+10 SET APCLFILE=$PIECE(^ATXAX(APCLTAXI,0),U,15)
+11 SET DA(1)=APCLTAXI
+12 SET DIC="^ATXAX("_DA_",21,"
+13 SET DIC(0)="L"
SET DIC("DR")=".02////"_APCLTXLI
KILL DD,DO
+14 IF '$DATA(^ATXAX(DA,21,0))
SET ^ATXAX(DA,21,0)="^9002226.02101A"
+15 DO FILE^DICN
+16 IF '$DATA(^ATXAX(APCLTAXI,21,"B",APCLTXLI))
WRITE !!,"adding ITEM failed."
HANG 2
GOTO ADD
+17 GOTO ADDX
LABADD ;
+1 KILL DIC
+2 SET DIC(0)="AEMQ"
SET DIC="^LAB(60,"
SET DIC("A")="Which LAB Test: "
DO ^DIC
+3 IF Y=-1
GOTO ADDX
+4 SET APCLTXLI=+Y
+5 IF '$PIECE(^ATXLAB(APCLTAXI,0),U,11)
IF $ORDER(^LAB(60,APCLTXLI,2,0))
SET APCLYN=""
Begin DoDot:1
+6 WRITE !!,"This lab test, ",$PIECE(^LAB(60,APCLTXLI,0),U),", is a panel test and the"
+7 WRITE !,"taxonomy ",$PIECE(^ATXLAB(APCLTAXI,0),U)," should not contain panel tests.",!
+8 SET DIR(0)="Y"
SET DIR("A")="Do you still want to add this lab test to this taxonomy"
SET DIR("B")="N"
KILL DA
DO ^DIR
KILL DIR
+9 IF $DATA(DIRUT)
QUIT
+10 SET APCLYN=Y
End DoDot:1
IF 'APCLYN
GOTO ADDX
+11 IF $DATA(^ATXLAB(APCLTAXI,21,"B",+Y))
WRITE !!,"Lab test ",$PIECE(^LAB(60,+Y,0),U)," is already in the taxonomy."
HANG 2
GOTO ADD
+12 SET DA=APCLTAXI
+13 SET X=APCLTXLI
+14 SET DA(1)=APCLTAXI
+15 SET DIC="^ATXLAB("_DA_",21,"
+16 SET DIC(0)="L"
KILL DD,DO
+17 IF '$DATA(^ATXLAB(DA,21,0))
SET ^ATXLAB(DA,21,0)="^9002228.02101PA"
+18 DO FILE^DICN
+19 IF '$DATA(^ATXLAB(APCLTAXI,21,"B",APCLTXLI))
WRITE !!,"adding lab test failed."
HANG 2
GOTO ADD
ADDX ;
+1 KILL DIC,DA,DR,APCLTXLI,DD,DO,APCLFILE
+2 DO BACK
+3 QUIT