- BGP4CTL ; IHS/CMI/LAB - DISPLAY IND LISTS ;
- ;;14.1;IHS CLINICAL REPORTING;;MAY 29, 2014;Build 114
- ;; ;
- EP(BGPTAXI) ;EP - CALLED FROM OPTION
- NEW BGPRPTTT,BGPRPTT1,BGPRPTT2
- D EN
- Q
- EOJ ;EP
- D EN^XBVK("BGP")
- Q
- ;; ;
- EN ;EP -- main entry point for
- D EN^VALM("BGP 14 CMS TAXONOMY EDIT")
- D CLEAR^VALM1
- D FULL^VALM1
- W:$D(IOF) @IOF
- D EOJ
- Q
- ;
- HDR ; -- header code
- S VALMHDR(1)="Updating the "_BGPTAXN_" taxonomy"
- Q
- ;
- INIT ; -- init variables and list array
- I BGPTAXJ="L" D LAB Q
- K BGPLAB S BGPHIGH="",C=0
- S BGPX=0 F S BGPX=$O(^ATXAX(BGPTAXI,21,BGPX)) Q:BGPX'=+BGPX D
- .S C=C+1
- .S BGPLABI=$P(^ATXAX(BGPTAXI,21,BGPX,0),U)
- .S BGPLAB(C,0)=C_") "_$$VAL^XBDIQ1($P(^ATXAX(BGPTAXI,0),U,15),BGPLABI,.01)
- .S BGPLAB("IDX",C,C)=BGPLABI
- .Q
- S (VALMCNT,BGPHIGH)=C
- Q
- LAB ;
- K BGPLAB S BGPHIGH="",C=0
- S BGPX=0 F S BGPX=$O(^ATXLAB(BGPTAXI,21,BGPX)) Q:BGPX'=+BGPX D
- .S C=C+1
- .S BGPLABI=$P(^ATXLAB(BGPTAXI,21,BGPX,0),U)
- .S BGPLAB(C,0)=C_") "_$P($G(^LAB(60,BGPLABI,0)),U)
- .S BGPLAB("IDX",C,C)=BGPLABI
- .Q
- S (VALMCNT,BGPHIGH)=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:"_BGPHIGH,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 BGPLABI=BGPLAB("IDX",Y,Y)
- ;sure
- I BGPTAXJ="L" K DIR S DIR(0)="Y",DIR("A")="Are you sure you want to remove the "_$P(^LAB(60,BGPLABI,0),U)_" lab test",DIR("B")="N" KILL DA D ^DIR KILL DIR
- I BGPTAXJ="T" K DIR S DIR(0)="Y",DIR("A")="Are you sure you want to remove the "_$$VAL^XBDIQ1($P(^ATXAX(BGPTAXI,0),U,15),BGPLABI,.01)_" "_$$VAL^XBDIQ1(9002226,BGPTAXI,.15),DIR("B")="N" KILL DA D ^DIR KILL DIR
- I 'Y G REM
- I $D(DIRUT) G REMX
- D ^XBFMK
- I BGPTAXJ="L" S DA(1)=BGPTAXI,DA=$O(^ATXLAB(BGPTAXI,21,"B",BGPLABI,0)),DIE="^ATXLAB("_BGPTAXI_",21,",DR=".01///@" D ^DIE
- I BGPTAXJ="T" S DA(1)=BGPTAXI,DA=$O(^ATXAX(BGPTAXI,21,"B",BGPLABI,0)),DIE="^ATXAX("_BGPTAXI_",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 BGPTAXJ="L" D LABADD G ADDX
- K DIC
- S DIC(0)="AEMQ",DIC=$P(^ATXAX(BGPTAXI,0),U,15) D ^DIC
- I Y=-1 G ADDX
- I $D(^ATXAX(BGPTAXI,21,"B",+Y)) W !!,"That item is already in the taxonomy." H 2 G ADD
- S DA=BGPTAXI
- S (X,BGPTXLI)=+Y
- S BGPFILE=$P(^ATXAX(BGPTAXI,0),U,15)
- S DA(1)=BGPTAXI
- S DIC="^ATXAX("_DA_",21,"
- S DIC(0)="L",DIC("DR")=".02////"_BGPTXLI K DD,DO
- S:'$D(^ATXAX(DA,21,0)) ^ATXAX(DA,21,0)="^9002226.02101A"
- D FILE^DICN
- I '$D(^ATXAX(BGPTAXI,21,"B",BGPTXLI)) 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
- I $D(^ATXLAB(BGPTAXI,21,"B",+Y)) W !!,"Lab test ",$P(^LAB(60,+Y,0),U)," is already in the taxonomy." H 2 G ADD
- S DA=BGPTAXI
- S (X,BGPTXLI)=+Y
- S DA(1)=BGPTAXI
- 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(BGPTAXI,21,"B",BGPTXLI)) W !!,"adding lab test failed." H 2 G ADD
- ADDX ;
- K DIC,DA,DR,BGPTXLI,DD,DO,BGPFILE
- D BACK
- Q
- BGP4CTL ; IHS/CMI/LAB - DISPLAY IND LISTS ;
- +1 ;;14.1;IHS CLINICAL REPORTING;;MAY 29, 2014;Build 114
- +2 ;; ;
- EP(BGPTAXI) ;EP - CALLED FROM OPTION
- +1 NEW BGPRPTTT,BGPRPTT1,BGPRPTT2
- +2 DO EN
- +3 QUIT
- EOJ ;EP
- +1 DO EN^XBVK("BGP")
- +2 QUIT
- +3 ;; ;
- EN ;EP -- main entry point for
- +1 DO EN^VALM("BGP 14 CMS 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 "_BGPTAXN_" taxonomy"
- +2 QUIT
- +3 ;
- INIT ; -- init variables and list array
- +1 IF BGPTAXJ="L"
- DO LAB
- QUIT
- +2 KILL BGPLAB
- SET BGPHIGH=""
- SET C=0
- +3 SET BGPX=0
- FOR
- SET BGPX=$ORDER(^ATXAX(BGPTAXI,21,BGPX))
- IF BGPX'=+BGPX
- QUIT
- Begin DoDot:1
- +4 SET C=C+1
- +5 SET BGPLABI=$PIECE(^ATXAX(BGPTAXI,21,BGPX,0),U)
- +6 SET BGPLAB(C,0)=C_") "_$$VAL^XBDIQ1($PIECE(^ATXAX(BGPTAXI,0),U,15),BGPLABI,.01)
- +7 SET BGPLAB("IDX",C,C)=BGPLABI
- +8 QUIT
- End DoDot:1
- +9 SET (VALMCNT,BGPHIGH)=C
- +10 QUIT
- LAB ;
- +1 KILL BGPLAB
- SET BGPHIGH=""
- SET C=0
- +2 SET BGPX=0
- FOR
- SET BGPX=$ORDER(^ATXLAB(BGPTAXI,21,BGPX))
- IF BGPX'=+BGPX
- QUIT
- Begin DoDot:1
- +3 SET C=C+1
- +4 SET BGPLABI=$PIECE(^ATXLAB(BGPTAXI,21,BGPX,0),U)
- +5 SET BGPLAB(C,0)=C_") "_$PIECE($GET(^LAB(60,BGPLABI,0)),U)
- +6 SET BGPLAB("IDX",C,C)=BGPLABI
- +7 QUIT
- End DoDot:1
- +8 SET (VALMCNT,BGPHIGH)=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:"_BGPHIGH
- 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 BGPLABI=BGPLAB("IDX",Y,Y)
- +7 ;sure
- +8 IF BGPTAXJ="L"
- KILL DIR
- SET DIR(0)="Y"
- SET DIR("A")="Are you sure you want to remove the "_$PIECE(^LAB(60,BGPLABI,0),U)_" lab test"
- SET DIR("B")="N"
- KILL DA
- DO ^DIR
- KILL DIR
- +9 IF BGPTAXJ="T"
- KILL DIR
- SET DIR(0)="Y"
- SET DIR("A")="Are you sure you want to remove the "_$$VAL^XBDIQ1($PIECE(^ATXAX(BGPTAXI,0),U,15),BGPLABI,.01)_" "_$$VAL^XBDIQ1(9002226,BGPTAXI,.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 BGPTAXJ="L"
- SET DA(1)=BGPTAXI
- SET DA=$ORDER(^ATXLAB(BGPTAXI,21,"B",BGPLABI,0))
- SET DIE="^ATXLAB("_BGPTAXI_",21,"
- SET DR=".01///@"
- DO ^DIE
- +14 IF BGPTAXJ="T"
- SET DA(1)=BGPTAXI
- SET DA=$ORDER(^ATXAX(BGPTAXI,21,"B",BGPLABI,0))
- SET DIE="^ATXAX("_BGPTAXI_",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 BGPTAXJ="L"
- DO LABADD
- GOTO ADDX
- +4 KILL DIC
- +5 SET DIC(0)="AEMQ"
- SET DIC=$PIECE(^ATXAX(BGPTAXI,0),U,15)
- DO ^DIC
- +6 IF Y=-1
- GOTO ADDX
- +7 IF $DATA(^ATXAX(BGPTAXI,21,"B",+Y))
- WRITE !!,"That item is already in the taxonomy."
- HANG 2
- GOTO ADD
- +8 SET DA=BGPTAXI
- +9 SET (X,BGPTXLI)=+Y
- +10 SET BGPFILE=$PIECE(^ATXAX(BGPTAXI,0),U,15)
- +11 SET DA(1)=BGPTAXI
- +12 SET DIC="^ATXAX("_DA_",21,"
- +13 SET DIC(0)="L"
- SET DIC("DR")=".02////"_BGPTXLI
- 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(BGPTAXI,21,"B",BGPTXLI))
- 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 IF $DATA(^ATXLAB(BGPTAXI,21,"B",+Y))
- WRITE !!,"Lab test ",$PIECE(^LAB(60,+Y,0),U)," is already in the taxonomy."
- HANG 2
- GOTO ADD
- +5 SET DA=BGPTAXI
- +6 SET (X,BGPTXLI)=+Y
- +7 SET DA(1)=BGPTAXI
- +8 SET DIC="^ATXLAB("_DA_",21,"
- +9 SET DIC(0)="L"
- KILL DD,DO
- +10 IF '$DATA(^ATXLAB(DA,21,0))
- SET ^ATXLAB(DA,21,0)="^9002228.02101PA"
- +11 DO FILE^DICN
- +12 IF '$DATA(^ATXLAB(BGPTAXI,21,"B",BGPTXLI))
- WRITE !!,"adding lab test failed."
- HANG 2
- GOTO ADD
- ADDX ;
- +1 KILL DIC,DA,DR,BGPTXLI,DD,DO,BGPFILE
- +2 DO BACK
- +3 QUIT