1 | SROPS ;B'HAM ISC/MAM - SELECT CASE ; [ 07/8/03 12:10 PM ]
|
---|
2 | ;;3.0; Surgery ;**18,44,51,64,121**;24 Jun 93
|
---|
3 | W ! S SRSOUT=0 K DIC S DIC("A")="Select Patient: ",DIC=2,DIC(0)="QEAM" D ^DIC K DIC I Y<0 S SRSOUT=1 G END
|
---|
4 | S DFN=+Y D DEM^VADPT
|
---|
5 | STL D HDR I $D(DUZ("SAV")) K SRNEWOP
|
---|
6 | ADT S (SRDT,CNT,SRBACK)=0 F S SRDT=$O(^SRF("ADT",DFN,SRDT)) Q:'SRDT!SRSOUT!$D(SRTN)!SRBACK S SROP=0 F S SROP=$O(^SRF("ADT",DFN,SRDT,SROP)) Q:'SROP!$D(SRTN)!SRSOUT!SRBACK D LIST
|
---|
7 | G:SRBACK ADT G:'$D(SRNEWOP)&SRSOUT END D:SRSOUT HDR I $D(SRTN) G FUTURE
|
---|
8 | I '$D(SRNEWOP),'$D(SRCASE(1)) W !!,"There are no cases entered for "_VADM(1)_".",!!,"Press RETURN to continue " R X:DTIME G END
|
---|
9 | I $D(SRNEWOP) S CNT=CNT+1,SRCASE(CNT)="" W !,CNT,". ENTER NEW SURGICAL CASE"
|
---|
10 | OPT S SRSOUT=0 W !!!,"Select Operation: " R X:DTIME I '$T!("^"[X) S SRSOUT=1 G END
|
---|
11 | I '$D(SRCASE(X)) W !!,"Enter the number of the desired operation" W $S('$D(SRNEWOP):".",1:", or '"_CNT_"' to enter a new case.") G OPT
|
---|
12 | I $D(SRNEWOP),(X=CNT) D NEW^SROPER Q
|
---|
13 | S SRTN=+SRCASE(X)
|
---|
14 | FUTURE ; is this a future case? if so, OK to proceed?
|
---|
15 | Q:$D(PRCP("I")) ; quit if called from Inventory
|
---|
16 | S SROP=SRTN,SRSDATE=$P(^SRF(SRTN,0),"^",9) I $E(SRSDATE,1,7)'>DT Q
|
---|
17 | D HDR W !,?1 D CASE W !,$C(7) K DIR
|
---|
18 | S DIR("A",1)=">>> The case you have selected has a future date.",DIR("A")=" Are you sure you have selected the correct case ? ",DIR("B")="NO",DIR(0)="YA" D ^DIR K DIR I $D(DTOUT)!$D(DUOUT) G END
|
---|
19 | I 'Y K SRTN D HDR G ADT
|
---|
20 | Q
|
---|
21 | LIST ; list cases
|
---|
22 | I '$D(SRNONOR),$P($G(^SRF(SROP,"NON")),"^")="Y" Q
|
---|
23 | S SRSCAN=1 I $D(^SRF(SROP,.2)),$P(^(.2),"^",12)'="" K SRSCAN
|
---|
24 | I $D(SRSCAN),$D(^SRF(SROP,30)),$P(^(30),"^") Q
|
---|
25 | I $D(SRSCAN),$D(^SRF(SROP,31)),$P(^(31),"^",8) Q
|
---|
26 | I $D(^SRF(SROP,37)),$P(^(37),"^") Q
|
---|
27 | I $Y+5>IOSL S SRBACK=0 D SEL^SROPER Q:$D(SRTN)!(SRSOUT) D HDR Q:SRBACK
|
---|
28 | S CNT=CNT+1,SRSDATE=$P(^SRF(SROP,0),"^",9) W !,CNT_". "
|
---|
29 | CASE W $E(SRSDATE,4,5)_"-"_$E(SRSDATE,6,7)_"-"_$E(SRSDATE,2,3)
|
---|
30 | S SROPER=$P(^SRF(SROP,"OP"),"^") I $O(^SRF(SROP,13,0)) S SROTHER=0 F I=0:0 S SROTHER=$O(^SRF(SROP,13,SROTHER)) Q:'SROTHER D OTHER
|
---|
31 | D ^SROP1,LOCK K SROPS,MM,MMM S:$L(SROPER)<65 SROPS(1)=SROPER I $L(SROPER)>64 S SROPER=SROPER_" " F M=1:1 D LOOP Q:MMM=""
|
---|
32 | W ?14,SROPS(1) I $D(SROPS(2)) W !,?14,SROPS(2) I $D(SROPS(3)) W !,?14,SROPS(3) W:$D(SROPS(4)) !,?14,SROPS(4)
|
---|
33 | W ! S SRCASE(CNT)=SROP_"^"_SRDT
|
---|
34 | Q
|
---|
35 | LOCK ; case locked?
|
---|
36 | I $D(SRTN),$P($G(^SRF(SRTN,"LOCK")),"^") S SROPER=SROPER_" **LOCKED**"
|
---|
37 | Q
|
---|
38 | OTHER ; other operations
|
---|
39 | S SRLONG=1 I $L(SROPER)+$L($P(^SRF(SROP,13,SROTHER,0),"^"))>235 S SRLONG=0,SROTHER=999,SROPERS=" ..."
|
---|
40 | I SRLONG S SROPERS=$P(^SRF(SROP,13,SROTHER,0),"^")
|
---|
41 | S SROPER=SROPER_$S(SROPERS=" ...":SROPERS,1:", "_SROPERS)
|
---|
42 | Q
|
---|
43 | LOOP ; break procedure
|
---|
44 | S SROPS(M)="" F LOOP=1:1 S MM=$P(SROPER," "),MMM=$P(SROPER," ",2,200) Q:MMM="" Q:$L(SROPS(M))+$L(MM)'<65 S SROPS(M)=SROPS(M)_MM_" ",SROPER=MMM
|
---|
45 | Q
|
---|
46 | END K SRTN D ^SRSKILL W @IOF
|
---|
47 | Q
|
---|
48 | HDR ; print heading
|
---|
49 | W @IOF,!,?1,VADM(1)_" "_VA("PID") S X=$P($G(VADM(6)),"^") W:X " * DIED "_$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)_" *" W !
|
---|
50 | Q
|
---|