source: FOIAVistA/trunk/r/SURGERY-SR/SRSCD.m@ 1800

Last change on this file since 1800 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.0 KB
Line 
1SRSCD ;B'HAM ISC/MAM - SCHEDULE OF OPERATIONS (SCREEN FORMAT) ; [ 10/13/98 10:19 AM ]
2 ;;3.0; Surgery ;**77,50**;24 Jun 93
3 W @IOF,!,"List of Scheduled Operations:",!
4DT S SRQ=0,%DT="AEFX",%DT("A")="List Scheduled Operations for which date ? " D ^%DT G:Y<1 END S SRSDATE=Y
5BEG W !!,"Do you want to sort by OPERATING ROOM, SPECIALTY or WARD LOCATION ? " R Z:DTIME S:'$T Z="^" G:"^^"[Z END S Z=$E(Z)
6 I "OoSsWw"'[Z W !!,"Enter 'O' to sort the schedule by operating room, 'S' to sort by specialty",!,"or 'W' to sort by ward." G BEG
7 S Y=SRSDATE D D^DIQ S SRDATE=Y G:"Ss"[Z ^SRSCDS G:"Ww"[Z ^SRSCDW
8ROOM ; sort by operating room
9 S (SROR,SROR("N"))="" K ^TMP("SR",$J) W !!,"Do you want a list of scheduled operations for all rooms ? YES// " R Z:DTIME S:'$T Z="^" G:Z["^" END S:Z="" Z="Y"
10 S Z=$E(Z) I "NnYy"'[Z W !!,"Enter 'NO' to list the scheduled operations for a specific operating room,",!,"or RETURN to list the scheduled cases for all rooms." G ROOM
11 I "Nn"[Z W !! S DIC("S")="I $$ORDIV^SROUTL0(+Y,$G(SRSITE(""DIV""))),('$P(^SRS(+Y,0),U,6))",DIC=131.7,DIC(0)="QEAMZ" D ^DIC G:Y<0 END S SROR=+Y,SROR("N")=$P(^SC($P(Y,"^",2),0),"^")
12 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",ZTRTN="ALL^SRSCD" D ZTSAVE,^%ZTLOAD G END
13ALL ; entry when queued
14 U IO S (SRQ,SRZ)=0 G:"Nn"[Z ONE S SROR=0 F S SROR=$O(^SRF("AOR",SROR)) Q:'SROR!SRQ I $$ORDIV^SROUTL0(SROR,$G(SRSITE("DIV"))) S SROR("N")=$P(^SC($P(^SRS(SROR,0),"^"),0),"^") D OR
15 D PRINT I '$D(^TMP("SR",$J)) D HDR W $$NODATA^SROUTL0()
16 G END
17ONE ; list scheduled cases for a specific room
18 D OR,PRINT I '$D(^TMP("SR",$J)) D HDR W $$NODATA^SROUTL0()
19END W:$E(IOST)="P" @IOF I $D(ZTQUEUED) K ^TMP("SR",$J) Q:$G(ZTSTOP) S ZTREQ="@" Q
20 I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue " R X:DTIME
21 D ^SRSKILL K SRTN D ^%ZISC W @IOF
22 Q
23LOOP ; break procedure if greater than 65 characters
24 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
25 Q
26HDR ; print heading
27 I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRQ=1 Q
28 S SRZ=1 W:$Y @IOF W !,?20,"* Scheduled Operations for "_SROR_" *",!,?30,SRDATE,!!,"Start Time",?13,"Patient",?43,"Surgical Specialty",?67,"Ward Location",!,?13,"ID #",! F LINE=1:1:80 W "="
29 Q
30OR S SRTN=0 F S SRTN=$O(^SRF("AOR",SROR,SRSDATE,SRTN)) Q:'SRTN!SRQ I $P($G(^SRF(SRTN,31)),"^",4),$$DIV^SROUTL0(SRTN) S SRST=$P(^SRF(SRTN,31),"^",4) D UTL
31 Q
32UTL ; set ^TMP("SR",$J)
33 I SRZ,$Y+5>IOSL D PAGE Q:SRQ D HDR Q:SRQ
34 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
35 I SRSS S SRSS=$P(^SRO(137.45,SRSS,0),"^")
36 S Y=SRST D D^DIQ S SRFIND=$F(Y,":"),SRTIME=$S(SRFIND:$E(Y,SRFIND-3,SRFIND+1),1:"")
37 S:SRSS="" SRSS="NOT ENTERED" S SRSS=$P(SRSS,"(")
38 S ^TMP("SR",$J,SROR("N"),SRST)=SRNM_"^"_SRSOP_"^"_SRWARD_"^"_SRSS_"^"_SRTIME_"^"_SRSSN
39 Q
40PRINT ; loop through ^TMP and print cases
41 S (SROR,SRST,SRZ)=0 F S SROR=$O(^TMP("SR",$J,SROR)) Q:SROR=""!SRQ D:SRZ PAGE Q:SRQ D HDR F S SRST=$O(^TMP("SR",$J,SROR,SRST)) Q:'SRST!SRQ D OUT
42 Q
43OUT ; output data
44 I $Y+5>IOSL D PAGE Q:SRQ D HDR Q:SRQ
45 S SR=^TMP("SR",$J,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=""
46 W !,$P(SR,"^",5),?12,$P(SR,"^"),?43,$P(SR,"^",4),?67,$P(SR,"^",3),!,?12,$P(SR,"^",6),!,?12,SROPS(1) I $D(SROPS(2)) W !,?12,SROPS(2) I $D(SROPS(3)) W !,?12,SROPS(3)
47 W ! F LINE=1:1:80 W "-"
48 Q
49PAGE I $E(IOST,1)'="P" W !!,"Press RETURN to continue or '^' to quit. " R X:DTIME I '$T!(X="^") S SRQ=1
50 Q
51ZTSAVE S (ZTSAVE("SRDATE"),ZTSAVE("SROR"),ZTSAVE("SROR(""N"")"),ZTSAVE("SRQ"),ZTSAVE("SRSDATE"),ZTSAVE("Z"),ZTSAVE("SRSITE*"))=""
52 Q
53WARD ; check for scheduled admission
54 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
55 Q:X=1 S SRWARD="OUTPATIENT"
56 Q
Note: See TracBrowser for help on using the repository browser.