source: FOIAVistA/trunk/r/ADVERSE_REACTION_TRACKING-GMRA-GMA/GMRAPST1.m@ 1446

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

initial load of FOIAVistA 6/30/08 version

File size: 3.5 KB
Line 
1GMRAPST1 ;HIRMFO/WAA- PRINT LISTING OF FATAL REACTIONS ;3/5/97 14:45
2 ;;4.0;Adverse Reaction Tracking;**7,33**;Mar 29, 1996;Build 5
3EN1 ; This routine will loop through the ADT entry point to get all
4 ; the entries where the patient has died.
5 S GMRAOUT=0
6 W !,"Select an Observed date range for this report."
7 D DT^GMRAPL G:GMRAOUT EXIT
8 D PRINTER
9EXIT ; Exit of program kill cleanup
10 D KILL^XUSCLEAN
11 K ^TMP($J,"GMRAPST1")
12 Q
13PRINTER ;Select printer
14 W ! K GMRAZIS D DEV^GMRAUTL I POP W !,"PLEASE TRY LATER" S GMRAOUT=1 Q
15 I $D(IO("Q")) D Q
16 . S ZTRTN="PRINT^GMRAPST1",(ZTSAVE("GMRAOUT"),ZTSAVE("GMAST"),ZTSAVE("GMAEN"))=""
17 . S ZTDESC="List of Fatal Reaction over a date range" D ^%ZTLOAD
18 . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try Later.")
19 . Q
20 U IO D PRINT U IO(0)
21 Q
22PRINT ;Queue point for report
23 ;Loop through the 120.85 file.
24 K ^TMP($J,"GMRAPST1")
25 D NOW^%DTC S GMRADPDT=X
26 S GMRADATE=GMAST-.0001,GMRAPG=1
27 F S GMRADATE=$O(^GMR(120.85,"B",GMRADATE)) Q:GMRADATE<1 Q:GMRADATE>GMAEN D
28 .S GMRAPA1=0 F S GMRAPA1=$O(^GMR(120.85,"B",GMRADATE,GMRAPA1)) Q:GMRAPA1<1 D
29 ..S GMRAPA1(0)=$G(^GMR(120.85,GMRAPA1,0)) Q:GMRAPA1(0)="" ;Bad Node
30 ..Q:+$G(^GMR(120.8,$P(GMRAPA1(0),U,15),"ER")) ;data entered in error
31 ..Q:$P(GMRAPA1(0),U,3)'="y" ; If patient did not die of the reaction
32 ..S GMRADFN=$P(GMRAPA1(0),U,2),GMRADDT=$P(GMRAPA1(0),U) ; reaction date
33 ..Q:'$$PRDTST^GMRAUTL1(GMRADFN) ;GMRA*4*33 Exclude test patient from report in production or legacy environments.
34 ..S (GMRAPID,GMRANAME)=""
35 ..D VAD^GMRAUTL1(GMRADFN,GMRADDT,"",.GMRANAME,"",.GMRAPID)
36 ..S GMRADIED=$P($G(^DPT(GMRADFN,.35)),U) ; Date patient died
37 ..S ^TMP($J,"GMRAPST1",$E(GMRANAME,1,30),GMRAPID,GMRADDT,GMRAPA1)=GMRADIED
38 ..Q
39 .Q
40 Q:GMRAOUT
41 I '$D(^TMP($J,"GMRAPST1")) D HEAD W !,"NO DATA FOR THIS REPORT..." Q
42 S GMRANAME=""
43 F S GMRANAME=$O(^TMP($J,"GMRAPST1",GMRANAME)) Q:GMRANAME="" D Q:GMRAOUT
44 .S GMRAPID=""
45 .F S GMRAPID=$O(^TMP($J,"GMRAPST1",GMRANAME,GMRAPID)) Q:GMRAPID="" D Q:GMRAOUT
46 ..D HEAD Q:GMRAOUT
47 ..W !,$E(GMRANAME,1,22)," (",$E(GMRANAME,1),$P(GMRAPID,"-",3),")"
48 ..S GMRADDT=0
49 ..F S GMRADDT=$O(^TMP($J,"GMRAPST1",GMRANAME,GMRAPID,GMRADDT)) Q:GMRADDT<1 D Q:GMRAOUT
50 ...S GMRAPA1=0
51 ...F S GMRAPA1=$O(^TMP($J,"GMRAPST1",GMRANAME,GMRAPID,GMRADDT,GMRAPA1)) Q:GMRAPA1<1 D Q:GMRAOUT W !
52 ....S GMRADIED=^TMP($J,"GMRAPST1",GMRANAME,GMRAPID,GMRADDT,GMRAPA1)
53 ....W ?31,$$FMTE^XLFDT($P(^GMR(120.85,GMRAPA1,0),U),"2D")
54 ....S GMRAX="",GMRACNT=1 K GMRARX
55 ....F S GMRAX=$O(^GMR(120.85,GMRAPA1,3,"B",GMRAX)) Q:GMRAX="" D
56 .....S GMRARX(GMRACNT)=GMRAX,GMRACNT=GMRACNT+1
57 .....Q
58 ....W ?40,GMRARX(1),?70,$$FMTE^XLFDT(GMRADIED,"2D")
59 ....D HEAD Q:GMRAOUT
60 ....S GMRACNT=1 F S GMRACNT=$O(GMRARX(GMRACNT)) Q:GMRACNT<1 D Q:GMRAOUT
61 .....W !,?40,GMRARX(GMRACNT) D HEAD Q:GMRAOUT
62 .....Q
63 ....Q
64 ...Q
65 ..W ! D HEAD Q:GMRAOUT
66 ..Q
67 .Q
68 D CLOSE^GMRAUTL
69 Q
70 ;has the patient died within the date
71HEAD ; Print header information
72 I GMRAPG'=1 Q:$Y<(IOSL-4)
73 I $E(IOST,1)="C" D Q:GMRAOUT
74 .I GMRAPG=1 W @IOF Q
75 .I GMRAPG'=1 D Q:GMRAOUT
76 ..N DIR S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
77 ..K Y
78 ..Q
79 .Q
80 Q:GMRAOUT
81 I GMRAPG'=1 W @IOF
82 W "Report Date: ",$P($$FMTE^XLFDT(GMRADPDT),"@"),?70,"Page: ",GMRAPG
83 W !,?22,"List of Fatal Reaction over a date range"
84 W !,?25,"From: ",$$FMTE^XLFDT(GMAST,"2D")," To: ",$$FMTE^XLFDT(GMAEN,"2D")
85 W !,"Patient",?31,"Dates",?40,"Related Reaction",?70,"Date Died"
86 W !,$$REPEAT^XLFSTR("-",79)
87 S GMRAPG=GMRAPG+1
88 I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
89 Q
Note: See TracBrowser for help on using the repository browser.