SRSRBS1 ;B'HAM ISC/MAM - REQUESTS BY SERVICE (ALL) ; [ 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 Report on which Device: ",%ZIS="Q" D ^%ZIS G:POP END I $D(IO("Q")) K IO("Q") S ZTDESC="Requests by Service",ZTRTN="SER^SRSRBS1",(ZTSAVE("DT"),ZTSAVE("SRSITE*"))="" D ^%ZTLOAD G END
SER ; entry when queued
 S X="T-1" D ^%DT S SRSDATE=Y,(DFN,SRTN,SRQ)=0 K ^TMP("SR",$J)
 F  S SRSDATE=$O(^SRF("AR",SRSDATE)) Q:'SRSDATE  F  S DFN=$O(^SRF("AR",SRSDATE,DFN)) Q:'DFN  F  S SRTN=$O(^SRF("AR",SRSDATE,DFN,SRTN)) Q:'SRTN  I $$DIV^SROUTL0(SRTN) S SRS=$S($P(^SRF(SRTN,0),"^",4):$P(^(0),"^",4),1:"") D SETUTL
WLIST ; get waiting list patients
 S (COUNT,SRSS)=0
 F  S SRSS=$O(^SRO(133.8,"AWL",SRSS)) Q:'SRSS  S SRS=+^SRO(133.8,SRSS,0),SRSDATE=0 F  S SRSDATE=$O(^SRO(133.8,"AWL",SRSS,SRSDATE)) Q:'SRSDATE  D MOREWL
UTL ; loop through ^TMP("SR",$J) and print data
 U IO S (SRS,SRSDATE,SRTN,SRZ)=0
 F  S SRS=$O(^TMP("SR",$J,SRS)) Q:SRS=""!SRQ  D PAGE Q:SRQ  D HDR F  S SRSDATE=$O(^TMP("SR",$J,SRS,SRSDATE)) Q:SRSDATE=""!SRQ  F  S SRTN=$O(^TMP("SR",$J,SRS,SRSDATE,SRTN)) Q:SRTN=""!SRQ  D PRINT
 I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue  " R X:DTIME
END 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
MOREWL ; continue getting patients on waiting list
 S SRWL=0 F  S SRWL=$O(^SRO(133.8,"AWL",SRSS,SRSDATE,SRWL)) Q:'SRWL  S DFN=+^SRO(133.8,SRSS,1,SRWL,0),SRSOP=$P(^(0),"^",2) D SETUTL1
 Q
SETUTL ; set ^TMP("SR",$J)
 S SRS("N")=$S(SRS:$P(^SRO(137.45,SRS,0),"^"),1:"UNKNOWN")
 D DEM^VADPT S SRNM=VADM(1),SRSSN=VA("PID"),SRSOP=$P(^SRF(SRTN,"OP"),"^"),SRWARD=$S($D(^DPT(DFN,.1)):$P(^(.1),"^"),1:"OUTPATIENT"),Y=SRSDATE D D^DIQ S SRDATE=Y
 I SRWARD="" D WARD
 S ^TMP("SR",$J,SRS("N"),SRSDATE,SRTN)=SRDATE_"^"_SRNM_"^"_SRWARD_"^"_SRSOP_"^"_SRSSN
 Q
SETUTL1 ; set ^TMP("SR",$J) with waiting list info
 D DEM^VADPT S SRS("N")=$P(^SRO(137.45,SRS,0),"^"),SRNM=VADM(1),SRSSN=VA("PID"),SRWARD=$S($D(^DPT(DFN,.1)):$P(^(.1),"^"),1:""),COUNT=COUNT+1
 I SRWARD="" D WARD
 S ^TMP("SR",$J,SRS("N"),"WL","WL"_COUNT)="WAITING LIST^"_SRNM_"^"_SRWARD_"^"_SRSOP_"^"_SRSSN
 Q
