Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: GMRAPST7

GMRAPST7.m

Go to the documentation of this file.
GMRAPST7 ;HIRMFO/WAA- ADVERSE DRUG REACTION REPORT ;20-Jul-2016 11:12;DU
 ;;4.0;Adverse Reaction Tracking;**7,33,1009**;Mar 29, 1996;Build 11
 ;IHS/MSC/MGH Patch 1009 changed to use HRCN
EN1 ; This routine will loop through the ADT entry point to get all
 ; the entries in that date range.
 S GMRAOUT=0
 W !,"Select an Observed date range for this report."
 D DT^GMRAPL G:GMRAOUT EXIT
 D PRINTER
EXIT ; Exit of program kill cleanup
 D KILL^XUSCLEAN
 K ^TMP($J,"GMRAPST7")
 Q
PRINTER ;Select printer
 W !!,"This report required a 132 column printer."
 K GMRAZIS S GMRAZIS="M132" D DEV^GMRAUTL I POP W !,"PLEASE TRY LATER" S GMRAOUT=1 Q
 I $D(IO("Q")) D  Q
 . S ZTRTN="PRINT^GMRAPST7",(ZTSAVE("GMRAOUT"),ZTSAVE("GMAST"),ZTSAVE("GMAEN"))=""
 . S ZTDESC="P&T Committee ADR Report" D ^%ZTLOAD
 . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try Later.")
 . Q
 U IO D PRINT U IO(0)
 Q
PRINT ;Queue point for report
 ;loop through the 120.85 file and look for the field that
 K ^TMP($J,"GMRAPST7")
 D NOW^%DTC S GMRADPDT=X
 S GMRADATE=GMAST-.0001,GMRAPG=1
 F  S GMRADATE=$O(^GMR(120.85,"B",GMRADATE)) Q:GMRADATE<1  Q:GMRADATE>GMAEN  D
 .S GMRAPA1=0 F  S GMRAPA1=$O(^GMR(120.85,"B",GMRADATE,GMRAPA1)) Q:GMRAPA1<1  D
 ..S GMRAPA1(0)=$G(^GMR(120.85,GMRAPA1,0)) Q:GMRAPA1(0)=""  ;Bad Node
 ..S GMRADDT=$P(GMRAPA1(0),U) ; reaction date
 ..S GMRAPA=$P(GMRAPA1(0),U,15) ; Get the 120.8 entry for this reaction in 120.85
 ..S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""  ; Bad node
 ..Q:+$G(^GMR(120.8,GMRAPA,"ER"))  ;Entered in error data
 ..S GMRACA=$P(GMRAPA(0),U,2) ; Causative Agent
 ..;Patch 1009 change to HRCN
 ..S DFN=$P(GMRAPA(0),U)
 ..S HRCN=$$HRCN^GMRAPST6(DFN,+$G(DUZ(2)))
 ..;GMRACA=$E(GMRACA,1,22)_"-"_$E($P(^DPT(DFN,0),U),1)_$E($P(^(0),U,9),6,9)
 ..S GMRACA=$E(GMRACA,1,22)_"-"_HRCN
 ..;end mod
 ..Q:'$$PRDTST^GMRAUTL1(DFN)  ;GMRA*4*33 Exclude test patients from report if production or legacy environment.
 ..S ^TMP($J,"GMRAPST7",GMRADDT,GMRACA,GMRAPA1)=GMRAPA
 ..Q
 .Q
 Q:GMRAOUT
 I '$D(^TMP($J,"GMRAPST7")) D HEAD W !,"NO DATA FOR THIS REPORT..." Q
 S GMRAOTH=$G(GMRAOTH,$O(^GMRD(120.83,"B","OTHER REACTION",0)))
 S GMRADDT=0
 F  S GMRADDT=$O(^TMP($J,"GMRAPST7",GMRADDT)) Q:GMRADDT<1  D  Q:GMRAOUT
 .S GMRACA=""
 .F  S GMRACA=$O(^TMP($J,"GMRAPST7",GMRADDT,GMRACA)) Q:GMRACA=""  D  Q:GMRAOUT
 ..S GMRAPA1=0
 ..F  S GMRAPA1=$O(^TMP($J,"GMRAPST7",GMRADDT,GMRACA,GMRAPA1)) Q:GMRAPA1<1  D  Q:GMRAOUT
 ...S GMRAPA=$G(^TMP($J,"GMRAPST7",GMRADDT,GMRACA,GMRAPA1))
 ...Q:GMRAPA=""
 ...S GMRAPA1(0)=$G(^GMR(120.85,GMRAPA1,0))
 ...Q:GMRAPA1(0)=""
 ...S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0))
 ...Q:GMRAPA(0)=""
 ...D HEAD Q:GMRAOUT
 ...W !,$J($$FMTE^XLFDT(GMRADDT,"2D"),8) ; Obs Date
 ...W ?8,"|",GMRACA ; Causative Agent
 ...W ?38,"|"
 ...S GMRAREC=0
 ...S GMRAREC=$O(^GMR(120.85,GMRAPA1,2,0)) D:GMRAREC>0 SIGN("0",GMRAREC)
 ...W ?58,"| " W $P(GMRAPA(0),U,14) ; Mechanism
 ...W ?63,"|" W $S($P(GMRAPA1(0),U,14)=1:"MILD",$P(GMRAPA1(0),U,14)=2:"MOD.",$P(GMRAPA1(0),U,14)=3:"SVR.",1:"") ; Severity
 ...W ?68,"|"
 ...K ^TMP($J,"GMRAWORD") D WORD^GMRAWORD(GMRAPA,"OVE",60)
 ...S GMRACNT=1 W $G(^TMP($J,"GMRAWORD",GMRACNT))
 ...F  S GMRAREC=$O(^GMR(120.85,GMRAPA1,2,GMRAREC)) Q:GMRAREC<1  D SIGN("1",GMRAREC) Q:GMRAOUT
 ...F  S GMRACNT=$O(^TMP($J,"GMRAWORD",GMRACNT)) Q:GMRACNT<1  D  Q:GMRAOUT
 ....D HEAD Q:GMRAOUT  W !,?8,"|",?38,"|",?58,"|",?63,"|",?68,"|"
 ....Q:GMRAOUT
 ....W $G(^TMP($J,"GMRAWORD",GMRACNT))
 ....Q
 ...K ^TMP($J,"GMRAWORD")
 ...Q:GMRAOUT
 ...D HEAD Q:GMRAOUT  W !,?8,"|",?38,"|",?58,"|",?63,"|",?68,"|"
 ...Q
 ..Q
 .Q
 D CLOSE^GMRAUTL
 Q
