Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: YTSBAMRC

YTSBAMRC.m

Go to the documentation of this file.
  1. YTSBAMRC ;SLC/PIJ/KCM - Score BAM-R-CSG-SUD ; 01/08/2016
  1. ;;5.01;MENTAL HEALTH;**234**;DEC 30,1994;Build 38
  1. ;
  1. Q
  1. ;
  1. DATA1 ; display scores for administration
  1. N ANS,LEG,NODE,YSCDA,YSSEQ,YS
  1. N DATA,DES,SCORE,YSANS,YSQN,CID
  1. S SCORE=0
  1. S YSINSNAM=$P($G(YSDATA(2)),U,3)
  1. I $G(YSINSNAM)="" S YSINSNAM=$G(YS("CODE"),"NO NAME PASSED")
  1. S NODE=2 F S NODE=$O(YSDATA(NODE)) Q:NODE="" D ; Start at YSDATA(3)
  1. .S DATA=YSDATA(NODE)
  1. .S YSQN=$P(DATA,U,1)
  1. .S YSSEQ=$P($P(DATA,U,2),";",1) ; Sequence Number
  1. .;if $P(YSSEQ,";",2)'"" then no Choice ID, piece 3 is data
  1. .S YSANS=$P($P(DATA,U,2),";",2)
  1. .S ANS=$P(DATA,U,3),ANS=$S(ANS=1155:0,ANS=1156:0,1:ANS)
  1. .D DESGNTR^YTSCORE(YSQN,.DES)
  1. .S YSCDA=$P($G(DATA),U,3) ; Choice ID
  1. .I $G(YSANS) S LEG=YSCDA
  1. .; legacy values are not correct for numerous CHOICE ID's, therefore set value from ID
  1. .I '$G(YSANS) S CID=YSCDA D
  1. ..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:"")
  1. .I (DES="A")!(DES="B") Q
  1. .D SCORE
  1. Q
  1. ;
  1. SCORE ;
  1. I DES=1 D
  1. .S HEALTH=HEALTH+LEG
  1. .S RISK=RISK+$$SCORADJ(LEG)
  1. I DES=2 D
  1. .S SLEEP=LEG
  1. .S RISK=RISK+LEG
  1. I DES=3 D
  1. .S DISTR=LEG
  1. .S RISK=RISK+LEG
  1. I DES=4 D
  1. .S DAYSAU=LEG
  1. .S USE=USE+LEG
  1. I DES="5A" D
  1. .S DAYSHA=LEG
  1. .S USE=USE+LEG
  1. I DES=6 D
  1. .S DAYSDRUG=LEG
  1. .S USE=USE+LEG
  1. I DES=8 D
  1. .S URGE=LEG
  1. .S RISK=RISK+$$SCORADJ(LEG)
  1. I DES=9 D
  1. .S CONFID=LEG
  1. .S PROTECT=PROTECT+$$SCORADJ(LEG)
  1. I DES=10 D
  1. .S SELF=LEG
  1. .S PROTECT=PROTECT+LEG
  1. I DES=11 D
  1. .S RISKY=LEG
  1. .S RISK=RISK+LEG
  1. I DES=12 D
  1. .S SPIRIT=LEG
  1. .S PROTECT=PROTECT+$$SCORADJ(LEG)
  1. I DES=13 D
  1. .S WORK=LEG
  1. .S PROTECT=PROTECT+LEG
  1. I DES=14 D
  1. .I LEG="Y" S INCME=4,PROTECT=PROTECT+30
  1. I DES=15 D
  1. .S RELAT=LEG
  1. .S RISK=RISK+$$SCORADJ(LEG)
  1. I DES=16 D
  1. .S SUPT=LEG
  1. .S PROTECT=PROTECT+LEG
  1. Q
  1. ;
  1. SCORADJ(SCOR) ;
  1. S ANS=0
  1. I SCOR=1 S ANS=8
  1. I SCOR=2 S ANS=15
  1. I SCOR=3 S ANS=22
  1. I SCOR=4 S ANS=30
  1. Q ANS
  1. ;
  1. SCORESV ;
  1. I $D(^TMP($J,"YSG",1)),^TMP($J,"YSG",1)="[ERROR]" D Q ;-->out
  1. .K ^TMP($J,"YSCOR")
  1. .S ^TMP($J,"YSCOR",1)="[ERROR]"
  1. .S ^TMP($J,"YSCOR",2)="BAM-R-CSG-SUD Scale not found"
  1. ;
  1. K ^TMP($J,"YSCOR")
  1. S ^TMP($J,"YSCOR",1)="[DATA]"
  1. S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,1506_",",3,"I")_"="_USE
  1. S ^TMP($J,"YSCOR",3)=$$GET1^DIQ(601.87,1507_",",3,"I")_"="_RISK
  1. S ^TMP($J,"YSCOR",4)=$$GET1^DIQ(601.87,1508_",",3,"I")_"="_PROTECT
  1. S ^TMP($J,"YSCOR",5)=$$GET1^DIQ(601.87,1509_",",3,"I")_"="_DAYSAU
  1. S ^TMP($J,"YSCOR",6)=$$GET1^DIQ(601.87,1510_",",3,"I")_"="_DAYSHA
  1. S ^TMP($J,"YSCOR",7)=$$GET1^DIQ(601.87,1511_",",3,"I")_"="_DAYSDRUG
  1. S ^TMP($J,"YSCOR",8)=$$GET1^DIQ(601.87,1512_",",3,"I")_"="_HEALTH
  1. S ^TMP($J,"YSCOR",9)=$$GET1^DIQ(601.87,1513_",",3,"I")_"="_SLEEP
  1. S ^TMP($J,"YSCOR",10)=$$GET1^DIQ(601.87,1514_",",3,"I")_"="_DISTR
  1. S ^TMP($J,"YSCOR",11)=$$GET1^DIQ(601.87,1515_",",3,"I")_"="_URGE
  1. S ^TMP($J,"YSCOR",12)=$$GET1^DIQ(601.87,1516_",",3,"I")_"="_RISKY
  1. S ^TMP($J,"YSCOR",13)=$$GET1^DIQ(601.87,1517_",",3,"I")_"="_RELAT
  1. S ^TMP($J,"YSCOR",14)=$$GET1^DIQ(601.87,1518_",",3,"I")_"="_CONFID
  1. S ^TMP($J,"YSCOR",15)=$$GET1^DIQ(601.87,1519_",",3,"I")_"="_SELF
  1. S ^TMP($J,"YSCOR",16)=$$GET1^DIQ(601.87,1520_",",3,"I")_"="_SPIRIT
  1. S ^TMP($J,"YSCOR",17)=$$GET1^DIQ(601.87,1521_",",3,"I")_"="_WORK
  1. S ^TMP($J,"YSCOR",18)=$$GET1^DIQ(601.87,1522_",",3,"I")_"="_INCME
  1. S ^TMP($J,"YSCOR",19)=$$GET1^DIQ(601.87,1523_",",3,"I")_"="_SUPT
  1. ;
  1. Q
  1. DLLSTR(YSDATA,YS,YSTRNG) ;
  1. ; YSTRNG = 1 Score Instrument
  1. ; YSTRNG = 2 get Report Answers and Text
  1. N YSINSNAM
  1. N USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP
  1. N DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT
  1. ;
  1. S (USE,RISK,PROTECT,DAYSAU,DAYSHA,DAYSDRUG,HEALTH,SLEEP)=0
  1. S (DISTR,URGE,RISKY,RELAT,CONFID,SELF,SPIRIT,WORK,INCME,SUPT)=0
  1. ;
  1. I YSTRNG=2 Q ; No special text, computations in the report.
  1. ;
  1. D DATA1
  1. D SCORESV
  1. Q
  1. ;
  1. VERIFY(ARGS,RESULTS) ; Add inconsistency messages based on set of answers in ARGS
  1. N MSGCNT S MSGCNT=0
  1. I $$LT("q9115","q9116") D MSG("more","4","5A")
  1. I $$LT("q9117","q9118") D MSG("less","7A","6")
  1. I $$LT("q9117","q9119") D MSG("less","7B","6")
  1. I $$LT("q9117","q9120") D MSG("less","7C","6")
  1. I $$LT("q9117","q9121") D MSG("less","7D","6")
  1. I $$LT("q9117","q9122") D MSG("less","7E","6")
  1. I $$LT("q9117","q9123") D MSG("less","7F","6")
  1. I $$LT("q9117","q9124") D MSG("less","7G","6")
  1. I $$GT("q9129","q9130") D MSG("more","5C","5B")
  1. S RESULTS("count")=MSGCNT
  1. Q
  1. LT(ID1,ID2) ; returns 1 if ID1 is less than ID2
  1. ; expects ARGS from VERIFY
  1. N VAL1,VAL2
  1. S VAL1=$G(ARGS(ID1)) S:VAL1="c1156" VAL1=0 ; 1156 = skipped by rule
  1. S VAL2=$G(ARGS(ID2)) S:VAL2="c1156" VAL2=0
  1. I +VAL1<+VAL2 Q 1
  1. Q 0
  1. ;
  1. GT(ID1,ID2) ; returns 1 if ID1 is more than ID2
  1. ; expects ARGS from VERIFY
  1. N VAL1,VAL2
  1. S VAL1=$G(ARGS(ID1)) S:VAL1="c1156" VAL1=0 ; 1156 = skipped by rule
  1. S VAL2=$G(ARGS(ID2)) S:VAL2="c1156" VAL2=0
  1. I +VAL1>+VAL2 Q 1
  1. Q 0
  1. ;
  1. MSG(REL,Q1,Q2) ; Add text of message to RESULTS
  1. ; expects MSGCNT, RESULTS from VERIFY
  1. N X,NOUN
  1. S NOUN=$S(Q1="5C":"drinks",1:"days")
  1. S X="There is an inconsistency: The number of "
  1. S X=X_NOUN_" entered in Question "_Q1
  1. S X=X_" should be equal to, or "_REL_" than,"
  1. S X=X_" the number of "_NOUN_" in Question "_Q2_"."
  1. S MSGCNT=MSGCNT+1,RESULTS("messages",MSGCNT)=X
  1. Q