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

YTSBAI.m

Go to the documentation of this file.
  1. YTSBAI ;SLC/PIJ - Score BAI ; 01/19/2016
  1. ;;5.01;MENTAL HEALTH;**123**;Dec 30, 1994;Build 73
  1. ;
  1. ;Public, Supported ICRs
  1. ; #2056 - Fileman API - $$GET1^DIQ
  1. ;
  1. Q
  1. ;
  1. DATA1 ;
  1. S YSINSNAM=$P(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($G(DATA),U,1)
  1. .S YSCDA=$P($G(DATA),U,3) ; Choice ID
  1. .; calculate skipped questions
  1. .I YSCDA=1155 S SKIPPED=SKIPPED+1 ; process instrument differently if > 5 questions skipped. below.
  1. .S LEG=$$GET1^DIQ(601.75,YSCDA_",",4,"I")
  1. .S SCORE=SCORE+LEG
  1. .S YSAN=$$GET1^DIQ(601.75,YSCDA_",",3,"I")
  1. .I YSAN="Skipped"!(LEG="") S YSAN="Not Answered."
  1. .D DESGNTR^YTSCORE(YSQN,.DES)
  1. .S STRING=STRING_"| "_$G(DES)_". "_$P($G(YSAN),"(",1)
  1. .I LEG'="X" S STRING=STRING_"("_LEG_$S(LEG=1:" point",1:" points")_")"
  1. I SKIPPED>5 S SCORE="CND"
  1. Q
  1. ;
  1. SCORE1 ;
  1. N RANGE,RISK
  1. I '$D(^TMP($J,"YSCOR")) D Q
  1. .S STRING1="| "_YSINSNAM_" score could not be determined. "
  1. ;
  1. S SCORE=$P($G(^TMP($J,"YSCOR",2)),"=",2)
  1. I SKIPPED>5 S SCORE=-1 D
  1. .S STRING1=STRING1_"|BAI score could not be determined."
  1. ;
  1. I SCORE>-1 D
  1. .S RISK=$S(SCORE<8:"minimal",SCORE<16:"mild",SCORE<26:"moderate",1:"severe")
  1. .S RANGE=$S(SCORE<8:"between 0 - 7",SCORE<16:"between 8 - 15",SCORE<26:"between 16 - 25",1:"above 25")
  1. .S STRING1=STRING1_"|BAI Score: "_SCORE_" indicates "_RISK_" anxiety."
  1. S STRING1=STRING1_"||The overall range is 0 to 63"
  1. ;
  1. I SCORE=-1 S STRING1=STRING1_"."
  1. ELSE S STRING1=STRING1_" with "_RISK_" anxiety "_RANGE_"."
  1. ;
  1. S STRING1=STRING1_"|| 0-7 Minimal level of anxiety"
  1. S STRING1=STRING1_"| 8-15 Mild anxiety"
  1. S STRING1=STRING1_"| 16-25 Moderate anxiety"
  1. S STRING1=STRING1_"| 26-63 Severe anxiety"
  1. S STRING1=STRING1_"|| Questions and answers"
  1. S STRING1=STRING1_"| "_STRING
  1. Q
  1. ;
  1. SCORESV ;
  1. ;
  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)=$G(YSINSNAM)_" 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,901_",",3,"I")_"="_SCORE
  1. Q
  1. ;
  1. DLLSTR(YSDATA,YS,YSTRNG) ;
  1. ; YSTRNG = 1 Score Instrument
  1. ; YSTRNG = 2 get Report Answers and Text
  1. N DATA,DES,LEG,NODE,SCORE,SKIPPED,STRING,STRING1
  1. N YSCDA,YSINSNAM,YSAN,YSQN
  1. ;
  1. S (SKIPPED,SCORE)=0
  1. S (STRING,STRING1)=""
  1. ;
  1. D DATA1
  1. I YSTRNG=1 D
  1. .D SCORESV
  1. I YSTRNG=2 D
  1. .D LDSCORES^YTSCORE(.YSDATA,.YS)
  1. .D SCORE1
  1. .S YSDATA($O(YSDATA(""),-1)+1)=999999999999_U_U_STRING1
  1. Q