| 1 | IMRLFOL ;ISC-SF.SEA/JLI,HCIOFO/FT-LIST OF PATIENTS POTENTIALLY LOST TO FOLLOW-UP ;10/16/97  9:39
 | 
|---|
| 2 |  ;;2.1;IMMUNOLOGY CASE REGISTRY;;Feb 09, 1998
 | 
|---|
| 3 |  ;[IMR FOLLOWUP LIST] - Follow Up Report
 | 
|---|
| 4 |  I '$D(^XUSEC("IMRMGR",DUZ)) S IMRLOC="IMRLFOL" D ACESSERR^IMRERR,H^XUS K IMRLOC
 | 
|---|
| 5 |  K DIR S DIR(0)="N^1:365",DIR("A")="Number of Days Patients Not Seen"
 | 
|---|
| 6 |  S DIR("?")="Enter the number of days you want to check if any patient has not been seen"
 | 
|---|
| 7 |  D ^DIR K DIR
 | 
|---|
| 8 |  I $D(DIRUT) D KILL Q
 | 
|---|
| 9 |  S IMRDAY=Y
 | 
|---|
| 10 |  S IMRSD=$$FMADD^XLFDT(DT,-IMRDAY) ;calculate date for DT-IMRDAY
 | 
|---|
| 11 |  S X=$$RX1589^IMRUTL() ;get pharmacy archive date from File 158.9
 | 
|---|
| 12 |  I X,X'<IMRSD D ASKN G:$D(DIRUT) KILL G DEV
 | 
|---|
| 13 |  D LRARC^IMRUTL ;check Lab archive date
 | 
|---|
| 14 |  I IMRLRC,IMRLRC'<IMRSD D ASKN I $D(DIRUT) KILL Q
 | 
|---|
| 15 | DEV D IMRDEV^IMREDIT I POP D KILL Q
 | 
|---|
| 16 |  I $D(IO("Q")) D  G KILL
 | 
|---|
| 17 |  .S ZTRTN="DQ^IMRLFOL",ZTDESC="Immunology Followup List",ZTIO=ION_";"_IOM_";"_IOSL
 | 
|---|
| 18 |  .S ZTSAVE("IMRDAY")="",ZTSAVE("IMRSD")=""
 | 
|---|
| 19 |  .D ^%ZTLOAD
 | 
|---|
| 20 |  .K ZTRTN,ZTDESC,ZTSK,ZTIO,ZTSAVE
 | 
|---|
| 21 |  .Q
 | 
|---|
| 22 | DQ ;
 | 
|---|
| 23 |  K ^TMP($J) S (IMRPG,IMRSEEN,IMRUT)=0
 | 
|---|
| 24 |  D GETNOW^IMRACESS ;get the current date/time
 | 
|---|
| 25 |  F IMRI=0:0 S IMRI=$O(^IMR(158,IMRI)) Q:IMRI'>0  D P1 I IMRDFN>0,IMRSEEN S IMRC=$P(^IMR(158,IMRI,0),U,42) S ^TMP($J,(9999999-IMRD),IMRI)=IMRD_U_IMRC_U_IMRNAM_U_IMRSSN
 | 
|---|
| 26 |  S:$D(ZTQUEUED) ZTREQ="@"
 | 
|---|
| 27 |  I $D(^TMP($J)) U IO D LIST
 | 
|---|
| 28 |  I '$D(^TMP($J)) U IO D HEDR W !!,"NO DATA FOR THIS REPORT"
 | 
|---|
| 29 | HOLD D:'IMRUT PRTC
 | 
|---|
| 30 | CLOSE D ^%ZISC
 | 
|---|
| 31 | KILL K ^TMP($J),DFN,D,K,IMRSTN,IMRFLG,IMRC,IMRD,IMRNAM,IMRSSN,IMRUT,I,J,POP,X,Y,IMRDFN,IMRDOD,X0,X1,X2,IMRI,IMRJ,VAERR,%T,DISYS,IMRDTE,IMRPG,IMRDAY,IMRSD,IMRSEEN,%I,%Y,IMRDL,IMRYES
 | 
|---|
| 32 |  K IMRAD,IMRDD,IMRDISP,IMRDSP,IMREC,IMRFB,IMRLRC,IMROUT,IMRPTF,IMRST,IMRSUF
 | 
|---|
| 33 |  Q
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 | P1 S X=+^IMR(158,IMRI,0) D ^IMRXOR S IMRDFN=X I '$D(^DPT(IMRDFN,0)) S IMRDFN=-1 Q
 | 
|---|
| 36 |  S DFN=IMRDFN D DEM^VADPT S IMRNAM=VADM(1),IMRSSN=$P(VADM(2),U),IMRDOD=+VADM(6) K DFN,VA,VADM
 | 
