source: FOIAVistA/trunk/r/ADVERSE_REACTION_TRACKING-GMRA-GMA/GMRAPU.m@ 1586

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

initial load of FOIAVistA 6/30/08 version

File size: 3.0 KB
Line 
1GMRAPU ;HIRMFO/WAA- PRINT ALLERGY LIST BY LOCATION UNVERIFIED ;8/27/93
2 ;;4.0;Adverse Reaction Tracking;**33**;Mar 29, 1996;Build 5
3EN1 ; This routine will loop through the GMRA patient allergy file (120.8)
4 ; to find all patients with unverified reactions
5 ;
6 S GMRAOUT=0 D PRINTER
7EXIT ; Exit of program kill cleanup
8 D KILL^XUSCLEAN
9 K ^TMP($J,"GMRAPU")
10 Q
11PRINTER ;Select printer
12 W ! K GMRAZIS D DEV^GMRAUTL I POP W !,"PLEASE TRY LATER" S GMRAOUT=1 Q
13 I $D(IO("Q")) D Q
14 . S ZTRTN="PRINT^GMRAPU",ZTSAVE("GMRAOUT")=""
15 . S ZTDESC="List of Unverified Reactions by Ward Location" D ^%ZTLOAD
16 . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try Later.")
17 . Q
18 U IO D PRINT U IO(0)
19 Q
20PRINT ;Queue point for report
21 K ^TMP($J,"GMRAPU") D FIND
22REPORT ; Print out the report
23 S GMRAOUT=$G(GMRAOUT)
24 S GMALOC="",GMRAPG=1,GMRADATE=$$NOW^XLFDT
25 I '$D(^TMP($J,"GMRAPU")) D HEAD W !,?20,"NO DATA FOR THIS REPORT"
26 F S GMALOC=$O(^TMP($J,"GMRAPU",GMALOC)) Q:GMALOC="" D HEAD Q:GMRAOUT D Q:GMRAOUT
27 .S GMRANAM="" F S GMRANAM=$O(^TMP($J,"GMRAPU",GMALOC,GMRANAM)) Q:GMRANAM="" D Q:GMRAOUT
28 ..S GMADFN=0 F S GMADFN=$O(^TMP($J,"GMRAPU",GMALOC,GMRANAM,GMADFN)) Q:GMADFN<1 D Q:GMRAOUT
29 ...S GMRASSN="",GMRARB=""
30 ...D VAD^GMRAUTL1(GMADFN,"","","","",.GMRASSN,.GMRARB)
31 ...W !,GMRARB,$S(GMRARB'="":" ",1:""),GMRANAM," (",GMRASSN,")"
32 ...S GMADT=0 F S GMADT=$O(^TMP($J,"GMRAPU",GMALOC,GMRANAM,GMADFN,GMADT)) Q:GMADT<1 S GMRAPA=0 F S GMRAPA=$O(^TMP($J,"GMRAPU",GMALOC,GMRANAM,GMADFN,GMADT,GMRAPA)) Q:GMRAPA<1 D Q:GMRAOUT
33 ....S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0))
34 ....Q:GMRAPA(0)=""
35 ....W !,?3,$$FMTE^XLFDT(GMADT,"1")
36 ....W ?30,$S($P(GMRAPA(0),U,5)'="":$E($P($G(^VA(200,$P(GMRAPA(0),U,5),0)),U),1,24),1:"<None>")
37 ....W ?55,$E($P(GMRAPA(0),U,2),1,24)
38 ....I $Y>(IOSL-4) D HEAD
39 ....Q
40 ...Q
41 ..Q
42 .Q
43 D CLOSE^GMRAUTL
44 Q
45HEAD ; Print header information
46 I $E(IOST,1)="C" D Q:GMRAOUT
47 .I GMRAPG=1 W @IOF Q
48 .I GMRAPG'=1 D Q:GMRAOUT
49 ..N DIR S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
50 ..K Y
51 ..Q
52 .Q
53 Q:GMRAOUT
54 I GMRAPG'=1 W @IOF
55 W "Report Date: ",$P($$FMTE^XLFDT(GMRADATE),"@"),?70,"Page: ",GMRAPG
56 W !,?19,"List of Unverified Reactions by Ward Location"
57 W !,?30,"Ward Location: ",GMALOC
58 W !,?3,"Origination Date/Time",?30,"Originator",?55,"Reaction"
59 W !,$$REPEAT^XLFSTR("-",78)
60 S GMRAPG=GMRAPG+1
61 I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
62 Q
63FIND ; This subroutines will build the data for the report.
64 N GMADFN
65 S GMADFN=0
66 F S GMADFN=$O(^GMR(120.8,"AVER",GMADFN)) Q:GMADFN<1 D
67 .N GMRALOC,GMRANAM,GMALOC,GMRAPA
68 .S GMRANAM="",GMRALOC=""
69 .Q:'$$PRDTST^GMRAUTL1(GMADFN) ;GMRA*4*33 Exclude test patients if production or legacy environment.
70 .D VAD^GMRAUTL1(GMADFN,"",.GMRALOC,.GMRANAM,"","","") I GMRALOC="" S GMALOC="OUTPATIENT"
71 .E S GMALOC=$P($G(^DIC(42,GMRALOC,0)),U)
72 .Q:GMALOC=""
73 .S GMRAPA=0
74 .F S GMRAPA=$O(^GMR(120.8,"AVER",GMADFN,GMRAPA)) Q:GMRAPA<1 D
75 ..N GMADT
76 ..S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""
77 ..S GMADT=$P(GMRAPA(0),U,4)
78 ..S ^TMP($J,"GMRAPU",GMALOC,GMRANAM,GMADFN,GMADT,GMRAPA)=""
79 ..Q
80 .Q
81 Q
Note: See TracBrowser for help on using the repository browser.