VistA-FOIAVistA/r/ADVERSE_REACTION_TRACKING-G.../GMRAPEE0.m

33 lines
1.6 KiB
Mathematica

GMRAPEE0 ;HIRMFO/YMP,RM-ENTERRED IN ERROR CHECK ; 10/16/91
;;4.0;Adverse Reaction Tracking;**2**;Mar 29, 1996
EN1 ; ENTRY TO SET GMRAERR IF THIS ALLERGY HAS BEEN ENTERED IN ERROR
S GMRAERR=0
K GMRAHEAD S GMRAPRNT=0 D EN1^GMRADSP2
S:GMRAOUT GMRAOUT=GMRAOUT-1 Q:GMRAOUT
I $P(^GMR(120.8,GMRAPA,0),U,16),$P(^(0),U,18)'="",'$D(^XUSEC("GMRA-ALLERGY VERIFY",DUZ)) Q
YNEE K GMRAEIE W !,"Is the reaction information correct" S %=1 D YN^DICN I '% W !?4,$C(7),"ANSWER NO IF THIS ALLERGY IS INCORRECT AND NEEDS TO BE MARKED",!?4,"AS ENTERED IN ERROR, ELSE ANSWER YES." G YNEE
I %=-1 S GMRAOUT=1 K GMRAPRCT Q
I %=2 D I $G(GMRAEIE)=1 G YNEE
.K DIR S DIR(0)="Y",DIR("A")="Mark this reaction as 'Entered-in-Error'"
.D ^DIR K DIR I $D(DIRUT)!(Y=0) S GMRAEIE=1 Q
.S GMRAERR=1,DIE="^GMR(120.8,",DA=GMRAPA,DR="22///1;23///NOW;24////"_DUZ D ^DIE
.D SITE^GMRAUTL S GMRASITE(0)=$G(^GMRD(120.84,GMRASITE,0))
.I $P(GMRASITE(0),U,11) S GMRAVCM="E" D ENDING^GMRAPEM1
.; This patch (#2) will loop through the patient reactions
.; and ensure that the patient's NKA information is marked
.; based on the existence of patient reactions.
.I $$NKASCR^GMRANKA($P(^GMR(120.8,GMRAPA,0),U)) D ; true NKA
..S DIK="^GMR(120.86,",DA=$P(^GMR(120.8,GMRAPA,0),U)
..D ^DIK ; purge the NKA node from 120.86
..Q
.D EN1^GMRAPET0($P(^GMR(120.8,GMRAPA,0),U),GMRAPA,"E",.GMRAOUT)
.D EN1^GMRAEAB
.D ; Execute the event point for this reaction
..Q:'$D(GMRAPA) S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""
..N OROLD,DFN S DFN=$P(GMRAPA(0),U)
..D INP^VADPT S X=$O(^ORD(101,"B","GMRA ENTERED IN ERROR",0))_";ORD(101," D EN^XQOR:X K VAIN,X
..Q
.Q
K %,DA,DIE,DR,GMRASITE
Q