|---|
| 37 |  S X0=0 F IMRPTF=0:0 S IMRPTF=$O(^DGPT("B",IMRDFN,IMRPTF)) Q:IMRPTF'>0  I $D(^DGPT(IMRPTF,0)),+^(0)=IMRDFN D PTF^IMRUTL S X1=+IMRAD S:X1>X0 X0=X1 S X1=$S(+IMRDD'>0:1,1:0) S:X1 X0=DT Q:X1  I +IMRDD>X0 S X0=+IMRDD
 | 
|---|
| 38 |  S VASD("F")=$S(X0=0:2850101,1:X0),VASD("T")=DT-1,DFN=IMRDFN D SDA^VADPT F IMRJ=0:0 S IMRJ=$O(^UTILITY("VASD",$J,IMRJ)) Q:IMRJ'>0  S X0=+^(IMRJ,"I")
 | 
|---|
| 39 |  K VASD,^UTILITY("VASD",$J)
 | 
|---|
| 40 |  I $D(^DPT(IMRDFN,"LR")),^("LR")>0 S X1=+^("LR"),X2=$O(^LR(X1,"CH",0)) S X=$S(X2'>0:0,'$D(^(X2,0)):0,1:1),X=$S(X:+^(0),1:-1) S:X>X0&(X'>DT) X0=X S X2=$O(^LR(X1,"MI",0)) S X=$S(X2'>0:0,'$D(^(X2,0)):0,1:1),X=$S(X:+^(0),1:-1) S:X>X0&(X'>DT) X0=X
 | 
|---|
| 41 |  F IMRJ=X0:0 S IMRJ=$O(^PS(55,IMRDFN,"P","A",IMRJ)) Q:IMRJ'>0  F J=0:0 S J=$O(^PS(55,IMRDFN,"P","A",IMRJ,J)) Q:J'>0  S:$D(^PSRX(J,2)) X1=$P(^(2),U,2) S:X1>X0 X0=X1 F K=0:0 S K=$O(^PSRX(J,1,K)) Q:K'>0  S X1=+^(K,0) S:X1>X0 X0=X1
 | 
|---|
| 42 |  F IMRJ=0:0 S IMRJ=$O(^RADPT(IMRDFN,"DT",IMRJ)) Q:IMRJ'>0  I $D(^(IMRJ,0)) S X=+^(0) I X'>DT Q:X<X0  I X>X0 S X0=X
 | 
|---|
| 43 |  S IMRDOD=$S(IMRDOD>0:1,'$D(^IMR(158,IMRI,5)):0,1:$P(^(5),U,19)>0)
 | 
|---|
| 44 |  S X1=DT,(X0,X2)=X0\1 D ^%DTC S:IMRDOD X=0 S IMRD=X0,IMRSEEN=$S(X>IMRDAY:1,1:0)
 | 
|---|
| 45 |  Q
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 | LIST D HEDR
 | 
|---|
| 48 |  F I=0:0 Q:IMRUT  S I=$O(^TMP($J,I)) Q:I'>0  F J=0:0 S J=$O(^TMP($J,I,J)) Q:J'>0  D L1 Q:IMRUT
 | 
|---|
| 49 |  Q
 | 
|---|
| 50 |  ;
 | 
|---|
| 51 | L1 ;
 | 
|---|
| 52 |  I ($Y+3>IOSL) D PRTC Q:IMRUT  D HEDR
 | 
|---|
| 53 |  S D=$P(^TMP($J,I,J),U,1,2) W !,$E(D,4,5),"-",$E(D,6,7),"-",$E(D,2,3),"   ",$P(^(J),U,3),?45,$E($P(^(J),U,4),6,9),?55,$P(D,U,2)
 | 
|---|
| 54 |  Q
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 | PRTC ;press return to continue prompt
 | 
|---|
| 57 |  Q:$D(IO("S"))
 | 
|---|
| 58 |  I IOST["C-" K DIR W ! S DIR(0)="E" D ^DIR K DIR I 'Y S IMRUT=1
 | 
|---|
| 59 |  Q
 | 
|---|
| 60 | HEDR ;print report header
 | 
|---|
| 61 |  S IMRPG=IMRPG+1
 | 
|---|
| 62 |  W:$Y>0 @IOF
 | 
|---|
| 63 |  W !?33,"FOLLOW UP REPORT",!?32,IMRDTE,?70,"Page: ",IMRPG,!?25,"PATIENTS AT RISK OF LOSS TO FOLLOW UP",!?30,"NOT SEEN IN OVER "_IMRDAY_" DAYS",!!?2,"LAST",!?2,"DATE",?45,"LAST",!?2,"SEEN",?13,"NAME",?45,"FOUR",?54,"CAT",!
 | 
|---|
| 64 |  Q
 | 
|---|
| 65 | ASKN ; Ask User Whether they Want to Query the National Registry
 | 
|---|
| 66 |  S IMRYES=0 D ASKQ1^IMRNTL Q:'IMRYES  S IMRDL="" D ASKQ2^IMRNTL Q:IMRDL=""  D MSG^IMRNTL,FOL^IMRNTL1
 | 
|---|
| 67 |  Q
 | 
|---|