[623] | 1 | GMRAPU ;HIRMFO/WAA- PRINT ALLERGY LIST BY LOCATION UNVERIFIED ; 8/27/93
|
---|
| 2 | ;;4.0;Adverse Reaction Tracking;;Mar 29, 1996
|
---|
| 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 | .D VAD^GMRAUTL1(GMADFN,"",.GMRALOC,.GMRANAM,"","","") I GMRALOC="" S GMALOC="OUTPATIENT"
|
---|
| 70 | .E S GMALOC=$P($G(^DIC(42,GMRALOC,0)),U)
|
---|
| 71 | .Q:GMALOC=""
|
---|
| 72 | .S GMRAPA=0
|
---|
| 73 | .F S GMRAPA=$O(^GMR(120.8,"AVER",GMADFN,GMRAPA)) Q:GMRAPA<1 D
|
---|
| 74 | ..N GMADT
|
---|
| 75 | ..S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""
|
---|
| 76 | ..S GMADT=$P(GMRAPA(0),U,4)
|
---|
| 77 | ..S ^TMP($J,"GMRAPU",GMALOC,GMRANAM,GMADFN,GMADT,GMRAPA)=""
|
---|
| 78 | ..Q
|
---|
| 79 | .Q
|
---|
| 80 | Q
|
---|