- SROPS ;B'HAM ISC/MAM - SELECT CASE ; [ 07/8/03 12:10 PM ]
- ;;3.0; Surgery ;**18,44,51,64,121**;24 Jun 93
- W ! S SRSOUT=0 K DIC S DIC("A")="Select Patient: ",DIC=2,DIC(0)="QEAM" D ^DIC K DIC I Y<0 S SRSOUT=1 G END
- S DFN=+Y D DEM^VADPT
- STL D HDR I $D(DUZ("SAV")) K SRNEWOP
- ADT S (SRDT,CNT,SRBACK)=0 F S SRDT=$O(^SRF("ADT",DFN,SRDT)) Q:'SRDT!SRSOUT!$D(SRTN)!SRBACK S SROP=0 F S SROP=$O(^SRF("ADT",DFN,SRDT,SROP)) Q:'SROP!$D(SRTN)!SRSOUT!SRBACK D LIST
- G:SRBACK ADT G:'$D(SRNEWOP)&SRSOUT END D:SRSOUT HDR I $D(SRTN) G FUTURE
- I '$D(SRNEWOP),'$D(SRCASE(1)) W !!,"There are no cases entered for "_VADM(1)_".",!!,"Press RETURN to continue " R X:DTIME G END
- I $D(SRNEWOP) S CNT=CNT+1,SRCASE(CNT)="" W !,CNT,". ENTER NEW SURGICAL CASE"
- OPT S SRSOUT=0 W !!!,"Select Operation: " R X:DTIME I '$T!("^"[X) S SRSOUT=1 G END
- I '$D(SRCASE(X)) W !!,"Enter the number of the desired operation" W $S('$D(SRNEWOP):".",1:", or '"_CNT_"' to enter a new case.") G OPT
- I $D(SRNEWOP),(X=CNT) D NEW^SROPER Q
- S SRTN=+SRCASE(X)
- FUTURE ; is this a future case? if so, OK to proceed?
- Q:$D(PRCP("I")) ; quit if called from Inventory
- S SROP=SRTN,SRSDATE=$P(^SRF(SRTN,0),"^",9) I $E(SRSDATE,1,7)'>DT Q
- D HDR W !,?1 D CASE W !,$C(7) K DIR
- S DIR("A",1)=">>> The case you have selected has a future date.",DIR("A")=" Are you sure you have selected the correct case ? ",DIR("B")="NO",DIR(0)="YA" D ^DIR K DIR I $D(DTOUT)!$D(DUOUT) G END
- I 'Y K SRTN D HDR G ADT
- Q
- LIST ; list cases
- I '$D(SRNONOR),$P($G(^SRF(SROP,"NON")),"^")="Y" Q
- S SRSCAN=1 I $D(^SRF(SROP,.2)),$P(^(.2),"^",12)'="" K SRSCAN
- I $D(SRSCAN),$D(^SRF(SROP,30)),$P(^(30),"^") Q
- I $D(SRSCAN),$D(^SRF(SROP,31)),$P(^(31),"^",8) Q
- I $D(^SRF(SROP,37)),$P(^(37),"^") Q
- I $Y+5>IOSL S SRBACK=0 D SEL^SROPER Q:$D(SRTN)!(SRSOUT) D HDR Q:SRBACK
- S CNT=CNT+1,SRSDATE=$P(^SRF(SROP,0),"^",9) W !,CNT_". "
- CASE W $E(SRSDATE,4,5)_"-"_$E(SRSDATE,6,7)_"-"_$E(SRSDATE,2,3)
- S SROPER=$P(^SRF(SROP,"OP"),"^") I $O(^SRF(SROP,13,0)) S SROTHER=0 F I=0:0 S SROTHER=$O(^SRF(SROP,13,SROTHER)) Q:'SROTHER D OTHER
- D ^SROP1,LOCK 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 ?14,SROPS(1) I $D(SROPS(2)) W !,?14,SROPS(2) I $D(SROPS(3)) W !,?14,SROPS(3) W:$D(SROPS(4)) !,?14,SROPS(4)
- W ! S SRCASE(CNT)=SROP_"^"_SRDT
- Q
- LOCK ; case locked?
- I $D(SRTN),$P($G(^SRF(SRTN,"LOCK")),"^") S SROPER=SROPER_" **LOCKED**"
- Q
- OTHER ; other operations
- S SRLONG=1 I $L(SROPER)+$L($P(^SRF(SROP,13,SROTHER,0),"^"))>235 S SRLONG=0,SROTHER=999,SROPERS=" ..."
- I SRLONG S SROPERS=$P(^SRF(SROP,13,SROTHER,0),"^")
- S SROPER=SROPER_$S(SROPERS=" ...":SROPERS,1:", "_SROPERS)
- Q
- LOOP ; break procedure
- 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
- END K SRTN D ^SRSKILL W @IOF
- Q
- HDR ; print heading
- W @IOF,!,?1,VADM(1)_" "_VA("PID") S X=$P($G(VADM(6)),"^") W:X " * DIED "_$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)_" *" W !
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSROPS 3051 printed Jan 18, 2025@03:46:29 Page 2
- SROPS ;B'HAM ISC/MAM - SELECT CASE ; [ 07/8/03 12:10 PM ]
- +1 ;;3.0; Surgery ;**18,44,51,64,121**;24 Jun 93
- +2 WRITE !
- SET SRSOUT=0
- KILL DIC
- SET DIC("A")="Select Patient: "
- SET DIC=2
- SET DIC(0)="QEAM"
- DO ^DIC
- KILL DIC
- IF Y<0
- SET SRSOUT=1
- GOTO END
- +3 SET DFN=+Y
- DO DEM^VADPT
- STL DO HDR
- IF $DATA(DUZ("SAV"))
- KILL SRNEWOP
- ADT SET (SRDT,CNT,SRBACK)=0
- FOR
- SET SRDT=$ORDER(^SRF("ADT",DFN,SRDT))
- if 'SRDT!SRSOUT!$DATA(SRTN)!SRBACK
- QUIT
- SET SROP=0
- FOR
- SET SROP=$ORDER(^SRF("ADT",DFN,SRDT,SROP))
- if 'SROP!$DATA(SRTN)!SRSOUT!SRBACK
- QUIT
- DO LIST
- +1 if SRBACK
- GOTO ADT
- if '$DATA(SRNEWOP)&SRSOUT
- GOTO END
- if SRSOUT
- DO HDR
- IF $DATA(SRTN)
- GOTO FUTURE
- +2 IF '$DATA(SRNEWOP)
- IF '$DATA(SRCASE(1))
- WRITE !!,"There are no cases entered for "_VADM(1)_".",!!,"Press RETURN to continue "
- READ X:DTIME
- GOTO END
- +3 IF $DATA(SRNEWOP)
- SET CNT=CNT+1
- SET SRCASE(CNT)=""
- WRITE !,CNT,". ENTER NEW SURGICAL CASE"
- OPT SET SRSOUT=0
- WRITE !!!,"Select Operation: "
- READ X:DTIME
- IF '$TEST!("^"[X)
- SET SRSOUT=1
- GOTO END
- +1 IF '$DATA(SRCASE(X))
- WRITE !!,"Enter the number of the desired operation"
- WRITE $SELECT('$DATA(SRNEWOP):".",1:", or '"_CNT_"' to enter a new case.")
- GOTO OPT
- +2 IF $DATA(SRNEWOP)
- IF (X=CNT)
- DO NEW^SROPER
- QUIT
- +3 SET SRTN=+SRCASE(X)
- FUTURE ; is this a future case? if so, OK to proceed?
- +1 ; quit if called from Inventory
- if $DATA(PRCP("I"))
- QUIT
- +2 SET SROP=SRTN
- SET SRSDATE=$PIECE(^SRF(SRTN,0),"^",9)
- IF $EXTRACT(SRSDATE,1,7)'>DT
- QUIT
- +3 DO HDR
- WRITE !,?1
- DO CASE
- WRITE !,$CHAR(7)
- KILL DIR
- +4 SET DIR("A",1)=">>> The case you have selected has a future date."
- SET DIR("A")=" Are you sure you have selected the correct case ? "
- SET DIR("B")="NO"
- SET DIR(0)="YA"
- DO ^DIR
- KILL DIR
- IF $DATA(DTOUT)!$DATA(DUOUT)
- GOTO END
- +5 IF 'Y
- KILL SRTN
- DO HDR
- GOTO ADT
- +6 QUIT
- LIST ; list cases
- +1 IF '$DATA(SRNONOR)
- IF $PIECE($GET(^SRF(SROP,"NON")),"^")="Y"
- QUIT
- +2 SET SRSCAN=1
- IF $DATA(^SRF(SROP,.2))
- IF $PIECE(^(.2),"^",12)'=""
- KILL SRSCAN
- +3 IF $DATA(SRSCAN)
- IF $DATA(^SRF(SROP,30))
- IF $PIECE(^(30),"^")
- QUIT
- +4 IF $DATA(SRSCAN)
- IF $DATA(^SRF(SROP,31))
- IF $PIECE(^(31),"^",8)
- QUIT
- +5 IF $DATA(^SRF(SROP,37))
- IF $PIECE(^(37),"^")
- QUIT
- +6 IF $Y+5>IOSL
- SET SRBACK=0
- DO SEL^SROPER
- if $DATA(SRTN)!(SRSOUT)
- QUIT
- DO HDR
- if SRBACK
- QUIT
- +7 SET CNT=CNT+1
- SET SRSDATE=$PIECE(^SRF(SROP,0),"^",9)
- WRITE !,CNT_". "
- CASE WRITE $EXTRACT(SRSDATE,4,5)_"-"_$EXTRACT(SRSDATE,6,7)_"-"_$EXTRACT(SRSDATE,2,3)
- +1 SET SROPER=$PIECE(^SRF(SROP,"OP"),"^")
- IF $ORDER(^SRF(SROP,13,0))
- SET SROTHER=0
- FOR I=0:0
- SET SROTHER=$ORDER(^SRF(SROP,13,SROTHER))
- if 'SROTHER
- QUIT
- DO OTHER
- +2 DO ^SROP1
- DO LOCK
- 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 ?14,SROPS(1)
- IF $DATA(SROPS(2))
- WRITE !,?14,SROPS(2)
- IF $DATA(SROPS(3))
- WRITE !,?14,SROPS(3)
- if $DATA(SROPS(4))
- WRITE !,?14,SROPS(4)
- +4 WRITE !
- SET SRCASE(CNT)=SROP_"^"_SRDT
- +5 QUIT
- LOCK ; case locked?
- +1 IF $DATA(SRTN)
- IF $PIECE($GET(^SRF(SRTN,"LOCK")),"^")
- SET SROPER=SROPER_" **LOCKED**"
- +2 QUIT
- OTHER ; other operations
- +1 SET SRLONG=1
- IF $LENGTH(SROPER)+$LENGTH($PIECE(^SRF(SROP,13,SROTHER,0),"^"))>235
- SET SRLONG=0
- SET SROTHER=999
- SET SROPERS=" ..."
- +2 IF SRLONG
- SET SROPERS=$PIECE(^SRF(SROP,13,SROTHER,0),"^")
- +3 SET SROPER=SROPER_$SELECT(SROPERS=" ...":SROPERS,1:", "_SROPERS)
- +4 QUIT
- LOOP ; break procedure
- +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
- END KILL SRTN
- DO ^SRSKILL
- WRITE @IOF
- +1 QUIT
- HDR ; print heading
- +1 WRITE @IOF,!,?1,VADM(1)_" "_VA("PID")
- SET X=$PIECE($GET(VADM(6)),"^")
- if X
- WRITE " * DIED "_$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)_" *"
- WRITE !
- +2 QUIT