source: WorldVistAEHR/trunk/r/ICR_IMMUNOLOGY_CASE_REGISTRY-IMR/IMRLFOL.m@ 1006

Last change on this file since 1006 was 613, checked in by George Lilly, 15 years ago

initial load of WorldVistAEHR

File size: 3.7 KB
Line 
1IMRLFOL ;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
15DEV 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
22DQ ;
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"
29HOLD D:'IMRUT PRTC
30CLOSE D ^%ZISC
31KILL 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 ;
35P1 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 ;
47LIST 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 ;
51L1 ;
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 ;
56PRTC ;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
60HEDR ;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
65ASKN ; 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
Note: See TracBrowser for help on using the repository browser.