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

YTSPHQ2.m

Go to the documentation of this file.
  1. YTSPHQ2 ;SLC/PIJ - Score PHQ-2 ; 01/08/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 SKIP=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=""!(SKIP) D ; Start at YSDATA(3)
  1. .S DATA=YSDATA(NODE)
  1. .S YSQN=$P(DATA,U,1)
  1. .S YSCDA=$P($G(DATA),U,3)
  1. .D DESGNTR^YTSCORE(YSQN,.DES)
  1. .I (YSCDA=1155)!(YSCDA=1156)!(YSCDA=1157)!(YSCDA="NOT ASKED") S TOTAL="",SKIP=1 Q
  1. .S LEG=$$GET1^DIQ(601.75,YSCDA_",",4,"I")
  1. .S TOTAL=TOTAL+LEG-1
  1. Q
  1. ;
  1. STRING ;
  1. N RES
  1. I '$D(^TMP($J,"YSCOR")) D Q
  1. .S STRING="| "_YSINSNAM_" score could not be determined. "
  1. S TOTAL=$P($G(^TMP($J,"YSCOR",2)),"=",2)
  1. ; If TOTAL = "", there are skipped questions and instrument is not valid
  1. I TOTAL="" D Q
  1. .S STRING="| Due to missing Items, this administration cannot be scored. |"
  1. S RES=$S(TOTAL<=2:"negative",1:"positive")
  1. S STRING="| The score on this administration is "_TOTAL_", which indicates a "
  1. S STRING=STRING_RES_" screen on the Depression Scale over the past two weeks."
  1. Q
  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)=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,492_",",3,"I")_"="_TOTAL
  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,YSCDA,TOTAL
  1. N YSINSNAM,STRING,SKIP
  1. ;
  1. S STRING=""
  1. S TOTAL=""
  1. D DATA1
  1. I YSTRNG=1 D SCORESV
  1. ;
  1. I YSTRNG=2 D
  1. .D LDSCORES^YTSCORE(.YSDATA,.YS)
  1. .D STRING
  1. .S YSDATA($O(YSDATA(""),-1)+1)=999999999999_U_U_STRING
  1. Q