SRSCDW1 ;B'HAM ISC/MAM - SCHEDULED OPERATIONS BY WARD ; [ 07/27/98   2:33 PM ]
 ;;3.0; Surgery ;**50**;24 Jun 93
 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 WARD",ZTRTN="SRW^SRSCDW1",(ZTSAVE("SRSDATE"),ZTSAVE("SRSITE*"))="" D ^%ZTLOAD G END
SRW ; entry when queued
 U IO S (SROR,SRQ,SRW,SRTN)=0,Y=SRSDATE D D^DIQ S SRDATE=Y
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
 D PRINT
 I '$D(^TMP("SR",$J)) D HDR W $$NODATA^SROUTL0()
END I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue  " R X:DTIME
 W:$E(IOST)="P" @IOF I $D(ZTQUEUED) K ^TMP("SR",$J) Q:$G(ZTSTOP)  S ZTREQ="@" Q
 D ^SRSKILL K SRTN D ^%ZISC W @IOF
 Q
LOOP ; break procedure if greater than 65 characters
 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
 Q
ZTSAVE S ZTSAVE("DT")=DT,ZTSAVE("SRW")=SRS,ZTSAVE("SRW(""N"")")=SRW("N"),ZTSAVE("SRSITE*")=""
HDR ; print heading
 I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRQ=1 Q
 S SRZ=1 W:$Y @IOF W !,?20,"* Scheduled Operations for "_SRWARD_" *",!,?30,SRDATE,!!,"Start Time",?12,"Patient",?45,"Operating Room",!,?12,"ID #",?45,"Speciality",! F LINE=1:1:80 W "="
 Q
UTL ; set ^TMP("SR",$J)
 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
 S SROR("N")=$P(^SRS(SROR,0),"^"),SROR("N")=$P(^SC(SROR("N"),0),"^")
 I SRSS S SRSS=$P(^SRO(137.45,SRSS,0),"^")
 S Y=SRST D D^DIQ S SRFIND=$F(Y,":"),SRTIME=$S(SRFIND:$E(Y,SRFIND-3,SRFIND+1),1:"")
 S:SRSS="" SRSS="NOT ENTERED" S SRSS=$P(SRSS,"(")
 S ^TMP("SR",$J,SRWARD,SROR("N"),SRST)=SRNM_"^"_SRSOP_"^"_SRSS_"^"_SRTIME_"^"_SRSSN
 Q
PRINT ; loop through ^TMP and print cases
 S (SROR,SRWARD,SRST,SRZ)=0
 F  S SRWARD=$O(^TMP("SR",$J,SRWARD)) Q:SRWARD=""!SRQ  D:SRZ PAGE Q:SRQ  D HDR F  S SROR=$O(^TMP("SR",$J,SRWARD,SROR)) Q:SROR=""!SRQ  F  S SRST=$O(^TMP("SR",$J,SRWARD,SROR,SRST)) Q:'SRST!SRQ  D OUT
 Q