PRINT ; print information
 I $Y+6>IOSL D PAGE Q:SRQ  D HDR Q:SRQ
 S SRZ=1,STBY=^TMP("SR",$J,SRS,SRSDATE,SRTN),SROPER=$P(STBY,"^",4) 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(STBY,"^"),?14,$P(STBY,"^",2),?45,$P(STBY,"^",3),!,SRTN,?14,$P(STBY,"^",5),!,?14,SROPS(1) I $D(SROPS(2)) W !,?14,SROPS(2) I $D(SROPS(3)) W !,?14,SROPS(3)
 W ! F LINE=1:1:80 W "-"
 Q
HDR ; print heading
 I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRQ=1 Q
 W:$Y @IOF W !,?5,"Operative Requests for "_SRS,!!,"Date",?14,"Patient",?45,"Ward Location",!,"Case Number",?14,"ID #",!,?14,"Operative Procedure",! F LINE=1:1:80 W "="
 Q
PAGE ; end of screen
 Q:'SRZ  I $E(IOST)'="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[HSRSRBS1   3431     printed  Sep 23, 2025@20:24:05                                                                                                                                                                                                     Page 2
SRSRBS1   ;B'HAM ISC/MAM - REQUESTS BY SERVICE (ALL) ; [ 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 Report on which Device: "
           SET %ZIS="Q"
           DO ^%ZIS
           if POP
               GOTO END
           IF $DATA(IO("Q"))
               KILL IO("Q")
               SET ZTDESC="Requests by Service"
               SET ZTRTN="SER^SRSRBS1"
               SET (ZTSAVE("DT"),ZTSAVE("SRSITE*"))=""
               DO ^%ZTLOAD
               GOTO END
SER       ; entry when queued
 +1        SET X="T-1"
           DO ^%DT
           SET SRSDATE=Y
           SET (DFN,SRTN,SRQ)=0
           KILL ^TMP("SR",$JOB)
 +2        FOR 
               SET SRSDATE=$ORDER(^SRF("AR",SRSDATE))
               if 'SRSDATE
                   QUIT 
               FOR 
                   SET DFN=$ORDER(^SRF("AR",SRSDATE,DFN))
                   if 'DFN
                       QUIT 
                   FOR 
                       SET SRTN=$ORDER(^SRF("AR",SRSDATE,DFN,SRTN))
                       if 'SRTN
                           QUIT 
                       IF $$DIV^SROUTL0(SRTN)
                           SET SRS=$SELECT($PIECE(^SRF(SRTN,0),"^",4):$PIECE(^(0),"^",4),1:"")
                           DO SETUTL
WLIST     ; get waiting list patients
 +1        SET (COUNT,SRSS)=0
 +2        FOR 
               SET SRSS=$ORDER(^SRO(133.8,"AWL",SRSS))
               if 'SRSS
                   QUIT 
               SET SRS=+^SRO(133.8,SRSS,0)
               SET SRSDATE=0
               FOR 
                   SET SRSDATE=$ORDER(^SRO(133.8,"AWL",SRSS,SRSDATE))
                   if 'SRSDATE
                       QUIT 
                   DO MOREWL
UTL       ; loop through ^TMP("SR",$J) and print data
 +1        USE IO
           SET (SRS,SRSDATE,SRTN,SRZ)=0
 +2        FOR 
               SET SRS=$ORDER(^TMP("SR",$JOB,SRS))
               if SRS=""!SRQ
                   QUIT 
               DO PAGE
               if SRQ
                   QUIT 
               DO HDR
               FOR 
                   SET SRSDATE=$ORDER(^TMP("SR",$JOB,SRS,SRSDATE))
                   if SRSDATE=""!SRQ
                       QUIT 
                   FOR 
                       SET SRTN=$ORDER(^TMP("SR",$JOB,SRS,SRSDATE,SRTN))
                       if SRTN=""!SRQ
                           QUIT 
                       DO PRINT
 +3        IF 'SRQ
               IF $EXTRACT(IOST)'="P"
                   WRITE !!,"Press RETURN to continue  "
                   READ X:DTIME
