source: Scheduling/trunk/m/BSDXAPI.m@ 1185

Last change on this file since 1185 was 1177, checked in by Sam Habiel, 14 years ago

M routines to support Radiology Scheduling Integration; version bumped to 1.6t1

File size: 16.2 KB
RevLine 
[1161]1BSDXAPI ; IHS/ANMC/LJF & VW/SMH - SCHEDULING APIs ; 4/28/11 10:30am
[1177]2 ;;1.6T1;BSDX;;May 11, 2011;Build 7
[1161]3 ; Licensed under LGPL
4 ;
[968]5 ;Orignal routine is BSDAPI by IHS/LJF, HMW, and MAW
6 ;local mods (many) by WV/SMH
7 ;Move to BSDX namespace as BSDXAPI from BSDAPI by WV/SMH
8 ; Change History:
[1080]9 ; 2010-11-5: (1.42)
[968]10 ; - Fixed errors having to do uncanceling patient appointments if it was a patient cancelled appointment.
11 ; - Use new style Fileman API for storing appointments in file 44 in $$MAKE due to problems with legacy API.
[1080]12 ; 2010-11-12: (1.42)
[1076]13 ; - Changed ="C" to ["C" in SCIEN. Cancelled appointments can be "PC" as well.
[1080]14 ; 2010-12-5 (1.42)
[1076]15 ; Added an entry point to update the patient note in file 44.
[1080]16 ; 2010-12-6 (1.42)
[1076]17 ; MAKE1 incorrectly put info field in BSDR("INFO") rather than BSDR("OI")
[1080]18 ; 2010-12-8 (1.42)
[1076]19 ; Removed restriction on max appt length. Even though this restriction
20 ; exists in fileman (120 minutes), PIMS ignores it. Therefore, I
21 ; will ignore it here too.
[1080]22 ; 2011-01-25 (v.1.5)
23 ; Added entry point $$RMCI to remove checked in appointments.
24 ; In $$CANCEL, if the appointment is checked in, delete check-in rather than
25 ; spitting an error message to the user saying 'Delete the check-in'
26 ; Changed all lines that look like this:
27 ; I $G(BSDR("ADT"))'?7N1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
28 ; to:
29 ; I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
30 ; to allow for date at midnight which does not have a dot at the end.
[1081]31 ; 2011-01-26 (v.1.5)
32 ; More user friendly message if patient already has appointment in $$MAKE:
33 ; Spits out pt name and user friendly date.
[1080]34 ;
[968]35 ;
36MAKE1(DFN,CLIN,TYP,DATE,LEN,INFO) ; Simplified PEP w/ parameters for $$MAKE - making appointment
37 ; Call like this for DFN 23435 having an appointment at Hospital Location 33
38 ; have 3 (scheduled) or 4 (walkin) appt at Dec 20, 2009 @ 10:11:59 for 30 minutes appt
39 ; for Baby foxes hallucinations.
40 ; S RESULT=$$MAKE1^BSDXAPI(23435,33,(3 or 4),3091220.221159,30,"I see Baby foxes")
41 S BSDR("PAT")=DFN ;DFN
42 S BSDR("CLN")=CLIN ;Hosp Loc IEN
43 S BSDR("TYP")=TYP ;3 sched or 4 walkin
44 S BSDR("ADT")=DATE ;Appointment date in FM format
45 S BSDR("LEN")=LEN ;Appt len upto 240 (min)
[1035]46 S BSDR("OI")=INFO ;Reason for appt - up to 150 char
[968]47 S BSDR("USR")=DUZ ;Person who made appt - current user
48 Q $$MAKE(.BSDR)
49 ;
50MAKE(BSDR) ;PEP; call to store appt made
51 ;
52 ; Make call using: S ERR=$$MAKE^BSDXAPI(.ARRAY)
53 ;
54 ; Input Array -
55 ; BSDR("PAT") = ien of patient in file 2
56 ; BSDR("CLN") = ien of clinic in file 44
57 ; BSDR("TYP") = 3 for scheduled appts, 4 for walkins
58 ; BSDR("ADT") = appointment date and time
[1081]59 ; BSDR("LEN") = appointment length in minutes (*1.42 limit removed)
[968]60 ; BSDR("OI") = reason for appt - up to 150 characters
61 ; BSDR("USR") = user who made appt
62 ;
63 ;Output: error status and message
64 ; = 0 or null: everything okay
65 ; = 1^message: error and reason
66 ;
67 I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
68 I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
69 I ($G(BSDR("TYP"))<3)!($G(BSDR("TYP"))>4) Q 1_U_"Appt Type error: "_$G(BSDR("TYP"))
70 I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
[1080]71 I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
[968]72 ;
[1041]73 ;I ($G(BSDR("LEN"))<5)!($G(BSDR("LEN"))>240) Q 1_U_"Appt Length error: "_$G(BSDR("LEN")) ; v 1.42 - no check on length is done anymore. see top comments for details.
[968]74 I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR"))
[1081]75 ;I $D(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0)),$P(^(0),U,2)'["C" Q 1_U_"Patient "_BSDR("PAT")_" already has appt at "_BSDR("ADT") ; v.1.5 more user friendly err msg
[968]76 ;
[1081]77 ; Following block to give an error message to user if there is already an appointment for patient. More verbose than others.
78 N BSDXERR ; place to store error message
79 I $D(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0)),$P(^(0),U,2)'["C" DO QUIT BSDXERR ; If there's an appt in the "S" node of file 2 and it's not cancelled
80 . S BSDXERR=1_U_"Patient "_$P(^DPT(BSDR("PAT"),0),U)_" ("_BSDR("PAT")_") "
81 . S BSDXERR=BSDXERR_"already has appt at "_$$FMTE^XLFDT(BSDR("ADT"))
82 . N BSDXSCIEN S BSDXSCIEN=$P(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0),U) ; Clinic IEN in ^SC (0 piece of 0 node of "S" multiple in file 2)
83 . N BSDXSCNAM S BSDXSCNAM=$P(^SC(BSDXSCIEN,0),U) ; PIMS Name of Clinic
84 . S BSDXERR=BSDXERR_$C(13,10)_"PIMS clinic: "_BSDXSCNAM ; tell the user of the PIMS clinic
85 . I $D(^BSDXRES("ALOC",BSDXSCIEN)) DO ; if the Clinic is linked to a BSDX Resource (we find out using the index ALOC in the BSDX RESOURCE file)
86 . . N BSDXRESIEN S BSDXRESIEN=$O(^BSDXRES("ALOC",BSDXSCIEN,""))
87 . . QUIT:'BSDXRESIEN ; Safeguard if index is corrupt
88 . . N BSDXRESNAM S BSDXRESNAM=$P(^BSDXRES(BSDXRESIEN,0),U)
89 . . S BSDXERR=BSDXERR_$C(13,10)_"Scheduling GUI clinic: "_BSDXRESNAM ; tell the user of the BSDX clinic
90 ;
[968]91 NEW DIC,DA,Y,X,DD,DO,DLAYGO
92 ;
93 I $D(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0)),$P(^(0),U,2)["C" D
94 . ; "un-cancel" existing appt in file 2
95 . N BSDXFDA,BSDXIENS,BSDXMSG
96 . S BSDXIENS=BSDR("ADT")_","_BSDR("PAT")_","
97 . S BSDXFDA(2.98,BSDXIENS,".01")=BSDR("CLN")
98 . S BSDXFDA(2.98,BSDXIENS,"3")=""
99 . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP")
100 . S BSDXFDA(2.98,BSDXIENS,"9.5")=9
101 . S BSDXFDA(2.98,BSDXIENS,"14")=""
102 . S BSDXFDA(2.98,BSDXIENS,"15")=""
103 . S BSDXFDA(2.98,BSDXIENS,"16")=""
104 . S BSDXFDA(2.98,BSDXIENS,"19")=""
105 . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT
106 . D FILE^DIE("","BSDXFDA","BSDXMSG")
107 . N BSDXTEMP S BSDXTEMP=$G(BSDXMSG)
108 E D I $G(BSDXERR(1)) Q 1_U_"FileMan add to DPT error: Patient="_BSDR("PAT")_" Appt="_BSDR("ADT")
109 . N BSDXFDA,BSDXIENS,BSDXMSG
110 . S BSDXIENS="?+2,"_BSDR("PAT")_","
111 . S BSDXIENS(2)=BSDR("ADT")
112 . S BSDXFDA(2.98,BSDXIENS,.01)=BSDR("CLN")
113 . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP")
114 . S BSDXFDA(2.98,BSDXIENS,"9.5")=9
115 . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT
116 . D UPDATE^DIE("","BSDXFDA","BSDXIENS","BSDXERR(1)")
117 ; add appt to file 44
118 K DIC,DA,X,Y,DLAYGO,DD,DO
119 I '$D(^SC(BSDR("CLN"),"S",0)) S ^SC(BSDR("CLN"),"S",0)="^44.001DA^^"
120 I '$D(^SC(BSDR("CLN"),"S",BSDR("ADT"),0)) D I Y<1 Q 1_U_"Error adding date to file 44: Clinic="_BSDR("CLN")_" Date="_BSDR("ADT")
121 . S DIC="^SC("_BSDR("CLN")_",""S"",",DA(1)=BSDR("CLN"),(X,DINUM)=BSDR("ADT")
122 . S DIC("P")="44.001DA",DIC(0)="L",DLAYGO=44.001
123 . S Y=1 I '$D(@(DIC_X_")")) D FILE^DICN
124 ;
125 ; Sep 28 2010: Changed old style API to new style API. Keep for reference //smh
126 ;K DIC,DA,X,Y,DLAYGO,DD,DO,DINUM
127 ;S DIC="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
128 ;S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),X=BSDR("PAT")
129 ;S DIC("DR")="1///"_BSDR("LEN")_";3///"_$E($G(BSDR("OI")),1,150)_";7///`"_BSDR("USR")_";8///"_$P($$NOW^XLFDT,".")
130 ;S DIC("P")="44.003PA",DIC(0)="L",DLAYGO=44.003
131 ;D FILE^DICN
132 ;
133 N BSDXIENS S BSDXIENS="?+1,"_BSDR("ADT")_","_BSDR("CLN")_","
134 N BSDXFDA
135 S BSDXFDA(44.003,BSDXIENS,.01)=BSDR("PAT")
136 S BSDXFDA(44.003,BSDXIENS,1)=BSDR("LEN")
137 S BSDXFDA(44.003,BSDXIENS,3)=$E($G(BSDR("OI")),1,150)
138 S BSDXFDA(44.003,BSDXIENS,7)=BSDR("USR")
139 S BSDXFDA(44.003,BSDXIENS,8)=$P($$NOW^XLFDT,".")
140 N BSDXERR
141 D UPDATE^DIE("","BSDXFDA","","BSDXERR")
142 ;
143 I $D(BSDXERR) Q 1_U_"Error adding appt to file 44: Clinic="_BSDR("CLN")_" Date="_BSDR("ADT")_" Patient="_BSDR("PAT")_" Error: "_BSDXERR("DIERR",1,"TEXT",1)
144 ;
145 ; call event driver
146 NEW DFN,SDT,SDCL,SDDA,SDMODE
147 S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2
148 S SDDA=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
149 D MAKE^SDAMEVT(DFN,SDT,SDCL,SDDA,SDMODE)
150 Q 0
151 ;
152CHECKIN1(DFN,CLIN,APDATE) ; Simplified PEP w/ parameters for $$CHECKIN - Checking in
153 ; Call like this for DFN 23435 checking in now at Hospital Location 33
154 ; for appt at Dec 20, 2009 @ 10:11:59
155 ; S RESULT=$$CHECKIN1^BSDXAPI(23435,33,3091220.221159)
156 S BSDR("PAT")=DFN ;DFN
157 S BSDR("CLN")=CLIN ;Hosp Loc IEN
158 S BSDR("ADT")=APDATE ;Appt Date
159 S BSDR("CDT")=$$NOW^XLFDT ;Check-in date defaults to now
160 S BSDR("USR")=DUZ ;Check-in user defaults to current
161 Q $$CHECKIN(.BSDR)
162 ;
163CHECKIN(BSDR) ;EP; call to add checkin info to appt; IHS/ITSC/LJF 12/23/2004 PATCH 1002
164 ;
165 ; Make call by using: S ERR=$$CHECKIN^BSDXAPI(.ARRAY)
166 ;
167 ; Input array -
168 ; BSDR("PAT") = ien of patient in file 2
169 ; BSDR("CLN") = ien of clinic in file 44
170 ; BSDR("ADT") = appt date/time
171 ; BSDR("CDT") = checkin date/time
172 ; BSDR("USR") = checkin user
173 ;
174 ; Output value -
175 ; = 0 means everything worked
176 ; = 1^message means error with reason message
177 ;
178 I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
179 I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
180 I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
[1080]181 I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
[968]182 I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12) ;remove seconds
[1080]183 I $G(BSDR("CDT"))'?7N.1".".4N Q 1_U_"Checkin Date/Time error: "_$G(BSDR("CDT"))
[968]184 I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR"))
185 ;
186 ; find ien for appt in file 44
187 NEW IEN,DIE,DA,DR
188 S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
189 I 'IEN Q 1_U_"Error trying to find appointment for checkin: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
190 ;
191 ; remember before status
192 NEW SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL
193 S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN
194 S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
195 D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
196 ;
197 ; set checkin
198 S DIE="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
199 S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN
200 S DR="309///"_BSDR("CDT")_";302///`"_BSDR("USR")_";305///"_$$NOW^XLFDT
201 D ^DIE
202 ;
203 ; set after status
204 S SDDA=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
205 S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
206 D AFTER^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
207 ;
208 ; call event driver
209 D EVT^SDAMEVT(.SDATA,4,SDMODE,SDCIHDL)
210 Q 0
211 ;
212CANCEL1(DFN,CLIN,TYP,APDATE,REASON,INFO) ; PEP w/ parameters for $$CANCEL - cancelling appointment
213 ; Call like this for DFN 23435 cancelling an appointment at Hospital Location 33,
214 ; cancellation initiated by patient ("PC" rather than clinic "C"),
215 ; cancelling appt at Dec 20, 2009 @ 10:11:59 because of reason 1 in file 409.2 IEN (weather)
216 ; because foxes come out during bad weather.
217 ; S RESULT=$$CANCEL1^BSDXAPI(23435,33,"PC",3091220.221159,1,"Afraid of foxes")
218 S BSDR("PAT")=DFN
219 S BSDR("CLN")=CLIN
220 S BSDR("TYP")=TYP
221 S BSDR("ADT")=APDATE
222 S BSDR("CDT")=$$NOW^XLFDT
223 S BSDR("USR")=DUZ
224 S BSDR("CR")=REASON
225 S BSDR("NOT")=INFO
226 Q $$CANCEL(.BSDR)
227 ;
228CANCEL(BSDR) ;PEP; called to cancel appt
229 ;
230 ; Make call using: S ERR=$$CANCEL^BSDXAPI(.ARRAY)
231 ;
232 ; Input Array -
233 ; BSDR("PAT") = ien of patient in file 2
234 ; BSDR("CLN") = ien of clinic in file 44
235 ; BSDR("TYP") = C for canceled by clinic; PC for patient canceled
236 ; BSDR("ADT") = appointment date and time
237 ; BSDR("CDT") = cancel date and time
238 ; BSDR("USR") = user who canceled appt
239 ; BSDR("CR") = cancel reason - pointer to file 409.2
240 ; BSDR("NOT") = cancel remarks - optional notes to 160 characters
241 ;
242 ;Output: error status and message
243 ; = 0 or null: everything okay
244 ; = 1^message: error and reason
245 ;
246 I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
247 I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
248 I ($G(BSDR("TYP"))'="C"),($G(BSDR("TYP"))'="PC") Q 1_U_"Cancel Status error: "_$G(BSDR("TYP"))
249 I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
[1080]250 I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
[968]251 I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12) ;remove seconds
[1080]252 I $G(BSDR("CDT"))'?7N.1".".4N Q 1_U_"Cancel Date/Time error: "_$G(BSDR("CDT"))
[968]253 I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Canceled Appt Error: "_$G(BSDR("USR"))
254 I '$D(^SD(409.2,+$G(BSDR("CR")))) Q 1_U_"Cancel Reason error: "_$G(BSDR("CR"))
255 ;
256 NEW IEN,DIE,DA,DR
257 S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
258 I 'IEN Q 1_U_"Error trying to find appointment for cancel: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
259 ;
[1080]260 ; BSDX 1.5 3110125
261 ; UJO/SMH - Add ability to remove check-in if the patient is checked in
262 ; I $$CI(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"),IEN) Q 1_U_"Patient already checked in; cannot cancel until checkin deleted: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
263 ; Remove check-in if the patient is checked in.
264 N BSDXRESULT S BSDXRESULT=0 ; Result; should be zero if success; -1 + message if failure
265 I $$CI(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"),IEN) SET BSDXRESULT=$$RMCI(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
266 I BSDXRESULT Q BSDXRESULT
[968]267 ;
268 ; remember before status
269 NEW SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL
270 S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN
271 S SDCPHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
272 D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL)
273 ;
274 ; get user who made appt and date appt made from ^SC
275 ; because data in ^SC will be deleted
276 NEW USER,DATE
277 S USER=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,6)
278 S DATE=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,7)
279 ;
280 ; update file 2 info
281 NEW DIE,DA,DR
282 S DIE="^DPT("_DFN_",""S"",",DA(1)=DFN,DA=SDT
283 S DR="3///"_BSDR("TYP")_";14///`"_BSDR("USR")_";15///"_BSDR("CDT")_";16///`"_BSDR("CR")_";19///`"_USER_";20///"_DATE
284 S:$G(BSDR("NOT"))]"" DR=DR_";17///"_$E(BSDR("NOT"),1,160)
285 D ^DIE
286 ;
287 ; delete data in ^SC
288 NEW DIK,DA
289 S DIK="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
290 S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN
291 D ^DIK
292 ;
293 ; call event driver
294 D CANCEL^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDMODE,SDCPHDL)
295 Q 0
296 ;
297CI(PAT,CLINIC,DATE,SDIEN) ;PEP; -- returns 1 if appt already checked-in
298 NEW X
299 S X=$G(SDIEN) ;ien sent in call
300 I 'X S X=$$SCIEN(PAT,CLINIC,DATE) I 'X Q 0
301 S X=$P($G(^SC(CLINIC,"S",DATE,1,X,"C")),U)
302 Q $S(X:1,1:0)
303 ;
[1085]304RMCI(PAT,CLINIC,DATE) ;PEP; -- Remove Check-in; $$
[1076]305 ; PAT = DFN
306 ; CLINIC = SC IEN
307 ; DATE = FM Date/Time of Appointment
308 ;
309 ; Returns:
310 ; 0 if okay
311 ; -1 if failure
312 ;
[1080]313 ; Call like this: $$RMCI(233,33,3110102.1130)
314 ;
315 ; Move my variables into the ones used by SDAPIs (just a convenience)
[1076]316 NEW SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL
317 S DFN=PAT,SDT=DATE,SDCL=CLINIC,SDMODE=2,SDDA=$$SCIEN(DFN,SDCL,SDT)
318 ;
319 I SDDA<1 QUIT 0 ; Appt cancelled; cancelled appts rm'ed from file 44
320 ;
[1080]321 ; remember before status
[1076]322 S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
323 D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
324 ;
325 ; remove check-in using filer.
326 N BSDXIENS S BSDXIENS=SDDA_","_DATE_","_CLINIC_","
327 S BSDXFDA(44.003,BSDXIENS,309)="@" ; CHECKED-IN
328 S BSDXFDA(44.003,BSDXIENS,302)="@" ; CHECK IN USER
329 S BSDXFDA(44.003,BSDXIENS,305)="@" ; CHECK IN ENTERED
330 N BSDXERR
331 D FILE^DIE("","BSDXFDA","BSDXERR")
332 I $D(BSDXERR) QUIT "-1~Can't file for Pat "_PAT_" in Clinic "_CLINIC_" at "_DATE_". Fileman reported an error: "_BSDXERR("DIERR",1,"TEXT",1)
333 ;
334 ; set after status
335 S SDDA=$$SCIEN(DFN,SDCL,SDT)
336 S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
337 D AFTER^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
338 ;
339 ; call event driver
340 D EVT^SDAMEVT(.SDATA,4,SDMODE,SDCIHDL)
341 QUIT 0
342 ;
[968]343SCIEN(PAT,CLINIC,DATE) ;PEP; returns ien for appt in ^SC
344 NEW X,IEN
345 S X=0 F S X=$O(^SC(CLINIC,"S",DATE,1,X)) Q:'X Q:$G(IEN) D
[1006]346 . Q:$P($G(^SC(CLINIC,"S",DATE,1,X,0)),U,9)["C" ;cancelled
[968]347 . I +$G(^SC(CLINIC,"S",DATE,1,X,0))=PAT S IEN=X
348 Q $G(IEN)
349 ;
350APPTYP(PAT,DATE) ;PEP; -- returns type of appt (scheduled or walk-in)
351 NEW X S X=$P($G(^DPT(PAT,"S",DATE,0)),U,7)
352 Q $S(X=3:"SCHED",X=4:"WALK-IN",1:"??")
353 ;
354CO(PAT,CLINIC,DATE,SDIEN) ;PEP; -- returns 1 if appt already checked-out
355 NEW X
356 S X=$G(SDIEN) ;ien sent in call
357 I 'X S X=$$SCIEN(PAT,CLINIC,DATE) I 'X Q 0
358 S X=$P($G(^SC(CLINIC,"S",DATE,1,X,"C")),U,3)
359 Q $S(X:1,1:0)
360 ;
[1041]361UPDATENOTE(PAT,CLINIC,DATE,NOTE) ; PEP; Update Note in ^SC for patient's appointment @ DATE
[1080]362 ; PAT = DFN
363 ; CLINIC = SC IEN
364 ; DATE = FM Date/Time of Appointment
365 ;
366 ; Returns:
367 ; 0 if okay
368 ; -1 if failure
369 N SCIEN S SCIEN=$$SCIEN(PAT,CLINIC,DATE) ; ien of appt in ^SC
370 I SCIEN<1 QUIT 0 ; Appt cancelled; cancelled appts rm'ed from file 44
371 N BSDXIENS S BSDXIENS=SCIEN_","_DATE_","_CLINIC_","
372 S BSDXFDA(44.003,BSDXIENS,3)=$E(NOTE,1,150)
373 N BSDXERR
374 D FILE^DIE("","BSDXFDA","BSDXERR")
375 I $D(BSDXERR) QUIT "-1~Can't file for Pat "_PAT_" in Clinic "_CLINIC_" at "_DATE_". Fileman reported an error: "_BSDXERR("DIERR",1,"TEXT",1)
376 QUIT 0
Note: See TracBrowser for help on using the repository browser.