1 | GMRAFX3 ;SLC/DAN Update existing entries to new reactant ;6/28/06 10:23
|
---|
2 | ;;4.0;Adverse Reaction Tracking;**17,19,23,20**;Mar 29, 1996;Build 1
|
---|
3 | ;DBIA SECTION
|
---|
4 | ;10018 - DIE
|
---|
5 | ;2056 - DIQ
|
---|
6 | ;3154 - ORQ1
|
---|
7 | ;4134 - ORCHECK
|
---|
8 | ;4135 - ORKCHK
|
---|
9 | ;10026 - DIR
|
---|
10 | ;
|
---|
11 | UIE ;Update individual entries
|
---|
12 | N DFN,GMRAOUT,GMRAING,GMRADRCL,DIE,DA,DR,AIFN,SIGN,TIME,SUB,ORX,GMRAORX,GMRAOC,GI,FND,COM,SIEN,DIR,Y
|
---|
13 | S GMRADONE=0 ;Flag to keep track of updated entries
|
---|
14 | S DFN=$P($G(^GMR(120.8,GMRAPA,0)),U) Q:'+DFN
|
---|
15 | W !!,"For patient ",$$GET1^DIQ(2,DFN_",",.01),!
|
---|
16 | I $D(GMRAAR) D
|
---|
17 | .S DIR(0)="Y",DIR("A")="Use reactant "_GMRAAR(0),DIR("B")="Y" D ^DIR
|
---|
18 | .K:'Y GMRAAR
|
---|
19 | .Q
|
---|
20 | I '$D(GMRAAR) D ^GMRAFX2 I $D(GMRAAR) D RUSURE(.GMRASURE) ;20 Get new reactant
|
---|
21 | I '$D(GMRAAR)!('$G(GMRASURE)) K GMRAAR Q ;20 stop if no reactant selected or if user doesn't want to use selected reactant
|
---|
22 | S GMRAOUT=0
|
---|
23 | I $$DUP W !,"Patient already has an active allergy for this reactant.",!,"Duplicate not allowed.",! D WAIT Q
|
---|
24 | I $$DUPCHK^GMRAPES0(GMRAAR(0),DFN,GMRAPA) Q ;Checks to see if reactant previously entered in error.
|
---|
25 | ;Update reactant, allergy and signed off fields
|
---|
26 | S DIE="^GMR(120.8,",DA=GMRAPA,DR=".02////"_GMRAAR(0)_";1////^S X=GMRAAR"_";3.1////"_GMRAAR("O")_";15///1" D ^DIE
|
---|
27 | I $D(^GMR(120.85,"C",GMRAPA)) D ;Observed reaction, need to update data
|
---|
28 | .S AIFN=0
|
---|
29 | .F S AIFN=$O(^GMR(120.85,"C",GMRAPA,AIFN)) Q:'+AIFN D
|
---|
30 | ..S SIEN=$O(^GMR(120.85,AIFN,3,"B",$P(^XTMP("GMRAFX",LTYPE,"IDX",+NMBR),"^"),0)) Q:'+SIEN ;Was previous reactant stored as "suspected agent"
|
---|
31 | ..S DA(1)=AIFN,DA=SIEN
|
---|
32 | ..S DIE="^GMR(120.85,DA(1),3,",DR=".01////^S X=GMRAAR(0)" D ^DIE ;Update suspected agent to new value
|
---|
33 | D DELMUL(2),DELMUL(3) ;Delete drug ingredient/drug classes multiples
|
---|
34 | I GMRAAR("O")["D" D UPDATE^GMRAPES1 ;If reactant type is Drug then add appropriate ingredients and classes
|
---|
35 | S GMRADONE=1 ;Update complete
|
---|
36 | S COM="Updated using clean up process. Changed reactant from "_$P(^XTMP("GMRAFX",LTYPE,"IDX",+NMBR),"^",2)_$S(LTYPE="FREE":" (free text) ",LTYPE="ING":" (ingredient) ",1:" (drug class) ")_"to "_GMRAAR(0)_"(file - "_$P(GMRAAR,";",2)_")"
|
---|
37 | D ADCOM^GMRAFX(GMRAPA,"O",COM) ;Add a comment for this update
|
---|
38 | ;Do order checking here - compare existing orders against new allergy information.
|
---|
39 | W !,"Performing order checking..."
|
---|
40 | K ^TMP("ORR",$J),GMRAOC,ORX
|
---|
41 | D EN^ORQ1(DFN_";DPT(") ;Retrieve active orders
|
---|
42 | S TIME=$O(^TMP("ORR",$J,0))
|
---|
43 | I '^TMP("ORR",$J,TIME,"TOT") W "patient has no active orders." Q ;20 No orders found
|
---|
44 | S SUB=0 F S SUB=$O(^TMP("ORR",$J,TIME,SUB)) Q:'+SUB D
|
---|
45 | .D BLD^ORCHECK(+^TMP("ORR",$J,TIME,SUB)) ;Get "order" information in order checking format
|
---|
46 | M GMRAORX=ORX K ORX ;19
|
---|
47 | D EN^ORKCHK(.GMRAOC,DFN,.GMRAORX,"ACCEPT")
|
---|
48 | S GI=0,FND=0 F S GI=$O(GMRAOC(GI)) Q:'+GI D
|
---|
49 | .Q:$P(GMRAOC(GI),U,2)'=3 ;Quit if not allergy related
|
---|
50 | .Q:$D(^OR(100,$P(GMRAOC(GI),U),9,"B",3)) ;23 If order check exists can't be for this data
|
---|
51 | .W !,"Patient has a(n) ",$P($$STATUS^ORQOR2($P(GMRAOC(GI),U)),U,2)," order for",$P($P(GMRAOC(GI),U,4),":",2),", order #",$P(GMRAOC(GI),U)
|
---|
52 | .S FND=1
|
---|
53 | W:'FND "No problems found"
|
---|
54 | D WAIT
|
---|
55 | Q
|
---|
56 | ;
|
---|
57 | DELMUL(FIELD) ;Delete multiple FIELD from GMR ALLERGY file
|
---|
58 | N MIEN,DA,DIE,DR
|
---|
59 | S MIEN=0 F S MIEN=$O(^GMR(120.8,GMRAPA,FIELD,MIEN)) Q:'+MIEN D
|
---|
60 | .S DA(1)=GMRAPA,DA=MIEN
|
---|
61 | .S DIE="^GMR(120.8,DA(1),FIELD,",DR=".01///@" D ^DIE ;Delete entry
|
---|
62 | Q
|
---|
63 | ;
|
---|
64 | DUP() ;Function returns true (1) if selected reactant is a duplicate
|
---|
65 | N LOOP,FND
|
---|
66 | S LOOP=0,FND=0
|
---|
67 | F S LOOP=$O(^GMR(120.8,"B",DFN,LOOP)) Q:'+LOOP!(FND) D
|
---|
68 | .I $P(^GMR(120.8,LOOP,0),U,3)=GMRAAR&('$D(^GMR(120.8,LOOP,"ER"))) S FND=1
|
---|
69 | Q FND
|
---|
70 | ;
|
---|
71 | WAIT ;Issues press enter to return prompt
|
---|
72 | N DIR
|
---|
73 | S DIR(0)="E",DIR("A")="Press enter to continue" D ^DIR
|
---|
74 | Q
|
---|
75 | ;
|
---|
76 | GETNUM(ACTION) ; -- Return numbers to act on, if action chosen first
|
---|
77 | N X,Y,DIR,MAX
|
---|
78 | S MAX=$S($D(^TMP($J,LTYPE,"IDX2")):$G(^TMP($J,LTYPE,"IDX2",0)),1:$G(VALMCNT)) Q:MAX'>0 ""
|
---|
79 | I ACTION="DET" W !!,"Please choose only one entry for the detailed display."
|
---|
80 | S DIR(0)="LAO^1:"_MAX,DIR("A")="Select Entries from list: "
|
---|
81 | S DIR("?")="Enter the items you wish to act on, as a range or list of numbers."
|
---|
82 | D ^DIR S:$D(DTOUT) Y="^"
|
---|
83 | I $D(Y(1)) W !,">>>Too many entries selected, try using smaller ranges" H 2 S Y="^"
|
---|
84 | I $L($G(Y),",")>2,ACTION="DET" W !,">>You may only choose ONE group for detailed display." H 2 S Y="^"
|
---|
85 | Q Y
|
---|
86 | ;
|
---|
87 | UPDATE ;Update display to account for changes to the list
|
---|
88 | N CNT,SP1,SP2,SP3
|
---|
89 | I VALMAR["GMRADET" N VALMAR S VALMAR="^XTMP(""GMRAFX"",LTYPE)"
|
---|
90 | S CNT=^XTMP("GMRAFX",LTYPE,"GMRAR",$P(ENTRY,U),$P(ENTRY,U,2))-1
|
---|
91 | S ^XTMP("GMRAFX",LTYPE,"GMRAR",$P(ENTRY,U),$P(ENTRY,U,2))=CNT K ^($P(ENTRY,U,2),GMRAJ)
|
---|
92 | S SP1=4-$L(+NUM),SP2=40-$L($P(ENTRY,U)),SP3=$S(CNT:16-$L(CNT)\2,1:2)
|
---|
93 | D SET^VALM10(+NUM,+NUM_$$REPEAT^XLFSTR(" ",SP1)_$P(ENTRY,U,2)_$$REPEAT^XLFSTR(" ",(SP2+SP3))_$S(CNT:CNT,1:"** FIXED **"))
|
---|
94 | Q
|
---|
95 | ;
|
---|
96 | LOCK(ENTRY) ;Lock entry in 120.8
|
---|
97 | N LOCK
|
---|
98 | S LOCK=1
|
---|
99 | L +^XTMP("GMRAFX",LTYPE,"IDX",ENTRY):1
|
---|
100 | I '$T D FULL^VALM1 S VALMBCK="R" W !,"The ",$P(^XTMP("GMRAFX",LTYPE,"IDX",ENTRY),U)," group is being edited by another user" D WAIT S LOCK=0
|
---|
101 | Q LOCK
|
---|
102 | ;
|
---|
103 | AR ;Add/edit patient reactions
|
---|
104 | N LCV,DFN,SUB
|
---|
105 | S VALMBCK="R" D FULL^VALM1
|
---|
106 | W !!,"You should use this option to add NEW reactions only. If you mark"
|
---|
107 | W !,"existing entries as entered in error from within this option it will"
|
---|
108 | W !,"not update the utility's display until the list is rebuilt upon re-entry"
|
---|
109 | W !,"of this option. This could cause confusion as the list will no longer"
|
---|
110 | W !,"be accurate.",!
|
---|
111 | I '$G(NMBR2) D WAIT,EN1^GMRAPEM0 Q
|
---|
112 | F LCV=1:1:$L(NMBR2,",")-1 S SUB=$P(NMBR2,",",LCV) S DFN=+$P($G(^GMR(120.8,+$P($G(^TMP($J,LTYPE,"IDX2",SUB)),U,2),0)),U) I DFN W !!,"Now working with patient ",$$GET1^DIQ(2,DFN,.01),! D WAIT D EN2^GMRAPEM0
|
---|
113 | Q
|
---|
114 | ;
|
---|
115 | DSPREACT ;Display detailed information about the reactant
|
---|
116 | N DIC,DA,GMRAI,STOP,NUM2,DIR,Y
|
---|
117 | S VALMBCK="R" D FULL^VALM1
|
---|
118 | I '$G(NMBR2) S NMBR2=$$GETNUM("") Q:'+NMBR2
|
---|
119 | F GMRAI=1:1:($L(NMBR2,",")-1) D Q:$G(STOP)
|
---|
120 | .S NUM2=$P(NMBR2,",",GMRAI)
|
---|
121 | .S DA=$P(^TMP($J,LTYPE,"IDX2",NUM2),U,2) Q:'DA
|
---|
122 | .S DIC="^GMR(120.8,"
|
---|
123 | .W ! D EN^DIQ
|
---|
124 | .S DIR(0)="E",DIR("A")="Press return to continue or '^' to stop" D ^DIR
|
---|
125 | .S:$D(DIRUT) STOP=1
|
---|
126 | .Q
|
---|
127 | Q
|
---|
128 | ;
|
---|
129 | GETTYPE(LTYPE) ;Function determines which list to work with
|
---|
130 | N DIR,X,Y
|
---|
131 | S DIR(0)="SO^1:Free Text;2:Ingredient;3:Drug Class"
|
---|
132 | S DIR("A")="Select the list you wish to work with"
|
---|
133 | D ^DIR K DIR
|
---|
134 | S LTYPE=$S(Y=1:"FREE",Y=2:"ING",Y=3:"DRUG",1:0)
|
---|
135 | Q LTYPE
|
---|
136 | ;
|
---|
137 | EIE ;Mark individual entry as entered in error
|
---|
138 | N DIE,DA,DR,Y,DIK,DFN,OROLD,VAIN,X,GMRAOUT
|
---|
139 | S DIE="^GMR(120.8,",DA=GMRAPA,DR="15///1;22///1;23///NOW;24////"_$G(DUZ,.5) ;20
|
---|
140 | D ^DIE ;Entered in error on date/time by user
|
---|
141 | D ADCOM^GMRAFX(GMRAPA,"E","Marked Entered in Error during clean up process")
|
---|
142 | I $$NKASCR^GMRANKA($P(^GMR(120.8,GMRAPA,0),U)) D
|
---|
143 | .S DIK="^GMR(120.86,",DA=$P(^GMR(120.8,GMRAPA,0),U)
|
---|
144 | .D ^DIK ;If patient's last allergy marked as entered in error then delete assessment
|
---|
145 | .W !!,"**NOTE: By marking this reaction as entered in error, ",$$GET1^DIQ(2,DA,.01,"E"),!,"no longer has an assessment on file. You may reassess this patient",!
|
---|
146 | .W "now by answering the following prompt or hit return to do it later.",!
|
---|
147 | .D NKAASK^GMRANKA(DA)
|
---|
148 | S GMRAPA(0)=$G(^GMR(120.8,GMRAPA,0)) Q:GMRAPA(0)=""
|
---|
149 | S GMRAOUT=0
|
---|
150 | D EN1^GMRAEAB ;Sends entered in error bulletin to appropriate mail groups
|
---|
151 | S DFN=$P(GMRAPA(0),U)
|
---|
152 | D INP^VADPT S X=$$FIND1^DIC(101,,"BX","GMRA ENTERED IN ERROR")_";ORD(101," ;19
|
---|
153 | D:X EN^XQOR ;Process protocols hanging off of "entered in error" protocol
|
---|
154 | Q
|
---|
155 | ;
|
---|
156 | RUSURE(GMRASURE) ;20 Make sure selection from ingredient or drug class file is ok
|
---|
157 | ;entire section added in patch 20
|
---|
158 | N DIR,Y,X
|
---|
159 | S GMRASURE=1
|
---|
160 | I $G(GMRAAR)["50.416"!($G(GMRAAR)["50.605") D
|
---|
161 | .S DIR("A")="Are you sure you want to use this reactant"
|
---|
162 | .S DIR("A",1)="You are about to update the entry with a selection from"
|
---|
163 | .S DIR("A",2)="the "_$S($G(GMRAAR)["50.416":"INGREDIENT",1:"VA DRUG CLASS")_" file. By doing that you are"
|
---|
164 | .S DIR("A",3)="limiting the information available for order checking."
|
---|
165 | .S DIR("A",4)=""
|
---|
166 | .S DIR("A",5)="In general, it is better to choose from one of the drug related files"
|
---|
167 | .S DIR("A",6)="as that ensures that drug class and ingredient information are part"
|
---|
168 | .S DIR("A",7)="of the patient's allergy definition and will provide better allergy"
|
---|
169 | .S DIR("A",8)="order checking."
|
---|
170 | .S DIR("A",9)=""
|
---|
171 | .S DIR(0)="Y",DIR("B")="NO"
|
---|
172 | .D ^DIR S GMRASURE=+Y
|
---|
173 | Q
|
---|