| 1 | GMRAPL ;HIRMFO/WAA- PRINT ALLERGY LIST BY LOCATION ;5/2/97  14:13 | 
|---|
| 2 | ;;4.0;Adverse Reaction Tracking;**7,33**;Mar 29, 1996;Build 5 | 
|---|
| 3 | EN1 ; This routine will loop through the GMRA patient allergy file | 
|---|
| 4 | ; to find all patient within the date range that meet the criteria | 
|---|
| 5 | ; and then display all the data for those patients first by location | 
|---|
| 6 | ; then by date/time range of the reaction. | 
|---|
| 7 | ; First select a starting date. | 
|---|
| 8 | ; then select an end date. | 
|---|
| 9 | ; then select a print device. | 
|---|
| 10 | ; GMAST = START DATE | 
|---|
| 11 | ; GMAEN = END DATE | 
|---|
| 12 | ; | 
|---|
| 13 | S GMRAOUT=0 | 
|---|
| 14 | D DT G:GMRAOUT EXIT | 
|---|
| 15 | S GMAPG=1 | 
|---|
| 16 | D DEVICE | 
|---|
| 17 | D EXIT | 
|---|
| 18 | Q | 
|---|
| 19 | GET ; This sub routine is to find all the reaction with in this observed | 
|---|
| 20 | ; date range. | 
|---|
| 21 | K ^TMP($J,"GMRAPL") | 
|---|
| 22 | N GMADT S GMADT=GMAST-.0001 | 
|---|
| 23 | F  S GMADT=$O(^GMR(120.8,"AODT",GMADT)) Q:GMADT<1  Q:GMADT>GMAEN  D | 
|---|
| 24 | .N GMRAPA S GMRAPA=0 | 
|---|
| 25 | .F  S GMRAPA=$O(^GMR(120.8,"AODT",GMADT,GMRAPA)) Q:GMRAPA<1  D | 
|---|
| 26 | ..S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) | 
|---|
| 27 | ..; Stop if it is not Signed or if is E/E | 
|---|
| 28 | ..Q:GMRAPA(0)=""  ; Bad Zero node | 
|---|
| 29 | ..Q:'$P(GMRAPA(0),U,12)  ; Not signed off | 
|---|
| 30 | ..Q:$P($G(^GMR(120.8,GMRAPA,"ER")),U)  ; Entered in error | 
|---|
| 31 | ..; Get patient name and location. | 
|---|
| 32 | ..S GMRATYP=$P(GMRAPA(0),U,20) ; Get the reaction types FDO | 
|---|
| 33 | ..S (GMRANAM,GMRALOC,GMRAVIP)="" | 
|---|
| 34 | ..Q:'$$PRDTST^GMRAUTL1($P($G(GMRAPA(0)),U))  ;GMRA*4*33 Exclude test patient from report if production or legacy environment | 
|---|
| 35 | ..D VAD^GMRAUTL1($P(GMRAPA(0),U),$P(GMRAPA(0),U,4),.GMRALOC,.GMRANAM,"","","","",.GMRAVIP) | 
|---|
| 36 | ..I GMRALOC'="",+$G(^DIC(42,GMRALOC,44)) S GMRALOC=$P($G(^SC(+$G(^DIC(42,GMRALOC,44)),0)),U) | 
|---|
| 37 | ..I GMRALOC="" S GMRALOC="Out Patients" | 
|---|
| 38 | ..;Data format is as follows.... | 
|---|
| 39 | ..;^TMP($J,"GMRAPL",Ward location,Patient,PID,Reaction Type(FDO),Reaction) | 
|---|
| 40 | ..S ^TMP($J,"GMRAPL",$E(GMRALOC,1,30),$E(GMRANAM,1,30),GMRAVIP,GMRATYP,GMRAPA)="" | 
|---|
| 41 | ..Q | 
|---|
| 42 | .Q | 
|---|
| 43 | Q | 
|---|
| 44 | PRINT ; Print data in the reaction global | 
|---|
| 45 | I $E(IOST,1)="C" W !,"One moment please...",! | 
|---|
| 46 | D GET | 
|---|
| 47 | S GMRALOC="" F  S GMRALOC=$O(^TMP($J,"GMRAPL",GMRALOC)) Q:GMRALOC=""  D  Q:GMRAOUT | 
|---|
| 48 | .D HEAD Q:GMRAOUT | 
|---|
| 49 | .S GMRANAM="" F  S GMRANAM=$O(^TMP($J,"GMRAPL",GMRALOC,GMRANAM)) Q:GMRANAM=""  D  Q:GMRAOUT | 
|---|
| 50 | ..S GMRAVIP="" F  S GMRAVIP=$O(^TMP($J,"GMRAPL",GMRALOC,GMRANAM,GMRAVIP)) Q:GMRAVIP=""  D  Q:GMRAOUT | 
|---|
| 51 | ...I $Y>(IOSL-4) D HEAD Q:GMRAOUT | 
|---|
| 52 | ...W !,?10,"Patient: ",GMRANAM," (",GMRAVIP,")" | 
|---|
| 53 | ...S GMRATYP="" F  S GMRATYP=$O(^TMP($J,"GMRAPL",GMRALOC,GMRANAM,GMRAVIP,GMRATYP)) W:GMRATYP="" ! Q:GMRATYP=""  D  Q:GMRAOUT | 
|---|
| 54 | ....S GMRAPA=0 F  S GMRAPA=$O(^TMP($J,"GMRAPL",GMRALOC,GMRANAM,GMRAVIP,GMRATYP,GMRAPA)) Q:GMRAPA<1  D  Q:GMRAOUT | 
|---|
| 55 | .....S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)="" | 
|---|
| 56 | .....W !,$$FMTE^XLFDT($P(GMRAPA(0),U,4),"1") ;When It was entered | 
|---|
| 57 | .....W ?20,$S($P(GMRAPA(0),U,5)'="":$E($P(^VA(200,$P(GMRAPA(0),U,5),0),U),1,25),1:"<None>") ;Who Entered it | 
|---|
| 58 | .....W ?46,GMRATYP ;Type of reaction | 
|---|
| 59 | .....W ?50,$E($P(GMRAPA(0),U,2),1,30) ;Reaction | 
|---|
| 60 | .....I $Y>(IOSL-4) D HEAD | 
|---|
| 61 | .....Q | 
|---|
| 62 | ....Q | 
|---|
| 63 | ...Q | 
|---|
| 64 | ..Q | 
|---|
| 65 | .Q | 
|---|
| 66 | Q | 
|---|
| 67 | HEAD ; Header | 
|---|
| 68 | I $E(IOST,1)="C" D  Q:GMRAOUT | 
|---|
| 69 | .I GMAPG=1 W @IOF Q | 
|---|
| 70 | .I GMAPG'=1 D  Q:GMRAOUT | 
|---|
| 71 | ..N DIR S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1 | 
|---|
| 72 | ..K Y | 
|---|
| 73 | ..Q | 
|---|
| 74 | .Q | 
|---|
| 75 | I GMAPG'=1 W @IOF | 
|---|
| 76 | W $$FMTE^XLFDT(GMRAPDT,"1"),?70,"Page: ",GMAPG S GMAPG=GMAPG+1 | 
|---|
| 77 | W !,?11,"List all Signed Patient Reactions for",$S(GMRALOC'="Out Patients":" Ward Location ",1:" "),GMRALOC | 
|---|
| 78 | W !,?15,"From ",$$FMTE^XLFDT(GMAST,"1")," to ",$$FMTE^XLFDT(GMAEN,"1") | 
|---|
| 79 | W !,"Date",?20,"Originator",?45,"Type",?50,"Causative Agent" | 
|---|
| 80 | W !,$$REPEAT^XLFSTR("-",79) | 
|---|
| 81 | Q | 
|---|
| 82 | DEVICE ; Select a device to print on | 
|---|
| 83 | D NOW^%DTC S GMRAPDT=X | 
|---|
| 84 | W ! K GMRAZIS D DEV^GMRAUTL I POP W !,"PLEASE TRY LATER" S GMRAOUT=1 Q | 
|---|
| 85 | I $D(IO("Q")) D  Q | 
|---|
| 86 | . S ZTRTN="PRINT^GMRAPL",(ZTSAVE("GMAST"),ZTSAVE("GMAEN"),ZTSAVE("GMRAOUT"),ZTSAVE("GMRAPDT"),ZTSAVE("GMAPG"))="" | 
|---|
| 87 | . S ZTDESC="List of Reactions by Ward Location within a date range." D ^%ZTLOAD | 
|---|
| 88 | . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try  Later.") | 
|---|
| 89 | . Q | 
|---|
| 90 | U IO D PRINT U IO(0) | 
|---|
| 91 | D CLOSE^GMRAUTL | 
|---|
| 92 | D EXIT | 
|---|
| 93 | Q | 
|---|
| 94 | DT ; Get dates | 
|---|
| 95 | S GMAST=$$DATE("Enter Start Date: ") I GMAST<1 S GMRAOUT=1 Q | 
|---|
| 96 | S GMAEN=$$DATE("Enter Ending Date: ",GMAST) I GMAEN<1 S GMRAOUT=1 Q | 
|---|
| 97 | S GMAEN=GMAEN_".24" ;Gives results through entire day when 'T' is selected | 
|---|
| 98 | Q | 
|---|
| 99 | DATE(PROMPT,GMADATE) ; Date sub routine | 
|---|
| 100 | S GMADATE=$G(GMADATE) | 
|---|
| 101 | S DATE="" | 
|---|
| 102 | N DIR | 
|---|
| 103 | S DIR(0)="DAO^"_GMADATE_"::AEP",DIR("A")=PROMPT | 
|---|
| 104 | D ^DIR I $D(DIRUT) S DATE="" Q DATE | 
|---|
| 105 | S DATE=Y | 
|---|
| 106 | Q DATE | 
|---|
| 107 | EXIT ;EXIT ROUTINE DATA | 
|---|
| 108 | K ^TMP($J,"GMRAPL") | 
|---|
| 109 | D KILL^XUSCLEAN | 
|---|
| 110 | Q | 
|---|