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

GMRADSP1.m

Go to the documentation of this file.
GMRADSP1 ;HIRMFO/WAA-DISPLAY ALLERGY ;01-May-2012 14:15;DU
 ;;4.0;Adverse Reaction Tracking;**41,1002,1006**;Mar 29, 1996;Build 29
DISBLD(IEN,ARRAY) ; This subroutine will bulid the array that will
 ; be displayed for each reactant.  The IEN for each reactant in
 ; stored in GMRAPA.
 N CNT,X,NODE,SOURCE
 S NODE=$G(^GMR(120.8,IEN,0)) Q:NODE=""  S CNT=1
 S SOURCE=$G(^GMR(120.8,IEN,9999999.11))
 I $L(GMRANAME)>50 S ARRAY(CNT)=$E(GMRANAME,1,50),CNT=CNT+1,ARRAY(CNT)=$E(GMRANAME,51,999)
 E  S ARRAY(CNT)=GMRANAME
ING ;Find all the ingredents for a reactant.
 I $O(^GMR(120.8,IEN,2,0))>0 D
 .N GMRAFST,GMRAGBAL,GMRAING,GMRAINGR,GMRALLEG,GMRALST
 .S GMRAINGR=0,GMRALLEG=0
 .F  S GMRAINGR=$O(^GMR(120.8,IEN,2,GMRAINGR)) Q:GMRAINGR'>0  S GMRAGBAL=^GMR(120.8,IEN,2,GMRAINGR,0) D
 ..;--41-1
 ..D ZERO^PSN50P41(GMRAGBAL,"","","ENCAP")
 ..I '$D(^TMP($J,"ENCAP",GMRAGBAL)) K ^TMP($J,"ENCAP") Q
 ..;--41-1
 ..;--41-2
 ..I $P(NODE,U,2)=$P(^TMP($J,"ENCAP",GMRAGBAL,.01),U) Q
 ..;--41-2
 ..;--41-3
 ..S GMRALLEG(IEN,$P(^TMP($J,"ENCAP",GMRAGBAL,.01),U))="",GMRALLEG=GMRALLEG+1
 ..K ^TMP($J,"ENCAP")
 ..;--41-3
 ..Q
 .I GMRALLEG S (GMRAINGR,GMRAING)="",CNT=CNT+1,ARRAY(CNT)="",GMRAFST=1,GMRALST=0 F  S GMRAINGR=$O(GMRALLEG(IEN,GMRAINGR)) Q:GMRAINGR=""  D
 ..I $O(GMRALLEG(IEN,GMRAINGR))="" S GMRALST=1
 ..S GMRAING=GMRAINGR
 ..I GMRAFST S GMRAING=" ("_GMRAING,GMRAFST=0
 ..I 'GMRALST S GMRAING=GMRAING_", "
 ..I GMRALST S GMRAING=GMRAING_")"
 ..I $L(ARRAY(CNT)_GMRAING)>52 S CNT=CNT+1,ARRAY(CNT)="  "_GMRAING
 ..E  S ARRAY(CNT)=ARRAY(CNT)_GMRAING
 ..Q
 .Q
