| [613] | 1 | IBDFLST ;ALM/MAF - Maintenance Utility Invalid Codes List - MAY 17 1995
 | 
|---|
 | 2 |  ;;3.0;AUTOMATED INFO COLLECTION SYS;**9,38,51**;APR 24, 1997
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 |  ;
 | 
|---|
 | 5 | START ;  -- Ask what invalid code you want to display CPT/ ICD9/ Visit
 | 
|---|
 | 6 |  N IBDFDIS
 | 
|---|
 | 7 |  D FULL^VALM1
 | 
|---|
 | 8 |  S DIR("B")="CPT",DIR(0)="SBM^C:CPT;I:ICD9;V:VISIT",DIR("A")="Display invalid codes for [C]PT, [I]CD9, [V]ISIT" D ^DIR
 | 
|---|
 | 9 |  K DIR I $D(DIRUT)!(Y<0) G QUIT
 | 
|---|
 | 10 |  ;W !!,"Display invalid codes for CPT// " D ZSET1^IBDFLST1 S X="" R X:DTIME G QUIT:X="^"!('$T) I X=""!("Cc"[X) S X="1"
 | 
|---|
 | 11 |  S X=$S("Ii"[X:2,"Vv"[X:3,1:1)
 | 
|---|
 | 12 |  ;I X="?" D ZSET1^IBDFLST1,HELP1^IBDFLST1 G START
 | 
|---|
 | 13 |  S IBDFTYP=$E(X)  ; D IN^DGHELP W ! I %=-1 D ZSET1^IBDFLST1,HELP1^IBDFLST1 G START
 | 
|---|
 | 14 |  S IBDFDIS=$S(IBDFTYP=1:"CPT",IBDFTYP=2:"ICD9",IBDFTYP=3:"VISIT",1:"QUIT")
 | 
|---|
 | 15 |  D WAIT^DICD
 | 
|---|
 | 16 |  D EN^VALM("IBDF UTIL COMPLETE LIST TEMP")
 | 
|---|
 | 17 |  Q
 | 
|---|
 | 18 |  ;
 | 
|---|
 | 19 |  ;
 | 
|---|
 | 20 | HDR ; -- header code
 | 
|---|
 | 21 |  S VALMHDR(1)="This screen displays the most current invalid codes for the "_IBDFDIS_" file."
 | 
|---|
 | 22 |  Q
 | 
|---|
 | 23 |  ;
 | 
|---|
 | 24 |  ;
 | 
|---|
 | 25 | SETSTR(S,V,X,L) ; -- insert text(S) into variable(V)
 | 
|---|
 | 26 |  ;    S := string
 | 
|---|
 | 27 |  ;    V := destination
 | 
|---|
 | 28 |  ;    X := @ col X
 | 
|---|
 | 29 |  ;    L := # of chars
 | 
|---|
 | 30 |  ;
 | 
|---|
 | 31 |  Q $E(V_$J("",X-1),1,X-1)_$E(S_$J("",L),1,L)_$E(V,X+L,999)
 | 
|---|
 | 32 |  ;
 | 
|---|
 | 33 |  ;
 | 
|---|
 | 34 | INIT ;  -- Set up list for display
 | 
|---|
 | 35 |  N IBDFCODE,IBDFDESC,IBDFIFN,IBDFCAT
 | 
|---|
 | 36 |  S (IBDCNT,VALMCNT,IBDCNT1)=0
 | 
|---|
 | 37 |  D @(IBDFDIS)
 | 
|---|
 | 38 |  Q
 | 
|---|
 | 39 |  ;
 | 
|---|
 | 40 |  ;  -- Gets CPT listing of invalid codes
 | 
|---|
 | 41 | CPT D FULL^VALM1 F IBDFIFN=0:0 S IBDFIFN=$O(^ICPT(IBDFIFN)) Q:'IBDFIFN  D
 | 
|---|
 | 42 |  .;; --change to api cpt ; dhh
 | 
|---|
 | 43 |  .;;     --note: 7th piece is status 0-inactive 1-active
 | 
|---|
 | 44 |  . S IBDFNODE=$$CPT^ICPTCOD(IBDFIFN),IBDFNODE=$G(IBDFNODE)
 | 
|---|
 | 45 |  . I $P(IBDFNODE,"^",7)=0 D
 | 
|---|
 | 46 |  .. S IBDFCODE=$P(IBDFNODE,"^",2),IBDFDESC=$P(IBDFNODE,"^",3)
 | 
|---|
 | 47 |  .. S IBDFCAT=$S($P(IBDFNODE,"^",4)]"":$P(^DIC(81.1,$P(IBDFNODE,"^",4),0),"^",1),1:"UNKNOWN") D ALPHA
 | 
|---|
 | 48 |  D LOOP
 | 
|---|
 | 49 |  Q
 | 
|---|
 | 50 |  ;
 | 
|---|
 | 51 |  ;  -- Gets ICD9 listing onf invalid codes
 | 
|---|
 | 52 |  ;  -- Use api for ICD9
 | 
|---|
 | 53 | ICD9 ;;F IBDFIFN=0:0 S IBDFIFN=$O(^ICD9(IBDFIFN)) Q:'IBDFIFN  S IBDFNODE=$G(^ICD9(IBDFIFN,0)) I $P(IBDFNODE,"^",9)]"" D
 | 
|---|
 | 54 |  ;
 | 
|---|
 | 55 |  ;Use ICD API to check the status for CSV.  No date is passed so the
 | 
|---|
 | 56 |  ;default day is DT (today).  $P10 = status 0-inactive 1-active
 | 
|---|
 | 57 |  F IBDFIFN=0:0 S IBDFIFN=$O(^ICD9(IBDFIFN)) Q:'IBDFIFN  S IBDFNODE=$$ICDDX^ICDCODE(IBDFIFN) I '$P(IBDFNODE,U,10) D
 | 
|---|
 | 58 |  .S IBDFCODE=$P(IBDFNODE,"^",2),IBDFDESC=$P(IBDFNODE,"^",4),IBDFCAT=$S($P(IBDFNODE,"^",6)]""&($G(^ICM(+$P(IBDFNODE,"^",6),0))]""):$P(^ICM($P(IBDFNODE,"^",6),0),"^",1),1:"UNKNOWN") D ALPHA
 | 
