SRSRBW ;B'HAM ISC/MAM - REQUESTS BY WARD ; [ 07/27/98 2:33 PM ]
;;3.0; Surgery ;**50**;24 Jun 93
BEG W !!,"Do you want requests for all wards ? YES// " R X:DTIME S:'$T X="^" S:X="" X="Y" G:X["^" END S X=$E(X)
I "YyNn"'[X W !!,"Enter RETURN if you would like a list of requests for all wards, or 'NO' to",!,"list the requests for a specific ward.",! G BEG
I "Yy"[X G ^SRSRBW1
W ! K DIC S DIC=42,DIC("A")="List Requests for which Ward ? ",DIC(0)="QEAMZ",DIC("S")="I $$WARD^SROUTL0(+Y,$G(SRSITE(""DIV"")),DT)" D ^DIC K DIC G:Y<0 END S SRW=+Y,SRW("N")=$P(Y(0),"^")
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^SRSRBW",(ZTSAVE("DT"),ZTSAVE("SRSITE*"),ZTSAVE("SRW"),ZTSAVE("SRW(""N"")"))="" 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),$D(^DPT(DFN,.1)),$P(^(.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 D HDR S (SRSDATE,SRTN)=0 F S SRSDATE=$O(^TMP("SR",$J,SRSDATE)) Q:SRSDATE=""!SRQ F S SRTN=$O(^TMP("SR",$J,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 D SETUTL1
Q
SETUTL ; set ^TMP("SR",$J)
S SRWARD=$P(^DPT(DFN,.1),"^") Q:SRWARD'=SRW("N") D DEM^VADPT
S SRS=$P(^SRF(SRTN,0),"^",4) S:SRS="" SRS="NOT ENTERED" S:SRS SRS=$P(^SRO(137.45,SRS,0),"^"),SRS=$P(SRS,"(") S SRNM=VADM(1),SRSSN=VA("PID"),SRSOP=$P(^SRF(SRTN,"OP"),"^"),Y=SRSDATE D D^DIQ S SRDATE=Y
S ^TMP("SR",$J,SRSDATE,SRTN)=SRDATE_"^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
Q
SETUTL1 ; set ^TMP("SR",$J) with waiting list info
S DFN=+^SRO(133.8,SRSS,1,SRWL,0) Q:'$D(^DPT(DFN,.1)) I $P(^(.1),"^")'=SRW("N") Q
D DEM^VADPT S SRS=$P(^SRO(137.45,SRSS,0),"^"),SRS=$P(SRS,"("),SRWARD=$P(^DPT(DFN,.1),"^"),SRNM=VADM(1),SRSSN=VA("PID"),COUNT=COUNT+1
S SRSOP=$P(^SRO(133.8,SRSS,1,SRWL,0),"^",2)
S ^TMP("SR",$J,"WL","WL"_COUNT)="WAITING LIST^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
Q
PRINT ; print information
I $Y+6>IOSL D PAGE Q:SRQ D HDR Q:SRQ
S STBY=^TMP("SR",$J,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($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 "_SRW("N"),!!,"Date",?14,"Patient",?45,"Surgical Specialty",!,"Case Number",?14,"ID #",!,?14,"Operative Procedure",! F LINE=1:1:80 W "="
Q
PAGE ; end of screen
I $E(IOST)'="P" W !!,"Press RETURN to continue or '^' to quit. " R X:DTIME I '$T!(X="^") S SRQ=1
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSRSRBW 3670 printed Dec 13, 2024@02:47:40 Page 2
SRSRBW ;B'HAM ISC/MAM - REQUESTS BY WARD ; [ 07/27/98 2:33 PM ]
+1 ;;3.0; Surgery ;**50**;24 Jun 93
BEG WRITE !!,"Do you want requests for all wards ? YES// "
READ X:DTIME
if '$TEST
SET X="^"
if X=""
SET X="Y"
if X["^"
GOTO END
SET X=$EXTRACT(X)
+1 IF "YyNn"'[X
WRITE !!,"Enter RETURN if you would like a list of requests for all wards, or 'NO' to",!,"list the requests for a specific ward.",!
GOTO BEG
+2 IF "Yy"[X
GOTO ^SRSRBW1
+3 WRITE !
KILL DIC
SET DIC=42
SET DIC("A")="List Requests for which Ward ? "
SET DIC(0)="QEAMZ"
SET DIC("S")="I $$WARD^SROUTL0(+Y,$G(SRSITE(""DIV"")),DT)"
DO ^DIC
KILL DIC
if Y<0
GOTO END
SET SRW=+Y
SET SRW("N")=$PIECE(Y(0),"^")
+4 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
+5 IF $DATA(IO("Q"))
KILL IO("Q")
SET ZTDESC="Requests by Service"
SET ZTRTN="SER^SRSRBW"
SET (ZTSAVE("DT"),ZTSAVE("SRSITE*"),ZTSAVE("SRW"),ZTSAVE("SRW(""N"")"))=""
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)
IF $DATA(^DPT(DFN,.1))
IF $PIECE(^(.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
DO HDR
SET (SRSDATE,SRTN)=0
FOR
SET SRSDATE=$ORDER(^TMP("SR",$JOB,SRSDATE))
if SRSDATE=""!SRQ
QUIT
FOR
SET SRTN=$ORDER(^TMP("SR",$JOB,SRSDATE,SRTN))
if SRTN=""!SRQ
QUIT
DO PRINT
+2 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
DO SETUTL1
+2 QUIT
SETUTL ; set ^TMP("SR",$J)
+1 SET SRWARD=$PIECE(^DPT(DFN,.1),"^")
if SRWARD'=SRW("N")
QUIT
DO DEM^VADPT
+2 SET SRS=$PIECE(^SRF(SRTN,0),"^",4)
if SRS=""
SET SRS="NOT ENTERED"
if SRS
SET SRS=$PIECE(^SRO(137.45,SRS,0),"^")
SET SRS=$PIECE(SRS,"(")
SET SRNM=VADM(1)
SET SRSSN=VA("PID")
SET SRSOP=$PIECE(^SRF(SRTN,"OP"),"^")
SET Y=SRSDATE
DO D^DIQ
SET SRDATE=Y
+3 SET ^TMP("SR",$JOB,SRSDATE,SRTN)=SRDATE_"^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
+4 QUIT
SETUTL1 ; set ^TMP("SR",$J) with waiting list info
+1 SET DFN=+^SRO(133.8,SRSS,1,SRWL,0)
if '$DATA(^DPT(DFN,.1))
QUIT
IF $PIECE(^(.1),"^")'=SRW("N")
QUIT
+2 DO DEM^VADPT
SET SRS=$PIECE(^SRO(137.45,SRSS,0),"^")
SET SRS=$PIECE(SRS,"(")
SET SRWARD=$PIECE(^DPT(DFN,.1),"^")
SET SRNM=VADM(1)
SET SRSSN=VA("PID")
SET COUNT=COUNT+1
+3 SET SRSOP=$PIECE(^SRO(133.8,SRSS,1,SRWL,0),"^",2)
+4 SET ^TMP("SR",$JOB,"WL","WL"_COUNT)="WAITING LIST^"_SRNM_"^"_SRS_"^"_SRSOP_"^"_SRSSN
+5 QUIT
PRINT ; print information
+1 IF $Y+6>IOSL
DO PAGE
if SRQ
QUIT
DO HDR
if SRQ
QUIT
+2 SET STBY=^TMP("SR",$JOB,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($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 "_SRW("N"),!!,"Date",?14,"Patient",?45,"Surgical Specialty",!,"Case Number",?14,"ID #",!,?14,"Operative Procedure",!
FOR LINE=1:1:80
WRITE "="
+3 QUIT
PAGE ; end of screen
+1 IF $EXTRACT(IOST)'="P"
WRITE !!,"Press RETURN to continue or '^' to quit. "
READ X:DTIME
IF '$TEST!(X="^")
SET SRQ=1
+2 QUIT