OUT ; output data
 I $Y+5>IOSL D PAGE Q:SRQ  D HDR Q:SRQ
 S SR=^TMP("SR",$J,SRWARD,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=""
 W !,$P(SR,"^",4),?12,$P(SR,"^"),?45,SROR,!,?12,$P(SR,"^",5),?45,$P(SR,"^",3),!,?12,SROPS(1) I $D(SROPS(2)) W !,?12,SROPS(2) I $D(SROPS(3)) W !,?12,SROPS(3)
 W ! F LINE=1:1:80 W "-"
 Q
PAGE I $E(IOST,1)'="P" W !!,"Press RETURN to continue or '^' to quit.  " R X:DTIME I '$T!(X="^") S SRQ=1
 Q
WARD ; check for scheduled admission
 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
 Q:X=1  S SRWARD="OUTPATIENT"
 Q
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSRSCDW1   3036     printed  Sep 23, 2025@20:23:32                                                                                                                                                                                                     Page 2
SRSCDW1   ;B'HAM ISC/MAM - SCHEDULED OPERATIONS BY WARD ; [ 07/27/98   2:33 PM ]
 +1       ;;3.0; Surgery ;**50**;24 Jun 93
 +2        WRITE !
           KILL IOP,%ZIS,POP,IO("Q")
           SET %ZIS("A")="Print the list on which device: "
           SET %ZIS="Q"
           DO ^%ZIS
           if POP
               GOTO END
 +3        IF $DATA(IO("Q"))
               KILL IO("Q")
               SET ZTDESC="SCHEDULED OPERATIONS BY WARD"
               SET ZTRTN="SRW^SRSCDW1"
               SET (ZTSAVE("SRSDATE"),ZTSAVE("SRSITE*"))=""
               DO ^%ZTLOAD
               GOTO END
SRW       ; entry when queued
 +1        USE IO
           SET (SROR,SRQ,SRW,SRTN)=0
           SET Y=SRSDATE
           DO D^DIQ
           SET SRDATE=Y
OR         FOR 
               SET SROR=$ORDER(^SRF("AOR",SROR))
               if 'SROR!SRQ
                   QUIT 
               IF $$ORDIV^SROUTL0(SROR,$GET(SRSITE("DIV")))
                   FOR 
                       SET SRTN=$ORDER(^SRF("AOR",SROR,SRSDATE,SRTN))
                       if 'SRTN!SRQ
                           QUIT 
                       IF $DATA(^SRF(SRTN,31))
                           IF $PIECE(^(31),"^",4)
                               SET SRST=$PIECE(^(31),"^",4)
                               DO UTL
 +1        DO PRINT
 +2        IF '$DATA(^TMP("SR",$JOB))
               DO HDR
               WRITE $$NODATA^SROUTL0()
END        IF 'SRQ
               IF $EXTRACT(IOST)'="P"
                   WRITE !!,"Press RETURN to continue  "
                   READ X:DTIME
 +1        if $EXTRACT(IOST)="P"
               WRITE @IOF
           IF $DATA(ZTQUEUED)
               KILL ^TMP("SR",$JOB)
               if $GET(ZTSTOP)
                   QUIT 
               SET ZTREQ="@"
               QUIT 
 +2        DO ^SRSKILL
           KILL SRTN
           DO ^%ZISC
           WRITE @IOF
 +3        QUIT 
LOOP      ; break procedure if greater than 65 characters
 +1        SET SROPS(M)=""
           FOR LOOP=1:1
               SET MM=$PIECE(SROPER," ")
               SET MMM=$PIECE(SROPER," ",2,200)
               if MMM=""
                   QUIT 
               if $LENGTH(SROPS(M))+$LENGTH(MM)'<65
                   QUIT 
               SET SROPS(M)=SROPS(M)_MM_" "
               SET SROPER=MMM
 +2        QUIT 
ZTSAVE     SET ZTSAVE("DT")=DT
           SET ZTSAVE("SRW")=SRS
           SET ZTSAVE("SRW(""N"")")=SRW("N")
           SET ZTSAVE("SRSITE*")=""
HDR       ; print heading
 +1        IF $DATA(ZTQUEUED)
               DO ^SROSTOP
               IF SRHALT
                   SET SRQ=1
                   QUIT 
 +2        SET SRZ=1
           if $Y
               WRITE @IOF
           WRITE !,?20,"* Scheduled Operations for "_SRWARD_" *",!,?30,SRDATE,!!,"Start Time",?12,"Patient",?45,"Operating Room",!,?12,"ID #",?45,"Speciality",!
           FOR LINE=1:1:80
               WRITE "="
 +3        QUIT 
UTL       ; set ^TMP("SR",$J)
 +1        SET DFN=$PIECE(^SRF(SRTN,0),"^")
           DO DEM^VADPT
           SET SRNM=VADM(1)
           SET SRSSN=VA("PID")
           SET SRWARD=$SELECT($DATA(^DPT(DFN,.1)):$PIECE(^(.1),"^"),1:"")
           SET SRSOP=$PIECE(^SRF(SRTN,"OP"),"^")
           SET SRSS=$PIECE(^SRF(SRTN,0),"^",4)
           IF SRWARD=""
               DO WARD
 +2        SET SROR("N")=$PIECE(^SRS(SROR,0),"^")
           SET SROR("N")=$PIECE(^SC(SROR("N"),0),"^")
 +3        IF SRSS
               SET SRSS=$PIECE(^SRO(137.45,SRSS,0),"^")
 +4        SET Y=SRST
           DO D^DIQ
           SET SRFIND=$FIND(Y,":")
           SET SRTIME=$SELECT(SRFIND:$EXTRACT(Y,SRFIND-3,SRFIND+1),1:"")
 +5        if SRSS=""
               SET SRSS="NOT ENTERED"
           SET SRSS=$PIECE(SRSS,"(")
 +6        SET ^TMP("SR",$JOB,SRWARD,SROR("N"),SRST)=SRNM_"^"_SRSOP_"^"_SRSS_"^"_SRTIME_"^"_SRSSN
 +7        QUIT 
PRINT     ; loop through ^TMP and print cases
 +1        SET (SROR,SRWARD,SRST,SRZ)=0
 +2        FOR 
               SET SRWARD=$ORDER(^TMP("SR",$JOB,SRWARD))
               if SRWARD=""!SRQ
                   QUIT 
               if SRZ
                   DO PAGE
               if SRQ
                   QUIT 
               DO HDR
               FOR 
                   SET SROR=$ORDER(^TMP("SR",$JOB,SRWARD,SROR))
                   if SROR=""!SRQ
                       QUIT 
                   FOR 
                       SET SRST=$ORDER(^TMP("SR",$JOB,SRWARD,SROR,SRST))
                       if 'SRST!SRQ
                           QUIT 
                       DO OUT
 +3        QUIT 
OUT       ; output data
 +1        IF $Y+5>IOSL
               DO PAGE
               if SRQ
                   QUIT 
               DO HDR
               if SRQ
                   QUIT 
 +2        SET SR=^TMP("SR",$JOB,SRWARD,SROR,SRST)
           SET SROPER=$PIECE(SR,"^",2)
           KILL SROPS,MM,MMM
           if $LENGTH(SROPER)<65
               SET SROPS(1)=SROPER
           IF $LENGTH(SROPER)>64
               SET SROPER=SROPER_"  "
               FOR M=1:1
                   DO LOOP
                   if MMM=""
                       QUIT 
 +3        WRITE !,$PIECE(SR,"^",4),?12,$PIECE(SR,"^"),?45,SROR,!,?12,$PIECE(SR,"^",5),?45,$PIECE(SR,"^",3),!,?12,SROPS(1)
           IF $DATA(SROPS(2))
               WRITE !,?12,SROPS(2)
               IF $DATA(SROPS(3))
                   WRITE !,?12,SROPS(3)
 +4        WRITE !
           FOR LINE=1:1:80
               WRITE "-"
 +5        QUIT 
PAGE       IF $EXTRACT(IOST,1)'="P"
               WRITE !!,"Press RETURN to continue or '^' to quit.  "
               READ X:DTIME
               IF '$TEST!(X="^")
                   SET SRQ=1
 +1        QUIT 
WARD      ; check for scheduled admission
 +1        SET (X,PEND)=0
           FOR 
               SET PEND=$ORDER(^DGS(41.1,"B",DFN,PEND))
               if 'PEND
                   QUIT 
               SET PDATE=$PIECE(^DGS(41.1,PEND,0),"^",2)
               IF PDATE>DT
                   SET SRWARD="ADM. PENDING"
                   SET X=1
 +2        if X=1
               QUIT 
           SET SRWARD="OUTPATIENT"
 +3        QUIT