- SROPRI ;B'HAM ISC/MAM - LIST OF OPERATIONS BY PRIORITY ; [ 09/22/98 11:42 AM ]
- ;;3.0; Surgery ;**38,53,50**;24 Jun 93
- U IO S (SRHDR,SRQ)=0,PAGE=1,SRINST=SRSITE("SITE") K ^TMP("SRLIST",$J),^TMP("SRSS",$J)
- N SRFRTO S Y=SRSD X ^DD("DD") S SRFRTO="FROM: "_Y_" TO: ",Y=SRED X ^DD("DD") S SRFRTO=SRFRTO_Y,Y=DT X ^DD("DD") S SRPRINT="DATE PRINTED: "_Y
- S SRD=SRSD-.0001,SRED1=SRED+.9999,SRSOUT=0 F S SRD=$O(^SRF("AC",SRD)) Q:SRD=""!(SRD>SRED1) S SRTN=0 F S SRTN=$O(^SRF("AC",SRD,SRTN)) Q:SRTN="" I $D(^SRF(SRTN,0)),$$DIV^SROUTL0(SRTN) D UTIL
- D PRIORITY^SROPRIO
- S SRP="" I SRORD F S SRP=$O(^TMP("SRLIST",$J,SRP)) Q:SRP=""!(SRQ) S SRSS="" F S SRSS=$O(^TMP("SRLIST",$J,SRP,SRSS)) Q:SRSS=""!(SRQ) D SPEC
- I SRORD,SRSP S SRSS="" F S SRSS=$O(SRSP(SRSS)) Q:SRSS=""!SRQ I '$D(^TMP("SRSS",$J,SRSS)) D NONE
- I 'SRORD F S SRP=$O(^TMP("SRLIST",$J,SRP)) Q:SRP=""!(SRQ) D HDR^SROPRIO Q:SRQ D ALL
- I 'SRSP,'$D(^TMP("SRLIST",$J)) D HDR^SROPRIO W $$NODATA^SROUTL0()
- END I 'SRQ,$E(IOST)'="P" W !!,"Press RETURN to continue or '^' to quit. " R X:DTIME
- W:$E(IOST)="P" @IOF K ^TMP("SRLIST",$J) I $D(ZTQUEUED) Q:$G(ZTSTOP) S ZTREQ="@" Q
- D ^%ZISC W @IOF D ^SRSKILL K SRTN
- Q
- UTIL ; set ^TMP("SRLIST",$J
- Q:$P($G(^SRF(SRTN,.2)),"^",12)=""
- S S(0)=^SRF(SRTN,0) S SRP=$P(S(0),"^",10) S:SRP="" SRP="ZZ" I SRPRIO'="ALL",SRP'=SRPRIO Q
- S SRSS=$P(S(0),"^",4) S:SRSS="" SRSS="ZZ" I SRSP,'$D(SRSP(SRSS)) Q
- S ^TMP("SRSS",$J,SRSS)="" I SRORD S ^TMP("SRLIST",$J,SRP,SRSS,SRD,SRTN)="" Q
- S ^TMP("SRLIST",$J,SRP,SRD,SRTN)=""
- Q
- SPEC S SRSPEC=$S(SRSS:$P(^SRO(137.45,SRSS,0),"^"),1:"NO SPECIALTY ENTERED") D HDR^SROPRIO Q:SRQ
- S (TOTAL,SRD)=0 F S SRD=$O(^TMP("SRLIST",$J,SRP,SRSS,SRD)) Q:'SRD!(SRQ) S SRTN=0 F S SRTN=$O(^TMP("SRLIST",$J,SRP,SRSS,SRD,SRTN)) Q:'SRTN!(SRQ) S TOTAL=TOTAL+1 D CASE
- Q:SRQ I $Y+5>IOSL D HDR^SROPRIO I SRQ Q
- W !!!,"TOTAL ",SRSPEC,": ",TOTAL
- Q
- NONE S SRSPEC=$P(^SRO(137.45,SRSS,0),"^") D HDR^SROPRIO Q:SRQ
- W !!,"TOTAL ",SRSPEC,": 0"
- Q
- ALL S (SRD,TOTAL)=0 F S SRD=$O(^TMP("SRLIST",$J,SRP,SRD)) Q:'SRD!(SRQ) S SRTN=0 F S SRTN=$O(^TMP("SRLIST",$J,SRP,SRD,SRTN)) Q:'SRTN!(SRQ) D CASE S TOTAL=TOTAL+1
- Q:SRQ I $Y+5>IOSL D HDR^SROPRIO I SRQ Q
- W !!!,"TOTAL ",SRCODE(SRP),": ",TOTAL
- Q
- CASE ; print individual case
- I $Y+7>IOSL D HDR^SROPRIO I SRQ Q
- S S(0)=^SRF(SRTN,0),DFN=$P(S(0),"^") D DEM^VADPT S SRNM=VADM(1),SRSSN=VA("PID"),SROD=$P(S(0),"^",9),(SRSUR,SRFST,SRTWO)=""
- I 'SRORD S SRSS=$P(S(0),"^",4),SRSS=$S(SRSS:$P(^SRO(137.45,SRSS,0),"^"),1:"NO SPECIALTY ENTERED")
- S S(.1)=$G(^SRF(SRTN,.1)) S SRSUR=$P(S(.1),"^",4),SRFST=$P(S(.1),"^",5),SRTWO=$P(S(.1),"^",6) S:SRSUR'="" SRSUR=$P(^VA(200,SRSUR,0),"^")
- S:SRFST'="" SRFST=$P(^VA(200,SRFST,0),"^") S:SRTWO'="" SRTWO=$P(^VA(200,SRTWO,0),"^")
- OPS K SROPERS S SROPER=$P(^SRF(SRTN,"OP"),"^"),OPER=0 F S OPER=$O(^SRF(SRTN,13,OPER)) Q:OPER="" D OTHER
- K SROPS,MM,MMM S:$L(SROPER)<50 SROPS(1)=SROPER I $L(SROPER)>49 S SROPER=SROPER_" " F M=1:1 D LOOP Q:MMM=""
- S SROT=0 I $D(^SRF(SRTN,.2)),$P(^(.2),"^",2)]"",$P(^(.2),"^",3)]"" S X=$P(^SRF(SRTN,.2),"^",2),X1=$P(^(.2),"^",3) D MINS^SRSUTL2 S SROT=X
- D TECH^SROPRIN
- S SRANES=$S($D(SRTECH):SRTECH,1:""),SRABORT=$S($P($G(^SRF(SRTN,30)),"^"):"*ABORTED*",1:"")
- PRINT ;
- W !!,?1,$E(SROD,4,5)_"/"_$E(SROD,6,7)_"/"_$E(SROD,2,3),?13,$E(SRNM,1,26),?38,SROPS(1)
- W ?90,$E(SRSUR,1,23),?114,$E(SRANES,1,14),!,?1,SRTN,?13,VA("PID") W:$D(SROPS(2)) ?38,SROPS(2) W ?90,$E(SRFST,1,23),?114,"OP TIME: ",SROT," MIN.",!,SRABORT
- W:'SRORD ?13,"(",$P(SRSS,"("),")" W:$D(SROPS(3)) ?38,SROPS(3) W ?90,$E(SRTWO,1,23)
- I $D(SROPS(4)) W !,?38,SROPS(4) I $D(SROPS(5)) W !,?38,SROPS(5) I $D(SROPS(6)) W !,?38,SROPS(6)
- Q
- LOOP ; break procedure if greater than 50 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)'<50 S SROPS(M)=SROPS(M)_MM_" ",SROPER=MMM
- Q
- OTHER ; other operations
- S SRLONG=1 I $L(SROPER)+$L($P(^SRF(SRTN,13,OPER,0),"^"))>250 S SRLONG=0,OPER=999,SROPERS=" ..."
- I SRLONG S SROPERS=$P(^SRF(SRTN,13,OPER,0),"^")
- S SROPER=SROPER_$S(SROPERS=" ...":SROPERS,1:", "_SROPERS)
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSROPRI 4099 printed Feb 19, 2025@00:11:41 Page 2
- SROPRI ;B'HAM ISC/MAM - LIST OF OPERATIONS BY PRIORITY ; [ 09/22/98 11:42 AM ]
- +1 ;;3.0; Surgery ;**38,53,50**;24 Jun 93
- +2 USE IO
- SET (SRHDR,SRQ)=0
- SET PAGE=1
- SET SRINST=SRSITE("SITE")
- KILL ^TMP("SRLIST",$JOB),^TMP("SRSS",$JOB)
- +3 NEW SRFRTO
- SET Y=SRSD
- XECUTE ^DD("DD")
- SET SRFRTO="FROM: "_Y_" TO: "
- SET Y=SRED
- XECUTE ^DD("DD")
- SET SRFRTO=SRFRTO_Y
- SET Y=DT
- XECUTE ^DD("DD")
- SET SRPRINT="DATE PRINTED: "_Y
- +4 SET SRD=SRSD-.0001
- SET SRED1=SRED+.9999
- SET SRSOUT=0
- FOR
- SET SRD=$ORDER(^SRF("AC",SRD))
- if SRD=""!(SRD>SRED1)
- QUIT
- SET SRTN=0
- FOR
- SET SRTN=$ORDER(^SRF("AC",SRD,SRTN))
- if SRTN=""
- QUIT
- IF $DATA(^SRF(SRTN,0))
- IF $$DIV^SROUTL0(SRTN)
- DO UTIL
- +5 DO PRIORITY^SROPRIO
- +6 SET SRP=""
- IF SRORD
- FOR
- SET SRP=$ORDER(^TMP("SRLIST",$JOB,SRP))
- if SRP=""!(SRQ)
- QUIT
- SET SRSS=""
- FOR
- SET SRSS=$ORDER(^TMP("SRLIST",$JOB,SRP,SRSS))
- if SRSS=""!(SRQ)
- QUIT
- DO SPEC
- +7 IF SRORD
- IF SRSP
- SET SRSS=""
- FOR
- SET SRSS=$ORDER(SRSP(SRSS))
- if SRSS=""!SRQ
- QUIT
- IF '$DATA(^TMP("SRSS",$JOB,SRSS))
- DO NONE
- +8 IF 'SRORD
- FOR
- SET SRP=$ORDER(^TMP("SRLIST",$JOB,SRP))
- if SRP=""!(SRQ)
- QUIT
- DO HDR^SROPRIO
- if SRQ
- QUIT
- DO ALL
- +9 IF 'SRSP
- IF '$DATA(^TMP("SRLIST",$JOB))
- DO HDR^SROPRIO
- WRITE $$NODATA^SROUTL0()
- END IF 'SRQ
- IF $EXTRACT(IOST)'="P"
- WRITE !!,"Press RETURN to continue or '^' to quit. "
- READ X:DTIME
- +1 if $EXTRACT(IOST)="P"
- WRITE @IOF
- KILL ^TMP("SRLIST",$JOB)
- IF $DATA(ZTQUEUED)
- if $GET(ZTSTOP)
- QUIT
- SET ZTREQ="@"
- QUIT
- +2 DO ^%ZISC
- WRITE @IOF
- DO ^SRSKILL
- KILL SRTN
- +3 QUIT
- UTIL ; set ^TMP("SRLIST",$J
- +1 if $PIECE($GET(^SRF(SRTN,.2)),"^",12)=""
- QUIT
- +2 SET S(0)=^SRF(SRTN,0)
- SET SRP=$PIECE(S(0),"^",10)
- if SRP=""
- SET SRP="ZZ"
- IF SRPRIO'="ALL"
- IF SRP'=SRPRIO
- QUIT
- +3 SET SRSS=$PIECE(S(0),"^",4)
- if SRSS=""
- SET SRSS="ZZ"
- IF SRSP
- IF '$DATA(SRSP(SRSS))
- QUIT
- +4 SET ^TMP("SRSS",$JOB,SRSS)=""
- IF SRORD
- SET ^TMP("SRLIST",$JOB,SRP,SRSS,SRD,SRTN)=""
- QUIT
- +5 SET ^TMP("SRLIST",$JOB,SRP,SRD,SRTN)=""
- +6 QUIT
- SPEC SET SRSPEC=$SELECT(SRSS:$PIECE(^SRO(137.45,SRSS,0),"^"),1:"NO SPECIALTY ENTERED")
- DO HDR^SROPRIO
- if SRQ
- QUIT
- +1 SET (TOTAL,SRD)=0
- FOR
- SET SRD=$ORDER(^TMP("SRLIST",$JOB,SRP,SRSS,SRD))
- if 'SRD!(SRQ)
- QUIT
- SET SRTN=0
- FOR
- SET SRTN=$ORDER(^TMP("SRLIST",$JOB,SRP,SRSS,SRD,SRTN))
- if 'SRTN!(SRQ)
- QUIT
- SET TOTAL=TOTAL+1
- DO CASE
- +2 if SRQ
- QUIT
- IF $Y+5>IOSL
- DO HDR^SROPRIO
- IF SRQ
- QUIT
- +3 WRITE !!!,"TOTAL ",SRSPEC,": ",TOTAL
- +4 QUIT
- NONE SET SRSPEC=$PIECE(^SRO(137.45,SRSS,0),"^")
- DO HDR^SROPRIO
- if SRQ
- QUIT
- +1 WRITE !!,"TOTAL ",SRSPEC,": 0"
- +2 QUIT
- ALL SET (SRD,TOTAL)=0
- FOR
- SET SRD=$ORDER(^TMP("SRLIST",$JOB,SRP,SRD))
- if 'SRD!(SRQ)
- QUIT
- SET SRTN=0
- FOR
- SET SRTN=$ORDER(^TMP("SRLIST",$JOB,SRP,SRD,SRTN))
- if 'SRTN!(SRQ)
- QUIT
- DO CASE
- SET TOTAL=TOTAL+1
- +1 if SRQ
- QUIT
- IF $Y+5>IOSL
- DO HDR^SROPRIO
- IF SRQ
- QUIT
- +2 WRITE !!!,"TOTAL ",SRCODE(SRP),": ",TOTAL
- +3 QUIT
- CASE ; print individual case
- +1 IF $Y+7>IOSL
- DO HDR^SROPRIO
- IF SRQ
- QUIT
- +2 SET S(0)=^SRF(SRTN,0)
- SET DFN=$PIECE(S(0),"^")
- DO DEM^VADPT
- SET SRNM=VADM(1)
- SET SRSSN=VA("PID")
- SET SROD=$PIECE(S(0),"^",9)
- SET (SRSUR,SRFST,SRTWO)=""
- +3 IF 'SRORD
- SET SRSS=$PIECE(S(0),"^",4)
- SET SRSS=$SELECT(SRSS:$PIECE(^SRO(137.45,SRSS,0),"^"),1:"NO SPECIALTY ENTERED")
- +4 SET S(.1)=$GET(^SRF(SRTN,.1))
- SET SRSUR=$PIECE(S(.1),"^",4)
- SET SRFST=$PIECE(S(.1),"^",5)
- SET SRTWO=$PIECE(S(.1),"^",6)
- if SRSUR'=""
- SET SRSUR=$PIECE(^VA(200,SRSUR,0),"^")
- +5 if SRFST'=""
- SET SRFST=$PIECE(^VA(200,SRFST,0),"^")
- if SRTWO'=""
- SET SRTWO=$PIECE(^VA(200,SRTWO,0),"^")
- OPS KILL SROPERS
- SET SROPER=$PIECE(^SRF(SRTN,"OP"),"^")
- SET OPER=0
- FOR
- SET OPER=$ORDER(^SRF(SRTN,13,OPER))
- if OPER=""
- QUIT
- DO OTHER
- +1 KILL SROPS,MM,MMM
- if $LENGTH(SROPER)<50
- SET SROPS(1)=SROPER
- IF $LENGTH(SROPER)>49
- SET SROPER=SROPER_" "
- FOR M=1:1
- DO LOOP
- if MMM=""
- QUIT
- +2 SET SROT=0
- IF $DATA(^SRF(SRTN,.2))
- IF $PIECE(^(.2),"^",2)]""
- IF $PIECE(^(.2),"^",3)]""
- SET X=$PIECE(^SRF(SRTN,.2),"^",2)
- SET X1=$PIECE(^(.2),"^",3)
- DO MINS^SRSUTL2
- SET SROT=X
- +3 DO TECH^SROPRIN
- +4 SET SRANES=$SELECT($DATA(SRTECH):SRTECH,1:"")
- SET SRABORT=$SELECT($PIECE($GET(^SRF(SRTN,30)),"^"):"*ABORTED*",1:"")
- PRINT ;
- +1 WRITE !!,?1,$EXTRACT(SROD,4,5)_"/"_$EXTRACT(SROD,6,7)_"/"_$EXTRACT(SROD,2,3),?13,$EXTRACT(SRNM,1,26),?38,SROPS(1)
- +2 WRITE ?90,$EXTRACT(SRSUR,1,23),?114,$EXTRACT(SRANES,1,14),!,?1,SRTN,?13,VA("PID")
- if $DATA(SROPS(2))
- WRITE ?38,SROPS(2)
- WRITE ?90,$EXTRACT(SRFST,1,23),?114,"OP TIME: ",SROT," MIN.",!,SRABORT
- +3 if 'SRORD
- WRITE ?13,"(",$PIECE(SRSS,"("),")"
- if $DATA(SROPS(3))
- WRITE ?38,SROPS(3)
- WRITE ?90,$EXTRACT(SRTWO,1,23)
- +4 IF $DATA(SROPS(4))
- WRITE !,?38,SROPS(4)
- IF $DATA(SROPS(5))
- WRITE !,?38,SROPS(5)
- IF $DATA(SROPS(6))
- WRITE !,?38,SROPS(6)
- +5 QUIT
- LOOP ; break procedure if greater than 50 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)'<50
- QUIT
- SET SROPS(M)=SROPS(M)_MM_" "
- SET SROPER=MMM
- +2 QUIT
- OTHER ; other operations
- +1 SET SRLONG=1
- IF $LENGTH(SROPER)+$LENGTH($PIECE(^SRF(SRTN,13,OPER,0),"^"))>250
- SET SRLONG=0
- SET OPER=999
- SET SROPERS=" ..."
- +2 IF SRLONG
- SET SROPERS=$PIECE(^SRF(SRTN,13,OPER,0),"^")
- +3 SET SROPER=SROPER_$SELECT(SROPERS=" ...":SROPERS,1:", "_SROPERS)
- +4 QUIT