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