| 1 | BSDXAPI ; IHS/LJF,HMW,MAW & VEN/SMH - SCHEDULING APIs ; 7/10/12 5:58pm | 
|---|
| 2 | ;;1.7;BSDX;;Jun 01, 2013;Build 24 | 
|---|
| 3 | ; Licensed under LGPL | 
|---|
| 4 | ; | 
|---|
| 5 | ; Orignal routine is BSDAPI by IHS/LJF, HMW, and MAW | 
|---|
| 6 | ; mods (many) by WV/SMH | 
|---|
| 7 | ; Move to BSDX namespace as BSDXAPI from BSDAPI by WV/SMH | 
|---|
| 8 | ; Change history is located in BSDXAPI1 (to save space). | 
|---|
| 9 | ; | 
|---|
| 10 | MAKE1(DFN,CLIN,TYP,DATE,LEN,INFO)       ; Simplified PEP w/ parameters for $$MAKE - making appointment | 
|---|
| 11 | ; Call like this for DFN 23435 having an appointment at Hospital Location 33 | 
|---|
| 12 | ; have 3 (scheduled) or 4 (walkin) appt at Dec 20, 2009 @ 10:11:59 for 30 minutes appt | 
|---|
| 13 | ; for Baby foxes hallucinations. | 
|---|
| 14 | ; S RESULT=$$MAKE1^BSDXAPI(23435,33,(3 or 4),3091220.221159,30,"I see Baby foxes") | 
|---|
| 15 | N BSDR | 
|---|
| 16 | S BSDR("PAT")=DFN       ;DFN | 
|---|
| 17 | S BSDR("CLN")=CLIN      ;Hosp Loc IEN | 
|---|
| 18 | S BSDR("TYP")=TYP       ;3 sched or 4 walkin | 
|---|
| 19 | S BSDR("ADT")=DATE      ;Appointment date in FM format | 
|---|
| 20 | S BSDR("LEN")=LEN       ;Appt len upto 240 (min) | 
|---|
| 21 | S BSDR("OI")=INFO     ;Reason for appt - up to 150 char | 
|---|
| 22 | S BSDR("USR")=DUZ       ;Person who made appt - current user | 
|---|
| 23 | Q $$MAKE(.BSDR) | 
|---|
| 24 | ; | 
|---|
| 25 | MAKE(BSDR)      ;PEP; call to store appt made | 
|---|
| 26 | ; | 
|---|
| 27 | ; Make call using: S ERR=$$MAKE^BSDXAPI(.ARRAY) | 
|---|
| 28 | ; | 
|---|
| 29 | ; Input Array - | 
|---|
| 30 | ; BSDR("PAT") = ien of patient in file 2 | 
|---|
| 31 | ; BSDR("CLN") = ien of clinic in file 44 | 
|---|
| 32 | ; BSDR("TYP") = 3 for scheduled appts, 4 for walkins | 
|---|
| 33 | ; BSDR("ADT") = appointment date and time | 
|---|
| 34 | ; BSDR("LEN") = appointment length in minutes (*1.42 limit removed) | 
|---|
| 35 | ; BSDR("OI")  = reason for appt - up to 150 characters | 
|---|
| 36 | ; BSDR("USR") = user who made appt | 
|---|
| 37 | ; | 
|---|
| 38 | ;Output: error status and message | 
|---|
| 39 | ;   = 0 or null:  everything okay | 
|---|
| 40 | ;   = 1^message:  error and reason | 
|---|
| 41 | ; | 
|---|
| 42 | N BSDXMKCK S BSDXMKCK=$$MAKECK(.BSDR) ; Check if we can make appointment | 
|---|
| 43 | I BSDXMKCK Q BSDXMKCK ; If we can't, quit with the reason why. | 
|---|
| 44 | ; | 
|---|
| 45 | ;Otherwise, we continue | 
|---|
| 46 | ; | 
|---|
| 47 | N BSDXFDA,BSDXIENS,BSDXMSG ; FILE/UPDATE^DIE variables | 
|---|
| 48 | ; | 
|---|
| 49 | I $D(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0)),$P(^(0),U,2)["C" D | 
|---|
| 50 | . ; "un-cancel" existing appt in file 2 | 
|---|
| 51 | . S BSDXIENS=BSDR("ADT")_","_BSDR("PAT")_"," | 
|---|
| 52 | . S BSDXFDA(2.98,BSDXIENS,".01")=BSDR("CLN") | 
|---|
| 53 | . S BSDXFDA(2.98,BSDXIENS,"3")="" | 
|---|
| 54 | . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP") | 
|---|
| 55 | . S BSDXFDA(2.98,BSDXIENS,"9.5")=9 | 
|---|
| 56 | . S BSDXFDA(2.98,BSDXIENS,"14")="" | 
|---|
| 57 | . S BSDXFDA(2.98,BSDXIENS,"15")="" | 
|---|
| 58 | . S BSDXFDA(2.98,BSDXIENS,"16")="" | 
|---|
| 59 | . S BSDXFDA(2.98,BSDXIENS,"17")="@" ; v 1.7; cancellation remarks were left over | 
|---|
| 60 | . S BSDXFDA(2.98,BSDXIENS,"19")="" | 
|---|
| 61 | . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT | 
|---|
| 62 | . D FILE^DIE("","BSDXFDA","BSDXMSG") | 
|---|
| 63 | Q:$D(BSDXMSG) 1_U_"Fileman edit to DPT error: Patient="_BSDR("PAT")_" Appt="_BSDR("ADT")_" Error="_BSDXMSG("DIERR",1,"TEXT",1) | 
|---|
| 64 | ; | 
|---|
| 65 | Q:$G(BSDXSIMERR2) 1_U_$NA(BSDXSIMERR2) ; Unit Test line | 
|---|
| 66 | ; | 
|---|
| 67 | E  D  ; File new appointment/edit existing appointment in file 2 | 
|---|
| 68 | . S BSDXIENS="?+2,"_BSDR("PAT")_"," | 
|---|
| 69 | . S BSDXIENS(2)=BSDR("ADT") | 
|---|
| 70 | . S BSDXFDA(2.98,BSDXIENS,.01)=BSDR("CLN") | 
|---|
| 71 | . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP") | 
|---|
| 72 | . S BSDXFDA(2.98,BSDXIENS,"9.5")=9 | 
|---|
| 73 | . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT | 
|---|
| 74 | . D UPDATE^DIE("","BSDXFDA","BSDXIENS","BSDXMSG") | 
|---|
| 75 | Q:$D(BSDXMSG) 1_U_"FileMan add to DPT error: Patient="_BSDR("PAT")_" Appt="_BSDR("ADT")_" Error="_BSDXMSG("DIERR",1,"TEXT",1) | 
|---|
| 76 | ; | 
|---|
| 77 | Q:$G(BSDXSIMERR3) 1_U_$NA(BSDXSIMERR3) ; Unit Test line | 
|---|
| 78 | ; | 
|---|
| 79 | ; add appt to file 44. This adds it to the FIRST subfile (Appointment) | 
|---|
| 80 | N DIC,DA,Y,X,DD,DO,DLAYGO,DINUM | 
|---|
| 81 | I '$D(^SC(BSDR("CLN"),"S",0)) S ^SC(BSDR("CLN"),"S",0)="^44.001DA^^" | 
|---|
| 82 | 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") | 
|---|
| 83 | . S DIC="^SC("_BSDR("CLN")_",""S"",",DA(1)=BSDR("CLN"),(X,DINUM)=BSDR("ADT") | 
|---|
| 84 | . S DIC("P")="44.001DA",DIC(0)="L",DLAYGO=44.001 | 
|---|
| 85 | . S Y=1 I '$D(@(DIC_X_")")) D FILE^DICN | 
|---|
| 86 | ; | 
|---|
| 87 | Q:$G(BSDXSIMERR4) 1_U_$NA(BSDXSIMERR4) ; Unit Test line | 
|---|
| 88 | ; | 
|---|
| 89 | ; add appt for file 44, second subfile (Appointment/Patient) | 
|---|
| 90 | ; Sep 28 2010: Changed old style API to new style API. Keep for reference //smh | 
|---|
| 91 | ;K DIC,DA,X,Y,DLAYGO,DD,DO,DINUM | 
|---|
| 92 | ;S DIC="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1," | 
|---|
| 93 | ;S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),X=BSDR("PAT") | 
|---|
| 94 | ;S DIC("DR")="1///"_BSDR("LEN")_";3///"_$E($G(BSDR("OI")),1,150)_";7///`"_BSDR("USR")_";8///"_$P($$NOW^XLFDT,".") | 
|---|
| 95 | ;S DIC("P")="44.003PA",DIC(0)="L",DLAYGO=44.003 | 
|---|
| 96 | ;D FILE^DICN | 
|---|
| 97 | ; | 
|---|
| 98 | N BSDXIENS S BSDXIENS="?+1,"_BSDR("ADT")_","_BSDR("CLN")_"," | 
|---|
| 99 | N BSDXFDA | 
|---|
| 100 | S BSDXFDA(44.003,BSDXIENS,.01)=BSDR("PAT") | 
|---|
| 101 | S BSDXFDA(44.003,BSDXIENS,1)=BSDR("LEN") | 
|---|
| 102 | S BSDXFDA(44.003,BSDXIENS,3)=$E($G(BSDR("OI")),1,150) | 
|---|
| 103 | S BSDXFDA(44.003,BSDXIENS,7)=BSDR("USR") | 
|---|
| 104 | S BSDXFDA(44.003,BSDXIENS,8)=$P($$NOW^XLFDT,".") | 
|---|
| 105 | N BSDXERR | 
|---|
| 106 | D UPDATE^DIE("","BSDXFDA","","BSDXERR") | 
|---|
| 107 | ; | 
|---|
| 108 | 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) | 
|---|
| 109 | ; | 
|---|
| 110 | ;Q:$G(BSDXSIMERR5) 1_U_$NA(BSDXSIMERR5) ; Unit Test line | 
|---|
| 111 | S:$G(BSDXSIMERR5) X=1/0 | 
|---|
| 112 | ; | 
|---|
| 113 | ; Update the Availablilities ; Doesn't fail. Global reads and sets. | 
|---|
| 114 | D AVUPDTMK^BSDXAPI1(BSDR("CLN"),BSDR("ADT"),BSDR("LEN"),BSDR("PAT")) | 
|---|
| 115 | ; | 
|---|
| 116 | ; call event driver | 
|---|
| 117 | NEW DFN,SDT,SDCL,SDDA,SDMODE | 
|---|
| 118 | S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2 | 
|---|
| 119 | S SDDA=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 120 | D MAKE^SDAMEVT(DFN,SDT,SDCL,SDDA,SDMODE) | 
|---|
| 121 | Q 0 | 
|---|
| 122 | ; | 
|---|
| 123 | MAKECK(BSDR)    ; $$ - Is it okay to make an appointment? ; PEP | 
|---|
| 124 | ; Input: Same as $$MAKE | 
|---|
| 125 | ; Output: 1^error or 0 for success | 
|---|
| 126 | ; NB: This subroutine saves no data. Only checks whether it's okay. | 
|---|
| 127 | ; | 
|---|
| 128 | I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT")) | 
|---|
| 129 | I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN")) | 
|---|
| 130 | I ($G(BSDR("TYP"))<3)!($G(BSDR("TYP"))>4) Q 1_U_"Appt Type error: "_$G(BSDR("TYP")) | 
|---|
| 131 | I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12)  ;remove seconds | 
|---|
| 132 | I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT")) | 
|---|
| 133 | ; | 
|---|
| 134 | ; Appt Length check removed in v 1.5 | 
|---|
| 135 | ; | 
|---|
| 136 | I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR")) | 
|---|
| 137 | ; More verbose error message in v1.5 | 
|---|
| 138 | ; Following block to give an error message to user if there is already an appointment for patient. More verbose than others. | 
|---|
| 139 | N BSDXERR ; place to store error message | 
|---|
| 140 | 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 | 
|---|
| 141 | . S BSDXERR=1_U_"Patient "_$P(^DPT(BSDR("PAT"),0),U)_" ("_BSDR("PAT")_") " | 
|---|
| 142 | . S BSDXERR=BSDXERR_"already has appt at "_$$FMTE^XLFDT(BSDR("ADT")) | 
|---|
| 143 | . 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) | 
|---|
| 144 | . N BSDXSCNAM S BSDXSCNAM=$P(^SC(BSDXSCIEN,0),U) ; PIMS Name of Clinic | 
|---|
| 145 | . S BSDXERR=BSDXERR_$C(13,10)_"PIMS clinic: "_BSDXSCNAM ; tell the user of the PIMS clinic | 
|---|
| 146 | . 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) | 
|---|
| 147 | . . N BSDXRESIEN S BSDXRESIEN=$O(^BSDXRES("ALOC",BSDXSCIEN,"")) | 
|---|
| 148 | . . QUIT:'BSDXRESIEN  ; Safeguard if index is corrupt | 
|---|
| 149 | . . N BSDXRESNAM S BSDXRESNAM=$P(^BSDXRES(BSDXRESIEN,0),U) | 
|---|
| 150 | . . S BSDXERR=BSDXERR_$C(13,10)_"Scheduling GUI clinic: "_BSDXRESNAM ; tell the user of the BSDX clinic | 
|---|
| 151 | Q 0 | 
|---|
| 152 | ; | 
|---|
| 153 | UNMAKE(BSDR)    ; Reverse Make - Private $$ | 
|---|
| 154 | ; Only used in Emergiencies where Fileman data filing fails. | 
|---|
| 155 | ; If previous data exists, which caused an error, it's destroyed. | 
|---|
| 156 | ; NB: ^DIK stops for nobody | 
|---|
| 157 | ; NB: If Patient Appointment previously existed as cancelled, it's removed. | 
|---|
| 158 | ; How can I tell if one previously existed when data is in an intermediate | 
|---|
| 159 | ; State? Can I restore it if the other file failed? Restoration can cause | 
|---|
| 160 | ; another error. If I restore the global, there will be cross-references | 
|---|
| 161 | ; missing (ASDCN specifically). | 
|---|
| 162 | ; | 
|---|
| 163 | ; Input: Same array as $$MAKE | 
|---|
| 164 | ; Output: Always 0 | 
|---|
| 165 | NEW DIK,DA | 
|---|
| 166 | S DIK="^DPT("_BSDR("PAT")_",""S""," | 
|---|
| 167 | S DA(1)=BSDR("PAT"),DA=BSDR("ADT") | 
|---|
| 168 | D ^DIK | 
|---|
| 169 | ; | 
|---|
| 170 | N IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 171 | I 'IEN QUIT 0 | 
|---|
| 172 | ; | 
|---|
| 173 | NEW DIK,DA | 
|---|
| 174 | S DIK="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1," | 
|---|
| 175 | S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN | 
|---|
| 176 | D ^DIK | 
|---|
| 177 | QUIT 0 | 
|---|
| 178 | ; | 
|---|
| 179 | CHECKIN1(DFN,CLIN,APDATE)       ; Simplified PEP w/ parameters for $$CHECKIN - Checking in | 
|---|
| 180 | ; Call like this for DFN 23435 checking in now at Hospital Location 33 | 
|---|
| 181 | ; for appt at Dec 20, 2009 @ 10:11:59 | 
|---|
| 182 | ; S RESULT=$$CHECKIN1^BSDXAPI(23435,33,3091220.221159) | 
|---|
| 183 | N BSDR | 
|---|
| 184 | S BSDR("PAT")=DFN          ;DFN | 
|---|
| 185 | S BSDR("CLN")=CLIN         ;Hosp Loc IEN | 
|---|
| 186 | S BSDR("ADT")=APDATE       ;Appt Date | 
|---|
| 187 | S BSDR("CDT")=$$NOW^XLFDT  ;Check-in date defaults to now | 
|---|
| 188 | S BSDR("USR")=DUZ          ;Check-in user defaults to current | 
|---|
| 189 | Q $$CHECKIN(.BSDR) | 
|---|
| 190 | ; | 
|---|
| 191 | CHECKIN(BSDR)   ;EP; call to add checkin info to appt; IHS/ITSC/LJF 12/23/2004 PATCH 1002 | 
|---|
| 192 | ; | 
|---|
| 193 | ; Make call by using:  S ERR=$$CHECKIN^BSDXAPI(.ARRAY) | 
|---|
| 194 | ; | 
|---|
| 195 | ; Input array - | 
|---|
| 196 | ;  BSDR("PAT") = ien of patient in file 2 | 
|---|
| 197 | ;  BSDR("CLN") = ien of clinic in file 44 | 
|---|
| 198 | ;  BSDR("ADT") = appt date/time | 
|---|
| 199 | ;  BSDR("CDT") = checkin date/time | 
|---|
| 200 | ;  BSDR("USR") = checkin user | 
|---|
| 201 | ; | 
|---|
| 202 | ; Output value - | 
|---|
| 203 | ;              = 0 means everything worked | 
|---|
| 204 | ;              = 1^message means error with reason message | 
|---|
| 205 | ; | 
|---|
| 206 | I $G(BSDXDIE2) N X S X=1/0 | 
|---|
| 207 | ; | 
|---|
| 208 | N BSDXERR S BSDXERR=$$CHECKICK(.BSDR) | 
|---|
| 209 | I BSDXERR Q BSDXERR | 
|---|
| 210 | ; | 
|---|
| 211 | ; find ien for appt in file 44 | 
|---|
| 212 | NEW IEN,DIE,DA,DR | 
|---|
| 213 | S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 214 | ; | 
|---|
| 215 | ; remember before status | 
|---|
| 216 | ; Failure analysis: Only ^TMP global is set here. | 
|---|
| 217 | NEW SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL,SDMODE | 
|---|
| 218 | S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN | 
|---|
| 219 | S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL | 
|---|
| 220 | D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL) | 
|---|
| 221 | ; | 
|---|
| 222 | ; set checkin; Old Code -- keep for ref VEN/SMH 3 Jul 2012 | 
|---|
| 223 | ; S DIE="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1," | 
|---|
| 224 | ; S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN | 
|---|
| 225 | ; S DR="309///"_BSDR("CDT")_";302///`"_BSDR("USR")_";305///"_$$NOW^XLFDT | 
|---|
| 226 | ; D ^DIE | 
|---|
| 227 | ; | 
|---|
| 228 | I $D(BSDXSIMERR3) Q 1_U_"Simulated Error" | 
|---|
| 229 | ; | 
|---|
| 230 | ; Failure analysis: If this fails, no other changes were made in this routine | 
|---|
| 231 | N BSDXIENS S BSDXIENS=IEN_","_BSDR("ADT")_","_BSDR("CLN")_"," | 
|---|
| 232 | N BSDXFDA | 
|---|
| 233 | S BSDXFDA(44.003,BSDXIENS,309)=BSDR("CDT") | 
|---|
| 234 | S BSDXFDA(44.003,BSDXIENS,302)=BSDR("USR") | 
|---|
| 235 | S BSDXFDA(44.003,BSDXIENS,305)=$$NOW^XLFDT() | 
|---|
| 236 | N BSDXERR | 
|---|
| 237 | D UPDATE^DIE("","BSDXFDA","BSDXERR") | 
|---|
| 238 | ; | 
|---|
| 239 | I $D(BSDXERR) Q 1_U_"Error checking in appointment to file 44. Error: "_BSDXERR("DIERR",1,"TEXT",1) | 
|---|
| 240 | ; | 
|---|
| 241 | ; set after status | 
|---|
| 242 | S SDDA=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 243 | S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL | 
|---|
| 244 | D AFTER^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL) | 
|---|
| 245 | ; | 
|---|
| 246 | ; Point of no Return | 
|---|
| 247 | ; call event driver | 
|---|
| 248 | D EVT^SDAMEVT(.SDATA,4,SDMODE,SDCIHDL) | 
|---|
| 249 | Q 0 | 
|---|
| 250 | ; | 
|---|
| 251 | CHECKIC1(DFN,CLIN,APDATE)       ; Simplified PEP w/ parameters for $$CHECKICK - | 
|---|
| 252 | ; Check-in Check | 
|---|
| 253 | ; Call like this for DFN 23435 checking in now at Hospital Location 33 | 
|---|
| 254 | ; for appt at Dec 20, 2009 @ 10:11:59 | 
|---|
| 255 | ; S RESULT=$$CHECKIC1^BSDXAPI(23435,33,3091220.221159) | 
|---|
| 256 | N BSDR | 
|---|
| 257 | S BSDR("PAT")=DFN          ;DFN | 
|---|
| 258 | S BSDR("CLN")=CLIN         ;Hosp Loc IEN | 
|---|
| 259 | S BSDR("ADT")=APDATE       ;Appt Date | 
|---|
| 260 | S BSDR("CDT")=$$NOW^XLFDT  ;Check-in date defaults to now | 
|---|
| 261 | S BSDR("USR")=DUZ          ;Check-in user defaults to current | 
|---|
| 262 | Q $$CHECKICK(.BSDR) | 
|---|
| 263 | ; | 
|---|
| 264 | CHECKICK(BSDR)  ; $$ PEP; - Is it okay to check-in patient? | 
|---|
| 265 | ; Input: Same as $$CHECKIN | 
|---|
| 266 | ; Output: 0 if okay or 1^message if error | 
|---|
| 267 | ; | 
|---|
| 268 | I $G(BSDXSIMERR2) Q 1_U_"Simulated Error" | 
|---|
| 269 | ; | 
|---|
| 270 | I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT")) | 
|---|
| 271 | I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN")) | 
|---|
| 272 | I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12)  ;remove seconds | 
|---|
| 273 | I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT")) | 
|---|
| 274 | I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12)  ;remove seconds | 
|---|
| 275 | I $G(BSDR("CDT"))'?7N.1".".4N Q 1_U_"Checkin Date/Time error: "_$G(BSDR("CDT")) | 
|---|
| 276 | I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR")) | 
|---|
| 277 | ; | 
|---|
| 278 | ; find ien for appt in file 44 | 
|---|
| 279 | N IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 280 | I 'IEN Q 1_U_"Error trying to find appointment for checkin: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT") | 
|---|
| 281 | Q 0 | 
|---|
| 282 | ; | 
|---|
| 283 | CANCEL1(DFN,CLIN,TYP,APDATE,REASON,INFO)        ; PEP w/ parameters for $$CANCEL - cancelling appointment | 
|---|
| 284 | ; Call like this for DFN 23435 cancelling an appointment at Hospital Location 33, | 
|---|
| 285 | ; cancellation initiated by patient ("PC" rather than clinic "C"), | 
|---|
| 286 | ; cancelling appt at Dec 20, 2009 @ 10:11:59 because of reason 1 in file 409.2 IEN (weather) | 
|---|
| 287 | ; because foxes come out during bad weather. | 
|---|
| 288 | ; S RESULT=$$CANCEL1^BSDXAPI(23435,33,"PC",3091220.221159,1,"Afraid of foxes") | 
|---|
| 289 | N BSDR | 
|---|
| 290 | S BSDR("PAT")=DFN | 
|---|
| 291 | S BSDR("CLN")=CLIN | 
|---|
| 292 | S BSDR("TYP")=TYP | 
|---|
| 293 | S BSDR("ADT")=APDATE | 
|---|
| 294 | S BSDR("CDT")=$$NOW^XLFDT | 
|---|
| 295 | S BSDR("USR")=DUZ | 
|---|
| 296 | S BSDR("CR")=REASON | 
|---|
| 297 | S BSDR("NOT")=INFO | 
|---|
| 298 | Q $$CANCEL(.BSDR) | 
|---|
| 299 | ; | 
|---|
| 300 | CANCEL(BSDR)    ;PEP; called to cancel appt | 
|---|
| 301 | ; | 
|---|
| 302 | ; Make call using: S ERR=$$CANCEL^BSDXAPI(.ARRAY) | 
|---|
| 303 | ; | 
|---|
| 304 | ; Input Array - | 
|---|
| 305 | ; BSDR("PAT") = ien of patient in file 2 | 
|---|
| 306 | ; BSDR("CLN") = ien of clinic in file 44 | 
|---|
| 307 | ; BSDR("TYP") = C for canceled by clinic; PC for patient canceled | 
|---|
| 308 | ; BSDR("ADT") = appointment date and time | 
|---|
| 309 | ; BSDR("CDT") = cancel date and time | 
|---|
| 310 | ; BSDR("USR") = user who canceled appt | 
|---|
| 311 | ; BSDR("CR")  = cancel reason - pointer to file 409.2 | 
|---|
| 312 | ; BSDR("NOT") = cancel remarks - optional notes to 160 characters | 
|---|
| 313 | ; | 
|---|
| 314 | ;Output: error status and message | 
|---|
| 315 | ;   = 0 or null:  everything okay | 
|---|
| 316 | ;   = 1^message:  error and reason | 
|---|
| 317 | ; | 
|---|
| 318 | ; Okay to Cancel? Call Cancel Check. | 
|---|
| 319 | N BSDXCANCK S BSDXCANCK=$$CANCELCK(.BSDR) | 
|---|
| 320 | I BSDXCANCK Q BSDXCANCK | 
|---|
| 321 | ; | 
|---|
| 322 | ; BSDX 1.5 3110125 | 
|---|
| 323 | ; UJO/SMH - Add ability to remove check-in if the patient is checked in | 
|---|
| 324 | ; VEN/SMH on 3120625/v1.7 - PIMS doesn't care if patient is already checked in | 
|---|
| 325 | ; Lets you remove appointment anyways! Not like RPMS. | 
|---|
| 326 | ; Plus... deleting checkin affects S node on 44, which is DELETED anyways! | 
|---|
| 327 | ; | 
|---|
| 328 | ; remember before status | 
|---|
| 329 | NEW SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL,SDMODE | 
|---|
| 330 | NEW IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 331 | S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN | 
|---|
| 332 | S SDCPHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL | 
|---|
| 333 | D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL) | 
|---|
| 334 | ; NB: Here only ^TMP globals are set with before values. | 
|---|
| 335 | ; | 
|---|
| 336 | ; get user who made appt and date appt made from ^SC | 
|---|
| 337 | ;    because data in ^SC will be deleted | 
|---|
| 338 | ; Appointment Length: ditto | 
|---|
| 339 | NEW USER,DATE | 
|---|
| 340 | S USER=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,6) | 
|---|
| 341 | S DATE=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,7) | 
|---|
| 342 | N BSDXLEN S BSDXLEN=$$APPLEN(DFN,SDCL,SDT) ; appt length | 
|---|
| 343 | ; | 
|---|
| 344 | ; update file 2 info --old code; keep for reference | 
|---|
| 345 | ;NEW DIE,DA,DR | 
|---|
| 346 | ;S DIE="^DPT("_DFN_",""S"",",DA(1)=DFN,DA=SDT | 
|---|
| 347 | ;S DR="3///"_BSDR("TYP")_";14///`"_BSDR("USR")_";15///"_BSDR("CDT")_";16///`"_BSDR("CR")_";19///`"_USER_";20///"_DATE | 
|---|
| 348 | ;S:$G(BSDR("NOT"))]"" DR=DR_";17///"_$E(BSDR("NOT"),1,160) | 
|---|
| 349 | ;D ^DIE | 
|---|
| 350 | N BSDXIENS S BSDXIENS=SDT_","_DFN_"," | 
|---|
| 351 | N BSDXFDA | 
|---|
| 352 | S BSDXFDA(2.98,BSDXIENS,3)=BSDR("TYP") | 
|---|
| 353 | S BSDXFDA(2.98,BSDXIENS,14)=BSDR("USR") | 
|---|
| 354 | S BSDXFDA(2.98,BSDXIENS,15)=BSDR("CDT") | 
|---|
| 355 | S BSDXFDA(2.98,BSDXIENS,16)=BSDR("CR") | 
|---|
| 356 | S BSDXFDA(2.98,BSDXIENS,19)=USER | 
|---|
| 357 | S BSDXFDA(2.98,BSDXIENS,20)=DATE | 
|---|
| 358 | S:$G(BSDR("NOT"))]"" BSDXFDA(2.98,BSDXIENS,17)=$E(BSDR("NOT"),1,160) | 
|---|
| 359 | N BSDXERR | 
|---|
| 360 | D FILE^DIE("","BSDXFDA","BSDXERR") | 
|---|
| 361 | I $D(BSDXERR) Q 1_U_"Cannot cancel appointment in File 2" | 
|---|
| 362 | ; Failure point 1: If we fail here, nothing has happened yet. | 
|---|
| 363 | ; | 
|---|
| 364 | ; delete data in ^SC -- this does not (typically) fail. Fileman won't stop | 
|---|
| 365 | NEW DIK,DA | 
|---|
| 366 | S DIK="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1," | 
|---|
| 367 | S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN | 
|---|
| 368 | D ^DIK | 
|---|
| 369 | ; Failure point 2: not expected to happen here | 
|---|
| 370 | ; | 
|---|
| 371 | ; Update PIMS availability -- this doesn't fail. Global gets/sets only. | 
|---|
| 372 | D AVUPDTCN^BSDXAPI1(SDCL,SDT,BSDXLEN) | 
|---|
| 373 | ; | 
|---|
| 374 | ; call event driver -- point of no return | 
|---|
| 375 | D CANCEL^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDMODE,SDCPHDL) | 
|---|
| 376 | ; | 
|---|
| 377 | Q 0 | 
|---|
| 378 | ; | 
|---|
| 379 | CANCELCK(BSDR)  ; $$ PEP; Okay to Cancel Appointment? | 
|---|
| 380 | ; Input: .BSDR array as documented in $$CANCEL | 
|---|
| 381 | ; Output: 0 or 1^Error message | 
|---|
| 382 | I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT")) | 
|---|
| 383 | I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN")) | 
|---|
| 384 | I ($G(BSDR("TYP"))'="C"),($G(BSDR("TYP"))'="PC") Q 1_U_"Cancel Status error: "_$G(BSDR("TYP")) | 
|---|
| 385 | I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12)  ;remove seconds | 
|---|
| 386 | I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT")) | 
|---|
| 387 | I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12)  ;remove seconds | 
|---|
| 388 | I $G(BSDR("CDT"))'?7N.1".".4N Q 1_U_"Cancel Date/Time error: "_$G(BSDR("CDT")) | 
|---|
| 389 | I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Canceled Appt Error: "_$G(BSDR("USR")) | 
|---|
| 390 | I '$D(^SD(409.2,+$G(BSDR("CR")))) Q 1_U_"Cancel Reason error: "_$G(BSDR("CR")) | 
|---|
| 391 | ; | 
|---|
| 392 | NEW IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT")) | 
|---|
| 393 | I 'IEN Q 1_U_"Error trying to find appointment for cancel: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT") | 
|---|
| 394 | ; | 
|---|
| 395 | ; Check-out check. New in v1.7 | 
|---|
| 396 | I $$CO(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"),IEN) Q 1_U_"Cannot delete. Appointment has already been checked-out!" | 
|---|
| 397 | Q 0 | 
|---|
| 398 | ; | 
|---|
| 399 | CI(PAT,CLINIC,DATE,SDIEN)       ;PEP; -- returns 1 if appt already checked-in | 
|---|
| 400 | NEW X | 
|---|
| 401 | S X=$G(SDIEN)   ;ien sent in call | 
|---|
| 402 | I 'X S X=$$SCIEN(PAT,CLINIC,DATE) I 'X Q 0 | 
|---|
| 403 | S X=$P($G(^SC(CLINIC,"S",DATE,1,X,"C")),U) | 
|---|
| 404 | Q $S(X:1,1:0) | 
|---|
| 405 | ; | 
|---|
| 406 | CO(PAT,CLINIC,DATE,SDIEN)       ;PEP; -- returns 1 if appt already checked-out | 
|---|
| 407 | NEW X | 
|---|
| 408 | S X=$G(SDIEN)   ;ien sent in call | 
|---|
| 409 | I 'X S X=$$SCIEN(PAT,CLINIC,DATE) I 'X Q 0 | 
|---|
| 410 | S X=$P($G(^SC(CLINIC,"S",DATE,1,X,"C")),U,3) | 
|---|
| 411 | Q $S(X:1,1:0) | 
|---|
| 412 | ; | 
|---|
| 413 | SCIEN(PAT,CLINIC,DATE)  ;PEP; returns ien for appt in ^SC | 
|---|
| 414 | NEW X,IEN | 
|---|
| 415 | S X=0 F  S X=$O(^SC(CLINIC,"S",DATE,1,X)) Q:'X  Q:$G(IEN)  D | 
|---|
| 416 | . Q:$P($G(^SC(CLINIC,"S",DATE,1,X,0)),U,9)["C"  ;cancelled | 
|---|
| 417 | . I +$G(^SC(CLINIC,"S",DATE,1,X,0))=PAT S IEN=X | 
|---|
| 418 | Q $G(IEN) | 
|---|
| 419 | ; | 
|---|
| 420 | APPLEN(PAT,CLINIC,DATE) ; $$ PEP; returns an appointment's length | 
|---|
| 421 | ; Get either the appointment length or zero | 
|---|
| 422 | N SCIEN S SCIEN=$$SCIEN(PAT,CLINIC,DATE) | 
|---|
| 423 | Q:SCIEN $P(^SC(CLINIC,"S",DATE,1,SCIEN,0),U,2) | 
|---|
| 424 | Q 0 | 
|---|
| 425 | APPTYP(PAT,DATE)        ;PEP; -- returns type of appt (scheduled or walk-in) | 
|---|
| 426 | NEW X S X=$P($G(^DPT(PAT,"S",DATE,0)),U,7) | 
|---|
| 427 | Q $S(X=3:"SCHED",X=4:"WALK-IN",1:"??") | 
|---|
| 428 | ; | 
|---|