1 | SRSCDS ;B'HAM ISC/MAM - SCHEDULED OPERATIONS BY SERVICE ; [ 07/27/98 2:33 PM ]
|
---|
2 | ;;3.0; Surgery ;**50**;24 Jun 93
|
---|
3 | SER S SRQ=0 K ^TMP("SR",$J) W !!,"Do you want a list of scheduled operations for a specific specialty ? YES// " R Z:DTIME S:'$T Z="^" G:Z["^" END S:Z="" Z="Y"
|
---|
4 | S Z=$E(Z) I "NnYy"'[Z W !!,"Enter RETURN to list the scheduled operations for a specific service,",!,"or 'NO' to list the scheduled cases for all services." G SER
|
---|
5 | I "Nn"[Z G ^SRSCDS1
|
---|
6 | W ! K DIC S DIC("A")="Print the list for which Specialty: ",DIC("S")="I '$P(^(0),""^"",3)",DIC=137.45,DIC(0)="QEAMZ" D ^DIC G:Y<0 END
|
---|
7 | S SRS=+Y,SRS("C")=$P(^SRO(137.45,SRS,0),"^",2),SRS("N")=$P(^SRO(137.45,SRS,0),"^"),SRS("N")=$P(SRS("N"),"(",1)
|
---|
8 | W ! K IOP,%ZIS,POP,IO("Q") S %ZIS("A")="Print the list on which device: ",%ZIS="Q" D ^%ZIS G:POP END I $D(IO("Q")) K IO("Q") S ZTDESC="SCHEDULED OPERATIONS BY SERVICE",ZTRTN="SRS^SRSCDS" D ZTSAVE,^%ZTLOAD G END
|
---|
9 | SRS ; entry when queued
|
---|
10 | U IO S (SROR,SRQ,SRTN)=0,Y=SRSDATE D D^DIQ S SRDATE=Y
|
---|
11 | OR F S SROR=$O(^SRF("AOR",SROR)) Q:'SROR!SRQ I $$ORDIV^SROUTL0(SROR,$G(SRSITE("DIV"))) F S SRTN=$O(^SRF("AOR",SROR,SRSDATE,SRTN)) Q:'SRTN!SRQ I $D(^SRF(SRTN,31)),$P(^(31),"^",4) S SRST=$P(^(31),"^",4) D UTL
|
---|
12 | D PRINT W:$E(IOST)="P" @IOF I $D(ZTQUEUED) K ^TMP("SR",$J) Q:$G(ZTSTOP) S ZTREQ="@" Q
|
---|
13 | I '$D(^TMP("SR",$J)) W $$NODATA^SROUTL0()
|
---|
14 | END I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue " R X:DTIME
|
---|
15 | D ^SRSKILL K SRTN D ^%ZISC W @IOF
|
---|
16 | Q
|
---|
17 | LOOP ; break procedure if greater than 65 characters
|
---|
18 | 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
|
---|
19 | Q
|
---|
20 | ZTSAVE S (ZTSAVE("SRSDATE"),ZTSAVE("SRS"),ZTSAVE("SRS(""C"")"),ZTSAVE("SRS(""N"")"),ZTSAVE("SRQ"),ZTSAVE("SRSITE*"))=""
|
---|
21 | Q
|
---|
22 | HDR ; print heading
|
---|
23 | I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRQ=1 Q
|
---|
24 | S SRZ=1 W:$Y @IOF W !,?20,"* Scheduled Operations for "_SRS("N")_" *",!,?30,SRDATE,!!,"Start Time",?13,"Patient",?43,"Operating Room",?67,"Ward Location",!,?13,"ID #",! F LINE=1:1:80 W "="
|
---|
25 | Q
|
---|
26 | UTL ; set ^TMP("SR",$J)
|
---|
27 | S DFN=$P(^SRF(SRTN,0),"^") D DEM^VADPT S SRNM=VADM(1),SRSSN=VA("PID"),SRWARD=$S($D(^DPT(DFN,.1)):$P(^(.1),"^"),1:""),SRSOP=$P(^SRF(SRTN,"OP"),"^"),SRSS=$P(^SRF(SRTN,0),"^",4) I SRWARD="" D WARD
|
---|
28 | S SROR("N")=$P(^SRS(SROR,0),"^"),SROR("N")=$P(^SC(SROR("N"),0),"^")
|
---|
29 | I SRSS S SRSS=$P(^SRO(137.45,SRSS,0),"^")
|
---|
30 | S Y=SRST D D^DIQ S SRFIND=$F(Y,":"),SRTIME=$S(SRFIND:$E(Y,SRFIND-3,SRFIND+1),1:"")
|
---|
31 | S:SRSS="" SRSS="NOT ENTERED" S SRSS=$P(SRSS,"(")
|
---|
32 | I SRSS=SRS("N") S ^TMP("SR",$J,SRS("N"),SROR("N"),SRST)=SRNM_"^"_SRSOP_"^"_SRWARD_"^"_SRTIME_"^"_SRSSN
|
---|
33 | Q
|
---|
34 | PRINT ; loop through ^TMP and print cases
|
---|
35 | S (SROR,SRST,SRZ)=0
|
---|
36 | D:SRZ PAGE Q:SRQ D HDR F S SROR=$O(^TMP("SR",$J,SRS("N"),SROR)) Q:SROR=""!SRQ F S SRST=$O(^TMP("SR",$J,SRS("N"),SROR,SRST)) Q:'SRST!SRQ D OUT
|
---|
37 | Q
|
---|
38 | OUT ; output data
|
---|
39 | I $Y+5>IOSL D PAGE Q:SRQ D HDR Q:SRQ
|
---|
40 | S SR=^TMP("SR",$J,SRS("N"),SROR,SRST),SROPER=$P(SR,"^",2) 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=""
|
---|
41 | W !,$P(SR,"^",4),?12,$P(SR,"^"),?45,SROR,?67,$P(SR,"^",3),!,?12,$P(SR,"^",5),!,?12,SROPS(1) I $D(SROPS(2)) W !,?12,SROPS(2) I $D(SROPS(3)) W !,?12,SROPS(3)
|
---|
42 | W ! F LINE=1:1:80 W "-"
|
---|
43 | Q
|
---|
44 | PAGE I $E(IOST,1)'="P" W !!,"Press RETURN to continue or '^' to quit. " R X:DTIME I '$T!(X="^") S SRQ=1
|
---|
45 | Q
|
---|
46 | WARD ; check for scheduled admission
|
---|
47 | S (X,PEND)=0 F S PEND=$O(^DGS(41.1,"B",DFN,PEND)) Q:'PEND S PDATE=$P(^DGS(41.1,PEND,0),"^",2) I PDATE>DT S SRWARD="ADM. PENDING",X=1
|
---|
48 | Q:X=1 S SRWARD="OUTPATIENT"
|
---|
49 | Q
|
---|