YTSCES ;SLC/BLD - Score for Combat Exposure Scale (CES) ; 9/26/2018
;;5.01;MENTAL HEALTH;**123,147**;DEC 30,1994;Build 283
;
;Public, Supported ICRs
; #2056 - Fileman API - $$GET1^DIQ
;
Q
;
DATA1 ;
;
S QUES1=($$GET1^DIQ(601.75,$P(YSDATA(3),"^",3)_",",4,"I")-1)*2
S QUES2=(+$$GET1^DIQ(601.75,$P(YSDATA(4),"^",3)_",",4,"I")-1)
S QUES3=+$$GET1^DIQ(601.75,$P(YSDATA(5),"^",3)_",",4,"I") D
.I QUES3>0,QUES3<5 S QUES3=(QUES3-1)*2
.I QUES3=5 S QUES3=(QUES3-2)*2
S QUES4=+$$GET1^DIQ(601.75,$P(YSDATA(6),"^",3)_",",4,"I") D
.I QUES4>0,QUES4<5 S QUES4=QUES4-1
.I QUES4=5 S QUES4=QUES4-2
S QUES5=+$$GET1^DIQ(601.75,$P(YSDATA(7),"^",3)_",",4,"I")-1
S QUES6=(+$$GET1^DIQ(601.75,$P(YSDATA(8),"^",3)_",",4,"I")-1)*2
S QUES7=(+$$GET1^DIQ(601.75,$P(YSDATA(9),"^",3)_",",4,"I")-1)*2
S TOTSCORE=QUES1+QUES2+QUES3+QUES4+QUES5+QUES6+QUES7
S STRING1=TOTSCORE
;
Q
;
STRING ;
;
I '$D(^TMP($J,"YSCOR")) D LDSCORES(.YSDATA,.YS)
S TOTSCORE=+$P(^TMP($J,"YSCOR",2),"=",2)
I TOTSCORE'<0,TOTSCORE'>8 S STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates light Combat Exposure" S N=N+1
I TOTSCORE>8,TOTSCORE<17 S STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates light - moderate Combat Exposure" S N=N+1
I TOTSCORE>16,TOTSCORE<25 S STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates moderate Combat Exposure" S N=N+1
I TOTSCORE>24,TOTSCORE<33 S STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates moderate-heavy Combat Exposure" S N=N+1
I TOTSCORE>32,TOTSCORE<42 S STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates heavy Combat Exposure" S N=N+1
Q
;
;
SCORESV ;
D DATA1
I $D(^TMP($J,"YSG",1)),^TMP($J,"YSG",1)="[ERROR]" D Q ;-->out
.K ^TMP($J,"YSCOR")
.S ^TMP($J,"YSCOR",1)="[ERROR]"
.S ^TMP($J,"YSCOR",2)=$G(YSINSNAM)_" Scale not found"
S YSSCNAM=$P($G(^TMP($J,"YSG",3)),U,4) ; Scale Name
;
K ^TMP($J,"YSCOR")
S ^TMP($J,"YSCOR",1)="[DATA]"
S YSSCALIEN=+$P(^TMP($J,"YSG",3),"=",2)
S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,YSSCALIEN_",",3,"I")_"="_STRING1
Q
;
DLLSTR(YSDATA,YS,YSTRNG) ;
; YSTRNG = 1 Score Instrument
; YSTRNG = 2 get Report Answers and Text
N DATA,DES,LEG,NODE,YSQN,YSSCALIEN,QUES5,QUES6,QUES7
N YSCDA,YSSCNAM,YSINSNAM,STRING,STRING1,QUES3,QUES4
N TOTAL,TXT,TEXT1,TEXT2,QUETOT,CES,QUES1,QUES2,TOTSCORE
;
; CES returns a scale score which is calculated and stored, no special text in report
I YSTRNG=1 D SCORESV
I YSTRNG=2 D
.D STRING
.S YSDATA(N)="7772^9999;1^"_STRING S N=N+1
Q
;
LDSCORES(YSDATA,YS) ; new call for patch 123
;input:AD = ADMINISTRATION #
;output: [DATA]
N G,N,IEN71,SCALE,YSAD,YSCODEN,YSCALE
S YSAD=$G(YS("AD"))
;
S YSDATA=$NA(^TMP($J,"YSCOR"))
S ^TMP($J,"YSCOR",1)="[DATA]",N=1
;
S YSCALE="",N=1
F S YSCALE=$O(^YTT(601.92,"AC",YSAD,YSCALE)) Q:'YSCALE D
.S G=$G(^YTT(601.92,YSCALE,0))
.S SCALE=$P(G,U,3),N=N+1
.S ^TMP($J,"YSCOR",N)=SCALE_"="_$P(G,U,4,7)
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HYTSCES 3007 printed Dec 13, 2024@02:19:31 Page 2
YTSCES ;SLC/BLD - Score for Combat Exposure Scale (CES) ; 9/26/2018
+1 ;;5.01;MENTAL HEALTH;**123,147**;DEC 30,1994;Build 283
+2 ;
+3 ;Public, Supported ICRs
+4 ; #2056 - Fileman API - $$GET1^DIQ
+5 ;
+6 QUIT
+7 ;
DATA1 ;
+1 ;
+2 SET QUES1=($$GET1^DIQ(601.75,$PIECE(YSDATA(3),"^",3)_",",4,"I")-1)*2
+3 SET QUES2=(+$$GET1^DIQ(601.75,$PIECE(YSDATA(4),"^",3)_",",4,"I")-1)
+4 SET QUES3=+$$GET1^DIQ(601.75,$PIECE(YSDATA(5),"^",3)_",",4,"I")
Begin DoDot:1
+5 IF QUES3>0
IF QUES3<5
SET QUES3=(QUES3-1)*2
+6 IF QUES3=5
SET QUES3=(QUES3-2)*2
End DoDot:1
+7 SET QUES4=+$$GET1^DIQ(601.75,$PIECE(YSDATA(6),"^",3)_",",4,"I")
Begin DoDot:1
+8 IF QUES4>0
IF QUES4<5
SET QUES4=QUES4-1
+9 IF QUES4=5
SET QUES4=QUES4-2
End DoDot:1
+10 SET QUES5=+$$GET1^DIQ(601.75,$PIECE(YSDATA(7),"^",3)_",",4,"I")-1
+11 SET QUES6=(+$$GET1^DIQ(601.75,$PIECE(YSDATA(8),"^",3)_",",4,"I")-1)*2
+12 SET QUES7=(+$$GET1^DIQ(601.75,$PIECE(YSDATA(9),"^",3)_",",4,"I")-1)*2
+13 SET TOTSCORE=QUES1+QUES2+QUES3+QUES4+QUES5+QUES6+QUES7
+14 SET STRING1=TOTSCORE
+15 ;
+16 QUIT
+17 ;
STRING ;
+1 ;
+2 IF '$DATA(^TMP($JOB,"YSCOR"))
DO LDSCORES(.YSDATA,.YS)
+3 SET TOTSCORE=+$PIECE(^TMP($JOB,"YSCOR",2),"=",2)
+4 IF TOTSCORE'<0
IF TOTSCORE'>8
SET STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates light Combat Exposure"
SET N=N+1
+5 IF TOTSCORE>8
IF TOTSCORE<17
SET STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates light - moderate Combat Exposure"
SET N=N+1
+6 IF TOTSCORE>16
IF TOTSCORE<25
SET STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates moderate Combat Exposure"
SET N=N+1
+7 IF TOTSCORE>24
IF TOTSCORE<33
SET STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates moderate-heavy Combat Exposure"
SET N=N+1
+8 IF TOTSCORE>32
IF TOTSCORE<42
SET STRING="Total Combat Exposure Score: "_TOTSCORE_" which indicates heavy Combat Exposure"
SET N=N+1
+9 QUIT
+10 ;
+11 ;
SCORESV ;
+1 DO DATA1
+2 ;-->out
IF $DATA(^TMP($JOB,"YSG",1))
IF ^TMP($JOB,"YSG",1)="[ERROR]"
Begin DoDot:1
+3 KILL ^TMP($JOB,"YSCOR")
+4 SET ^TMP($JOB,"YSCOR",1)="[ERROR]"
+5 SET ^TMP($JOB,"YSCOR",2)=$GET(YSINSNAM)_" Scale not found"
End DoDot:1
QUIT
+6 ; Scale Name
SET YSSCNAM=$PIECE($GET(^TMP($JOB,"YSG",3)),U,4)
+7 ;
+8 KILL ^TMP($JOB,"YSCOR")
+9 SET ^TMP($JOB,"YSCOR",1)="[DATA]"
+10 SET YSSCALIEN=+$PIECE(^TMP($JOB,"YSG",3),"=",2)
+11 SET ^TMP($JOB,"YSCOR",2)=$$GET1^DIQ(601.87,YSSCALIEN_",",3,"I")_"="_STRING1
+12 QUIT
+13 ;
DLLSTR(YSDATA,YS,YSTRNG) ;
+1 ; YSTRNG = 1 Score Instrument
+2 ; YSTRNG = 2 get Report Answers and Text
+3 NEW DATA,DES,LEG,NODE,YSQN,YSSCALIEN,QUES5,QUES6,QUES7
+4 NEW YSCDA,YSSCNAM,YSINSNAM,STRING,STRING1,QUES3,QUES4
+5 NEW TOTAL,TXT,TEXT1,TEXT2,QUETOT,CES,QUES1,QUES2,TOTSCORE
+6 ;
+7 ; CES returns a scale score which is calculated and stored, no special text in report
+8 IF YSTRNG=1
DO SCORESV
+9 IF YSTRNG=2
Begin DoDot:1
+10 DO STRING
+11 SET YSDATA(N)="7772^9999;1^"_STRING
SET N=N+1
End DoDot:1
+12 QUIT
+13 ;
LDSCORES(YSDATA,YS) ; new call for patch 123
+1 ;input:AD = ADMINISTRATION #
+2 ;output: [DATA]
+3 NEW G,N,IEN71,SCALE,YSAD,YSCODEN,YSCALE
+4 SET YSAD=$GET(YS("AD"))
+5 ;
+6 SET YSDATA=$NAME(^TMP($JOB,"YSCOR"))
+7 SET ^TMP($JOB,"YSCOR",1)="[DATA]"
SET N=1
+8 ;
+9 SET YSCALE=""
SET N=1
+10 FOR
SET YSCALE=$ORDER(^YTT(601.92,"AC",YSAD,YSCALE))
if 'YSCALE
QUIT
Begin DoDot:1
+11 SET G=$GET(^YTT(601.92,YSCALE,0))
+12 SET SCALE=$PIECE(G,U,3)
SET N=N+1
+13 SET ^TMP($JOB,"YSCOR",N)=SCALE_"="_$PIECE(G,U,4,7)
End DoDot:1
+14 QUIT