| 1 | SDAPI ;ALB/MJK - Outpatient API ; 22 FEB 1994 11:30 am
|
---|
| 2 | ;;5.3;Scheduling;**27,44,97,132**;08/13/93
|
---|
| 3 | ;
|
---|
| 4 | EN(DFN,SDT,SDCL,SDEVENT,SDERR,SDVIEN) ; -- main entry point for api
|
---|
| 5 | N SDROOT,SDMODE,SDRET,SDUZ,SDERROOT
|
---|
| 6 | ;
|
---|
| 7 | ; -- set init vars and do basic checks
|
---|
| 8 | D INIT(DFN,SDT,SDCL,.SDEVENT,.SDROOT,.SDMODE,.SDRET,.SDUZ)
|
---|
| 9 | IF $$ERRCHK^SDAPIER() G ENQ
|
---|
| 10 | ;
|
---|
| 11 | ; -- appointment check out event
|
---|
| 12 | IF @SDROOT@("EVENT")="CHECK-OUT" D G ENQ
|
---|
| 13 | . N SDOE
|
---|
| 14 | . S SDOE=$$EN^SDAPIAP(DFN,SDT,SDCL,SDUZ,SDMODE,$G(SDVIEN))
|
---|
| 15 | . S SDRET=$$FINAL(SDOE)
|
---|
| 16 | ;
|
---|
| 17 | S SDT1=SDT ;this is to record the actual date for SDVSIT
|
---|
| 18 | ; -- disposition event
|
---|
| 19 | IF @SDROOT@("EVENT")="DISPOSITION" D G ENQ
|
---|
| 20 | . N SDOE
|
---|
| 21 | . S SDOE=$$EN^SDAPIDP(DFN,SDT,SDCL,SDUZ,SDMODE,$G(SDVIEN))
|
---|
| 22 | . S SDRET=$$FINAL(SDOE)
|
---|
| 23 | ;
|
---|
| 24 | ; -- add/edit check out event ; return list of iens
|
---|
| 25 | IF @SDROOT@("EVENT")="ADD/EDIT CHECK-OUT" D G ENQ
|
---|
| 26 | . N SDOE
|
---|
| 27 | . S SDOE=$$EN^SDAPIAE0(DFN,SDT,SDCL,SDUZ,SDMODE,+$G(SDVIEN))
|
---|
| 28 | . S SDRET=$$FINAL(SDOE)
|
---|
| 29 | ;
|
---|
| 30 | ; -- delete appointment check out event
|
---|
| 31 | IF @SDROOT@("EVENT")="CHECK-OUT DELETE",$G(SDVIEN) D G ENQ
|
---|
| 32 | . N SDOE
|
---|
| 33 | . S SDOE=0
|
---|
| 34 | . F SDOE=$O(^SCE("AVSIT",SDVIEN,SDOE)) Q:'SDOE DO
|
---|
| 35 | ..I $D(^SCE(+SDOE,0)) D EN^SDCODEL(SDOE,SDMODE,,"PCE")
|
---|
| 36 | ..Q
|
---|
| 37 | .Q
|
---|
| 38 | ;
|
---|
| 39 | ENQ D HDL
|
---|
| 40 | Q '$$ERRCHK^SDAPIER()_U_SDRET
|
---|
| 41 | ;
|
---|
| 42 | INIT(DFN,SDT,SDCL,SDEVENT,SDROOT,SDMODE,SDRET,SDUZ) ; -- initialization of environment
|
---|
| 43 | S SDMODE="",SDRET=""
|
---|
| 44 | ; -- set error root
|
---|
| 45 | S SDERROOT=$S($G(SDERR)]"":SDERR,1:"SDERR")
|
---|
| 46 | ;
|
---|
| 47 | ; -- set event root
|
---|
| 48 | S SDROOT=$S($G(SDEVENT)]"":SDEVENT,1:"SDEVENT")
|
---|
| 49 | ;
|
---|
| 50 | ; -- error if no event data
|
---|
| 51 | I $G(@SDROOT@("EVENT"))="" D ERRFILE^SDAPIER(1)
|
---|
| 52 | ;
|
---|
| 53 | ; -- kill evt drv handle
|
---|
| 54 | D HDL
|
---|
| 55 | ;
|
---|
| 56 | ; -- error if no patient
|
---|
| 57 | I '$D(^DPT(+$G(DFN),0)) D ERRFILE^SDAPIER(2,DFN)
|
---|
| 58 | ;
|
---|
| 59 | ; -- error if no user
|
---|
| 60 | S SDUZ=+$G(@SDROOT@("USER")) I '$D(^VA(200,SDUZ,0)) D ERRFILE^SDAPIER(3,SDUZ)
|
---|
| 61 | ;
|
---|
| 62 | ; -- error if not a clinic
|
---|
| 63 | I @SDROOT@("EVENT")'="DISPOSITION",$P($G(^SC(+$G(SDCL),0)),U,3)'="C" D ERRFILE^SDAPIER(4,SDCL)
|
---|
| 64 | ;
|
---|
| 65 | ; -- error if no encounter date
|
---|
| 66 | I SDT="" D ERRFILE^SDAPIER(5)
|
---|
| 67 | ;
|
---|
| 68 | INITQ Q
|
---|
| 69 | ;
|
---|
| 70 | FINAL(SDOE) ; -- set up return value
|
---|
| 71 | ; -- return ien and status if c/o attempted
|
---|
| 72 | S SDRET=$S(SDOE:SDOE_U_$P($G(^SD(409.63,+$P($G(^SCE(SDOE,0)),U,12),0)),U),1:"")
|
---|
| 73 | I SDOE,'$$CHK^SDCOM(SDOE) D COMDT^SDCODEL(SDOE,0)
|
---|
| 74 | Q SDRET
|
---|
| 75 | ;
|
---|
| 76 | ;
|
---|
| 77 | HOST(PROTOCOL,MESSAGE) ; -- specify info by protocol
|
---|
| 78 | Q
|
---|
| 79 | N SDRESULT
|
---|
| 80 | S SDRESULT=$$EN(DFN,SDT,SDCL,SDUZ,.SDEVENT)
|
---|
| 81 | Q
|
---|
| 82 | ;
|
---|
| 83 | HDL ; -- kill evt drv hanndle
|
---|
| 84 | I $G(@SDROOT@("KILL HANDLE")) D HDLKILL^SDAMEVT()
|
---|
| 85 | Q
|
---|
| 86 | ;
|
---|