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

YTQLIB.m

Go to the documentation of this file.
  1. YTQLIB ;ASF/ALB - MHQ LIBRARY FUNCTIONS ;Jun 26, 2024@09:53:51
  1. ;;5.01;MENTAL HEALTH;**85,252**;Dec 30, 1994;Build 3
  1. ;
  1. ;
  1. Q
  1. TSLIST(YSDATA) ;list tests and surveys
  1. N YSTESTN,YSTEST,N
  1. K YSDATA
  1. S N=1,YSDATA(N)="[DATA]"
  1. S YSTEST="" F S YSTEST=$O(^YTT(601.71,"B",YSTEST)) Q:YSTEST="" D
  1. . S YSTESTN=$O(^YTT(601.71,"B",YSTEST,0))
  1. . S N=N+1
  1. . S YSDATA(N)=YSTESTN_U_YSTEST_U_$$GET1^DIQ(601.71,YSTESTN_",",18)
  1. Q
  1. ;
  1. NEW(YSFILEN) ;Adding New Entries - return an internal number - EXTRINSIC FUNCTION
  1. ;if $D YSPROG then National and pointers less than 100,000 else pointers greater than 100,000
  1. ;
  1. ; Calling application must lock file header node (^YTT(YSFILEN,0)) before calling this function,
  1. ; and needs to file the data using the returned IEN before releasing the lock.
  1. ;
  1. N MHQ2X,YS
  1. K YSPROG
  1. S:$D(^XUSEC("YSPROG",DUZ)) YSPROG=1
  1. S YS=$P($G(^YTT(YSFILEN,0)),U,3) S:YS<1 YS=1
  1. I $D(YSPROG) S YS=$S(YS<100000:YS,1:1)
  1. I '$D(YSPROG) S YS=$S(YS>100000:YS,1:100000)
  1. F MHQ2X=YS:1 I '$D(^YTT(YSFILEN,MHQ2X)) QUIT
  1. Q MHQ2X
  1. ;
  1. ADMCK(YSDATA,YS) ;check administration
  1. N G,K,YSA,YSAD,YSCANS,YSCOMP,YSCTREF,YSDFN,YSDG,YSDS,YSIEN,YSINS,YSK,YSQN
  1. S N=1
  1. S YSDATA(1)="[ERROR]"
  1. S YSAD=$G(YS("AD"))
  1. I YSAD'?1N.N S YSDATA(2)="bad admin #" D SAY Q ;-->out
  1. I '$D(^YTT(601.84,YSAD,0)) S YSDATA(2)="bad admin ref" D SAY Q ;-->out
  1. S G=^YTT(601.84,YSAD,0)
  1. S YSDFN=$P(G,U,2) I '$D(^DPT(YSDFN,0)) S YSDATA(2)="bad pt ref" D SAY Q ;-->out
  1. S YSINS=$P(G,U,3) I '$D(^YTT(601.71,YSINS)) S YSDATA(2)="test not found" D SAY Q ;-->out
  1. S YSDG=$P(G,U,4) I YSDG'?7N.NP S YSDATA(2)="date given bad" D SAY Q ;-->out
  1. S YSDS=$P(G,U,5) I YSDG'?7N.NP S YSDATA(2)="date SAVED bad" D SAY Q ;-->out
  1. S YSCOMP=$P(G,U,9)
  1. S YSDATA(1)="[DATA]"
  1. I YSCOMP'="Y" S YSDATA(2)="incomplete" D SAY Q ;-->out
  1. D SAY
  1. ;loop thru answers to this admin
  1. S YSQN=0,YSDATA(1)="[ERROR]"
  1. F S YSQN=$O(^YTT(601.85,"AC",YSAD,YSQN)) Q:YSQN'>0 S YSIEN=0 F S YSIEN=$O(^YTT(601.85,"AC",YSAD,YSQN,YSIEN)) Q:YSIEN'>0 D
  1. . S YSA=$G(^YTT(601.85,YSIEN,0)),YSCANS=$P(YSA,U,4)
  1. . I '$D(^YTT(601.76,"AF",YSINS,YSQN)) S YSDATA(2)="question not in battery" D SAYQ Q ;-->out
  1. . S YSCTREF=$P(^YTT(601.72,YSQN,2),U,3)
  1. . S K=0,YSK=0
  1. . I YSCANS?1N.N F S K=$O(^YTT(601.751,"ACT",YSCANS,K)) Q:(YSK)!(K'>0) I $P(^YTT(601.751,K,0),U,1)=YSCTREF S YSK=1
  1. . I YSK=0 S YSDATA(2)="bad choice" D SAYQ Q
  1. . S YSDATA(1)="[DATA]" K YSDATA(2) D SAYQ
  1. Q
  1. SAY W !,N," ",YSAD," ",YSDATA(1)," ",$G(YSDATA(2)) Q
  1. SAYQ W !?10,$G(YSDATA(1))," ",YSAD," ",YSQN," ",YSA," ctype: ",YSCTREF," Cans: ",YSCANS Q