Ignore:
Timestamp:
Jun 1, 2013, 10:54:38 AM (11 years ago)
Author:
Tariq Hamkari
Message:

Ayman Ghaith : adding the correct routines which not has the transactions.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • Scheduling/trunk/m/BSDXAPI.m

    r1563 r1625  
    1 BSDXAPI ; IHS/ANMC/LJF & VW/SMH - SCHEDULING APIs ; 4/28/11 10:30am
    2         ;;1.6;BSDX;;Aug 31, 2011;Build 25
     1BSDXAPI ; IHS/LJF,HMW,MAW & VEN/SMH - SCHEDULING APIs ; 7/10/12 5:58pm
     2        ;;1.7;BSDX;;Jun 01, 2013;Build 24
    33        ; Licensed under LGPL 
    44        ;
    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:
    9         ; 2010-11-5: (1.42)
    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.
    12         ; 2010-11-12: (1.42)
    13         ; - Changed ="C" to ["C" in SCIEN. Cancelled appointments can be "PC" as well.
    14         ; 2010-12-5 (1.42)
    15         ; Added an entry point to update the patient note in file 44.
    16         ; 2010-12-6 (1.42)
    17         ; MAKE1 incorrectly put info field in BSDR("INFO") rather than BSDR("OI")
    18         ; 2010-12-8 (1.42)
    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.
    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.
    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.
    34         ; 
     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).
    359        ;
    3610MAKE1(DFN,CLIN,TYP,DATE,LEN,INFO)       ; Simplified PEP w/ parameters for $$MAKE - making appointment
     
    3913        ; for Baby foxes hallucinations.
    4014        ; S RESULT=$$MAKE1^BSDXAPI(23435,33,(3 or 4),3091220.221159,30,"I see Baby foxes")
     15        N BSDR
    4116        S BSDR("PAT")=DFN       ;DFN
    4217        S BSDR("CLN")=CLIN      ;Hosp Loc IEN
     
    6540        ;   = 1^message:  error and reason
    6641        ;
     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        ;
     123MAKECK(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        ;
    67128        I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
    68129        I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
     
    71132        I $G(BSDR("ADT"))'?7N.1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
    72133        ;
    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.
     134        ; Appt Length check removed in v 1.5
     135        ;
    74136        I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR"))
    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
    76         ;
     137        ; More verbose error message in v1.5
    77138        ; Following block to give an error message to user if there is already an appointment for patient. More verbose than others.
    78139        N BSDXERR ; place to store error message
     
    88149        . . N BSDXRESNAM S BSDXRESNAM=$P(^BSDXRES(BSDXRESIEN,0),U)
    89150        . . S BSDXERR=BSDXERR_$C(13,10)_"Scheduling GUI clinic: "_BSDXRESNAM ; tell the user of the BSDX clinic
    90         ;
    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        Q 0
     152        ;
     153UNMAKE(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
    151178        ;
    152179CHECKIN1(DFN,CLIN,APDATE)       ; Simplified PEP w/ parameters for $$CHECKIN - Checking in
     
    154181        ; for appt at Dec 20, 2009 @ 10:11:59
    155182        ; S RESULT=$$CHECKIN1^BSDXAPI(23435,33,3091220.221159)
     183        N BSDR
    156184        S BSDR("PAT")=DFN          ;DFN
    157185        S BSDR("CLN")=CLIN         ;Hosp Loc IEN
     
    175203        ;              = 0 means everything worked
    176204        ;              = 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        ;
     251CHECKIC1(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        ;
     264CHECKICK(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"
    177269        ;
    178270        I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
     
    185277        ;
    186278        ; find ien for appt in file 44
    187         NEW IEN,DIE,DA,DR
    188         S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
     279        N IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
    189280        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)
    210281        Q 0
    211282        ;
     
    216287        ; because foxes come out during bad weather.
    217288        ; S RESULT=$$CANCEL1^BSDXAPI(23435,33,"PC",3091220.221159,1,"Afraid of foxes")
     289        N BSDR
    218290        S BSDR("PAT")=DFN
    219291        S BSDR("CLN")=CLIN
     
    244316        ;   = 1^message:  error and reason
    245317        ;
     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        ;
     379CANCELCK(BSDR)  ; $$ PEP; Okay to Cancel Appointment?
     380        ; Input: .BSDR array as documented in $$CANCEL
     381        ; Output: 0 or 1^Error message
    246382        I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
    247383        I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
     
    254390        I '$D(^SD(409.2,+$G(BSDR("CR")))) Q 1_U_"Cancel Reason error: "_$G(BSDR("CR"))
    255391        ;
    256         NEW IEN,DIE,DA,DR
    257         S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
     392        NEW IEN S IEN=$$SCIEN(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
    258393        I 'IEN Q 1_U_"Error trying to find appointment for cancel: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
    259394        ;
    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
    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)
     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!"
    295397        Q 0
    296398        ;
     
    302404        Q $S(X:1,1:0)
    303405        ;
    304 RMCI(PAT,CLINIC,DATE)    ;PEP; -- Remove Check-in; $$
    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         ;
    313         ; Call like this: $$RMCI(233,33,3110102.1130)
    314         ;
    315         ; Move my variables into the ones used by SDAPIs (just a convenience)
    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         ;
    321         ; remember before status
    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
     406CO(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)
    342412        ;
    343413SCIEN(PAT,CLINIC,DATE)  ;PEP; returns ien for appt in ^SC
     
    348418        Q $G(IEN)
    349419        ;
     420APPLEN(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
    350425APPTYP(PAT,DATE)        ;PEP; -- returns type of appt (scheduled or walk-in)
    351426        NEW X S X=$P($G(^DPT(PAT,"S",DATE,0)),U,7)
    352427        Q $S(X=3:"SCHED",X=4:"WALK-IN",1:"??")
    353428        ;
    354 CO(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         ;
    361 UPDATENOTE(PAT,CLINIC,DATE,NOTE)        ; PEP; Update Note in ^SC for patient's appointment @ DATE
    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 TracChangeset for help on using the changeset viewer.