SIGN(CNT,GMRAREC) ; Print Sign/Symptoms
 N NAM,Y
 S Y=$G(^GMR(120.85,GMRAPA1,2,GMRAREC,0))
 S NAM=$S(+Y=GMRAOTH:$P(Y,U,2),$D(^GMRD(120.83,+Y,0)):$P(^GMRD(120.83,+Y,0),U),1:"")
 I 'CNT W $E(NAM,1,19)
 E  D
 .D HEAD Q:GMRAOUT  W !,?8,"|",?38,"|",$E(NAM,1,19),?58,"|",?63,"|",?68,"|"
 .I $D(^TMP($J,"GMRAWORD",(GMRACNT+1))) S GMRACNT=GMRACNT+1 W $G(^TMP($J,"GMRAWORD",GMRACNT))
 .Q
 Q
 I GMRAPG'=1  Q:$Y<(IOSL-4)
 I $E(IOST,1)="C" D  Q:GMRAOUT
 .I GMRAPG=1 W @IOF Q
 .I GMRAPG'=1 D  Q:GMRAOUT
 ..N DIR S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
 ..K Y
 ..Q
 .Q
 Q:GMRAOUT
 I GMRAPG'=1 W @IOF
 N Z
 W "Report Date: ",$P($$FMTE^XLFDT(GMRADPDT),"@"),?125,"Page: ",GMRAPG
 W !,?48,"P&T Committee ADR Report"
 W !,?51,"From: ",$$FMTE^XLFDT(GMAST,"2D")," To: ",$$FMTE^XLFDT(GMAEN,"2D")
 W !,$$REPEAT^XLFSTR("-",130)
 W !,"Obsv.",?8,"|",?38,"|",?58,"|ADR",?63,"|ADR",?68,"|"
 W !,"Date",?8,"|Causative agent-Pat. ID",?38,"|Sign/Symptoms",?58,"|Mech",?63,"|Svr.",?68,"|Comments"
 W !,$$REPEAT^XLFSTR("-",130)
 S GMRAPG=GMRAPG+1
 I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
 Q