- YTSDBAS ;SLC/BLD- MHAX ANSWERS SPECIAL HANDLING FOR DBAS
- ;;5.01;MENTAL HEALTH;**151**;DEC 30,1994;Build 92
- ;
- ;Public, Supported ICRs
- ; #2056 - Fileman API - $$GET1^DIQ
- ;
- Q
- ;
- DLLSTR(YSDATA,YS,YSTRNG) ;
- ; YSTRNG = 1 Score Instrument
- ; YSTRNG = 2 get Report Answers and Text
- N DATA,DES,LEG,NODE,YSQN,YSSCALIEN,TOTSCORE,QUES,BASIS
- N YSCDA,YSSCNAM,YSINSNAM,STRING,STRING1,TOTSCR,I
- ;
- ; Basis-24 Psychosis returns a scale score which is calculated and stored, no special text in report
- I YSTRNG=1 D SCORESV Q
- I YSTRNG=2 Q ;D
- ;
- Q
- ;
- STRING ;
- Q
- ;
- DATA1 ;
- ;
- S TOTSCR=0
- F I=3:1 Q:'$D(YSDATA(I)) S TOTSCR=$G(TOTSCR)+$$GET1^DIQ(601.75,$P(YSDATA(I),"^",3)_",",4,"I")
- S TOTSCR=TOTSCR/16
- ;
- S YSSCGROUP=$P($P(^TMP($J,"YSG",2),"^",1),"=",2)
- S YSSCALIEN=$P($P(^TMP($J,"YSG",3),"^",1),"=",2)
- Q
- ;
- SCORESV ;
- N YSSCGROUP
- D DATA1
- I $D(^TMP($J,"YSG",1)),^TMP($J,"YSG",1)="[ERROR]" D Q ;-->out
- .K ^TMP($J,"YSCOR")
- .S ^TMP($J,"YSCOR",1)="[ERROR]"
- .S ^TMP($J,"YSCOR",2)=$G(YSINSNAM)_" Scale not found"
- S YSSCNAM=$P($G(^TMP($J,"YSG",3)),U,4) ; Scale Name
- ;
- K ^TMP($J,"YSCOR")
- ;
- S ^TMP($J,"YSCOR",1)="[DATA]"
- S ^TMP($J,"YSCOR",2)=$$GET1^DIQ(601.87,YSSCALIEN_",",3,"I")_"="_+$FN(TOTSCR,"",2)
- Q
- ;
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HYTSDBAS 1273 printed Feb 18, 2025@23:46:01 Page 2
- YTSDBAS ;SLC/BLD- MHAX ANSWERS SPECIAL HANDLING FOR DBAS
- +1 ;;5.01;MENTAL HEALTH;**151**;DEC 30,1994;Build 92
- +2 ;
- +3 ;Public, Supported ICRs
- +4 ; #2056 - Fileman API - $$GET1^DIQ
- +5 ;
- +6 QUIT
- +7 ;
- DLLSTR(YSDATA,YS,YSTRNG) ;
- +1 ; YSTRNG = 1 Score Instrument
- +2 ; YSTRNG = 2 get Report Answers and Text
- +3 NEW DATA,DES,LEG,NODE,YSQN,YSSCALIEN,TOTSCORE,QUES,BASIS
- +4 NEW YSCDA,YSSCNAM,YSINSNAM,STRING,STRING1,TOTSCR,I
- +5 ;
- +6 ; Basis-24 Psychosis returns a scale score which is calculated and stored, no special text in report
- +7 IF YSTRNG=1
- DO SCORESV
- QUIT
- +8 ;D
- IF YSTRNG=2
- QUIT
- +9 ;
- +10 QUIT
- +11 ;
- STRING ;
- +1 QUIT
- +2 ;
- DATA1 ;
- +1 ;
- +2 SET TOTSCR=0
- +3 FOR I=3:1
- if '$DATA(YSDATA(I))
- QUIT
- SET TOTSCR=$GET(TOTSCR)+$$GET1^DIQ(601.75,$PIECE(YSDATA(I),"^",3)_",",4,"I")
- +4 SET TOTSCR=TOTSCR/16
- +5 ;
- +6 SET YSSCGROUP=$PIECE($PIECE(^TMP($JOB,"YSG",2),"^",1),"=",2)
- +7 SET YSSCALIEN=$PIECE($PIECE(^TMP($JOB,"YSG",3),"^",1),"=",2)
- +8 QUIT
- +9 ;
- SCORESV ;
- +1 NEW YSSCGROUP
- +2 DO DATA1
- +3 ;-->out
- IF $DATA(^TMP($JOB,"YSG",1))
- IF ^TMP($JOB,"YSG",1)="[ERROR]"
- Begin DoDot:1
- +4 KILL ^TMP($JOB,"YSCOR")
- +5 SET ^TMP($JOB,"YSCOR",1)="[ERROR]"
- +6 SET ^TMP($JOB,"YSCOR",2)=$GET(YSINSNAM)_" Scale not found"
- End DoDot:1
- QUIT
- +7 ; Scale Name
- SET YSSCNAM=$PIECE($GET(^TMP($JOB,"YSG",3)),U,4)
- +8 ;
- +9 KILL ^TMP($JOB,"YSCOR")
- +10 ;
- +11 SET ^TMP($JOB,"YSCOR",1)="[DATA]"
- +12 SET ^TMP($JOB,"YSCOR",2)=$$GET1^DIQ(601.87,YSSCALIEN_",",3,"I")_"="_+$FNUMBER(TOTSCR,"",2)
- +13 QUIT
- +14 ;