|---|
 | 59 |  D LOOP
 | 
|---|
 | 60 |  Q
 | 
|---|
 | 61 |  ;
 | 
|---|
 | 62 |  ;
 | 
|---|
 | 63 | VISIT ;  -- Gets visit code listing of invalid codes
 | 
|---|
 | 64 |  N IEN
 | 
|---|
 | 65 |  F IBDFVST=0:0 S IBDFVST=$O(^IBE(357.69,"B",IBDFVST)) Q:'IBDFVST  D
 | 
|---|
 | 66 |  . S IEN=$O(^IBE(357.69,"B",IBDFVST,0))
 | 
|---|
 | 67 |  . Q:'IEN
 | 
|---|
 | 68 |  . S IBDFNODE=$$CPT^ICPTCOD(IBDFVST)
 | 
|---|
 | 69 |  . Q:$P(IBDFNODE,U,7)=1  ;(CSV) status 0-inactive 1-active
 | 
|---|
 | 70 |  . ;;Q:+IBDFNODE=-1
 | 
|---|
 | 71 |  . S IBDFIFN=+IBDFNODE
 | 
|---|
 | 72 |  . S IBDFCODE=$P(IBDFNODE,"^",2)
 | 
|---|
 | 73 |  . S IBDFDESC=$P(IBDFNODE,"^",3)
 | 
|---|
 | 74 |  . S IBDFCAT=$S($P(IBDFNODE,"^",4)]"":$P(^DIC(81.1,$P(IBDFNODE,"^",4),0),"^",1),1:"UNKNOWN")
 | 
|---|
 | 75 |  . D ALPHA
 | 
|---|
 | 76 |  D LOOP
 | 
|---|
 | 77 |  Q
 | 
|---|
 | 78 |  ;
 | 
|---|
 | 79 |  ;
 | 
|---|
 | 80 | LOOP ;  -- Loop thru global ^TMP("ALPHA",$J) alphabetic by category
 | 
|---|
 | 81 |  S IBDFCAT=0
 | 
|---|
 | 82 |  F IBDCAT=0:0 S IBDFCAT=$O(^TMP("ALPHA",$J,IBDFCAT)) Q:IBDFCAT']""  F IBDFIFN=0:0 S IBDFIFN=$O(^TMP("ALPHA",$J,IBDFCAT,IBDFIFN)) Q:'IBDFIFN  S IBDFNODE=$G(^TMP("ALPHA",$J,IBDFCAT,IBDFIFN)) D
 | 
|---|
 | 83 |  .S IBDFIFN=$P(IBDFNODE,"^",1)
 | 
|---|
 | 84 |  .S IBDFCODE=$P(IBDFNODE,"^",2)
 | 
|---|
 | 85 |  .S IBDFCAT=$P(IBDFNODE,"^",3)
 | 
|---|
 | 86 |  .S IBDFDESC=$P(IBDFNODE,"^",4)
 | 
|---|
 | 87 |  .D:'$D(IBDFC(IBDFCAT)) HEADER^IBDFLST1 D SET
 | 
|---|
 | 88 |  Q
 | 
|---|
 | 89 |  ;
 | 
|---|
 | 90 |  ;
 | 
|---|
 | 91 | SET ;  -- Set up list array
 | 
|---|
 | 92 |  S IBDCNT1=IBDCNT1+1
 | 
|---|
 | 93 |  S IBDCNT=IBDCNT+1,VALMCNT=VALMCNT+1
 | 
|---|
 | 94 |  S X=""
 | 
|---|
 | 95 |  S IBDFVAL=$J(IBDCNT1_")",5)
 | 
|---|
 | 96 |  S X=$$SETSTR(IBDFVAL,X,1,5)
 | 
