SROANEW ;BIR/MAM - CREATE NEW RISK ASSESSMENT ;01/18/07
;;3.0;Surgery;**34,47,71,100,135,160,182**;24 Jun 93;Build 49
W @IOF,!,?1,VADM(1)_" "_VA("PID")
W !! S (SRDT,CNT)=0 F I=0:0 S SRDT=$O(^SRF("ADT",DFN,SRDT)) Q:'SRDT!(SRSOUT) S SRASS=0 F I=0:0 S SRASS=$O(^SRF("ADT",DFN,SRDT,SRASS)) Q:'SRASS!($D(SRTN))!(SRSOUT) D LIST I $D(SRTN) G ASK
I 'CNT W "No operations exist for this patient. Assessment cannot be entered.",!!,"Press RETURN to continue... " R X:DTIME G END
OPT 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
S SRTN=+SRCASE(X)
ASK I SRATYPE="N" D EXCL^SROASS
I $P($G(^SRF(SRTN,"RA")),"^",6)="N"!($P($G(^SRF(SRTN,"RA")),"^",7)'="") W !!,"This case is currently flagged as meeting Risk Assessment exclusion criteria.",$C(7)
W !!,"Are you sure that you want to create a Risk Assessment for this surgical",!,"case ? YES// " R SRYN:DTIME I '$T!(SRYN["^") K SRTN S SRSOUT=1 Q
S SRYN=$E(SRYN) I "YyNn"'[SRYN W !!,"Enter 'YES' to create an assessment for this surgical case, or 'NO' to quit",!,"this option." G ASK
I "Yy"'[SRYN K SRTN S SRSOUT=1 Q
I $$LOCK^SROUTL(SRTN) D D UNLOCK^SROUTL(SRTN) Q
.I $P($G(^SRF(SRTN,"RA")),"^",6)="N"!($P($G(^SRF(SRTN,"RA")),"^",7)'="") D DRDEL^SRONASS
.K DIE,DR,DA S DA=SRTN,DIE=130,DR="284////"_SRATYPE_";Q;323////Y;235////I" D ^DIE K DR,DIE,DA
.N X S X=$P($G(^SRF(SRTN,205)),"^",43) I X="" D
..S DA=SRTN,DIE=130,DR="645////N" D ^DIE K DR,DIE,DA
E K SRTN
Q
LIST ; list assessments
I $P($G(^SRF(SRASS,"NON")),"^")="Y" Q
S SRSCAN=1 I $D(^SRF(SRASS,.2)),$P(^(.2),"^",12)'="" K SRSCAN
I $D(SRSCAN),$P($G(^SRF(SRASS,30)),"^") Q
I $D(SRSCAN),$P($G(^SRF(SRASS,31)),"^",8) Q
I $D(^SRF(SRASS,37)),$P(^(37),"^") Q
I $Y+5>IOSL S SRBACK=0 D SEL Q:$D(SRTN)!(SRSOUT) I SRBACK S CNT=0,SRASS=SRCASE(1)-1,SRDT=$P(SRCASE(1),"^",2) W @IOF,!,?1,VADM(1)_" "_VA("PID"),! Q
S CNT=CNT+1,SRSDATE=$P(^SRF(SRASS,0),"^",9)
DISP S SROPER=$P(^SRF(SRASS,"OP"),"^") I $O(^SRF(SRASS,13,0)) S SROTHER=0 F I=0:0 S SROTHER=$O(^SRF(SRASS,13,SROTHER)) Q:'SROTHER D OTHER
S SR("RA")=$G(^SRF(SRASS,"RA")) I "N"'[$P(SR("RA"),"^",6) S CNT=CNT-1 Q
S SROP=SRASS D ^SROP1
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=""
I '$D(SRTN) W CNT_". "
CASE W $E(SRSDATE,4,5)_"-"_$E(SRSDATE,6,7)_"-"_$E(SRSDATE,2,3),?14,SROPS(1) I $D(SROPS(2)) W !,?14,SROPS(2) I $D(SROPS(3)) W !,?14,SROPS(3)
I $D(SROPS(4)) W !,?14,SROPS(4)
I $D(SRTN) Q
W !! S SRCASE(CNT)=SRASS_"^"_SRDT
Q
OTHER ; other operations
S SRLONG=1 I $L(SROPER)+$L($P(^SRF(SRASS,13,SROTHER,0),"^"))>235 S SRLONG=0,SROTHER=999,SROPERS=" ..."
I SRLONG S SROPERS=$P(^SRF(SRASS,13,SROTHER,0),"^")
S SROPER=SROPER_$S(SROPERS'=" ...":", "_SROPERS,1:SROPERS)
Q
LOOP ; break procedures
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
SEL ; select case
W !!!,"Select Operation, or enter <RET> to continue listing Procedures: " R X:DTIME I '$T!(X["^") S SRSOUT=1 Q
I X="" W @IOF,!,?1,VADM(1)_" "_VA("PID"),!! Q
I '$D(SRCASE(X)) W !!,"Please enter the number corresponding to the Surgical Case you want to edit.",!,"If the case desired does not appear, enter <RET> to continue listing",!,"additional cases."
I '$D(SRCASE(X)) W !!,"Press <RET> to continue " R X:DTIME S:'$T SRSOUT=1 S SRBACK=1 Q
S SRTN=+SRCASE(X)
Q
TYPE K DR,DIE S DR="284////"_SRATYPE,DIE=139,DA=SRTN D ^DIE
K DR,DA,DIE S DR="235////I",DIE=139,DA=SRTN D ^DIE K DR
END D ^SRSKILL W @IOF
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HSROANEW 3716 printed Dec 13, 2024@02:41:08 Page 2
SROANEW ;BIR/MAM - CREATE NEW RISK ASSESSMENT ;01/18/07
+1 ;;3.0;Surgery;**34,47,71,100,135,160,182**;24 Jun 93;Build 49
+2 WRITE @IOF,!,?1,VADM(1)_" "_VA("PID")
+3 WRITE !!
SET (SRDT,CNT)=0
FOR I=0:0
SET SRDT=$ORDER(^SRF("ADT",DFN,SRDT))
if 'SRDT!(SRSOUT)
QUIT
SET SRASS=0
FOR I=0:0
SET SRASS=$ORDER(^SRF("ADT",DFN,SRDT,SRASS))
if 'SRASS!($DATA(SRTN))!(SRSOUT)
QUIT
DO LIST
IF $DATA(SRTN)
GOTO ASK
+4 IF 'CNT
WRITE "No operations exist for this patient. Assessment cannot be entered.",!!,"Press RETURN to continue... "
READ X:DTIME
GOTO END
OPT 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 SET SRTN=+SRCASE(X)
ASK IF SRATYPE="N"
DO EXCL^SROASS
+1 IF $PIECE($GET(^SRF(SRTN,"RA")),"^",6)="N"!($PIECE($GET(^SRF(SRTN,"RA")),"^",7)'="")
WRITE !!,"This case is currently flagged as meeting Risk Assessment exclusion criteria.",$CHAR(7)
+2 WRITE !!,"Are you sure that you want to create a Risk Assessment for this surgical",!,"case ? YES// "
READ SRYN:DTIME
IF '$TEST!(SRYN["^")
KILL SRTN
SET SRSOUT=1
QUIT
+3 SET SRYN=$EXTRACT(SRYN)
IF "YyNn"'[SRYN
WRITE !!,"Enter 'YES' to create an assessment for this surgical case, or 'NO' to quit",!,"this option."
GOTO ASK
+4 IF "Yy"'[SRYN
KILL SRTN
SET SRSOUT=1
QUIT
+5 IF $$LOCK^SROUTL(SRTN)
Begin DoDot:1
+6 IF $PIECE($GET(^SRF(SRTN,"RA")),"^",6)="N"!($PIECE($GET(^SRF(SRTN,"RA")),"^",7)'="")
DO DRDEL^SRONASS
+7 KILL DIE,DR,DA
SET DA=SRTN
SET DIE=130
SET DR="284////"_SRATYPE_";Q;323////Y;235////I"
DO ^DIE
KILL DR,DIE,DA
+8 NEW X
SET X=$PIECE($GET(^SRF(SRTN,205)),"^",43)
IF X=""
Begin DoDot:2
+9 SET DA=SRTN
SET DIE=130
SET DR="645////N"
DO ^DIE
KILL DR,DIE,DA
End DoDot:2
End DoDot:1
DO UNLOCK^SROUTL(SRTN)
QUIT
+10 IF '$TEST
KILL SRTN
+11 QUIT
LIST ; list assessments
+1 IF $PIECE($GET(^SRF(SRASS,"NON")),"^")="Y"
QUIT
+2 SET SRSCAN=1
IF $DATA(^SRF(SRASS,.2))
IF $PIECE(^(.2),"^",12)'=""
KILL SRSCAN
+3 IF $DATA(SRSCAN)
IF $PIECE($GET(^SRF(SRASS,30)),"^")
QUIT
+4 IF $DATA(SRSCAN)
IF $PIECE($GET(^SRF(SRASS,31)),"^",8)
QUIT
+5 IF $DATA(^SRF(SRASS,37))
IF $PIECE(^(37),"^")
QUIT
+6 IF $Y+5>IOSL
SET SRBACK=0
DO SEL
if $DATA(SRTN)!(SRSOUT)
QUIT
IF SRBACK
SET CNT=0
SET SRASS=SRCASE(1)-1
SET SRDT=$PIECE(SRCASE(1),"^",2)
WRITE @IOF,!,?1,VADM(1)_" "_VA("PID"),!
QUIT
+7 SET CNT=CNT+1
SET SRSDATE=$PIECE(^SRF(SRASS,0),"^",9)
DISP SET SROPER=$PIECE(^SRF(SRASS,"OP"),"^")
IF $ORDER(^SRF(SRASS,13,0))
SET SROTHER=0
FOR I=0:0
SET SROTHER=$ORDER(^SRF(SRASS,13,SROTHER))
if 'SROTHER
QUIT
DO OTHER
+1 SET SR("RA")=$GET(^SRF(SRASS,"RA"))
IF "N"'[$PIECE(SR("RA"),"^",6)
SET CNT=CNT-1
QUIT
+2 SET SROP=SRASS
DO ^SROP1
+3 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 IF '$DATA(SRTN)
WRITE CNT_". "
CASE WRITE $EXTRACT(SRSDATE,4,5)_"-"_$EXTRACT(SRSDATE,6,7)_"-"_$EXTRACT(SRSDATE,2,3),?14,SROPS(1)
IF $DATA(SROPS(2))
WRITE !,?14,SROPS(2)
IF $DATA(SROPS(3))
WRITE !,?14,SROPS(3)
+1 IF $DATA(SROPS(4))
WRITE !,?14,SROPS(4)
+2 IF $DATA(SRTN)
QUIT
+3 WRITE !!
SET SRCASE(CNT)=SRASS_"^"_SRDT
+4 QUIT
OTHER ; other operations
+1 SET SRLONG=1
IF $LENGTH(SROPER)+$LENGTH($PIECE(^SRF(SRASS,13,SROTHER,0),"^"))>235
SET SRLONG=0
SET SROTHER=999
SET SROPERS=" ..."
+2 IF SRLONG
SET SROPERS=$PIECE(^SRF(SRASS,13,SROTHER,0),"^")
+3 SET SROPER=SROPER_$SELECT(SROPERS'=" ...":", "_SROPERS,1:SROPERS)
+4 QUIT
LOOP ; break procedures
+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
SEL ; select case
+1 WRITE !!!,"Select Operation, or enter <RET> to continue listing Procedures: "
READ X:DTIME
IF '$TEST!(X["^")
SET SRSOUT=1
QUIT
+2 IF X=""
WRITE @IOF,!,?1,VADM(1)_" "_VA("PID"),!!
QUIT
+3 IF '$DATA(SRCASE(X))
WRITE !!,"Please enter the number corresponding to the Surgical Case you want to edit.",!,"If the case desired does not appear, enter <RET> to continue listing",!,"additional cases."
+4 IF '$DATA(SRCASE(X))
WRITE !!,"Press <RET> to continue "
READ X:DTIME
if '$TEST
SET SRSOUT=1
SET SRBACK=1
QUIT
+5 SET SRTN=+SRCASE(X)
+6 QUIT
TYPE KILL DR,DIE
SET DR="284////"_SRATYPE
SET DIE=139
SET DA=SRTN
DO ^DIE
+1 KILL DR,DA,DIE
SET DR="235////I"
SET DIE=139
SET DA=SRTN
DO ^DIE
KILL DR
END DO ^SRSKILL
WRITE @IOF
+1 QUIT