| [613] | 1 | IBQLD1A ;LEB/MRY - ACUTE/NON-ACUTE DOWNLOAD ; 17-MAY-95 | 
|---|
|  | 2 | ;;1.0;UTILIZATION MGMT ROLLUP LOCAL;;Oct 01, 1995 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; -- called from IBQLR1 | 
|---|
|  | 5 | PRINT D SVCTAB^IBQLR1B S (IBTEXT,IBDATA,IBTS,IBQUIT,IBHDR,IBSVC)="",IBPAG=0 D MONTH | 
|---|
|  | 6 | ; -- call to return header dates, IBTDT, IBDRNG | 
|---|
|  | 7 | D DTC^IBQLPL2 | 
|---|
|  | 8 | S IBHDR="UTILIZATION MANAGEMENT",IBHDR2="ACUTE AND NON-ACUTE REPORT FOR "_IBDRNG S:IBTY="S" IBHDR1="SERVICE" S:IBTY="T" IBHDR1="TREATING SPECIALTY.(SERVICE)" | 
|---|
|  | 9 | ; | 
|---|
|  | 10 | F  S IBSVC=$O(^TMP("IBQLD1",$J,IBSVC)) Q:IBSVC=""  D TS Q:IBQUIT | 
|---|
|  | 11 | G END | 
|---|
|  | 12 | TS F  S IBTS=$O(^TMP("IBQLD1",$J,IBSVC,IBTS)) Q:IBTS=""  D  Q:IBQUIT | 
|---|
|  | 13 | .I IBTS=999 S IBSUBH=$S($D(IBSVC(IBSVC)):IBSVC(IBSVC),1:IBSVC("UNK")) | 
|---|
|  | 14 | .E  S IBSUBH=IBTS_",("_$S($D(IBSVC(IBSVC)):IBSVC(IBSVC),1:IBSVC("UNK"))_")" | 
|---|
|  | 15 | .I IBTY="I",'$D(IBTS(IBTS)) Q | 
|---|
|  | 16 | .D PLINE | 
|---|
|  | 17 | .F IBDAY=1,2 D  Q:IBQUIT | 
|---|
|  | 18 | ..S (IBCAT,IBCATF)="" | 
|---|
|  | 19 | ..F  S IBCAT=$O(^TMP("IBQLD1",$J,IBSVC,IBTS,IBDAY,IBCAT)) Q:IBCAT=""  D  Q:IBQUIT | 
|---|
|  | 20 | ...I $E(IBCAT,1)="C" D ACUTE | 
|---|
|  | 21 | ...I $E(IBCAT,1)="R" D REASON | 
|---|
|  | 22 | Q | 
|---|
|  | 23 | ; | 
|---|
|  | 24 | END K IBTS,IBTEXT,IBDATA,IBQUIT,IBHDR,IBMONTH,IBMD,IBMTH,IBCAT,MSTRING,N,I,X,IBDAY,IBRES,IBCATF | 
|---|
|  | 25 | Q | 
|---|
|  | 26 | ACUTE ; | 
|---|
|  | 27 | S IBMONTH="" | 
|---|
|  | 28 | I IBDAY=2&('IBCATF) W !,"CONTINUED STAY DAYS" S IBCATF=1 | 
|---|
|  | 29 | S IBMONTH="" F  S IBMONTH=$O(IBMONTH(IBMONTH)) Q:'IBMONTH  D  Q:IBQUIT | 
|---|
|  | 30 | .S IBRES=$G(^TMP("IBQLD1",$J,IBSVC,IBTS,IBDAY,IBCAT,IBMONTH)) S:'IBRES IBRES=0 D MDATA | 
|---|
|  | 31 | D PLINE Q:IBQUIT | 
|---|
|  | 32 | Q | 
|---|
|  | 33 | REASON ; | 
|---|
|  | 34 | S IBREA="" | 
|---|
|  | 35 | W:IBDAY=1 !,"REASONS FOR NON-ACUTE ADMISSIONS" W:IBDAY=2 !,"REASONS FOR NON-ACUTE STAY DAYS" | 
|---|
|  | 36 | F  S IBREA=$O(^TMP("IBQLD1",$J,IBSVC,IBTS,IBDAY,IBCAT,IBREA)) Q:'IBREA  D  Q:IBQUIT | 
|---|
|  | 37 | .S IBMONTH="" F  S IBMONTH=$O(IBMONTH(IBMONTH)) Q:'IBMONTH  D  Q:IBQUIT | 
|---|
|  | 38 | ..S IBRES=$G(^TMP("IBQLD1",$J,IBSVC,IBTS,IBDAY,IBCAT,IBREA,IBMONTH)) S:'IBRES IBRES=0 D MDATA | 
|---|
|  | 39 | .D PLINE Q:IBQUIT | 
|---|
|  | 40 | Q | 
|---|
|  | 41 | MDATA ; | 
|---|
|  | 42 | S IBMTH=+$E(IBMONTH,4,5),IBMD=$P(MSTRING,"^",IBMTH) | 
|---|
|  | 43 | F I=1:1 S X=$P(IBTEXT,"^",I) Q:X=""!(X=IBMD) | 
|---|
|  | 44 | I X'="" D | 
|---|
|  | 45 | .S $P(IBDATA,"^",I)=IBRES | 
|---|
|  | 46 | .S $P(IBDATA,"^",1)=$S(IBCAT="CNTA":"ACUTE",IBCAT="CNTN":"NON-ACUTE",IBCAT="REA":IBREA,1:"") | 
|---|
|  | 47 | Q | 
|---|
|  | 48 | ; | 
|---|
|  | 49 | PLINE ; | 
|---|
|  | 50 | I $G(IBCAT)="" D | 
|---|
|  | 51 | .W !!,IBSUBH,! S IBDATA=IBTEXT | 
|---|
|  | 52 | W !,IBDATA | 
|---|
|  | 53 | Q | 
|---|
|  | 54 | ; | 
|---|
|  | 55 | MONTH ; | 
|---|
|  | 56 | S MSTRING="JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",X="" | 
|---|
|  | 57 | F I=1:1 S X=$O(IBMONTH(X)) Q:'X  D | 
|---|
|  | 58 | .S IBTEXT=IBTEXT_$P(MSTRING,"^",+$E(X,4,5))_"^" | 
|---|
|  | 59 | S IBTEXT="ADMISSIONS^"_IBTEXT | 
|---|
|  | 60 | Q | 
|---|