1 | ORWDAL32 ; SLC/REV - Allergy calls to support windows ;5/31/05 14:14
|
---|
2 | ;;3.0;ORDER ENTRY/RESULTS REPORTING;**10,85,109,190,195,233,243**;Dec 17, 1997;Build 242
|
---|
3 | ;
|
---|
4 | DEF(LST) ; Get dialog data for allergies
|
---|
5 | N ILST,I,X S ILST=0
|
---|
6 | S LST($$NXT)="~Allergy Types" D ALLGYTYP
|
---|
7 | S LST($$NXT)="~Reactions" D ALLGYTYP
|
---|
8 | S LST($$NXT)="~Nature of Reaction" D NATREACT
|
---|
9 | S LST($$NXT)="~Top Ten" D TOPTEN
|
---|
10 | S LST($$NXT)="~Observ/Hist" D OBSHIST
|
---|
11 | S LST($$NXT)="~Severity" D SEVERITY
|
---|
12 | Q
|
---|
13 | GMRASITE(ORY) ;Return GMRA Site Params
|
---|
14 | N GMRASITE
|
---|
15 | D SITE^GMRAUTL
|
---|
16 | S ORY=$G(^GMRD(120.84,GMRASITE,0))
|
---|
17 | Q
|
---|
18 | TOPTEN ; Get top ten symptoms from Allergy Site Parameters file
|
---|
19 | N X0,I,CNT,GMRASITE S I=0,X0="",CNT=0 ;233
|
---|
20 | D SITE^GMRAUTL ;233
|
---|
21 | F S I=$O(^GMRD(120.84,GMRASITE,1,I)),CNT=CNT+1 Q:+I=0!(CNT>10) D ;233
|
---|
22 | . S X0=^GMRD(120.84,GMRASITE,1,I,0) Q:'$D(^GMRD(120.83,X0)) Q:$P(^GMRD(120.83,X0,0),"^")="OTHER REACTION" ;233 Don't send this entry
|
---|
23 | . ;233 Don't send if inactive term
|
---|
24 | . I $L($T(SCREEN^XTID)) Q:$$SCREEN^XTID(120.83,.01,X0_",")
|
---|
25 | . S LST($$NXT)="i"_X0_U_$P($G(^GMRD(120.83,X0,0)),U,1)
|
---|
26 | Q
|
---|
27 | ALLSRCH(Y,X) ; Return list of partial matches ; CHANGED TO PRODUCE TREEVIEW IN GUI
|
---|
28 | N ORX,ROOT,XP,CNT,ORFILE,ORSRC,ORIEN,ORREAX S ORIEN=0,CNT=0,ORSRC=0,ORFILE=""
|
---|
29 | S ORX=X,X=$$UP^XLFSTR(X)
|
---|
30 | F ROOT="^GMRD(120.82,""B"")","^GMRD(120.82,""D"")",$$B^PSNAPIS,$$T^PSNAPIS,"^PSDRUG(""B"")","^PSDRUG(""C"")","^PS(50.416,""P"")","^PS(50.605,""C"")" D
|
---|
31 | . S ORSRC=$G(ORSRC)+1,ORFILE=$P(ROOT,",",1)_")",ORSRC(ORSRC)=$P($T(FILENAME+ORSRC),";;",2)
|
---|
32 | . I (ORSRC'=2),(ORSRC'=6) S CNT=CNT+1,Y(CNT)=ORSRC_U_ORSRC(ORSRC)_U_U_U_"TOP"_U_"+"
|
---|
33 | . I ORSRC=1!(ORSRC=2) D
|
---|
34 | .. I $D(@ROOT@(X)) D
|
---|
35 | ... I ORSRC=1,X="OTHER ALLERGY/ADVERSE REACTION" Q ;don't send this entry
|
---|
36 | ... S ORIEN=$O(@ROOT@(X,0))
|
---|
37 | ... I $L($T(SCREEN^XTID)) I $$SCREEN^XTID(120.82,.01,ORIEN_",") Q ;233 Is term active?
|
---|
38 | ... I ORSRC=2 S CNT=CNT+1,Y(CNT)=ORIEN_U_$P($G(^GMRD(120.82,+ORIEN,0)),U,1)_" <"_X_">"_ROOT
|
---|
39 | ... I ORSRC'=2 S CNT=CNT+1,Y(CNT)=ORIEN_U_X_ROOT
|
---|
40 | ... S Y(CNT)=Y(CNT)_U_$P($G(^GMRD(120.82,+Y(CNT),0)),U,2)_U_$S(ORSRC=2:1,1:ORSRC)
|
---|
41 | .. S XP=X F S XP=$O(@ROOT@(XP)) Q:XP="" Q:$E(XP,1,$L(X))'=X D
|
---|
42 | ... I ORSRC=1,XP="OTHER ALLERGY/ADVERSE REACTION" Q ;don't send this entry
|
---|
43 | ... S ORIEN=$O(@ROOT@(XP,0))
|
---|
44 | ... I $L($T(SCREEN^XTID)) I $$SCREEN^XTID(120.82,.01,ORIEN_",") Q ;233 Is term active?
|
---|
45 | ... I ORSRC=2 S CNT=CNT+1,Y(CNT)=ORIEN_U_$P($G(^GMRD(120.82,+ORIEN,0)),U,1)_" <"_XP_">"_ROOT ; partial matches
|
---|
46 | ... I ORSRC'=2 S CNT=CNT+1,Y(CNT)=ORIEN_U_XP_ROOT
|
---|
47 | ... S Y(CNT)=Y(CNT)_U_$P($G(^GMRD(120.82,+Y(CNT),0)),U,2)_U_$S(ORSRC=2:1,1:ORSRC)
|
---|
48 | . I (ORSRC>2),(ORSRC'=4),(ORSRC'=5),(ORSRC'=6) D
|
---|
49 | .. N CODE,LIST,VAL,NAME
|
---|
50 | .. S CODE=$S(ORSRC=3:"S VAL=$$TGTOG2^PSNAPIS(X,.LIST)",ORSRC=4:"D TRDNAME(X,.LIST)",ORSRC=7:"D INGSRCH(X,.LIST)",ORSRC=8:"D CLASRCH(X,.LIST)",1:"") Q:'$L(CODE)
|
---|
51 | .. X CODE I $D(LIST) S ORIEN=0 F S ORIEN=$O(LIST(ORIEN)) Q:'ORIEN D
|
---|
52 | ... S NAME=$P(LIST(ORIEN),U,2)
|
---|
53 | ... Q:$E($P(LIST(ORIEN),U,2),1,$L(X))'=X
|
---|
54 | ... I $L($T(SCREEN^XTID)) I $$SCREEN^XTID($S(ORSRC=3:50.6,(ORSRC=4):50.6,ORSRC=7:50.416,ORSRC=8:50.605,1:0),.01,ORIEN_",") Q
|
---|
55 | ... S CNT=CNT+1,Y(CNT)=ORIEN_U_NAME_ROOT_U_"D"_U_ORSRC
|
---|
56 | . I ORSRC=4 D
|
---|
57 | .. N CODE,LIST,VAL,NAME
|
---|
58 | .. S CODE="D TRDNAME(X,.LIST)"
|
---|
59 | .. X CODE I $D(LIST) S ORIEN=0 F S ORIEN=$O(LIST(ORIEN)) Q:'ORIEN D
|
---|
60 | ... S NAME=$P(LIST(ORIEN),U,2)
|
---|
61 | ... Q:$E($P(LIST(ORIEN),U,2),1,$L(X))'=X
|
---|
62 | ... I $L($T(SCREEN^XTID)) I $$SCREEN^XTID(50.6,.01,+LIST(ORIEN)_",") Q
|
---|
63 | ... S CNT=CNT+1,Y(CNT)=+LIST(ORIEN)_U_NAME_ROOT_U_"D"_U_ORSRC
|
---|
64 | Q
|
---|
65 | FILENAME ; Display text of filenames for search treeview
|
---|
66 | ;;VA Allergies File
|
---|
67 | ;;VA Allergies File (Synonyms) SPACER ONLY - NOT DISPLAYED
|
---|
68 | ;;National Drug File - Generic Drug Name
|
---|
69 | ;;National Drug file - Trade Name
|
---|
70 | ;;Local Drug File
|
---|
71 | ;;Local Drug File (Synonyms) SPACER ONLY - NOT DISPLAYED
|
---|
72 | ;;Drug Ingredients File
|
---|
73 | ;;VA Drug Class File
|
---|
74 | ;;
|
---|
75 | NATREACT ; Get the NATURE OF REACTION types
|
---|
76 | ;Removing "R^Adverse Reaction" from choices below until we can add it as a choice in the nature of reaction/mechanism file
|
---|
77 | F X="A^Allergy","P^Pharmacological","U^Unknown" D
|
---|
78 | . S LST($$NXT)="i"_X
|
---|
79 | Q
|
---|
80 | ALLGYTYP ; Get the allergy types
|
---|
81 | F X="D^Drug","F^Food","O^Other","DF^Drug,Food","DO^Drug,Other","FO^Food,Other","DFO^Drug,Food,Other" D
|
---|
82 | . S LST($$NXT)="i"_X
|
---|
83 | Q
|
---|
84 | OBSHIST ; Observed or historical
|
---|
85 | F X="o^Observed","h^Historical" D
|
---|
86 | . S LST($$NXT)="i"_X
|
---|
87 | Q
|
---|
88 | SEVERITY ; Severity
|
---|
89 | F X="3^Severe","2^Moderate","1^Mild" D
|
---|
90 | . S LST($$NXT)="i"_X
|
---|
91 | Q
|
---|
92 | SYMPTOMS(Y,FROM,DIR) ; Return a subset of symptoms
|
---|
93 | ; .Return Array, Starting Text, Direction
|
---|
94 | N I,IEN,CNT,X,NAME,SUB S I=0,CNT=44 ;233
|
---|
95 | K ^TMP($J,"SIGNS") ;233
|
---|
96 | ;The following lines were added in 233. Now accounts for synonyms
|
---|
97 | M ^TMP($J,"SIGNS","B")=^GMRD(120.83,"B") ;233
|
---|
98 | S SYN="" F S SYN=$O(^GMRD(120.83,"D",SYN)) Q:SYN="" S SUB=0 F S SUB=$O(^GMRD(120.83,"D",SYN,SUB)) Q:'+SUB D ;233
|
---|
99 | .S NAME=$P(^GMRD(120.83,SUB,0),U) S ^TMP($J,"SIGNS","B",(SYN_$C(9)_"<"_NAME_">"_U_NAME),SUB)="" ;233
|
---|
100 | F Q:I'<CNT S FROM=$O(^TMP($J,"SIGNS","B",FROM),DIR) Q:FROM="" D ;233
|
---|
101 | . I FROM="OTHER REACTION" Q ;Don't send this entry
|
---|
102 | . S IEN=0 F S IEN=$O(^TMP($J,"SIGNS","B",FROM,IEN)) Q:'IEN D ;233
|
---|
103 | . . I $L($T(SCREEN^XTID)) I $$SCREEN^XTID(120.83,.01,IEN_",") Q ;233 Is term active
|
---|
104 | . . S I=I+1
|
---|
105 | . . S Y(I)=IEN_U_FROM
|
---|
106 | Q
|
---|
107 | NXT() ; Increment index of LST
|
---|
108 | S ILST=ILST+1
|
---|
109 | Q ILST
|
---|
110 | EDITLOAD(Y,ORALIEN) ; Load an allergy/adverse reaction for editing
|
---|
111 | Q:+$G(ORALIEN)=0
|
---|
112 | N ORNODE,I
|
---|
113 | S ORNODE=$NAME(^TMP("GMRA",$J)),I=0
|
---|
114 | ;following patch check is made via GUI RPC call to ORWU PATCH instead
|
---|
115 | ;I '$$PATCH^XPDUTL("GMRA*4.0*21") S @ORNODE@(0)="-1^Not yet implemented",Y=ORNODE Q
|
---|
116 | D GETREC^GMRAGUI(ORALIEN,ORNODE)
|
---|
117 | S Y=ORNODE
|
---|
118 | Q
|
---|
119 | EDITSAVE(ORY,ORALIEN,ORDFN,OREDITED) ; Save Edit/Add of an allergy/adverse reaction
|
---|
120 | ;following patch check is made via GUI RPC call to ORWU PATCH instead
|
---|
121 | ;I '$$PATCH^XPDUTL("GMRA*4.0*21") S Y="-1^Not yet implemented" Q
|
---|
122 | N ORNODE
|
---|
123 | S ORNODE=$NAME(^TMP("GMRA",$J))
|
---|
124 | K @ORNODE M @ORNODE=OREDITED
|
---|
125 | S ORY=0
|
---|
126 | I $G(@ORNODE@("GMRAERR"))="YES" D EIE^GMRAGUI1(ORALIEN,ORDFN,ORNODE) Q ;Handle entered in error
|
---|
127 | I $G(@ORNODE@("GMRANKA"))="YES" D NKA^GMRAGUI1 Q
|
---|
128 | D UPDATE^GMRAGUI1(ORALIEN,ORDFN,ORNODE) Q ;Add/edit reactions
|
---|
129 | Q
|
---|
130 | SENDBULL(Y,ORDUZ,ORDFN,ORTEXT,ORCMTS) ; Send bulletin if user attempts free-text entry
|
---|
131 | I '$D(ORCMTS) D
|
---|
132 | . S Y=$$SENDREQ^GMRAPES0(ORDUZ,ORDFN,ORTEXT)
|
---|
133 | E D
|
---|
134 | . S Y=$$SENDREQ^GMRAPES0(ORDUZ,ORDFN,ORTEXT,.ORCMTS)
|
---|
135 | Q
|
---|
136 | INGSRCH(NAME,LIST) ;
|
---|
137 | K ^TMP($J,"ORWDAL32")
|
---|
138 | D NAME^PSN50P41(NAME,"ORWDAL32")
|
---|
139 | I $D(^TMP($J,"ORWDAL32","P")) D
|
---|
140 | . N I S I="" F S I=$O(^TMP($J,"ORWDAL32","P",I)) Q:I="" D
|
---|
141 | .. N J S J=0 F S J=$O(^TMP($J,"ORWDAL32","P",I,J)) Q:'J S LIST(J)=J_U_I
|
---|
142 | K ^TMP($J,"ORWDAL32")
|
---|
143 | Q
|
---|
144 | CLASRCH(NAME,LIST) ;
|
---|
145 | K ^TMP($J,"ORWDAL32")
|
---|
146 | D C^PSN50P65(,NAME,"ORWDAL32")
|
---|
147 | I $D(^TMP($J,"ORWDAL32","C")) D
|
---|
148 | . N I S I="" F S I=$O(^TMP($J,"ORWDAL32","C",I)) Q:I="" D
|
---|
149 | .. N J S J=0 F S J=$O(^TMP($J,"ORWDAL32","C",I,J)) Q:'J S LIST(J)=J_U_$G(^TMP($J,"ORWDAL32",J,1))
|
---|
150 | K ^TMP($J,"ORWDAL32")
|
---|
151 | Q
|
---|
152 | TRDNAME(NAME,LIST) ;
|
---|
153 | K ^TMP($J,"ORWDAL32")
|
---|
154 | D ALL^PSN5067(,NAME,,"ORWDAL32")
|
---|
155 | I $D(^TMP($J,"ORWDAL32","B")) D
|
---|
156 | . N I S I="" F S I=$O(^TMP($J,"ORWDAL32","B",I)) Q:I="" D
|
---|
157 | .. N J,K S J=$O(^TMP($J,"ORWDAL32","B",I,0)) Q:'J S K=$$TGTOG^PSNAPIS(I),LIST(J)=K_U_$G(^TMP($J,"ORWDAL32",J,4))
|
---|
158 | K ^TMP($J,"ORWDAL32")
|
---|
159 | Q
|
---|