END        if $EXTRACT(IOST)="P"
               WRITE @IOF
           IF $DATA(ZTQUEUED)
               KILL ^TMP("SR",$JOB)
               if $GET(ZTSTOP)
                   QUIT 
               SET ZTREQ="@"
               QUIT 
 +1        DO ^SRSKILL
           KILL SRTN
           DO ^%ZISC
           WRITE @IOF
 +2        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 
MOREWL    ; continue getting patients on waiting list
 +1        SET SRWL=0
           FOR 
               SET SRWL=$ORDER(^SRO(133.8,"AWL",SRSS,SRSDATE,SRWL))
               if 'SRWL
                   QUIT 
               SET DFN=+^SRO(133.8,SRSS,1,SRWL,0)
               SET SRSOP=$PIECE(^(0),"^",2)
               DO SETUTL1
 +2        QUIT 
SETUTL    ; set ^TMP("SR",$J)
 +1        SET SRS("N")=$SELECT(SRS:$PIECE(^SRO(137.45,SRS,0),"^"),1:"UNKNOWN")
 +2        DO DEM^VADPT
           SET SRNM=VADM(1)
           SET SRSSN=VA("PID")
           SET SRSOP=$PIECE(^SRF(SRTN,"OP"),"^")
           SET SRWARD=$SELECT($DATA(^DPT(DFN,.1)):$PIECE(^(.1),"^"),1:"OUTPATIENT")
           SET Y=SRSDATE
           DO D^DIQ
           SET SRDATE=Y
 +3        IF SRWARD=""
               DO WARD
 +4        SET ^TMP("SR",$JOB,SRS("N"),SRSDATE,SRTN)=SRDATE_"^"_SRNM_"^"_SRWARD_"^"_SRSOP_"^"_SRSSN
 +5        QUIT 
SETUTL1   ; set ^TMP("SR",$J) with waiting list info
 +1        DO DEM^VADPT
           SET SRS("N")=$PIECE(^SRO(137.45,SRS,0),"^")
           SET SRNM=VADM(1)
           SET SRSSN=VA("PID")
           SET SRWARD=$SELECT($DATA(^DPT(DFN,.1)):$PIECE(^(.1),"^"),1:"")
           SET COUNT=COUNT+1
 +2        IF SRWARD=""
               DO WARD
 +3        SET ^TMP("SR",$JOB,SRS("N"),"WL","WL"_COUNT)="WAITING LIST^"_SRNM_"^"_SRWARD_"^"_SRSOP_"^"_SRSSN
 +4        QUIT 
PRINT     ; print information
 +1        IF $Y+6>IOSL
               DO PAGE
               if SRQ
                   QUIT 
               DO HDR
               if SRQ
                   QUIT 
 +2        SET SRZ=1
           SET STBY=^TMP("SR",$JOB,SRS,SRSDATE,SRTN)
           SET SROPER=$PIECE(STBY,"^",4)
           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(STBY,"^"),?14,$PIECE(STBY,"^",2),?45,$PIECE(STBY,"^",3),!,SRTN,?14,$PIECE(STBY,"^",5),!,?14,SROPS(1)
           IF $DATA(SROPS(2))
               WRITE !,?14,SROPS(2)
               IF $DATA(SROPS(3))
                   WRITE !,?14,SROPS(3)
 +4        WRITE !
           FOR LINE=1:1:80
               WRITE "-"
 +5        QUIT 
HDR       ; print heading
 +1        IF $DATA(ZTQUEUED)
               DO ^SROSTOP
               IF SRHALT
                   SET SRQ=1
                   QUIT 
 +2        if $Y
               WRITE @IOF
           WRITE !,?5,"Operative Requests for "_SRS,!!,"Date",?14,"Patient",?45,"Ward Location",!,"Case Number",?14,"ID #",!,?14,"Operative Procedure",!
           FOR LINE=1:1:80
               WRITE "="
 +3        QUIT 
PAGE      ; end of screen
 +1        if 'SRZ
               QUIT 
           IF $EXTRACT(IOST)'="P"
               WRITE !!,"Press RETURN to continue or '^' to quit.  "
               READ X:DTIME
               IF '$TEST!(X="^")
                   SET SRQ=1
 +2        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