- SROAT0P ;B'HAM ISC/MAM - ATTENDING SURGEON REPORT (CONT.) ; [ 05/11/04 2:33 PM ]
- ;;3.0;Surgery;**50,129,182**;24 Jun 93;Build 49
- S SRPAGE=1 D HDR Q:SRSOUT
- S SRSDATE=0 F S SRSDATE=$O(^TMP("SR",$J,SRSDATE)) Q:'SRSDATE!(SRSOUT) S SRTN=0 F S SRTN=$O(^TMP("SR",$J,SRSDATE,SRTN)) Q:'SRTN!(SRSOUT) D SET
- Q
- SET ; print case
- I $Y+7>IOSL D PAGE I SRSOUT Q
- K SRATC S SRATC="",Y=$P($G(^SRF(SRTN,.1)),"^",10) I Y S C=$P(^DD(130,.166,0),"^",2) D Y^DIQ S SRATC=Y
- I SRATC="" S SRATC="ATTENDING/RES SUP CODE NOT ENTERED"
- S:SRATC<36 SRATC(1)=SRATC I $L(SRATC)>35 D
- .N I,J,X,Y S X=SRATC F I=0:1:34 S J=35-I,Y=$E(X,J) I Y=" " S SRATC(1)=$E(X,1,J-1) S SRATC(2)=$E(X,J+1,$L(X)) Q
- S SRDT=$E(SRSDATE,4,5)_"/"_$E(SRSDATE,6,7)_"/"_$E(SRSDATE,2,3),SR(0)=^SRF(SRTN,0),DFN=$P(SR(0),"^") D DEM^VADPT
- S SRSS=$P(^SRF(SRTN,0),"^",4),SRSS=$S(SRSS:$P(^SRO(137.45,SRSS,0),"^"),1:"SPECIALTY NOT ENTERED")
- S SRDIAG=$S($D(^SRF(SRTN,34)):$P(^(34),"^"),1:"POSTOPERATIVE DIAGNOSIS NOT ENTERED")
- S SR(.1)=$S($D(^SRF(SRTN,.1)):^(.1),1:""),SRSUR=$P(SR(.1),"^",4),SRFST=$P(SR(.1),"^",5),SRTWO=$P(SR(.1),"^",6)
- I SRSUR S SRSUR=$P(^VA(200,SRSUR,0),"^") I $L(SRSUR)>17 S SRSUR=$P(SRSUR,",")_","_$E($P(SRSUR,",",2))
- I SRFST S SRFST=$P(^VA(200,SRFST,0),"^") I $L(SRFST)>17 S SRFST=$P(SRFST,",")_","_$E($P(SRFST,",",2))
- I SRTWO S SRTWO=$P(^VA(200,SRTWO,0),"^") I $L(SRTWO)>17 S SRTWO=$P(SRTWO,",")_","_$E($P(SRTWO,",",2))
- OPS S SROPER=$P(^SRF(SRTN,"OP"),"^"),OPER=0 F I=0:0 S OPER=$O(^SRF(SRTN,13,OPER)) Q:OPER="" D OTHER
- K SROP,MM,MMM S:$L(SROPER)<55 SROP(1)=SROPER I $L(SROPER)>54 S SROPER=SROPER_" " S SROPER=SROPER_" " F M=1:1 D LOOP Q:MMM=""
- W !!,SRDT,?12,VADM(1),?50,SRSS,?112,SRSUR,!,SRTN,?12,VA("PID"),?50,SRDIAG,?112,SRFST,! W:$P($G(^SRF(SRTN,30)),"^") "ABORTED" W ?12,SRATC(1),?50,SROP(1),?112,SRTWO
- I $D(SRATC(2))!$D(SROP(2)) W ! W:$D(SRATC(2)) ?13,SRATC(2) W:$D(SROP(2)) ?50,SROP(2)
- I $D(SROP(3)) W !,?50,SROP(3) I $D(SROP(4)) W !,?50,SROP(4)
- Q
- OTHER ; other operations
- S SRLONG=1 I $L(SROPER)+$L($P(^SRF(SRTN,13,OPER,0),"^"))>240 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
- LOOP ; break procedure if greater than 55 characters
- S SROP(M)="" F LOOP=1:1 S MM=$P(SROPER," "),MMM=$P(SROPER," ",2,200) Q:MMM="" Q:$L(SROP(M))+$L(MM)'<55 S SROP(M)=SROP(M)_MM_" ",SROPER=MMM
- Q
- PAGE I $E(IOST)="P" D HDR Q
- W !!,"Press RETURN to continue, or '^' to quit: " R X:DTIME I '$T!(X["^") S SRSOUT=1 Q
- I X["?" W !!,"There are more cases for the date range selected. If you want to continue",!,"listing them, enter RETURN. Enter '^' to exit from this option." G PAGE
- HDR ; print heading
- I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRSOUT=1 Q
- I $Y W @IOF
- W !,?(132-$L(SRINST)\2),SRINST,?120,"PAGE: ",SRPAGE,!,?58,"SURGICAL SERVICE",?100,"REVIEWED BY: ",!,?54,"ATTENDING SURGEON REPORT",?100,"DATE REVIEWED: "
- W !,?(132-$L(SRFRTO)\2),SRFRTO,?100,SRPRINT
- W !!,?3,"DATE",?12,"PATIENT",?50,"SURGICAL SPECIALTY",?112,"PRIMARY SURGEON",!,?2,"CASE #",?14,"ID#",?50,"PRINCIPAL DIAGNOSIS",?112,"1ST ASST",!,?12,"ATTENDING/RES SUP CODE",?50,"OPERATIVE PROCEDURE(S)",?112,"2ND ASST",! F I=1:1:132 W "="
- W !!,?(132-$L(SRATT)\2),SRATT,!,?(132-$L(SRATT)\2),SRATT1 S SRPAGE=SRPAGE+1
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSROAT0P 3294 printed Feb 19, 2025@00:08:29 Page 2
- SROAT0P ;B'HAM ISC/MAM - ATTENDING SURGEON REPORT (CONT.) ; [ 05/11/04 2:33 PM ]
- +1 ;;3.0;Surgery;**50,129,182**;24 Jun 93;Build 49
- +2 SET SRPAGE=1
- DO HDR
- if SRSOUT
- QUIT
- +3 SET SRSDATE=0
- FOR
- SET SRSDATE=$ORDER(^TMP("SR",$JOB,SRSDATE))
- if 'SRSDATE!(SRSOUT)
- QUIT
- SET SRTN=0
- FOR
- SET SRTN=$ORDER(^TMP("SR",$JOB,SRSDATE,SRTN))
- if 'SRTN!(SRSOUT)
- QUIT
- DO SET
- +4 QUIT
- SET ; print case
- +1 IF $Y+7>IOSL
- DO PAGE
- IF SRSOUT
- QUIT
- +2 KILL SRATC
- SET SRATC=""
- SET Y=$PIECE($GET(^SRF(SRTN,.1)),"^",10)
- IF Y
- SET C=$PIECE(^DD(130,.166,0),"^",2)
- DO Y^DIQ
- SET SRATC=Y
- +3 IF SRATC=""
- SET SRATC="ATTENDING/RES SUP CODE NOT ENTERED"
- +4 if SRATC<36
- SET SRATC(1)=SRATC
- IF $LENGTH(SRATC)>35
- Begin DoDot:1
- +5 NEW I,J,X,Y
- SET X=SRATC
- FOR I=0:1:34
- SET J=35-I
- SET Y=$EXTRACT(X,J)
- IF Y=" "
- SET SRATC(1)=$EXTRACT(X,1,J-1)
- SET SRATC(2)=$EXTRACT(X,J+1,$LENGTH(X))
- QUIT
- End DoDot:1
- +6 SET SRDT=$EXTRACT(SRSDATE,4,5)_"/"_$EXTRACT(SRSDATE,6,7)_"/"_$EXTRACT(SRSDATE,2,3)
- SET SR(0)=^SRF(SRTN,0)
- SET DFN=$PIECE(SR(0),"^")
- DO DEM^VADPT
- +7 SET SRSS=$PIECE(^SRF(SRTN,0),"^",4)
- SET SRSS=$SELECT(SRSS:$PIECE(^SRO(137.45,SRSS,0),"^"),1:"SPECIALTY NOT ENTERED")
- +8 SET SRDIAG=$SELECT($DATA(^SRF(SRTN,34)):$PIECE(^(34),"^"),1:"POSTOPERATIVE DIAGNOSIS NOT ENTERED")
- +9 SET SR(.1)=$SELECT($DATA(^SRF(SRTN,.1)):^(.1),1:"")
- SET SRSUR=$PIECE(SR(.1),"^",4)
- SET SRFST=$PIECE(SR(.1),"^",5)
- SET SRTWO=$PIECE(SR(.1),"^",6)
- +10 IF SRSUR
- SET SRSUR=$PIECE(^VA(200,SRSUR,0),"^")
- IF $LENGTH(SRSUR)>17
- SET SRSUR=$PIECE(SRSUR,",")_","_$EXTRACT($PIECE(SRSUR,",",2))
- +11 IF SRFST
- SET SRFST=$PIECE(^VA(200,SRFST,0),"^")
- IF $LENGTH(SRFST)>17
- SET SRFST=$PIECE(SRFST,",")_","_$EXTRACT($PIECE(SRFST,",",2))
- +12 IF SRTWO
- SET SRTWO=$PIECE(^VA(200,SRTWO,0),"^")
- IF $LENGTH(SRTWO)>17
- SET SRTWO=$PIECE(SRTWO,",")_","_$EXTRACT($PIECE(SRTWO,",",2))
- OPS SET SROPER=$PIECE(^SRF(SRTN,"OP"),"^")
- SET OPER=0
- FOR I=0:0
- SET OPER=$ORDER(^SRF(SRTN,13,OPER))
- if OPER=""
- QUIT
- DO OTHER
- +1 KILL SROP,MM,MMM
- if $LENGTH(SROPER)<55
- SET SROP(1)=SROPER
- IF $LENGTH(SROPER)>54
- SET SROPER=SROPER_" "
- SET SROPER=SROPER_" "
- FOR M=1:1
- DO LOOP
- if MMM=""
- QUIT
- +2 WRITE !!,SRDT,?12,VADM(1),?50,SRSS,?112,SRSUR,!,SRTN,?12,VA("PID"),?50,SRDIAG,?112,SRFST,!
- if $PIECE($GET(^SRF(SRTN,30)),"^")
- WRITE "ABORTED"
- WRITE ?12,SRATC(1),?50,SROP(1),?112,SRTWO
- +3 IF $DATA(SRATC(2))!$DATA(SROP(2))
- WRITE !
- if $DATA(SRATC(2))
- WRITE ?13,SRATC(2)
- if $DATA(SROP(2))
- WRITE ?50,SROP(2)
- +4 IF $DATA(SROP(3))
- WRITE !,?50,SROP(3)
- IF $DATA(SROP(4))
- WRITE !,?50,SROP(4)
- +5 QUIT
- OTHER ; other operations
- +1 SET SRLONG=1
- IF $LENGTH(SROPER)+$LENGTH($PIECE(^SRF(SRTN,13,OPER,0),"^"))>240
- 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
- LOOP ; break procedure if greater than 55 characters
- +1 SET SROP(M)=""
- FOR LOOP=1:1
- SET MM=$PIECE(SROPER," ")
- SET MMM=$PIECE(SROPER," ",2,200)
- if MMM=""
- QUIT
- if $LENGTH(SROP(M))+$LENGTH(MM)'<55
- QUIT
- SET SROP(M)=SROP(M)_MM_" "
- SET SROPER=MMM
- +2 QUIT
- PAGE IF $EXTRACT(IOST)="P"
- DO HDR
- QUIT
- +1 WRITE !!,"Press RETURN to continue, or '^' to quit: "
- READ X:DTIME
- IF '$TEST!(X["^")
- SET SRSOUT=1
- QUIT
- +2 IF X["?"
- WRITE !!,"There are more cases for the date range selected. If you want to continue",!,"listing them, enter RETURN. Enter '^' to exit from this option."
- GOTO PAGE
- HDR ; print heading
- +1 IF $DATA(ZTQUEUED)
- DO ^SROSTOP
- IF SRHALT
- SET SRSOUT=1
- QUIT
- +2 IF $Y
- WRITE @IOF
- +3 WRITE !,?(132-$LENGTH(SRINST)\2),SRINST,?120,"PAGE: ",SRPAGE,!,?58,"SURGICAL SERVICE",?100,"REVIEWED BY: ",!,?54,"ATTENDING SURGEON REPORT",?100,"DATE REVIEWED: "
- +4 WRITE !,?(132-$LENGTH(SRFRTO)\2),SRFRTO,?100,SRPRINT
- +5 WRITE !!,?3,"DATE",?12,"PATIENT",?50,"SURGICAL SPECIALTY",?112,"PRIMARY SURGEON",!,?2,"CASE #",?14,"ID#",?50,"PRINCIPAL DIAGNOSIS",?112,"1ST ASST",!,?12,"ATTENDING/RES SUP CODE",?50,"OPERATIVE PROCEDURE(S)",?112,"2ND ASST",!
- FOR I=1:1:132
- WRITE "="
- +6 WRITE !!,?(132-$LENGTH(SRATT)\2),SRATT,!,?(132-$LENGTH(SRATT)\2),SRATT1
- SET SRPAGE=SRPAGE+1
- +7 QUIT