- 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
- 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