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