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

APCLAUD5.m

Go to the documentation of this file.
  1. APCLAUD5 ; IHS/CMI/LAB - USER INTERFACE TO SELECT ICD CODES ;
  1. ;;2.0;IHS PCC SUITE;**11**;MAY 14, 2009;Build 58
  1. ;
  1. ;cmi/anch/maw 9/10/2007 code set versioning in DISPLAY
  1. BEGIN ;
  1. W !
  1. S APCL("NO DISPLAY")=0
  1. D ASK1
  1. I Y="^" S APCLSTP=1 G X
  1. I $D(APCLTABL) D CHECK I Y'=1 G @$S(Y=0:"BEGIN",1:"X")
  1. X I $D(APCLTABL) D SETUTIL
  1. D EOJ
  1. Q
  1. ;
  1. ASK1 ;
  1. ;WHAT CODING SYSTEM?
  1. S APCLSYS="",APCLA=0
  1. W !,"You must enter the coding system from which you want to enter a code,",!,"or range of codes.",!
  1. S DIC="^ICDS(",DIC("S")="I $P(^(0),U,3)=80",DIC(0)="AEMQ" D ^DIC K DIC
  1. I Y=-1 G X1
  1. S APCLSYS=+Y
  1. K APCL("LOW"),APCL("HI")
  1. S DIR("A")=$S('$D(APCLTABL):"Enter Diagnosis (or range of DX codes)",1:"Enter Another Diagnosis (or range of DX codes)") D SETDIR^APCLAUD6,^DIR K DIR
  1. I "^"[Y G X1
  1. D PROCESS
  1. I $D(APCLTABL),'APCL("NO DISPLAY") D RANGES
  1. S APCL("NO DISPLAY")=0
  1. G ASK1
  1. X1 Q
  1. ;
  1. PROCESS ;EVALUATE USER RESPONSE
  1. S (APCLSUB,APCLONE)=0 ;APCLSUB=0 => NO DELETE OF CODE(S),APCLONE=0 => RANGE OF CODES ENTERED
  1. I $E(X,1,2)="-[" W $C(7)," ?? Not allowed" S APCL("NO DISPLAY")=1 G X2
  1. I $E(X,$L(X))="*" D STAR G X2
  1. I X'["-" S APCLTYP="LOW",APCLONE=1 D LOOK^APCLAUD6 G X2
  1. I $E(X)="-",'$D(APCLTABL) W $C(7)," ?? No previous codes entered!" G X2
  1. I $L(X,"-")>3 W $C(7)," ??" S APCLA=1 S APCL("NO DISPLAY")=1 G X2
  1. I $L(X,"-")=3,$E(X,$L(X))="-" W $C(7)," ??" S APCLA=1 S APCL("NO DISPLAY")=1 G X2
  1. I $L(X,"-")=3,$P(X,"-")]"" W $C(7)," ??" S APCLA=1 S APCL("NO DISPLAY")=1 G X2
  1. I $E(X)="-" S APCLSUB=1 D I 1
  1. . S APCLSAVE("X")=X
  1. . I $L(X,"-")=3 S X=$P(APCLSAVE("X"),"-",2),APCLTYP="LOW" D LOOK^APCLAUD6 I 'APCLA S X=$P(APCLSAVE("X"),"-",3),APCLTYP="HI" W ! D LOOK^APCLAUD6 Q
  1. . I $L(APCLSAVE("X"),"-")=2 S X=$E(X,2,99),APCLTYP="LOW",APCLONE=1 D LOOK^APCLAUD6
  1. E S APCLSAVE("X")=X S APCLTYP="LOW",X=$P(APCLSAVE("X"),"-") D LOOK^APCLAUD6 I 'APCLA S APCLTYP="HI",X=$P(APCLSAVE("X"),"-",2) W ! D LOOK^APCLAUD6
  1. X2 Q
  1. ;
  1. DISPLAY ;EP - SHOW CODES IN RANGE SELECTED
  1. W:$D(IOF) @IOF
  1. NEW APCLX,APCLQ,APCLARR,X
  1. ;W !!,"ICD codes in this range =>",!! W $P(APCL("LOW")," ") S APCLDFN=$O(^ICD9("BA",APCL("LOW"),"")) W ?9,$P(^ICD9(APCLDFN,0),U,3) ;cmi/anch/maw 9/10/2007 orig line
  1. W !!,"ICD codes in this range =>",!!
  1. ;call new API to get all codes back in APCLARR
  1. D LST^ATXAPI(APCLSYS,80,$$STRIP^XLFSTR(APCL("LOW"))_"-"_$$STRIP^XLFSTR(APCL("HI")),"CODE","APCLARR")
  1. S APCLX="",APCLQ=0 F S APCLX=$O(APCLARR(APCLX)) Q:APCLX=""!($G(APCLQ)) D
  1. .I $Y>(IOSL-2) D EOP Q:APCLQ
  1. .I $P(APCLARR(APCLX),U,2)=1 W !,APCLX,?12,$E($P($$ICDDX^ICDEX($P(APCLARR(APCLX),U,1)),U,4),1,40),?60,$P(APCLARR(APCLX),U,4) I 1
  1. .E W !,APCLX,?12,$E($P($$ICDDX^ICDEX($P(APCLARR(APCLX),U,1)),U,4),1,40),?60,$P(APCLARR(APCLX),U,4)
  1. NEW DIR
  1. S DIR(0)="E",DIR("A")="Press Enter to Continue <>" D ^DIR
  1. Q
  1. EOP ;
  1. S APCLQ=0
  1. NEW DIR
  1. K DIRUT,DFOUT,DLOUT,DTOUT,DUOUT
  1. S DIR(0)="E" D ^DIR K DIR
  1. I $D(DUOUT) S APCLQ=1 Q
  1. W:$D(IOF) @IOF
  1. Q
  1. ;
  1. SETUTIL ;SET UP UTILITY NODES TO STORE CODES
  1. NEW APCLX,APCLQ,APCLARR
  1. S APCLIRNG=0,APCL("LOW")="" F S APCL("LOW")=$O(APCLTABL(APCL("LOW"))) Q:APCL("LOW")="" S APCL("HI")=$P(APCLTABL(APCL("LOW")),U,1) D
  1. .S APCLIRNG=APCLIRNG+1
  1. .KILL APCLX,APCLQ,APCLARR
  1. .D LST^ATXAPI(APCLSYS,80,$$STRIP^XLFSTR(APCL("LOW"))_"-"_$$STRIP^XLFSTR(APCL("HI")),"CODE","APCLARR")
  1. .S ^XTMP("APCLAUD",APCLJOB,APCLBT,APCLIRNG,"ICDB")=APCL("LOW")
  1. .S ^XTMP("APCLAUD",APCLJOB,APCLBT,APCLIRNG,"ICDE")=APCL("HI")
  1. .;S APCLDFN=$$CODEN^ICDEX(APCL("LOW")),^XTMP("APCLAUD",APCLJOB,APCLBT,"ICDDFN",APCLDFN,APCLIRNG)=""
  1. .S X="" F S X=$O(APCLARR(X)) Q:X="" D
  1. ..S ^XTMP("APCLAUD",APCLJOB,APCLBT,"ICDDFN",$P(APCLARR(X),U,1),APCLIRNG)=""
  1. .Q
  1. Q
  1. RANGES ;DISPLAY TABLE OF ALL RANGES
  1. W:$D(IOF) @IOF
  1. W !!,"ICD Code Range(s) Selected So Far =>",!
  1. S (APCL("NUM"),APCL)=0 F S APCL=$O(APCLTABL(APCL)) Q:APCL="" S APCL("NUM")=APCL("NUM")+1 W !,APCL("NUM"),") ",APCL,$S(APCL'=$P(APCLTABL(APCL),U,1):"- "_$P(APCLTABL(APCL),U,1),1:"")
  1. I '$D(APCL("BANG")) W !
  1. Q
  1. ;
  1. SHOW ; ENTRY POINT - ALLOW USER TO SELECT FROM RANGES TO DISPLAY CODES
  1. D RANGES
  1. A W !,"Enter an Item Number from the table above to display code(s): " R APCL("N"):300 W:"^"[APCL("N") ! Q:"^"[APCL("N") I APCL("N")'?1N!(APCL("N")>APCL("NUM")) W " ??",$C(7) G A
  1. F APCLI=1:1:APCL("N") S APCL=$O(APCLTABL(APCL)) I APCLI=APCL("N") S APCL("LOW")=APCL,APCL("HI")=$P(APCLTABL(APCL),U,1) D DISPLAY Q
  1. S APCL("BANG")="" D RANGES K APCL("BANG")
  1. Q
  1. ;
  1. ;
  1. CHECK ;ASKS USER IF SATISFIED WITH ENTERED RANGES
  1. NEW DIR
  1. W ! S DIR(0)="Y",DIR("B")="Y",DIR("A")="Are all of the ICD ranges okay" D ^DIR K DIR
  1. W !
  1. Q
  1. ;
  1. EOJ ;ENTRY POINT
  1. I $D(APCL("NOT TAX")) K APCLSTP,APCLX
  1. K APCLSUB,APCLTYP,APCLDFN,DIR,APCLSAVE,APCLA,APCLCNT,APCL,APCLR,APCLI,APCLONE,APCLFLG
  1. Q
  1. ;
  1. STAR ;
  1. I $E(X)="-" S APCLSUB=1
  1. NEW APCLTEMP
  1. D LST^ATXAPI(APCLSYS,80,$S($E(X)="-":$E(X,2,999),1:X),"CODE","APCLTEMP")
  1. I '$D(APCLTEMP) W " ?? There are no codes in that range!" S APCL("NO DISPLAY")=1 Q
  1. S APCL("LOW")=$O(APCLTEMP(0))
  1. NEW Z,C
  1. S (Z,C)="" F S Z=$O(APCLTEMP(Z)) Q:Z="" S C=Z
  1. S APCL("HI")=C
  1. D DISPLAY
  1. D ^APCLAUD7
  1. Q