SIGN ;Get all the patient Sign/Symptoms
 I $O(^GMR(120.8,IEN,10,0))>0 D
 .N GMRAFST,GMRALST,GMRAOTH,GMRAREAC,GMRAREAN,GMRATONS,GMRASRC,GMRAIN
 .N GMRAEA,GMRIDT,GMRIBY,GMRIRE,GMRIRE,GMRIREBY,SR,GMRABY
 .S GMRAOTH=$O(^GMRD(120.83,"B","OTHER REACTION",0))
 .S GMRAFST=1,GMRALST=0,CNT=CNT+1,ARRAY(CNT)="    Reactions:"
 .S GMRAREAC=0 F  S GMRAREAC=$O(^GMR(120.8,IEN,10,GMRAREAC)) Q:GMRAREAC'>0  S GMRAREAN=$P($G(^GMR(120.8,IEN,10,GMRAREAC,0)),U) I GMRAREAN'="" D
 ..N GMRAREC
 ..I '$O(^GMR(120.8,IEN,10,GMRAREAC)) S GMRALST=1
 ..S GMRATONS=$S(GMRAREAN'=GMRAOTH:$P(^GMRD(120.83,GMRAREAN,0),U),1:$P(^GMR(120.8,IEN,10,GMRAREAC,0),U,2))
 ..;IHS/MSC/MGH source returned patch 1006
 ..S GMRSRC=$P($G(^GMR(120.8,IEN,10,GMRAREAC,9999999.11)),U,1)
 ..S GMRSRC=$$GET1^DIQ(90460.05,GMRSRC,.01)
 ..S GMRAREC=GMRATONS_"(Source: "_GMRSRC_")"
 ..;S GMRAREC=GMRATONS
 ..;end mods
 ..I GMRAFST S GMRAREC=" "_GMRAREC,GMRAFST=0
 ..I 'GMRALST S GMRAREC=GMRAREC_", "
 ..I $L(ARRAY(CNT)_GMRAREC)>52 S CNT=CNT+1,ARRAY(CNT)="               "_GMRAREC
 ..E  S ARRAY(CNT)=ARRAY(CNT)_GMRAREC
 ..Q
 .Q
 ;IHS/MSC/MGH reentered code for inactive data patch 1006
 S GMRAIN=0 F  S GMRAIN=$O(^GMR(120.8,IEN,9999999.12,GMRAIN)) Q:'+GMRAIN  D
 .S GMRAZ2=$G(^GMR(120.8,IEN,9999999.12,GMRAIN,0))
 .S IIEN=GMRAIN_","_IEN_","
 .S GMREA=$$GET1^DIQ(120.899999912,IIEN,.01)
 .S CNT=CNT+1,ARRAY(CNT)="    Inactive: "
 .S GMRIDT=$$GET1^DIQ(120.899999912,IIEN,.01),GMREA=$$GET1^DIQ(120.899999912,IIEN,1),GMRABY=$$GET1^DIQ(120.899999912,IIEN,2)
 .S GMRIRE=$$GET1^DIQ(120.899999912,IIEN,3)
 .S ARRAY(CNT)=ARRAY(CNT)_GMRIDT_"( "_GMREA_" ) "
 .I GMRIRE'="" D
 ..S CNT=CNT+1
 ..S ARRAY(CNT)="    Reactivated: "_GMRIRE
 .K IIEN,GMRAZ2
 ;Added data to get the source of the reactions PATCH 1001 MSC/IHS/MGH
 S %=$P(SOURCE,U,1) I % S SR=$P($G(^BEHOAR(90460.05,%,0)),U,1) S ARRAY(1)=ARRAY(1)_$J(" ",(40-$L(ARRAY(1))))_SR
 S %=$S($P(NODE,U,16):"YES",1:" NO") I $P(NODE,U,16),$P(NODE,U,18)="" S %="AUTO"
 S ARRAY(1)=ARRAY(1)_$J(" ",(53-$L(ARRAY(1))))_%
 S %=$P(NODE,U,14),%=$S(%="P":"PHARM  ",%="A":"ALLERGY",%="U":"UNKNOWN ",1:""),ARRAY(1)=ARRAY(1)_$J(" ",(59-$L(ARRAY(1))))_%
 S %=$P(NODE,U,6),%=$S(%="o":"OBS",%="h":"HIST",1:""),ARRAY(1)=ARRAY(1)_$J(" ",(68-$L(ARRAY(1))))_%
TYPE S %="" F X=1:1:($L(GMRATYPE)) D
 .S %=$P("^FOOD^DRUG^OTHER",U,$F("FDO",$E(GMRATYPE,X)))
 .S ARRAY(X)=$G(ARRAY(X))
 .S ARRAY(X)=ARRAY(X)_$J(" ",(74-$L(ARRAY(X))))_%
 .Q
 Q