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 | ;
|
---|