| 1 | GMRAPU ;HIRMFO/WAA- PRINT ALLERGY LIST BY LOCATION UNVERIFIED ;8/27/93
 | 
|---|
| 2 |  ;;4.0;Adverse Reaction Tracking;**33**;Mar 29, 1996;Build 5
 | 
|---|
| 3 | EN1 ; 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
 | 
|---|
| 7 | EXIT ; Exit of program kill cleanup
 | 
|---|
| 8 |  D KILL^XUSCLEAN
 | 
|---|
| 9 |  K ^TMP($J,"GMRAPU")
 | 
|---|
| 10 |  Q
 | 
|---|
| 11 | PRINTER ;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
 | 
|---|
| 20 | PRINT ;Queue point for report
 | 
|---|
| 21 |  K ^TMP($J,"GMRAPU") D FIND
 | 
|---|
| 22 | REPORT ; 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
 | 
|---|
| 45 | HEAD ; 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
 | 
|---|
| 63 | FIND ; 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
 | 
|---|