YTSBAMR ;SLC/PIJ - Score BAM-Revision ; 01/08/2016
;;5.01;MENTAL HEALTH;**123,130**;DEC 30,1994;Build 62
;
;Public, Supported ICRs
; #2056 - Fileman API - $$GET1^DIQ
;
Q
;
DATA1 ; display scores for administration
N ANS,LEG,NODE,YSCDA,YSSEQ,YS
N DATA,DES,SCORE,YSANS,YSQN,CID
S SCORE=0
S YSINSNAM=$P($G(YSDATA(2)),U,3)
I $G(YSINSNAM)="" S YSINSNAM=$G(YS("CODE"),"NO NAME PASSED")
S NODE=2 F S NODE=$O(YSDATA(NODE)) Q:NODE="" D ; Start at YSDATA(3)
.S DATA=YSDATA(NODE)
.S YSQN=$P(DATA,U,1)
.S YSSEQ=$P($P(DATA,U,2),";",1) ; Sequence Number
.;if $P(YSSEQ,";",2)'"" then no Choice ID, piece 3 is data
.S YSANS=$P($P(DATA,U,2),";",2)
.S ANS=$P(DATA,U,3),ANS=$S(ANS=1155:0,ANS=1156:0,1:ANS)
.D DESGNTR^YTSCORE(YSQN,.DES)
.S YSCDA=$P($G(DATA),U,3) ; Choice ID
.I $G(YSANS) S LEG=YSCDA
.; legacy values are not correct for numerous CHOICE ID's, therefore set value from ID
.I '$G(YSANS) S CID=YSCDA D
..S LEG=$S(CID=212:0,CID=1059:0,CID=1060:1,CID=1061:2,CID=1062:3,CID=1063:4,CID=717:1,CID=685:2,CID=2312:3,CID=687:4,CID=241:"Y",1:"")
.I (DES="A")!(DES="B") Q
.D SCORE
Q
;
SCORE ;
I DES=1 D
.S HEALTH=HEALTH+LEG
.S RISK=RISK+$$SCORADJ(LEG)
I DES=2 D
.S SLEEP=LEG
.S RISK=RISK+LEG
I DES=3 D
.S DISTR=LEG
.S RISK=RISK+LEG
I DES=4 D
.S DAYSAU=LEG
.S USE=USE+LEG
I DES=5 D
.S DAYSHA=LEG
.S USE=USE+LEG
I DES=6 D
.S DAYSDRUG=LEG
.S USE=USE+LEG
I DES=8 D
.S URGE=LEG
.S RISK=RISK+$$SCORADJ(LEG)
I DES=9 D
.S CONFID=LEG
.S PROTECT=PROTECT+$$SCORADJ(LEG)
I DES=10 D
.S SELF=LEG
.S PROTECT=PROTECT+LEG
I DES=11 D
.S RISKY=LEG
.S RISK=RISK+LEG
I DES=12 D
.S SPIRIT=LEG
.S PROTECT=PROTECT+$$SCORADJ(LEG)
I DES=13 D
.S WORK=LEG
.S PROTECT=PROTECT+LEG
I DES=14 D
.I LEG="Y" S INCME=4,PROTECT=PROTECT+30
I DES=15 D
.S RELAT=LEG
.S RISK=RISK+$$SCORADJ(LEG)
I DES=16 D
.S SUPT=LEG
.S PROTECT=PROTECT+LEG
Q
;
SCORADJ(SCOR) ;
S ANS=0
I SCOR=1 S ANS=8
I SCOR=2 S ANS=15
I SCOR=3 S ANS=22
I SCOR=4 S ANS=30
Q ANS
;
SCORESV ;
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)="BAMR Scale not found"
;
K ^TMP($J,"YSCOR")
S ^TMP($J,"YSCOR",1)="[DATA]"
S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,861_",",3,"I")_"="_USE
S ^TMP($J,"YSCOR",3)=$$GET1^DIQ(601.87,863_",",3,"I")_"="_RISK
S ^TMP($J,"YSCOR",4)=$$GET1^DIQ(601.87,864_",",3,"I")_"="_PROTECT
S ^TMP($J,"YSCOR",5)=$$GET1^DIQ(601.87,865_",",3,"I")_"="_DAYSAU
S ^TMP($J,"YSCOR",6)=$$GET1^DIQ(601.87,866_",",3,"I")_"="_DAYSHA
S ^TMP($J,"YSCOR",7)=$$GET1^DIQ(601.87,867_",",3,"I")_"="_DAYSDRUG
S ^TMP($J,"YSCOR",8)=$$GET1^DIQ(601.87,868_",",3,"I")_"="_HEALTH
S ^TMP($J,"YSCOR",9)=$$GET1^DIQ(601.87,869_",",3,"I")_"="_SLEEP
S ^TMP($J,"YSCOR",10)=$$GET1^DIQ(601.87,870_",",3,"I")_"="_DISTR
S ^TMP($J,"YSCOR",11)=$$GET1^DIQ(601.87,871_",",3,"I")_"="_URGE
S ^TMP($J,"YSCOR",12)=$$GET1^DIQ(601.87,872_",",3,"I")_"="_RISKY
S ^TMP($J,"YSCOR",13)=$$GET1^DIQ(601.87,873_",",3,"I")_"="_RELAT
S ^TMP($J,"YSCOR",14)=$$GET1^DIQ(601.87,874_",",3,"I")_"="_CONFID
S ^TMP($J,"YSCOR",15)=$$GET1^DIQ(601.87,875_",",3,"I")_"="_SELF
S ^TMP($J,"YSCOR",16)=$$GET1^DIQ(601.87,876_",",3,"I")_"="_SPIRIT
S ^TMP($J,"YSCOR",17)=$$GET1^DIQ(601.87,877_",",3,"I")_"="_WORK
S ^TMP($J,"YSCOR",18)=$$GET1^DIQ(601.87,878_",",3,"I")_"="_INCME
S ^TMP($J,"YSCOR",19)=$$GET1^DIQ(601.87,879_",",3,"I")_"="_SUPT
;
Q
DLLSTR(YSDATA,YS,YSTRNG) ;
; YSTRNG = 1 Score Instrument
; YSTRNG = 2 get Report Answers and Text
N YSINSNAM
N USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP
N DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT
;
S (USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP)=0
S (DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT)=0
;
I YSTRNG=2 Q ; No special text, computations in the report.
;
D DATA1
D SCORESV
Q
;
VERIFY(ARGS,RESULTS) ; Add inconsistency messages based on set of answers in ARGS
N MSGCNT S MSGCNT=0
I $$LT("q6501","q6502") D MSG("more","4","5")
I $$LT("q6503","q6504") D MSG("less","7A","6")
I $$LT("q6503","q6505") D MSG("less","7B","6")
I $$LT("q6503","q6506") D MSG("less","7C","6")
I $$LT("q6503","q6507") D MSG("less","7D","6")
I $$LT("q6503","q6508") D MSG("less","7E","6")
I $$LT("q6503","q6509") D MSG("less","7F","6")
I $$LT("q6503","q6510") D MSG("less","7G","6")
S RESULTS("count")=MSGCNT
Q
LT(ID1,ID2) ; returns 1 if ID1 is less than ID2
; expects ARGS from VERIFY
N VAL1,VAL2
S VAL1=$G(ARGS(ID1)) S:VAL1="c1156" VAL1=0 ; 1156 = skipped by rule
S VAL2=$G(ARGS(ID2)) S:VAL2="c1156" VAL2=0
I +VAL1<+VAL2 Q 1
Q 0
;
MSG(REL,Q1,Q2) ; Add text of message to RESULTS
; expects MSGCNT, RESULTS from VERIFY
N X
S X="There is an inconsistency: The number of days entered in Question "_Q1
S X=X_" should be equal to, or "_REL_" than,"
S X=X_" the number of days in Question "_Q2_"."
S MSGCNT=MSGCNT+1,RESULTS("messages",MSGCNT)=X
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HYTSBAMR 5071 printed Dec 13, 2024@02:19:17 Page 2
YTSBAMR ;SLC/PIJ - Score BAM-Revision ; 01/08/2016
+1 ;;5.01;MENTAL HEALTH;**123,130**;DEC 30,1994;Build 62
+2 ;
+3 ;Public, Supported ICRs
+4 ; #2056 - Fileman API - $$GET1^DIQ
+5 ;
+6 QUIT
+7 ;
DATA1 ; display scores for administration
+1 NEW ANS,LEG,NODE,YSCDA,YSSEQ,YS
+2 NEW DATA,DES,SCORE,YSANS,YSQN,CID
+3 SET SCORE=0
+4 SET YSINSNAM=$PIECE($GET(YSDATA(2)),U,3)
+5 IF $GET(YSINSNAM)=""
SET YSINSNAM=$GET(YS("CODE"),"NO NAME PASSED")
+6 ; Start at YSDATA(3)
SET NODE=2
FOR
SET NODE=$ORDER(YSDATA(NODE))
if NODE=""
QUIT
Begin DoDot:1
+7 SET DATA=YSDATA(NODE)
+8 SET YSQN=$PIECE(DATA,U,1)
+9 ; Sequence Number
SET YSSEQ=$PIECE($PIECE(DATA,U,2),";",1)
+10 ;if $P(YSSEQ,";",2)'"" then no Choice ID, piece 3 is data
+11 SET YSANS=$PIECE($PIECE(DATA,U,2),";",2)
+12 SET ANS=$PIECE(DATA,U,3)
SET ANS=$SELECT(ANS=1155:0,ANS=1156:0,1:ANS)
+13 DO DESGNTR^YTSCORE(YSQN,.DES)
+14 ; Choice ID
SET YSCDA=$PIECE($GET(DATA),U,3)
+15 IF $GET(YSANS)
SET LEG=YSCDA
+16 ; legacy values are not correct for numerous CHOICE ID's, therefore set value from ID
+17 IF '$GET(YSANS)
SET CID=YSCDA
Begin DoDot:2
+18 SET LEG=$SELECT(CID=212:0,CID=1059:0,CID=1060:1,CID=1061:2,CID=1062:3,CID=1063:4,CID=717:1,CID=685:2,CID=2312:3,CID=687:4,CID=241:"Y",1:"")
End DoDot:2
+19 IF (DES="A")!(DES="B")
QUIT
+20 DO SCORE
End DoDot:1
+21 QUIT
+22 ;
SCORE ;
+1 IF DES=1
Begin DoDot:1
+2 SET HEALTH=HEALTH+LEG
+3 SET RISK=RISK+$$SCORADJ(LEG)
End DoDot:1
+4 IF DES=2
Begin DoDot:1
+5 SET SLEEP=LEG
+6 SET RISK=RISK+LEG
End DoDot:1
+7 IF DES=3
Begin DoDot:1
+8 SET DISTR=LEG
+9 SET RISK=RISK+LEG
End DoDot:1
+10 IF DES=4
Begin DoDot:1
+11 SET DAYSAU=LEG
+12 SET USE=USE+LEG
End DoDot:1
+13 IF DES=5
Begin DoDot:1
+14 SET DAYSHA=LEG
+15 SET USE=USE+LEG
End DoDot:1
+16 IF DES=6
Begin DoDot:1
+17 SET DAYSDRUG=LEG
+18 SET USE=USE+LEG
End DoDot:1
+19 IF DES=8
Begin DoDot:1
+20 SET URGE=LEG
+21 SET RISK=RISK+$$SCORADJ(LEG)
End DoDot:1
+22 IF DES=9
Begin DoDot:1
+23 SET CONFID=LEG
+24 SET PROTECT=PROTECT+$$SCORADJ(LEG)
End DoDot:1
+25 IF DES=10
Begin DoDot:1
+26 SET SELF=LEG
+27 SET PROTECT=PROTECT+LEG
End DoDot:1
+28 IF DES=11
Begin DoDot:1
+29 SET RISKY=LEG
+30 SET RISK=RISK+LEG
End DoDot:1
+31 IF DES=12
Begin DoDot:1
+32 SET SPIRIT=LEG
+33 SET PROTECT=PROTECT+$$SCORADJ(LEG)
End DoDot:1
+34 IF DES=13
Begin DoDot:1
+35 SET WORK=LEG
+36 SET PROTECT=PROTECT+LEG
End DoDot:1
+37 IF DES=14
Begin DoDot:1
+38 IF LEG="Y"
SET INCME=4
SET PROTECT=PROTECT+30
End DoDot:1
+39 IF DES=15
Begin DoDot:1
+40 SET RELAT=LEG
+41 SET RISK=RISK+$$SCORADJ(LEG)
End DoDot:1
+42 IF DES=16
Begin DoDot:1
+43 SET SUPT=LEG
+44 SET PROTECT=PROTECT+LEG
End DoDot:1
+45 QUIT
+46 ;
SCORADJ(SCOR) ;
+1 SET ANS=0
+2 IF SCOR=1
SET ANS=8
+3 IF SCOR=2
SET ANS=15
+4 IF SCOR=3
SET ANS=22
+5 IF SCOR=4
SET ANS=30
+6 QUIT ANS
+7 ;
SCORESV ;
+1 ;-->out
IF $DATA(^TMP($JOB,"YSG",1))
IF ^TMP($JOB,"YSG",1)="[ERROR]"
Begin DoDot:1
+2 KILL ^TMP($JOB,"YSCOR")
+3 SET ^TMP($JOB,"YSCOR",1)="[ERROR]"
+4 SET ^TMP($JOB,"YSCOR",2)="BAMR Scale not found"
End DoDot:1
QUIT
+5 ;
+6 KILL ^TMP($JOB,"YSCOR")
+7 SET ^TMP($JOB,"YSCOR",1)="[DATA]"
+8 SET ^TMP($JOB,"YSCOR",2)=$$GET1^DIQ(601.87,861_",",3,"I")_"="_USE
+9 SET ^TMP($JOB,"YSCOR",3)=$$GET1^DIQ(601.87,863_",",3,"I")_"="_RISK
+10 SET ^TMP($JOB,"YSCOR",4)=$$GET1^DIQ(601.87,864_",",3,"I")_"="_PROTECT
+11 SET ^TMP($JOB,"YSCOR",5)=$$GET1^DIQ(601.87,865_",",3,"I")_"="_DAYSAU
+12 SET ^TMP($JOB,"YSCOR",6)=$$GET1^DIQ(601.87,866_",",3,"I")_"="_DAYSHA
+13 SET ^TMP($JOB,"YSCOR",7)=$$GET1^DIQ(601.87,867_",",3,"I")_"="_DAYSDRUG
+14 SET ^TMP($JOB,"YSCOR",8)=$$GET1^DIQ(601.87,868_",",3,"I")_"="_HEALTH
+15 SET ^TMP($JOB,"YSCOR",9)=$$GET1^DIQ(601.87,869_",",3,"I")_"="_SLEEP
+16 SET ^TMP($JOB,"YSCOR",10)=$$GET1^DIQ(601.87,870_",",3,"I")_"="_DISTR
+17 SET ^TMP($JOB,"YSCOR",11)=$$GET1^DIQ(601.87,871_",",3,"I")_"="_URGE
+18 SET ^TMP($JOB,"YSCOR",12)=$$GET1^DIQ(601.87,872_",",3,"I")_"="_RISKY
+19 SET ^TMP($JOB,"YSCOR",13)=$$GET1^DIQ(601.87,873_",",3,"I")_"="_RELAT
+20 SET ^TMP($JOB,"YSCOR",14)=$$GET1^DIQ(601.87,874_",",3,"I")_"="_CONFID
+21 SET ^TMP($JOB,"YSCOR",15)=$$GET1^DIQ(601.87,875_",",3,"I")_"="_SELF
+22 SET ^TMP($JOB,"YSCOR",16)=$$GET1^DIQ(601.87,876_",",3,"I")_"="_SPIRIT
+23 SET ^TMP($JOB,"YSCOR",17)=$$GET1^DIQ(601.87,877_",",3,"I")_"="_WORK
+24 SET ^TMP($JOB,"YSCOR",18)=$$GET1^DIQ(601.87,878_",",3,"I")_"="_INCME
+25 SET ^TMP($JOB,"YSCOR",19)=$$GET1^DIQ(601.87,879_",",3,"I")_"="_SUPT
+26 ;
+27 QUIT
DLLSTR(YSDATA,YS,YSTRNG) ;
+1 ; YSTRNG = 1 Score Instrument
+2 ; YSTRNG = 2 get Report Answers and Text
+3 NEW YSINSNAM
+4 NEW USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP
+5 NEW DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT
+6 ;
+7 SET (USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP)=0
+8 SET (DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT)=0
+9 ;
+10 ; No special text, computations in the report.
IF YSTRNG=2
QUIT
+11 ;
+12 DO DATA1
+13 DO SCORESV
+14 QUIT
+15 ;
VERIFY(ARGS,RESULTS) ; Add inconsistency messages based on set of answers in ARGS
+1 NEW MSGCNT
SET MSGCNT=0
+2 IF $$LT("q6501","q6502")
DO MSG("more","4","5")
+3 IF $$LT("q6503","q6504")
DO MSG("less","7A","6")
+4 IF $$LT("q6503","q6505")
DO MSG("less","7B","6")
+5 IF $$LT("q6503","q6506")
DO MSG("less","7C","6")
+6 IF $$LT("q6503","q6507")
DO MSG("less","7D","6")
+7 IF $$LT("q6503","q6508")
DO MSG("less","7E","6")
+8 IF $$LT("q6503","q6509")
DO MSG("less","7F","6")
+9 IF $$LT("q6503","q6510")
DO MSG("less","7G","6")
+10 SET RESULTS("count")=MSGCNT
+11 QUIT
LT(ID1,ID2) ; returns 1 if ID1 is less than ID2
+1 ; expects ARGS from VERIFY
+2 NEW VAL1,VAL2
+3 ; 1156 = skipped by rule
SET VAL1=$GET(ARGS(ID1))
if VAL1="c1156"
SET VAL1=0
+4 SET VAL2=$GET(ARGS(ID2))
if VAL2="c1156"
SET VAL2=0
+5 IF +VAL1<+VAL2
QUIT 1
+6 QUIT 0
+7 ;
MSG(REL,Q1,Q2) ; Add text of message to RESULTS
+1 ; expects MSGCNT, RESULTS from VERIFY
+2 NEW X
+3 SET X="There is an inconsistency: The number of days entered in Question "_Q1
+4 SET X=X_" should be equal to, or "_REL_" than,"
+5 SET X=X_" the number of days in Question "_Q2_"."
+6 SET MSGCNT=MSGCNT+1
SET RESULTS("messages",MSGCNT)=X
+7 QUIT