|---|
 | 97 |  S IBDFVAL=IBDFCODE
 | 
|---|
 | 98 |  S X=$$SETSTR(IBDFVAL,X,7,8)
 | 
|---|
 | 99 |  S IBDFVAL=IBDFDESC
 | 
|---|
 | 100 |  S X=$$SETSTR(IBDFVAL,X,17,20)
 | 
|---|
 | 101 |  S IBDFVAL=IBDFCAT
 | 
|---|
 | 102 |  S X=$$SETSTR(IBDFVAL,X,39,20)
 | 
|---|
 | 103 |  ;
 | 
|---|
 | 104 |  ;
 | 
|---|
 | 105 | TMP ; -- Set up Array
 | 
|---|
 | 106 |  S ^TMP("CODE",$J,IBDCNT,0)=$$LOWER^VALM1(X),^TMP("CODE",$J,"IDX",VALMCNT,IBDCNT1)=""
 | 
|---|
 | 107 |  S ^TMP("CODEIDX",$J,IBDCNT1)=VALMCNT_"^"_IBDFIFN_"^"_IBDFCODE_"^"_IBDFCAT_"^"_IBDFDESC
 | 
|---|
 | 108 |  Q
 | 
|---|
 | 109 |  ;
 | 
|---|
 | 110 |  ;
 | 
|---|
 | 111 | ALPHA ;  - Alphabetize by category
 | 
|---|
 | 112 |  S ^TMP("ALPHA",$J,IBDFCAT,IBDFIFN)=IBDFIFN_"^"_IBDFCODE_"^"_IBDFCAT_"^"_IBDFDESC
 | 
|---|
 | 113 |  Q
 | 
|---|
 | 114 |  ;
 | 
|---|
 | 115 |  ;
 | 
|---|
 | 116 | QUIT ;  -- Kill variables and reset to last display if no change has been taken place.
 | 
|---|
 | 117 |  ;
 | 
|---|
 | 118 |  ;
 | 
|---|
 | 119 | EXIT K ^TMP("CODE",$J),^TMP("CODEIDX",$J),^TMP("ALPHA",$J)
 | 
|---|
 | 120 |  K IBDFC,IBDFTYP,IBDFCNT1,IBDCAT
 | 
|---|
 | 121 |  Q
 | 
|---|
 | 122 |  ;
 | 
|---|
 | 123 |  ;
 | 
|---|
 | 124 | JUMP ; -- Jump action to display a specific category on the screen.
 | 
|---|
 | 125 |  D FULL^VALM1
 | 
|---|
 | 126 |  I $D(XQORNOD(0)),$P(XQORNOD(0),"^",4)]"" S X=$P(XQORNOD(0),"^",4) S X=$P(X,"=",2) I X]"" D:X?1.6N JSEL S DIC=$S(IBDFDIS="ICD9":"^ICM(",1:"^DIC(81.1,"),DIC(0)="QEZ" D ^DIC K DIC G:Y<0 JMP S Y=+Y D JUMP1 Q
 | 
|---|
 | 127 | JMP S DIC=$S(IBDFDIS="ICD9":"^ICM(",1:"^DIC(81.1,"),DIC(0)="AEMN",DIC("A")="Select "_$S(IBDFDIS="ICD9":"ICD9",1:"CPT")_" category you wish to move to: "
 | 
|---|
 | 128 |  D ^DIC K DIC
 | 
|---|
 | 129 |  I X["^" S VALMBG=1,VALMBCK="R" Q
 | 
|---|
 | 130 |  ;
 | 
|---|
 | 131 |  ;
 | 
|---|
 | 132 | JUMP1 I Y<0 G JUMP
 | 
|---|
 | 133 |  N IBDFCAT
 | 
|---|
 | 134 |  S IBDFCAT=$S(IBDFDIS="ICD9":$P(^ICM(+Y,0),"^",1),1:$P(^DIC(81.1,+Y,0),"^",1))
 | 
|---|
 | 135 |  I '$D(IBDFC(IBDFCAT)) W !!,"There is no data listed for this Clinic Group" G JMP
 | 
|---|
 | 136 |  S VALMBG=+IBDFC(IBDFCAT) S VALMBCK="R" Q
 | 
|---|
 | 137 |  Q
 | 
|---|
 | 138 |  ;
 | 
|---|
 | 139 |  ;
 | 
|---|
 | 140 | JSEL ; -- Convert number selected to name
 | 
|---|
 | 141 |  S IBDVALM=X I $D(^TMP("CGIDX",$J,IBDVALM)) S X=$P(^TMP("CGIDX",$J,IBDVALM),"^",2),X=$P(^IBD(357.99,X,0),"^",1)
 | 
|---|
 | 142 |  Q
 | 
|---|
 | 143 | HLP ; -- help code
 | 
|---|
 | 144 |  S X="?" D DISP^XQORM1 W !!
 | 
|---|
 | 145 |  Q
 | 
|---|
 | 146 |  ;
 | 
|---|