1 | DGPFDD ;ALB/RPM - PRF DATA DICTIONARY UTILITIES ; 9/06/06 1:14pm
|
---|
2 | ;;5.3;Registration;**425,554,650**;Aug 13, 1993;Build 3
|
---|
3 | ;
|
---|
4 | Q ;No direct entry
|
---|
5 | ;
|
---|
6 | INACT(DGIEN,DGSTAT,DGFILE,DGUSER) ;Inactivate flag trigger
|
---|
7 | ; This procedure is used as a trigger that is fired when the
|
---|
8 | ; STATUS (#.02) field of a record in either the PRF LOCAL FLAG (#26.11)
|
---|
9 | ; file or PRF NATIONAL FLAG (#26.15) file is changed from Active to
|
---|
10 | ; Inactive. The trigger will inactivate all Patient Record
|
---|
11 | ; Flag assignments associated with the inactivated Flag.
|
---|
12 | ;
|
---|
13 | ; Input:
|
---|
14 | ; DGIEN - IEN of entry in PRF LOCAL FLAG file or PRF NATIONAL
|
---|
15 | ; FLAG file
|
---|
16 | ; DGSTAT - Flag Status
|
---|
17 | ; DGFILE - PRF LOCAL FLAG file number (26.11) or PRF NATIONAL
|
---|
18 | ; FLAG file number (26.15)
|
---|
19 | ; DGUSER - IEN of user in NEW PERSON file
|
---|
20 | ;
|
---|
21 | ; Output: none
|
---|
22 | ;
|
---|
23 | N DGAIEN ;assignment record IEN
|
---|
24 | N DGSUB ;variable ptr index subscript
|
---|
25 | ;
|
---|
26 | Q:('$G(DGIEN))
|
---|
27 | Q:($G(DGSTAT)'=0)
|
---|
28 | Q:(($G(DGFILE)'=26.11)&($G(DGFILE)'=26.15))
|
---|
29 | Q:('$G(DGUSER))
|
---|
30 | ;
|
---|
31 | S DGSUB=DGIEN_";DGPF("_DGFILE_","
|
---|
32 | S DGAIEN=0
|
---|
33 | F S DGAIEN=$O(^DGPF(26.13,"ASTAT",1,DGSUB,DGAIEN)) Q:'DGAIEN D
|
---|
34 | . N DGPFA ;assignment data array
|
---|
35 | . N DGPFAH ;assignment history data array
|
---|
36 | . I $$GETASGN^DGPFAA(DGAIEN,.DGPFA) D
|
---|
37 | . . Q:($P($G(DGPFA("STATUS")),U,1)=0)
|
---|
38 | . . S DGPFA("STATUS")=0
|
---|
39 | . . S DGPFA("REVIEWDT")=""
|
---|
40 | . . S DGPFAH("ACTION")=3
|
---|
41 | . . S DGPFAH("ASSIGNDT")=$$NOW^XLFDT()
|
---|
42 | . . S DGPFAH("ENTERBY")=DGUSER
|
---|
43 | . . S DGPFAH("APPRVBY")=DGUSER
|
---|
44 | . . S DGPFAH("COMMENT",1,0)="Assignment Inactivated automatically due to Flag Inactivation."
|
---|
45 | . . I $$STOALL^DGPFAA(.DGPFA,.DGPFAH)
|
---|
46 | Q
|
---|
47 | ;
|
---|
48 | PIHELP ;Executable help for PRINCIPAL INVESTIGATOR(S) (#.01) sub-field of
|
---|
49 | ;PRINCIPLE INVESTIGATOR(S) (#2) multiple field of PRF LOCAL FLAG
|
---|
50 | ;(#26.11) file.
|
---|
51 | ;
|
---|
52 | ;This sub-routine displays individuals selected as a principal
|
---|
53 | ;investigator for a research type patient record flag.
|
---|
54 | ;
|
---|
55 | ; Input:
|
---|
56 | ; DGLKUP - (required) array of principal investigators subscripted
|
---|
57 | ; by the pointer to the NEW PERSON (#200) file and the
|
---|
58 | ; pointer to the PRF LOCAL FLAG (#26.11) file.
|
---|
59 | ; Example: DGLKUP(11744,6)=""
|
---|
60 | ;
|
---|
61 | ; Output:
|
---|
62 | ; none
|
---|
63 | ;
|
---|
64 | Q:'$D(DGLKUP)
|
---|
65 | ;
|
---|
66 | N DGCNT
|
---|
67 | N DGIEN
|
---|
68 | N DGNAMES
|
---|
69 | ;
|
---|
70 | S DGIEN=0,DGCNT=0
|
---|
71 | F S DGIEN=$O(DGLKUP(DGIEN)) Q:'DGIEN D
|
---|
72 | . S DGCNT=DGCNT+1
|
---|
73 | . S DGNAMES(DGCNT)=$$EXTERNAL^DILFD(26.112,.01,"F",DGIEN)
|
---|
74 | S DGNAMES(DGCNT+1)="" ;add a blank line
|
---|
75 | D EN^DDIOL(.DGNAMES)
|
---|
76 | Q
|
---|
77 | ;
|
---|
78 | COS(DGAPRV) ;transform POSTMASTER to CHIEF OF STAFF
|
---|
79 | ;This output transform converts the internal field value of .5
|
---|
80 | ;(POSTMASTER) to CHIEF OF STAFF.
|
---|
81 | ;
|
---|
82 | ; Supported DBIA #10060 - This supported DBIA permits FileMan reads
|
---|
83 | ; on all fields of the NEW PERSON (#200) file.
|
---|
84 | ;
|
---|
85 | ; Input:
|
---|
86 | ; DGAPRV - internal value of PRF ASSIGNMENT HISTORY (#26.14) file
|
---|
87 | ; APPROVED BY (#.05) field
|
---|
88 | ;
|
---|
89 | ; Output:
|
---|
90 | ; Function Value - Returns "CHIEF OF STAFF" when input value is .5 or
|
---|
91 | ; external value from NAME (.01) field of the NEW
|
---|
92 | ; PERSON (#200) file on success.
|
---|
93 | ; Returns null ("") on failure.
|
---|
94 | ;
|
---|
95 | N DGERR
|
---|
96 | ;
|
---|
97 | Q:(+$G(DGAPRV)'>0) ""
|
---|
98 | ;
|
---|
99 | Q $S(DGAPRV=.5:"CHIEF OF STAFF",1:$$GET1^DIQ(200,DGAPRV_",",.01,"","","DGERR"))
|
---|
100 | ;
|
---|
101 | TIULIST(DGTIUIEN) ;DD lookup screen for (#26.11) file (#.07) field
|
---|
102 | ;Get list of TIU Progress Note Titles for Category II (Local) Flags.
|
---|
103 | ;This function will assist the DIC("S") lookup screen of allowable
|
---|
104 | ;TIU Progress Note Titles the user can see and select from.
|
---|
105 | ;
|
---|
106 | ; Supported DBIA: #4380 - $$CHKDOC^TIUPRF - TIU API's for PRF
|
---|
107 | ; #4383 - $$FNDTITLE^DGPFAPI1
|
---|
108 | ;
|
---|
109 | ; Input:
|
---|
110 | ; DGTIUIEN - [Required] IEN of (#8925.1) entry being screened
|
---|
111 | ;
|
---|
112 | ; Output:
|
---|
113 | ; Function Value - Returns 1 on success, 0 on failure
|
---|
114 | ;
|
---|
115 | N DGPNLIST ;temporary file name to hold list of titles
|
---|
116 | N DGRSLT ;function return value
|
---|
117 | N DGX ;loop var
|
---|
118 | N DGY ;loop var
|
---|
119 | ;
|
---|
120 | Q:DGTIUIEN']"" 0
|
---|
121 | ;
|
---|
122 | S DGRSLT=0
|
---|
123 | ;
|
---|
124 | ; get list from TIU Progress Note Title API call IA #4380
|
---|
125 | S DGPNLIST=$NA(^TMP("DGPNLIST",$J))
|
---|
126 | K @DGPNLIST
|
---|
127 | ;
|
---|
128 | ; only get Category II (Local) TIU PN Titles (pass a 2)
|
---|
129 | I $$GETLIST(2,DGPNLIST) D
|
---|
130 | . S (DGX,DGY)="" F S DGX=$O(@DGPNLIST@("CAT II",DGX)) Q:DGX="" D
|
---|
131 | . . S DGY=$G(@DGPNLIST@("CAT II",DGX))
|
---|
132 | . . ; Need to setup the current assigned progress note title as a
|
---|
133 | . . ; selectable entry or the ^DIR call won't accept the default
|
---|
134 | . . ; entry when the user hits the retrun key to go to next prompt.
|
---|
135 | . . ; Only setup if called by PRF action protocol DGPF EDIT FLAG
|
---|
136 | . . I $P($G(XQORNOD(0)),U,3)="Edit Record Flag",+DGY=$P($G(DGPFORIG("TIUTITLE")),U) D Q
|
---|
137 | . . . S @DGPNLIST@(+DGY)=""
|
---|
138 | . . Q:'DGY
|
---|
139 | . . I '$$FNDTITLE^DGPFAPI1($P(DGY,U,1)) S @DGPNLIST@(+DGY)=""
|
---|
140 | ;
|
---|
141 | I $D(@DGPNLIST@(DGTIUIEN)) S DGRSLT=1
|
---|
142 | K @DGPNLIST
|
---|
143 | ;
|
---|
144 | Q DGRSLT
|
---|
145 | ;
|
---|
146 | GETLIST(DGCAT,DGLIST) ;Get list of TIU Progress Note Titles
|
---|
147 | ; This function is used to retrieve a list of active TIU Progress
|
---|
148 | ; Note Titles that can be associated with Category I or Category II
|
---|
149 | ; Record Flags.
|
---|
150 | ;
|
---|
151 | ; Supported DBIA: #4380 - $$CHKDOC^TIUPRF - TIU API's for PRF
|
---|
152 | ;
|
---|
153 | ; Input: [Required]
|
---|
154 | ; DGCAT - Category of TIU Progress Note Titles to look for
|
---|
155 | ; 1:Category I
|
---|
156 | ; 2:Category II
|
---|
157 | ; 3:Both Category I and II
|
---|
158 | ; DGLIST - Closed root reference array name to return values
|
---|
159 | ;
|
---|
160 | ; Output:
|
---|
161 | ; Function Value - returns 1 on success, 0 on failure
|
---|
162 | ; DGLIST() - Closed Root reference name of returned data
|
---|
163 | ;
|
---|
164 | N DGRSLT ;function value
|
---|
165 | S DGRSLT=0
|
---|
166 | ;
|
---|
167 | I $G(DGCAT)>0,DGLIST]"",$$GETLIST^TIUPRF(DGCAT,DGLIST) S DGRSLT=1
|
---|
168 | ;
|
---|
169 | Q DGRSLT
|
---|
170 | ;
|
---|
171 | EVENT(DGDFN) ;PRF HL7 EVENT trigger
|
---|
172 | ;This trigger creates an entry in the PRF HL7 EVENT (#26.21) file
|
---|
173 | ;with an INCOMPLETE status.
|
---|
174 | ;
|
---|
175 | ; Input:
|
---|
176 | ; DGDFN - pointer to patient in PATIENT (#2) file
|
---|
177 | ;
|
---|
178 | ; Output: none
|
---|
179 | ;
|
---|
180 | N DGASGN
|
---|
181 | ;
|
---|
182 | ;validate input parameter
|
---|
183 | Q:'$G(DGDFN)!('$D(^DPT(+$G(DGDFN),0)))
|
---|
184 | ;
|
---|
185 | ;don't record event when file re-indexing
|
---|
186 | I $D(DIU(0))!($D(DIK)&$D(DIKJ)&$D(DIKLK)&$D(DIKS)&$D(DIN)) Q
|
---|
187 | ;
|
---|
188 | ;ICN must be national value
|
---|
189 | Q:'$$MPIOK^DGPFUT(DGDFN)
|
---|
190 | ;
|
---|
191 | ;limit to one event per patient
|
---|
192 | Q:$$FNDEVNT^DGPFHLL1(DGDFN)
|
---|
193 | ;
|
---|
194 | ;don't trigger when Category I PRF assignments exist
|
---|
195 | Q:$$GETALL^DGPFAA(DGDFN,.DGASGN,"",1)
|
---|
196 | ;
|
---|
197 | ;record event
|
---|
198 | D STOEVNT^DGPFHLL1(DGDFN)
|
---|
199 | ;
|
---|
200 | Q
|
---|
201 | ;
|
---|
202 | SCRNSEL(DGIEN,DGSEL) ;screen user selection
|
---|
203 | ;This function checks that the selected action does not equal the
|
---|
204 | ;current field value.
|
---|
205 | ;
|
---|
206 | ; Input:
|
---|
207 | ; DGIEN - (required) MEDICAL CENTER DIVISION (#40.8) file (IEN)
|
---|
208 | ;
|
---|
209 | ; DGSEL - (required) user selected action [1=enable, 0=disable]
|
---|
210 | ;
|
---|
211 | ; Output:
|
---|
212 | ; Function value - returns 1 on success, 0 on failure
|
---|
213 | ;
|
---|
214 | N DGERR ;error root
|
---|
215 | N DGFLD ;field value
|
---|
216 | N DGRSLT ;function result
|
---|
217 | ;
|
---|
218 | S DGRSLT=0
|
---|
219 | ;
|
---|
220 | I +$G(DGIEN)>0,($G(DGSEL)]"") D
|
---|
221 | . ;
|
---|
222 | . S DGFLD=+$$GET1^DIQ(40.8,DGIEN_",",26.01,"I","","DGERR")
|
---|
223 | . Q:$D(DGERR)
|
---|
224 | . Q:(DGFLD=DGSEL)
|
---|
225 | . ;
|
---|
226 | . S DGRSLT=1
|
---|
227 | ;
|
---|
228 | Q DGRSLT
|
---|
229 | ;
|
---|
230 | SCRNDIV(DGIEN,DGSEL) ;division screen
|
---|
231 | ;This function contains the screen logic for enabling/disabling a
|
---|
232 | ;medical center division.
|
---|
233 | ;
|
---|
234 | ;The function (screen) is called from the following locations:
|
---|
235 | ; Function: $$ASKDIV^DGPFDIV
|
---|
236 | ; DD: Screen code for PRF ASSIGNMENT OWNERSHIP (#26.01) field
|
---|
237 | ; of the MEDICAL CENTER DIVISION (#40.8) file
|
---|
238 | ;
|
---|
239 | ;Entries will be screened if:
|
---|
240 | ; - division is enabled and active assignments are associated with
|
---|
241 | ; the division
|
---|
242 | ; - division is not associated with an active institution
|
---|
243 | ; - division does not have a PARENT association in the
|
---|
244 | ; INSTITUTION (#4) file
|
---|
245 | ;
|
---|
246 | ; Input:
|
---|
247 | ; DGIEN - (required) MEDICAL CENTER DIVISION (#40.8) file entry (IEN)
|
---|
248 | ; being screened
|
---|
249 | ; DGSEL - (required) user selected action [1=enable, 0=disable]
|
---|
250 | ;
|
---|
251 | ; Output:
|
---|
252 | ; Function value - returns 1 on success, 0 on failure
|
---|
253 | ;
|
---|
254 | N DGINST ;ptr to INSTITUTION file
|
---|
255 | N DGRSLT ;function result
|
---|
256 | ;
|
---|
257 | S DGRSLT=0
|
---|
258 | ;
|
---|
259 | I +$G(DGIEN)>0,($G(DGSEL)]"") D
|
---|
260 | . ;
|
---|
261 | . S DGINST=+$P($G(^DG(40.8,DGIEN,0)),U,7)
|
---|
262 | . I DGSEL=0,($D(^DGPF(26.13,"AOWN",DGINST,1))) Q
|
---|
263 | . I DGSEL=1,'$$ACTIVE^XUAF4(DGINST) Q
|
---|
264 | . I DGSEL=1,'$$PARENT^DGPFUT1(DGINST) Q
|
---|
265 | . ;
|
---|
266 | . S DGRSLT=1
|
---|
267 | ;
|
---|
268 | Q DGRSLT
|
---|