source: WorldVistAEHR/trunk/r/MENTAL_HEALTH-YS-RUCL-YI-YT/YTQLIB.m@ 1474

Last change on this file since 1474 was 613, checked in by George Lilly, 15 years ago

initial load of WorldVistAEHR

File size: 2.3 KB
RevLine 
[613]1YTQLIB ;ASF/ALB MHQ LIBRARY FUNCTIONS ; 4/4/07 2:00pm
2 ;;5.01;MENTAL HEALTH;**85**;Dec 30, 1994;Build 49
3 Q
4TSLIST(YSDATA) ;list tests and surveys
5 N YSTESTN,YSTEST,N
6 K YSDATA
7 S N=1,YSDATA(N)="[DATA]"
8 S YSTEST="" F S YSTEST=$O(^YTT(601.71,"B",YSTEST)) Q:YSTEST="" D
9 . S YSTESTN=$O(^YTT(601.71,"B",YSTEST,0))
10 . S N=N+1
11 . S YSDATA(N)=YSTESTN_U_YSTEST_U_$$GET1^DIQ(601.71,YSTESTN_",",18)
12 Q
13 ;
14NEW(YSFILEN) ;Adding New Entries - return an internal number - EXTRINSIC FUNCTION
15 ;if $D YSPROG then National and pointers less than 100,000 else pointers greater than 100,000
16 N MHQ2X,YS
17 K YSPROG
18 S:$D(^XUSEC("YSPROG",DUZ)) YSPROG=1
19 S YS=$P($G(^YTT(YSFILEN,0)),U,3) S:YS<1 YS=1
20 I $D(YSPROG) S YS=$S(YS<100000:YS,1:1)
21 I '$D(YSPROG) S YS=$S(YS>100000:YS,1:100000)
22 F MHQ2X=YS:1 I '$D(^YTT(YSFILEN,MHQ2X)) L ^YTT(YSFILEN,MHQ2X):0 Q:$T
23 Q MHQ2X
24 ;
25ADMCK(YSDATA,YS) ;check administration
26 N G,K,YSA,YSAD,YSCANS,YSCOMP,YSCTREF,YSDFN,YSDG,YSDS,YSIEN,YSINS,YSK,YSQN
27 S N=1
28 S YSDATA(1)="[ERROR]"
29 S YSAD=$G(YS("AD"))
30 I YSAD'?1N.N S YSDATA(2)="bad admin #" D SAY Q ;-->out
31 I '$D(^YTT(601.84,YSAD,0)) S YSDATA(2)="bad admin ref" D SAY Q ;-->out
32 S G=^YTT(601.84,YSAD,0)
33 S YSDFN=$P(G,U,2) I '$D(^DPT(YSDFN,0)) S YSDATA(2)="bad pt ref" D SAY Q ;-->out
34 S YSINS=$P(G,U,3) I '$D(^YTT(601.71,YSINS)) S YSDATA(2)="test not found" D SAY Q ;-->out
35 S YSDG=$P(G,U,4) I YSDG'?7N.NP S YSDATA(2)="date given bad" D SAY Q ;-->out
36 S YSDS=$P(G,U,5) I YSDG'?7N.NP S YSDATA(2)="date SAVED bad" D SAY Q ;-->out
37 S YSCOMP=$P(G,U,9)
38 S YSDATA(1)="[DATA]"
39 I YSCOMP'="Y" S YSDATA(2)="incomplete" D SAY Q ;-->out
40 D SAY
41 ;loop thru answers to this admin
42 S YSQN=0,YSDATA(1)="[ERROR]"
43 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
44 . S YSA=$G(^YTT(601.85,YSIEN,0)),YSCANS=$P(YSA,U,4)
45 . I '$D(^YTT(601.76,"AF",YSINS,YSQN)) S YSDATA(2)="question not in battery" D SAYQ Q ;-->out
46 . S YSCTREF=$P(^YTT(601.72,YSQN,2),U,3)
47 . S K=0,YSK=0
48 . 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
49 . I YSK=0 S YSDATA(2)="bad choice" D SAYQ Q
50 . S YSDATA(1)="[DATA]" K YSDATA(2) D SAYQ
51 Q
52SAY W !,N," ",YSAD," ",YSDATA(1)," ",$G(YSDATA(2)) Q
53SAYQ W !?10,$G(YSDATA(1))," ",YSAD," ",YSQN," ",YSA," ctype: ",YSCTREF," Cans: ",YSCANS Q
Note: See TracBrowser for help on using the repository browser.