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

YTSEAT26.m

Go to the documentation of this file.
  1. YTSEAT26 ;SLC/BLD- MHAX ANSWERS SPECIAL HANDLING FOR EAT-26
  1. ;;5.01;MENTAL HEALTH;**150,234,250**;DEC 30,1994;Build 26
  1. ;
  1. ;Public, Supported ICRs
  1. ; #2056 - Fileman API - $$GET1^DIQ
  1. ;
  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,YSQN,YSSCALIEN,TOTSCORE,QUES,BASIS,TOTSCR
  1. N YSCDA,YSSCNAM,YSINSNAM,STRING,STRING1,TOTSCORE,STRING,STRING2
  1. ;
  1. ; Basis-24 Psychosis returns a scale score which is calculated and stored, no special text in report
  1. N QSTN
  1. D BLDQSTN(.QSTN)
  1. I YSTRNG=1 D SCORESV Q
  1. I YSTRNG=2 D
  1. .D STRING
  1. .N N S N=$O(YSDATA(""),-1) ; get last node
  1. .S YSDATA(N+1)="7772^9999;1^"_STRING
  1. .S YSDATA(N+2)="7773^9999;1^"_STRING2
  1. ;
  1. Q
  1. ;
  1. STRING ;
  1. N CURWT,HT,BMI,YSALERT
  1. S CURWT=$G(QSTN(8454))
  1. S HT=($G(QSTN(8453))*12)+$G(QSTN(8459))
  1. S BMI=$S(HT>0:((CURWT*703)/HT)/HT,1:0)
  1. S STRING=$FN(BMI,"",2)
  1. ;
  1. S STRING2="NO"
  1. D YSALERT(.YSALERT)
  1. I 2345[YSALERT("A") S STRING2="YES" Q
  1. I 12345[YSALERT("B") S STRING2="YES" Q
  1. I 12345[YSALERT("C") S STRING2="YES" Q
  1. I YSALERT("D")=5 S STRING2="YES" Q
  1. I YSALERT("E")=1 S STRING2="YES" Q
  1. ;
  1. Q
  1. BLDQSTN(QSTN) ; build list of questions and response values in .QSTN
  1. ; expects YSDATA from DLLSTR
  1. N I
  1. S I=2 F S I=$O(YSDATA(I)) Q:'I S QSTN($P(YSDATA(I),U))=$P(YSDATA(I),U,3)
  1. Q
  1. ;
  1. DATA1 ;
  1. ;
  1. N I,II
  1. S TOTSCORE=0
  1. F I=8420:1:8445 S TOTSCORE=TOTSCORE+$$GET1^DIQ(601.75,$G(QSTN(I))_",",4,"I")
  1. Q
  1. ;
  1. SCORESV ;
  1. N YSSCGROUP,I
  1. D DATA1
  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. ;
  1. S ^TMP($J,"YSCOR",1)="[DATA]"
  1. S YSSCALIEN=$P($P(^TMP($J,"YSG",3),"^",1),"=",2)
  1. S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,YSSCALIEN_",",3,"I")_"="_TOTSCORE
  1. Q
  1. ;
  1. YSALERT(YSALERT) ;ARRAY FOR BEHAVIORAL ALERTS
  1. ;
  1. S YSALERT("A")=$$GET1^DIQ(601.75,+$G(QSTN(8446))_",",4,"I")
  1. S YSALERT("B")=$$GET1^DIQ(601.75,+$G(QSTN(8447))_",",4,"I")
  1. S YSALERT("C")=$$GET1^DIQ(601.75,+$G(QSTN(8448))_",",4,"I")
  1. S YSALERT("D")=$$GET1^DIQ(601.75,+$G(QSTN(8449))_",",4,"I")
  1. S YSALERT("E")=$$GET1^DIQ(601.75,+$G(QSTN(8450))_",",4,"I")
  1. ;
  1. Q