Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: BSDAPI

BSDAPI.m

Go to the documentation of this file.
  1. BSDAPI ; IHS/ANMC/LJF - SCHEDULING APIs ; [ 03/08/2004 10:36 AM ]
  1. ;;5.3;PIMS;**1002,1003,1006,1010,1012**;MAY 28, 2004
  1. ;IHS/ITSC/LJF 12/23/2004 PATCH 1002 removed PEP from CHECKIN entry point
  1. ; 04/22/2005 PATCH 1003 added code to handle call from BSDAPI4
  1. ;IHS/OIT/LJF 10/18/2006 PATCH 1006 now allow 240 minute appts as DD does
  1. ;cmi/anch/maw 10/20/2008 PATCH 1010 RQMT69 added FUTURE PEP function to return whether patient has a future appointment
  1. ;cmi/flag/maw 02/18/2010 PATCH 1012 added check of data in DPT node when cancelling an appointment
  1. ;
  1. MAKE(BSDR) ;PEP; call to store appt made
  1. ;
  1. ; Make call using: S ERR=$$MAKE^BSDAPI(.ARRAY)
  1. ;
  1. ; Input Array -
  1. ; BSDR("PAT") = ien of patient in file 2
  1. ; BSDR("CLN") = ien of clinic in file 44
  1. ; BSDR("TYP") = 3 for scheduled appts, 4 for walkins
  1. ; BSDR("ADT") = appointment date and time
  1. ; BSDR("LEN") = appointment length in minutes (5-120)
  1. ; BSDR("OI") = reason for appt - up to 150 characters
  1. ; BSDR("USR") = user who made appt
  1. ;
  1. ;Output: error status and message
  1. ; = 0 or null: everything okay
  1. ; = 1^message: error and reason
  1. ;
  1. I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
  1. I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
  1. I ($G(BSDR("TYP"))<3)!($G(BSDR("TYP"))>4) Q 1_U_"Appt Type error: "_$G(BSDR("TYP"))
  1. I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
  1. I $G(BSDR("ADT"))'?7N1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
  1. ;
  1. ;IHS/OIT/LJF 10/18/2006 PATCH 1006 DD now allows 240 minutes
  1. ;I ($G(BSDR("LEN"))<5)!($G(BSDR("LEN"))>120) Q 1_U_"Appt Length error: "_$G(BSDR("LEN"))
  1. I ($G(BSDR("LEN"))<5)!($G(BSDR("LEN"))>240) Q 1_U_"Appt Length error: "_$G(BSDR("LEN"))
  1. I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR"))
  1. 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")
  1. ;
  1. NEW DIC,DA,Y,X,DD,DO,DLAYGO
  1. ;
  1. I $D(^DPT(BSDR("PAT"),"S",BSDR("ADT"),0)),$P(^(0),U,2)="C" D
  1. . ; "un-cancel" existing appt in file 2
  1. . N BSDXFDA,BSDXIENS,BSDXMSG
  1. . S BSDXIENS=BSDR("ADT")_","_BSDR("PAT")_","
  1. . S BSDXFDA(2.98,BSDXIENS,".01")=BSDR("CLN")
  1. . S BSDXFDA(2.98,BSDXIENS,"3")=""
  1. . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP")
  1. . S BSDXFDA(2.98,BSDXIENS,"9.5")=9
  1. . S BSDXFDA(2.98,BSDXIENS,"14")=""
  1. . S BSDXFDA(2.98,BSDXIENS,"15")=""
  1. . S BSDXFDA(2.98,BSDXIENS,"16")=""
  1. . S BSDXFDA(2.98,BSDXIENS,"19")=""
  1. . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT
  1. . D FILE^DIE("","BSDXFDA","BSDXMSG")
  1. . N BSDXTEMP S BSDXTEMP=$G(BSDXMSG)
  1. ;E D I Y<1 Q 1_U_"FileMan add to DPT error: Patient="_BSDR("PAT")_" Appt="_BSDR("ADT") ;cmi/maw 9/9/2008 orig line PATCH 1010
  1. E D I $G(BSDXERR(1)) Q 1_U_"FileMan add to DPT error: Patient="_BSDR("PAT")_" Appt="_BSDR("ADT") ;cmi/maw 9/9/2008 new line patch 1010
  1. . ; add appt to file 2
  1. . ;cmi/maw 9/9/2008 changed call to silent server call PATCH 1010
  1. . N BSDXFDA,BSDXIENS,BSDXMSG
  1. . S BSDXIENS="?+2,"_BSDR("PAT")_","
  1. . S BSDXIENS(2)=BSDR("ADT")
  1. . S BSDXFDA(2.98,BSDXIENS,.01)=BSDR("CLN")
  1. . S BSDXFDA(2.98,BSDXIENS,"9")=BSDR("TYP")
  1. . S BSDXFDA(2.98,BSDXIENS,"9.5")=9
  1. . S BSDXFDA(2.98,BSDXIENS,"20")=$$NOW^XLFDT
  1. . D UPDATE^DIE("","BSDXFDA","BSDXIENS","BSDXERR(1)")
  1. . ;S DIC="^DPT("_BSDR("PAT")_",""S"",",DA(1)=BSDR("PAT"),X=BSDR("CLN") ;cmi/maw 9/9/2008 orig line
  1. . ;S DIC("DR")="9///"_BSDR("TYP")_";9.5///9;20///"_$$NOW^XLFDT ;cmi/maw 9/9/2008 orig line
  1. . ;S DIC("P")="2.98P",DIC(0)="L",DLAYGO=2.98,DINUM=BSDR("ADT") ;cmi/maw 9/9/2008 orig line
  1. . ;K DD,DO ;cmi/maw 9/9/2008 orig line
  1. . ;D FILE^DICN ;cmi/maw 9/9/2008 orig line
  1. ;
  1. ;
  1. ; add appt to file 44
  1. K DIC,DA,X,Y,DLAYGO,DD,DO
  1. I '$D(^SC(BSDR("CLN"),"S",0)) S ^SC(BSDR("CLN"),"S",0)="^44.001DA^^"
  1. 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")
  1. . S DIC="^SC("_BSDR("CLN")_",""S"",",DA(1)=BSDR("CLN"),(X,DINUM)=BSDR("ADT")
  1. . S DIC("P")="44.001DA",DIC(0)="L",DLAYGO=44.001
  1. . S Y=1 I '$D(@(DIC_X_")")) D FILE^DICN
  1. ;
  1. K DIC,DA,X,Y,DLAYGO,DD,DO,DINUM
  1. S DIC="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
  1. S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),X=BSDR("PAT")
  1. ;S DIC("DR")="1///"_BSDR("LEN")_";3///"_$E($G(BSDR("OI")),1,150)_";7///`"_BSDR("USR")_";8///"_$$NOW^XLFDT ;cmi/maw 9/19/2008 orig line
  1. S DIC("DR")="1///"_BSDR("LEN")_";3///"_$E($G(BSDR("OI")),1,150)_";7////"_BSDR("USR")_";8////"_$$NOW^XLFDT ;cmi/maw 9/19/2008 mod line PATCH 1010
  1. S DIC("P")="44.003PA",DIC(0)="L",DLAYGO=44.003
  1. D FILE^DICN
  1. ;
  1. ; call event driver
  1. NEW DFN,SDT,SDCL,SDDA,SDMODE
  1. S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2
  1. S SDDA=$$SCIEN^BSDU2(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
  1. D MAKE^SDAMEVT(DFN,SDT,SDCL,SDDA,SDMODE)
  1. Q 0
  1. ;
  1. CHECKIN(BSDR) ;EP; call to add checkin info to appt; IHS/ITSC/LJF 12/23/2004 PATCH 1002
  1. ; PATCH 1002 - entry point no longer public; other apps must call GETVISIT^BSDAPI4
  1. ;
  1. ; Make call by using: S ERR=$$CHECKIN^BSDAPI(.ARRAY)
  1. ;
  1. ; Input array -
  1. ; BSDR("PAT") = ien of patient in file 2
  1. ; BSDR("CLN") = ien of clinic in file 44
  1. ; BSDR("ADT") = appt date/time
  1. ; BSDR("CDT") = checkin date/time
  1. ; BSDR("USR") = checkin user
  1. ; BSDR("OPT") = option used to create visit (optional)
  1. ;
  1. ;IHS/ITSC/LJF 4/22/2005 PATCH 1003 new variable sent from BSDAPI4
  1. ; BSDR("VIEN") = visit IEN (sent if new visit is NOT to be created)
  1. ;
  1. ; variables to create visit under event driver
  1. ; BSDR("CC") = clinic code for creating visit - optional
  1. ; BSDR("PRV") = visit provider - pointer to file 200
  1. ;
  1. ; Output value -
  1. ; = 0 means everything worked
  1. ; = 1^message means error with reason message
  1. ;
  1. I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
  1. I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
  1. I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
  1. I $G(BSDR("ADT"))'?7N1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
  1. I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12) ;remove seconds
  1. I $G(BSDR("CDT"))'?7N1".".4N Q 1_U_"Checkin Date/Time error: "_$G(BSDR("CDT"))
  1. I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Made Appt Error: "_$G(BSDR("USR"))
  1. ;
  1. ; find ien for appt in file 44
  1. NEW IEN,DIE,DA,DR
  1. S IEN=$$SCIEN^BSDU2(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
  1. I 'IEN Q 1_U_"Error trying to find appointment for checkin: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
  1. ;
  1. ; remember before status
  1. NEW SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL
  1. S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN
  1. S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
  1. D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
  1. ;
  1. ; set checkin
  1. S DIE="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
  1. S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN
  1. S DR="309///"_BSDR("CDT")_";302///`"_BSDR("USR")_";305///"_$$NOW^XLFDT
  1. D ^DIE
  1. ;
  1. ; set after status
  1. S SDDA=$$SCIEN^BSDU2(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
  1. S SDCIHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
  1. D AFTER^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCIHDL)
  1. ;
  1. ;IHS/ITSC/LJF 4/22/2005 PATCH 1003 set visit variable if not creating new visit
  1. ; event driver kills variable after all protocols run
  1. I $G(BSDR("VIEN")) S BSDVSTN=BSDR("VIEN")
  1. ;
  1. ; call event driver
  1. D EVT^SDAMEVT(.SDATA,4,SDMODE,SDCIHDL)
  1. Q 0
  1. ;
  1. CANCEL(BSDR) ;PEP; called to cancel appt
  1. ;
  1. ; Make call using: S ERR=$$CANCEL^BSDAPI(.ARRAY)
  1. ;
  1. ; Input Array -
  1. ; BSDR("PAT") = ien of patient in file 2
  1. ; BSDR("CLN") = ien of clinic in file 44
  1. ; BSDR("TYP") = C for canceled by clinic; PC for patient canceled
  1. ; BSDR("ADT") = appointment date and time
  1. ; BSDR("CDT") = cancel date and time
  1. ; BSDR("USR") = user who canceled appt
  1. ; BSDR("CR") = cancel reason - pointer to file 409.2
  1. ; BSDR("NOT") = cancel remarks - optional notes to 160 characters
  1. ;
  1. ;Output: error status and message
  1. ; = 0 or null: everything okay
  1. ; = 1^message: error and reason
  1. ;
  1. I '$D(^DPT(+$G(BSDR("PAT")),0)) Q 1_U_"Patient not on file: "_$G(BSDR("PAT"))
  1. I '$D(^SC(+$G(BSDR("CLN")),0)) Q 1_U_"Clinic not on file: "_$G(BSDR("CLN"))
  1. I ($G(BSDR("TYP"))'="C"),($G(BSDR("TYP"))'="PC") Q 1_U_"Cancel Status error: "_$G(BSDR("TYP"))
  1. I $G(BSDR("ADT")) S BSDR("ADT")=+$E(BSDR("ADT"),1,12) ;remove seconds
  1. I $G(BSDR("ADT"))'?7N1".".4N Q 1_U_"Appt Date/Time error: "_$G(BSDR("ADT"))
  1. I $G(BSDR("CDT")) S BSDR("CDT")=+$E(BSDR("CDT"),1,12) ;remove seconds
  1. I $G(BSDR("CDT"))'?7N1".".4N Q 1_U_"Cancel Date/Time error: "_$G(BSDR("CDT"))
  1. I '$D(^VA(200,+$G(BSDR("USR")),0)) Q 1_U_"User Who Canceled Appt Error: "_$G(BSDR("USR"))
  1. I '$D(^SD(409.2,+$G(BSDR("CR")))) Q 1_U_"Cancel Reason error: "_$G(BSDR("CR"))
  1. ;
  1. NEW IEN,DIE,DA,DR
  1. S IEN=$$SCIEN^BSDU2(BSDR("PAT"),BSDR("CLN"),BSDR("ADT"))
  1. I 'IEN Q 1_U_"Error trying to find appointment for cancel: Patient="_BSDR("PAT")_" Clinic="_BSDR("CLN")_" Appt="_BSDR("ADT")
  1. ;
  1. I $$CI^BSDU2(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")
  1. ;
  1. ; remember before status
  1. NEW SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL
  1. S DFN=BSDR("PAT"),SDT=BSDR("ADT"),SDCL=BSDR("CLN"),SDMODE=2,SDDA=IEN
  1. S SDCPHDL=$$HANDLE^SDAMEVT(1),SDATA=SDDA_U_DFN_U_SDT_U_SDCL
  1. D BEFORE^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDCPHDL)
  1. ;
  1. ; get user who made appt and date appt made from ^SC
  1. ; because data in ^SC will be deleted
  1. NEW USER,DATE
  1. S USER=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,6)
  1. S DATE=$P($G(^SC(SDCL,"S",SDT,1,IEN,0)),U,7)
  1. ;
  1. ; update file 2 info
  1. I $D(^DPT(DFN,"S",SDT)) D ;cmi/maw 02/18/2010 allows cancellation to continue if DPT node missing
  1. . NEW DIE,DA,DR
  1. . S DIE="^DPT("_DFN_",""S"",",DA(1)=DFN,DA=SDT
  1. . S DR="3///"_BSDR("TYP")_";14///`"_BSDR("USR")_";15///"_BSDR("CDT")_";16///`"_BSDR("CR")_";19///`"_USER_";20///"_DATE
  1. . S:$G(BSDR("NOT"))]"" DR=DR_";17///"_$E(BSDR("NOT"),1,160)
  1. . D ^DIE
  1. ;
  1. ; delete data in ^SC
  1. NEW DIK,DA
  1. S DIK="^SC("_BSDR("CLN")_",""S"","_BSDR("ADT")_",1,"
  1. S DA(2)=BSDR("CLN"),DA(1)=BSDR("ADT"),DA=IEN
  1. D ^DIK
  1. ;
  1. ; call event driver
  1. D CANCEL^SDAMEVT(.SDATA,DFN,SDT,SDCL,SDDA,SDMODE,SDCPHDL)
  1. Q 0
  1. ;
  1. FUTURE(BSDPAT) ;PEP - PATCH 1010 RQMT69 API that returns 1 if patient has a future appointment or 0 if not DFN is passed in
  1. N BSDDA,BSDFUT
  1. S BSDFUT=0
  1. S BSDDA=0 F S BSDDA=$O(^DPT(BSDPAT,"S",BSDDA)) Q:'BSDDA D
  1. . I BSDDA>DT S BSDFUT=1
  1. Q $G(BSDFUT)
  1. ;