| 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 | ; | 
|---|