source: FOIAVistA/trunk/r/ADVERSE_REACTION_TRACKING-GMRA-GMA/GMRAPST4.m@ 949

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

initial load of FOIAVistA 6/30/08 version

File size: 3.0 KB
Line 
1GMRAPST4 ;HIRMFO/WAA- PRINT FREQUENCY OF DIST OVR DT BY DC ;3/5/97 15:15
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 in that date range.
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 K ^TMP($J,"GMRAPST4")
11 D KILL^XUSCLEAN
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^GMRAPST4",(ZTSAVE("GMRAOUT"),ZTSAVE("GMAST"),ZTSAVE("GMAEN"))=""
17 . S ZTDESC="Frequency Distribution of Drug Classes" 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 and look for the field that
24 D NOW^%DTC S GMRADPDT=X
25 S GMRADATE=GMAST-.0001,GMRAPG=1
26 K ^TMP($J,"GMRAPST4")
27 S GMRATOT=0
28 F S GMRADATE=$O(^GMR(120.85,"B",GMRADATE)) Q:GMRADATE<1 Q:GMRADATE>GMAEN D
29 .S GMRAPA1=0 F S GMRAPA1=$O(^GMR(120.85,"B",GMRADATE,GMRAPA1)) Q:GMRAPA1<1 D
30 ..S GMRAPA1(0)=$G(^GMR(120.85,GMRAPA1,0)) Q:GMRAPA1(0)="" ;Bad Node
31 ..Q:+$G(^GMR(120.8,$P(GMRAPA1(0),U,15),"ER")) ;Entered in error data
32 ..Q:'$$PRDTST^GMRAUTL1($P(GMRAPA1(0),U,2)) ;GMRA*4*33 Exclude test patient from report if production or legacy environment.
33 ..S GMRATOT=GMRATOT+1
34 ..S GMRAPA=$P(GMRAPA1(0),U,15) Q:'GMRAPA
35 ..S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""
36 ..S GMRADC=0
37 ..F S GMRADC=$O(^GMR(120.8,GMRAPA,3,GMRADC)) Q:GMRADC<1 D
38 ...S GMRADCN=$P($G(^GMR(120.8,GMRAPA,3,GMRADC,0)),U) Q:GMRADCN=""
39 ...S ^TMP($J,"GMRAPST4",GMRADCN)=$G(^TMP($J,"GMRAPST4",GMRADCN))+1
40 ...Q
41 ..Q
42 .Q
43 Q:GMRAOUT
44 Q:'$D(^TMP($J,"GMRAPST4"))
45 S GMRADCN=0
46 ;Sort in value order.
47 F S GMRADCN=$O(^TMP($J,"GMRAPST4",GMRADCN)) Q:GMRADCN<1 D
48 .S GMRADC=$G(^TMP($J,"GMRAPST4",GMRADCN)) Q:GMRADC<1
49 .S ^TMP($J,"GMRAPST4","B",GMRADC,GMRADCN)=""
50 .Q
51 D HEAD
52 S GMRADC=""
53 F S GMRADC=$O(^TMP($J,"GMRAPST4","B",GMRADC),-1) Q:GMRADC<1 D Q:GMRAOUT
54 .S GMRADCN=0
55 .F S GMRADCN=$O(^TMP($J,"GMRAPST4","B",GMRADC,GMRADCN)) Q:GMRADCN<1 D Q:GMRAOUT
56 ..S GMRADC0=$G(^PS(50.605,GMRADCN,0)) Q:GMRADC0=""
57 ..S GMRATAB=30-$L($E($P(GMRADC0,U,2),1,30))
58 ..W !,?GMRATAB,$E($P(GMRADC0,U,2),1,30)," (",$P(GMRADC0,U),") :",$J(GMRADC,5)
59 ..D HEAD Q:GMRAOUT
60 ..Q
61 .Q
62 W !!,?22,"Total number of records processed ",GMRATOT
63 D CLOSE^GMRAUTL
64 Q
65HEAD ; Print header information
66 I GMRAPG'=1 Q:$Y<(IOSL-4)
67 I $E(IOST,1)="C" D Q:GMRAOUT
68 .I GMRAPG=1 W @IOF Q
69 .I GMRAPG'=1 D Q:GMRAOUT
70 ..N DIR S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
71 ..K Y
72 ..Q
73 .Q
74 Q:GMRAOUT
75 I GMRAPG'=1 W @IOF
76 W "Report Date: ",$P($$FMTE^XLFDT(GMRADPDT),"@"),?70,"Page: ",GMRAPG
77 W !,?20,"Frequency Distribution of Drug Classes"
78 W !,?25,"From: ",$$FMTE^XLFDT(GMAST,"2D")," To: ",$$FMTE^XLFDT(GMAEN,"2D")
79 W !,"Drug Class",?39,"Number"
80 W !,$$REPEAT^XLFSTR("-",79)
81 S GMRAPG=GMRAPG+1
82 I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
83 Q
Note: See TracBrowser for help on using the repository browser.