1 | SDCO3 ;ALB/RMO - Provider - Check Out;08 DEC 1992 4:05 pm
|
---|
2 | ;;5.3;Scheduling;**28,27,44,67,71,132,466**;08/13/93;Build 2
|
---|
3 | ;
|
---|
4 | EN ;Entry point for SDCO PROVIDER protocol
|
---|
5 | ; Input -- SDOE
|
---|
6 | ;
|
---|
7 | S VALMBCK=""
|
---|
8 | ;
|
---|
9 | ; -- if OLD encounter, quit
|
---|
10 | IF '$$EDITOK($G(SDOE),1) G ENQ
|
---|
11 | ;
|
---|
12 | ; -- call PCE interview
|
---|
13 | N SDVISIT,SDHL
|
---|
14 | S SDVISIT=$P($G(^SCE(+SDOE,0)),U,5)
|
---|
15 | S X=$$INTV^PXAPI("PRV","SD","PIMS",SDVISIT)
|
---|
16 | D BLD^SDCO S VALMBCK="R"
|
---|
17 | ENQ Q
|
---|
18 | ;
|
---|
19 | PRASK(SDOE) ;Ask Provider on Check Out
|
---|
20 | ; Input -- SDOE Outpatient Encounter IEN
|
---|
21 | ; Output -- 0=No, 1=Yes/Required, 2=Yes/Not Required
|
---|
22 | N SDCL,SDOE0,SDORG,Y
|
---|
23 | S SDOE0=$G(^SCE(+SDOE,0)),SDCL=+$P(SDOE0,"^",4),SDORG=+$P(SDOE0,"^",8)
|
---|
24 | I $$REQ^SDM1A(+SDOE0)'="CO" G PRASKQ
|
---|
25 | I SDORG=1,'$$CLINIC^SDAMU(SDCL) G PRASKQ
|
---|
26 | ;I "^1^2^"[("^"_SDORG_"^"),$$INP^SDAM2(+$P(SDOE0,"^",2),+SDOE0)="I" G PRASKQ ;SD*5.3*466 allow provider check for inpatients
|
---|
27 | I +SDOE0<2961001 S Y=2 G PRASKQ
|
---|
28 | I SDCL S Y=1 G PRASKQ
|
---|
29 | I SDORG=3 S Y=1
|
---|
30 | PRASKQ Q +$G(Y)
|
---|
31 | ;
|
---|
32 | SET(SDOE) ;Set-up Provider Array for Outpatient Encounter
|
---|
33 | ; Input -- SDOE Outpatient Encounter IEN
|
---|
34 | ; Output -- SDPRY Provider Array Subscripted by a Number
|
---|
35 | ; SDCNT Number of Array Entries
|
---|
36 | N SDVA200,SDVPRV,SDPRVS
|
---|
37 | K SDPRY
|
---|
38 | D GETPRV^SDOE(SDOE,"SDPRVS")
|
---|
39 | S (SDCNT,SDVPRV)=0
|
---|
40 | F S SDVPRV=$O(SDPRVS(SDVPRV)) Q:'SDVPRV D
|
---|
41 | . S SDVA200=+$G(SDPRVS(SDVPRV))
|
---|
42 | . S SDCNT=SDCNT+1
|
---|
43 | . S SDPRY(SDCNT)=SDVPRV_"^"_SDVA200
|
---|
44 | SETQ Q
|
---|
45 | ;
|
---|
46 | LIST(SDPRY) ;List Provider Array
|
---|
47 | ; Input -- SDPRY Provider Array Subscripted by a Number
|
---|
48 | ; Output -- List Provider Array
|
---|
49 | N I
|
---|
50 | W !
|
---|
51 | S I=0 F S I=$O(SDPRY(I)) Q:'I W !?2,I," ",$$PR^SDCO31(+$P(SDPRY(I),"^",2))
|
---|
52 | Q
|
---|
53 | ;
|
---|
54 | EDITOK(SDOE,SDMODE) ; -- ok to edit?
|
---|
55 | ; input: SDOE := ien of 409.68 [required]
|
---|
56 | ; SDMODE := 1 -- interactive ; 0 -- silent [required]
|
---|
57 | ;
|
---|
58 | ; returned: 1 -- yes, it's ok to edit or delete SDOE entry
|
---|
59 | ; 0 -- no, cannot not change SDOE entry
|
---|
60 | ;
|
---|
61 | N DIR,SDOK
|
---|
62 | S SDOK=$$NEW^SDPCE($P($G(^SCE(+$G(SDOE),0)),U))
|
---|
63 | IF 'SDOK,SDMODE D OLDMSG
|
---|
64 | EDITOKQ Q SDOK
|
---|
65 | ;
|
---|
66 | OLDMSG ; -- display message to user
|
---|
67 | W !!,">>> Editing and deleting old encounters not allowed.",!
|
---|
68 | N DIR
|
---|
69 | S DIR(0)="E"
|
---|
70 | S DIR("A")="Press Return key to continue"
|
---|
71 | D ^DIR
|
---|
72 | Q
|
---|
73 | ;
|
---|