SROPS1 ;BIR/ADM - SELECT CASE (INCLUDING NON-OR) ;08/23/05
;;3.0; Surgery ;**100,142**;24 Jun 93
;** NOTICE: This routine is part of an implementation of a nationally
;** controlled procedure. Local modifications to this routine
;** are prohibited.
;
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 D HDR
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 Q:$D(SRTN)
I '$D(SRCASE(1)) W !!,"There are no cases entered for "_VADM(1)_".",!!,"Press RETURN to continue " R X:DTIME G END
OPT S SRSOUT=0 W !!,"Select Case: " R X:DTIME I '$T!("^"[X) S SRSOUT=1 G END
I '$D(SRCASE(X)) W !!,"Enter the number of the desired operation." G OPT
S SRTN=+SRCASE(X)
Q
END D ^SRSKILL K SRTN W @IOF
Q
LIST ; list cases
S SRNON=0 I $P($G(^SRF(SROP,"NON")),"^")="Y" S SRNON=1
I SRNON,('$P(^SRF(SROP,"NON"),"^",4)!'$P(^SRF(SROP,"NON"),"^",5)) Q
I 'SRNON,('$P($G(^SRF(SROP,.2)),"^",10)!'$P($G(^SRF(SROP,.2)),"^",12)) Q
I $D(^SRF(SROP,37)),$P(^(37),"^") Q
I $Y+5>IOSL S SRBACK=0 D SEL 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
I SRNON S SROPER=SROPER_" (NON-OR PROCEDURE)"
D:'SRNON ^SROP1 D 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
SEL ; select case
W ! K DIR S DIR("A")="Select case or enter RETURN to continue listing cases: ",DIR(0)="FOA" D ^DIR K DIR I $D(DTOUT)!$D(DUOUT) S SRSOUT=1 Q
I X="" Q
I '$D(SRCASE(X)) W ! S DIR("A",1)="Please enter the number corresponding to the case you want to edit.",DIR("A",2)="If the case desired does not appear, enter RETURN to continue listing",DIR("A",3)="additional cases."
I '$D(SRCASE(X)) S DIR("A",4)="",DIR("A")="Press RETURN to continue " D ^DIR K DIR S:$D(DTOUT)!$D(DUOUT) SRSOUT=1 S SRBACK=1 Q
S SRTN=+SRCASE(X)
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
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
SROPS1 ;BIR/ADM - SELECT CASE (INCLUDING NON-OR) ;08/23/05
+1 ;;3.0; Surgery ;**100,142**;24 Jun 93
+2 ;** NOTICE: This routine is part of an implementation of a nationally
+3 ;** controlled procedure. Local modifications to this routine
+4 ;** are prohibited.
+5 ;
+6 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
+7 SET DFN=+Y
DO DEM^VADPT
DO HDR
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(SRTN)
QUIT
+2 IF '$DATA(SRCASE(1))
WRITE !!,"There are no cases entered for "_VADM(1)_".",!!,"Press RETURN to continue "
READ X:DTIME
GOTO END
OPT SET SRSOUT=0
WRITE !!,"Select Case: "
READ X:DTIME
IF '$TEST!("^"[X)
SET SRSOUT=1
GOTO END
+1 IF '$DATA(SRCASE(X))
WRITE !!,"Enter the number of the desired operation."
GOTO OPT
+2 SET SRTN=+SRCASE(X)
+3 QUIT
END DO ^SRSKILL
KILL SRTN
WRITE @IOF
+1 QUIT
LIST ; list cases
+1 SET SRNON=0
IF $PIECE($GET(^SRF(SROP,"NON")),"^")="Y"
SET SRNON=1
+2 IF SRNON
IF ('$PIECE(^SRF(SROP,"NON"),"^",4)!'$PIECE(^SRF(SROP,"NON"),"^",5))
QUIT
+3 IF 'SRNON
IF ('$PIECE($GET(^SRF(SROP,.2)),"^",10)!'$PIECE($GET(^SRF(SROP,.2)),"^",12))
QUIT
+4 IF $DATA(^SRF(SROP,37))
IF $PIECE(^(37),"^")
QUIT
+5 IF $Y+5>IOSL
SET SRBACK=0
DO SEL
IF $DATA(SRTN)!(SRSOUT)
QUIT
DO HDR
IF SRBACK
QUIT
+6 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 IF SRNON
SET SROPER=SROPER_" (NON-OR PROCEDURE)"
+3 IF 'SRNON
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
+4 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)
+5 WRITE !
SET SRCASE(CNT)=SROP_"^"_SRDT
+6 QUIT
SEL ; select case
+1 WRITE !
KILL DIR
SET DIR("A")="Select case or enter RETURN to continue listing cases: "
SET DIR(0)="FOA"
DO ^DIR
KILL DIR
IF $DATA(DTOUT)!$DATA(DUOUT)
SET SRSOUT=1
QUIT
+2 IF X=""
QUIT
+3 IF '$DATA(SRCASE(X))
WRITE !
SET DIR("A",1)="Please enter the number corresponding to the case you want to edit."
SET DIR("A",2)="If the case desired does not appear, enter RETURN to continue listing"
SET DIR("A",3)="additional cases."
+4 IF '$DATA(SRCASE(X))
SET DIR("A",4)=""
SET DIR("A")="Press RETURN to continue "
DO ^DIR
KILL DIR
IF $DATA(DTOUT)!$DATA(DUOUT)
SET SRSOUT=1
SET SRBACK=1
QUIT
+5 SET SRTN=+SRCASE(X)
+6 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
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