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

GMRAPES0.m

Go to the documentation of this file.
  1. GMRAPES0 ;HIRMFO/RM-SELECT PATIENT ALLERGY TO EDIT ;11/16/07 10:26
  1. ;;4.0;Adverse Reaction Tracking;**13,17,19,21,23,20,41**;Mar 29, 1996;Build 8
  1. ;DBIA Section
  1. ;PSN5067 - 4829
  1. ;DIC - 10006
  1. ;DICN - 10009
  1. ;DIQ - 2056
  1. ;DIR - 10026
  1. ;DIWE - 10028
  1. ;PSNAPIS - 2574
  1. ;PSNDI - 4554
  1. ;XLFDT - 10103
  1. ;XLFSTR - 10104
  1. ;XMD - 10070
  1. ;XTID - 4631
  1. EN1 ; GIVEN DFN, SELECT PATIENT ALLERGY
  1. N GMRAGOUT,ROOT,CNT,LST,NAM,DIR,GMRAET
  1. S GMRARET=0
  1. S GMRAPA=-1,GMRANEW=0 R !!,"Enter Causative Agent: ",GMRALAR:DTIME S:'$T GMRALAR="^^" S:GMRALAR="" GMRARET=1 I "^^"[GMRALAR S GMRAOUT='$L(GMRALAR)+1 G Q1
  1. I GMRALAR?1P.E!($L(GMRALAR)<3)!($L(GMRALAR)>30) S GMRAHLP=1 D EN1^GMRAHLP0 G EN1:'GMRAOUT,Q1
  1. I GMRALAR?.E1L.E S GMRALAR=$$UP^XLFSTR(GMRALAR)
  1. PAL K Y,DTOUT,DUOUT S DGSENFLG="",DIC="^GMR(120.8,",DIC(0)="SEZ",X=GMRANAM,DIC("S")="I '+$G(^(""ER"")),$P(^(0),U,2)?@(""1""""""_GMRALAR_"""""".E""),$D(^GMR(120.8,""B"",DFN,+Y))",DIC("W")="W $P(^(0),U,2)"
  1. W !!,"Checking existing PATIENT ALLERGIES (#120.8) file for matches...",!
  1. D ^DIC S X=$P($G(Y(0)),"^",2) K DIC,DGSENFLG,DTOUT,DUOUT D DIC I GMRAOUT S GMRAOUT=GMRAOUT-1 G:GMRAOUT Q1 G EN1
  1. S:+Y>0 GMRAPA=+Y G Q1:+Y>0!GMRAOUT,PAL:X?1"?".E,EN1:Y=0
  1. G Q1:'GMRALAGO
  1. NPA W !!,"Now checking GMR ALLERGIES (#120.82) file for matches...",!
  1. S DIC("S")="I $P(^(0),U)'=""OTHER ALLERGY/ADVERSE REACTION""&($S($L($T(SCREEN^XTID)):'$$SCREEN^XTID(120.82,.01,Y_"",""),1:1))" ;21,23
  1. K Y,DTOUT,DUOUT S X=GMRALAR,DIC="^GMRD(120.82,",DIC(0)="EZM",DIC("W")="" D ^DIC K DIC S:+Y>0 X=$P(Y,"^",2) D DIC I GMRAOUT S GMRAOUT=GMRAOUT-1 G:GMRAOUT Q1 G EN1
  1. I +Y>0 S GMRAAR=+Y_";GMRD(120.82,",GMRAAR(0)=$P(Y,"^",2),GMRAAR("O")=$P(Y(0),"^",2) D:'GMRAOUT ADAR^GMRAPES1 G EN1:GMRAPA'>0,Q1
  1. G Q1:GMRAOUT,NPA:X?1"?".E,EN1:Y=0
  1. NDF ;find partial matches and select from NDF
  1. K Y,DTOUT,DUOUT
  1. W !!,"Now checking the National Drug File - Generic Names (#50.6)",!
  1. S DIC=50.6,X=GMRALAR,DIC(0)="EZM",DIC("S")="I $S($L($T(SCREEN^XTID)):'$$SCREEN^XTID(50.6,.01,Y_"",""),1:1)" D DIC^PSNDI(50.6,"GMRA",.DIC,.X,,$$DT^XLFDT) K DIC D DIC ;23,41
  1. I +Y>0 S GMRAAR=+Y_";PSNDF(50.6,",GMRAAR(0)=$P(Y,U,2),GMRAAR("O")="D" D:'GMRAOUT ADAR^GMRAPES1 G EN1:GMRAPA'>0,Q1
  1. W !!,"Now checking the National Drug File - Trade Names (#50.67)",!
  1. K DUOUT,DTOUT,Y
  1. S ROOT="^TMP($J,""GMRASEL"",""B"")",CNT=0,X=GMRALAR ;41
  1. D ALL^PSN5067(,X,$$DT^XLFDT,"GMRASEL") ;41
  1. I $D(@ROOT@(X)),$S($L($T(SCREEN^XTID)):'$$SCREEN^XTID(50.6,.01,$$TGTOG^PSNAPIS(X)_","),1:1) S CNT=CNT+1,LST(CNT)=$$TGTOG^PSNAPIS(X)_U_X ;23 Exact match stores IEN in 50.6 along with trade name
  1. S NAM=X F S NAM=$O(@ROOT@(NAM)) Q:NAM=""!($E(NAM,1,$L(X))'=X) D
  1. .Q:$S($L($T(SCREEN^XTID)):$$SCREEN^XTID(50.6,.01,$$TGTOG^PSNAPIS(NAM)_","),1:0) ;23
  1. .S CNT=CNT+1,LST(CNT)=$$TGTOG^PSNAPIS(NAM)_U_NAM
  1. I 'CNT S Y=-1 ;No matches found
  1. I CNT=1 S Y(0)=LST(1),X=$P(Y(0),U,2),Y=+LST(1) ;Only one choice
  1. I CNT>1 D
  1. .D MATCHES
  1. .S DIR(0)="NAO^1:"_CNT,DIR("A")="Select 1-"_CNT_": "
  1. .S DIR("?")="Select the number of desired causative agent"
  1. .D ^DIR S Y=$S(+Y:+Y,1:-1) S:Y>0 Y(0)=LST(Y),X=$P(Y(0),U,2)
  1. D DIC I GMRAOUT S GMRAOUT=GMRAOUT=1 G:GMRAOUT Q1 G EN1
  1. I +Y>0 S GMRAAR=+Y(0)_";PSNDF(50.6,",GMRAAR(0)=$P(Y(0),U,2),GMRAAR("O")="D" D:'GMRAOUT ADAR^GMRAPES1 G EN1:GMRAPA'>0,Q1
  1. ;Selection from file 50 removed in patch 23 and code actually removed in 41
  1. ;19 - Moved ING and CLASS code here
  1. ING W !!,"Now checking the INGREDIENTS (#50.416) file for matches...",!
  1. K Y,DTOUT,DUOUT S D="P",DIC="^PS(50.416,",DIC(0)="SEMZ",DIC("S")="I $S($L($T(SCREEN^XTID)):'$$SCREEN^XTID(50.416,.01,Y_"",""),1:1)",X=GMRALAR D IX^PSNDI(50.416,"GMRA",.DIC,D,.X,,$$DT^XLFDT) K DIC D DIC ;41
  1. I GMRAOUT S GMRAOUT=GMRAOUT-1 G:GMRAOUT Q1 G EN1 ;41
  1. I +Y>0 S GMRAAR=+Y_";PS(50.416,",GMRAAR(0)=$S(X?1A.E:X,1:$P(Y,"^",2)),GMRAAR("O")="D" D:'GMRAOUT ADAR^GMRAPES1 G EN1:GMRAPA'>0,Q1
  1. G Q1:GMRAOUT,ING:X?1"?".E,EN1:Y=0
  1. CLASS W !!,"Now checking VA DRUG CLASS (50.605) file for matches...",!
  1. K Y,DTOUT,DUOUT S X=GMRALAR,DIC="^PS(50.605,",DIC(0)="SEZ",D="C",DIC("S")="I $S($L($T(SCREEN^XTID)):'$$SCREEN^XTID(50.605,.01,Y_"",""),1:1)" D IX^PSNDI(50.605,"GMRA",.DIC,D,.X,,$$DT^XLFDT) K DIC D DIC ;41
  1. I GMRAOUT S GMRAOUT=GMRAOUT-1 G:GMRAOUT Q1 G EN1 ;41
  1. I +Y>0 S GMRAAR=+Y_";PS(50.605,",GMRAAR(0)=$S(X?1A.E:X,1:$P(Y,"^",2)),GMRAAR("O")="D" D:'GMRAOUT ADAR^GMRAPES1 G EN1:GMRAPA'>0,Q1
  1. G Q1:GMRAOUT,CLASS:X?1"?".E,EN1:Y=0
  1. YNOTH W !!,"Could not find ",GMRALAR," in any files."
  1. W !!,"Before sending an email requesting the addition of a new reactant, please",!,"try entering the first 3 or 4 letters of the reactant to search for",!,"the desired entry.",!
  1. W !,"Would you like to send an email requesting ",GMRALAR,!,"be added as a causative agent?"
  1. S DIR("A")="Send email"
  1. S DIR(0)="Y",DIR("B")="NO",DIR("?")="^D MESS^GMRAPES0"
  1. D ^DIR
  1. I Y'=+Y S GMRAOUT=1 G Q1
  1. I '+Y G EN1
  1. YNDRG ;
  1. D GETINPUT(.GMRAET)
  1. S X=$$SENDREQ(DUZ,DFN,GMRALAR,.GMRAET)
  1. I '+X W !!,"Error - Message not sent - ",$P(X,U,2)
  1. I +X W !!,"Message sent - NOTE: This reactant was NOT added for this patient."
  1. W !
  1. Q1 ;
  1. S:GMRAPA>0 GMRAPA(0)=$S($D(^GMR(120.8,+GMRAPA,0)):^(0),1:"")
  1. K %,D,DA,DIC,DTOUT,DUOUT,GMRAAR,GMRAHLP,GMRAING,GMRALAGO,GMRALAR,PSNDA,PSODA,X,Y
  1. Q
  1. DIC ; VALIDATE LOOKUP FOR A/AR
  1. S:$D(DTOUT) X="^^" I X="^^" S GMRAOUT=1 Q
  1. S:$D(DUOUT) Y=0 Q:+Y'>0
  1. YNOK W !?3,X," OK" S %=1 D YN^DICN S:%=-1 GMRAOUT=1,Y=-1 Q:GMRAOUT S:%=2 Y=-1 Q:Y=-1 S:$$DUPCHK(X,DFN,Y) Y=-1 Q:GMRAOUT I % W ! Q ;19
  1. W !?5,$C(7),"ANSWER YES IF THIS IS THE CORRECT ALLERGY/ADVERSE REACTION,",!?5,"ELSE ANSWER NO."
  1. G YNOK
  1. DUPCHK(X,Y,Z) ;CHECK FOR ENTERED IN ERROR
  1. N GMRAPA,GMRAGOUT,%,%Y S GMRAGOUT=0
  1. I $P($G(^GMR(120.8,+Z,0)),U,2)=X Q GMRAGOUT
  1. I $O(^GMR(120.8,"B",Y,0)) S GMRAPA=0 F S GMRAPA=$O(^GMR(120.8,"B",Y,GMRAPA)) Q:GMRAPA<1 D Q:GMRAOUT!(GMRAGOUT)
  1. .I $P(^GMR(120.8,GMRAPA,0),U,2)'=X Q
  1. .I $D(^GMR(120.8,GMRAPA,"ER")) D
  1. ..F S %=2 W !,?5,$C(7),"This Agent has been Entered in Error once before.",!,?5,"Are you sure you want to select this Agent again" D Q:%
  1. ...D YN^DICN S:%'=1 %=2,GMRAOUT=1 S:%Y?2"^" GMRAOUT=2
  1. ...Q:% W !,?10,"ENTER 'Y' FOR YES OR 'N' FOR NO"
  1. ...Q
  1. ..S GMRAGOUT=%
  1. ..Q
  1. .Q
  1. I GMRAGOUT=0 S GMRAGOUT=1
  1. Q (GMRAGOUT-1)
  1. MATCHES ; -- List matches for NDF
  1. N I,J,QUIT
  1. W !!,"Choose from the following "_+$G(CNT)_" matches:"
  1. S (I,J,QUIT)=0 F S I=$O(LST(I)) Q:I'>0 D Q:QUIT
  1. . S J=J+1 I '(J#(IOSL-5)) S:'$$MORE QUIT=1 Q:QUIT
  1. . W !,J," ",$P(LST(I),"^",2)
  1. Q
  1. ;
  1. MORE() ; -- show more matches
  1. N DIR,DTOUT,DUOUT,X,Y
  1. S DIR(0)="EA",DIR("A")="Press <return> to see more, or ^ to stop ..."
  1. D ^DIR
  1. Q +Y
  1. ;
  1. SENDREQ(USER,PAT,TEXT,GMRAET) ;Send email to GMRA REQUEST NEW REACTANT indicating user's request for a new allergy
  1. ;Returns 0^reason for error
  1. ; 1 if successful
  1. N XMDUZ,XMY,XMSUB,GMRATXT,XMTEXT,XMZ,XMMG,GMRAUI,GMRAPI,GMRAUS,GMRAPS,CNT,J
  1. Q:'$G(USER)!('+$G(DUZ))!('$L(TEXT)) "0^Required information missing"
  1. S XMDUZ="Allergy Package",XMSUB="Request to add new reactant"
  1. S XMY("G.GMRA REQUEST NEW REACTANT")=""
  1. S XMY(DUZ)="" ;Include requestor in message
  1. D GETS^DIQ(200,USER,".01;.132;.138;8","E","GMRAUI"),GETS^DIQ(2,PAT,".01;.09","IE","GMRAPI") S GMRAUS=USER_",",GMRAPS=PAT_","
  1. S CNT=1
  1. S GMRATXT(CNT)="A request to add "_TEXT_" as a new reactant was entered",CNT=CNT+1
  1. S GMRATXT(CNT)="by "_GMRAUI(200,GMRAUS,.01,"E")_" for patient "_GMRAPI(2,GMRAPS,.01,"E")_" ("_$E(GMRAPI(2,GMRAPS,.09,"I"),6,9)_")",CNT=CNT+1
  1. S GMRATXT(CNT)="",CNT=CNT+1
  1. S GMRATXT(CNT)="User's contact information:",CNT=CNT+1
  1. S GMRATXT(CNT)="Title : "_GMRAUI(200,GMRAUS,8,"E"),CNT=CNT+1
  1. S GMRATXT(CNT)="Office Phone : "_GMRAUI(200,GMRAUS,.132,"E"),CNT=CNT+1
  1. S GMRATXT(CNT)="Digital Pager: "_GMRAUI(200,GMRAUS,.138,"E"),CNT=CNT+1
  1. S GMRATXT(CNT)="",CNT=CNT+1
  1. I $D(GMRAET) S GMRATXT(CNT)="The user added the following comment:",CNT=CNT+1,GMRATXT(CNT)="",CNT=CNT+1 F J=1:1:$P(GMRAET(0),U,3) S GMRATXT(CNT)=GMRAET(J,0),CNT=CNT+1 ;20 Added blank line following comment
  1. I $D(GMRAET) S GMRATXT(CNT)="",CNT=CNT+1
  1. S GMRATXT(CNT)="Please verify with the user the intended reactant and then take the",CNT=CNT+1
  1. S GMRATXT(CNT)="appropriate action. Be sure to try alternate spellings, etc before",CNT=CNT+1
  1. S GMRATXT(CNT)="requesting new reactants through NTRT (New Term Rapid Turnaround).",CNT=CNT+1 ;23
  1. S GMRATXT(CNT)="",CNT=CNT+1
  1. S GMRATXT(CNT)="Please note, an allergy to "_TEXT_" was NOT entered for this patient!",CNT=CNT+1 ;20
  1. S XMTEXT="GMRATXT("
  1. D ^XMD
  1. Q $S($D(XMMG):"0^Mail group GMRA REQUEST NEW REACTANT has no members - contact IRM",1:1)
  1. ;
  1. MESS ;Provide help for sending email message
  1. W !,"Enter YES to send an email to the allergy coordinator(s) indicating that",!,"Reactant--> ",GMRALAR,!,"was not found when you were trying to add it for this patient.",!,"Enter NO to try entering the reactant again."
  1. Q
  1. ;
  1. GETINPUT(GMRAET) ;Allow user to add comment to message
  1. N DIC,DWLW,DWPK,DIWEPSE
  1. S ^TMP($J,"TEXT",0)=""
  1. S DIC="^TMP($J,""TEXT"","
  1. S DWLW=70,DWPK=1,DIWEPSE=""
  1. W !!,"You may now add any comments you may have to the message that",!,"is going to be sent with the request to add this reactant."
  1. W !,"You may want to add things like sign/symptoms, observed or historical, etc",!,"that may be useful to the reviewer.",!
  1. D EN^DIWE
  1. I $O(^TMP($J,"TEXT",0)) M GMRAET=^TMP($J,"TEXT")
  1. K ^TMP($J,"TEXT")
  1. Q