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

YTSBAMC.m

Go to the documentation of this file.
  1. YTSBAMC ;SLC/PIJ - Score BAMC ; 01/08/2016
  1. ;;5.01;MENTAL HEALTH;**123,130**;DEC 30,1994;Build 62
  1. ;
  1. ;Public, Supported ICRs
  1. ; #2056 - Fileman API - $$GET1^DIQ
  1. ;
  1. Q
  1. ;
  1. DATA1 ; display scores for administration
  1. N ANS
  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 ANS=$P(DATA,U,3),ANS=$S(ANS=1155:0,ANS=1156:0,1:ANS)
  1. .I YSQN=6464 S ALCO=ANS
  1. .I YSQN=6465 S HALCO=ANS
  1. .I YSQN=6466 S DRUG=ANS
  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,778_",",3,"I")_"="_ALCO
  1. S ^TMP($J,"YSCOR",3)=$$GET1^DIQ(601.87,838_",",3,"I")_"="_HALCO
  1. S ^TMP($J,"YSCOR",4)=$$GET1^DIQ(601.87,839_",",3,"I")_"="_DRUG
  1. Q
  1. ;
  1. DLLSTR(YSDATA,YS,YSTRNG) ;
  1. ; YSTRNG = 1 Score Instrument
  1. ; YSTRNG = 2 get Report Answers and Text
  1. ;
  1. N ALCO,DATA,DRUG,HALCO,NODE,YSQN,YSINSNAM
  1. ;
  1. I YSTRNG=2 Q ; no special processing or text
  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 $$NV("q6464") D NVMSG("1")
  1. I $$NV("q6465") D NVMSG("2")
  1. I $$LT("q6464","q6465") D MSG("more","1","2")
  1. I $$NV("q6466") D NVMSG("3")
  1. I $$NV("q6467") D NVMSG("4A")
  1. I $$LT("q6466","q6467") D MSG("less","4A","3")
  1. I $$NV("q6468") D NVMSG("4B")
  1. I $$LT("q6466","q6468") D MSG("less","4B","3")
  1. I $$NV("q6469") D NVMSG("4C")
  1. I $$LT("q6466","q6469") D MSG("less","4C","3")
  1. I $$NV("q6470") D NVMSG("4D")
  1. I $$LT("q6466","q6470") D MSG("less","4D","3")
  1. I $$NV("q6471") D NVMSG("4E")
  1. I $$LT("q6466","q6471") D MSG("less","4E","3")
  1. I $$NV("q6472") D NVMSG("4F")
  1. I $$LT("q6466","q6472") D MSG("less","4F","3")
  1. I $$NV("q6473") D NVMSG("4G")
  1. I $$LT("q6466","q6473") D MSG("less","4G","3")
  1. D ALLSUB
  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 ; 1155=not answered, 1156=skipped by rule
  1. S VAL1=$G(ARGS(ID1)) S:(VAL1="c1156")!(VAL1="c1155") VAL1=0
  1. S VAL2=$G(ARGS(ID2)) S:(VAL2="c1156")!(VAL2="c1155") VAL2=0
  1. I +VAL1<+VAL2 Q 1
  1. Q 0
  1. ;
  1. NV(ID) ; returns 1 if ID had no value (has been skipped)
  1. ; expects ARGS from VERIFY
  1. N VAL ; 1155=not answered
  1. S VAL=$G(ARGS(ID)) I VAL="c1155" 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
  1. S X="There is an inconsistency: The number of days entered in Question "_Q1
  1. S X=X_" should be equal to, or "_REL_" than,"
  1. S X=X_" the number of days in Question "_Q2_"."
  1. S MSGCNT=MSGCNT+1,RESULTS("messages",MSGCNT)=X
  1. Q
  1. NVMSG(Q1) ; Add message for no value present
  1. ; expects MSGCNT, RESULTS from VERIFY
  1. N X
  1. S X="There is an inconsistency: The number of days entered in Question "_Q1
  1. S X=X_" should not be blank."
  1. S MSGCNT=MSGCNT+1,RESULTS("messages",MSGCNT)=X
  1. Q
  1. ALLSUB ; compare total of all substances with any substance number
  1. ; expects ARGS, RESULT from VERIFY
  1. N SUM,ID,X
  1. S SUM=0
  1. F ID="q6467","q6468","q6469","q6470","q6471","q6472","q6473" S SUM=SUM+$G(ARGS(ID))
  1. I SUM<+$G(ARGS("q6466")) D
  1. . S X="There is an inconsistency: The addition of all the itemized substances"
  1. . S X=X_" in questions 4A through 4G should be equal to, or greater than, the"
  1. . S X=X_" number of days in Question 3."
  1. . S MSGCNT=MSGCNT+1,RESULTS("messages",MSGCNT)=X
  1. Q