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

NURQUTL.m

Go to the documentation of this file.
  1. NURQUTL ;HIRMFO/RM-QI SUMMARY UTILITIES ;4/24/96
  1. ;;4.0;NURSING SERVICE;;Apr 25, 1997
  1. PERFORM(NURQSURV,NURQLOC) ; This function will do a lookup on the
  1. ; Performance measure multiple and return a valid entry, or -1.
  1. ; Input variables: NURQSURV=IEN in file 217
  1. ; NURQLOC=IEN in 217.04 sub-file (Location)
  1. ; Return Value: IEN in 217.43 sub-file, or -1 if none selected.
  1. ; NURQOUT=1 if user abnormally terminated selection.
  1. ;
  1. N NURQFXN S NURQFXN=-1
  1. K ^TMP($J,"NURQPMS"),^TMP($J,"NURQPMA")
  1. D GETPM(","_NURQLOC_","_NURQSURV_",")
  1. S %=$P($G(^SC(+$P($G(^NURQ(217,NURQSURV,2,NURQLOC,0)),"^"),0)),"^"),NURQPLOC=$S(%?1"NUR ".E:$P(%,"NUR ",2),1:%)
  1. REPM ; Label is here so can jump back to reask Performance Measures.
  1. W !!!,"The following performance measures have been selected for "_NURQPLOC_":"
  1. D LISTQUES("^TMP($J,""NURQPMS"",") G QPM:NURQOUT
  1. S Y=$O(^TMP($J,"NURQPMS",9999999),-1) S:$G(NURQDA)>0 Y=""
  1. W !,"Select PERFORMANCE MEASURE: "_$S(Y]"":Y_"// ",1:"") R X:DTIME
  1. S:'$T X="^^" S:X=""&$L(Y) X=Y I X="^"!(X="^^") S NURQOUT=1
  1. I "^^"'[X D G QPM:NURQOUT,REPM:NURQFXN<0
  1. . S NURQX=X,NURQY=Y
  1. . S NURQFXN=$P($G(^TMP($J,"NURQPMS",NURQX)),"^",2) Q:NURQFXN>0
  1. . S NURQFXN=-1 D:'$D(^TMP($J,"NURQPMA")) GETQUES(","_NURQSURV_",")
  1. . S NURQFXN=$P($G(^TMP($J,"NURQPMA",NURQX)),"^",2) Q:NURQFXN>0
  1. . S NURQFXN=-1 I NURQX'?1"?".E W !,$C(7),"INVALID ENTRY"
  1. . W !," Choose from: "
  1. . D LISTQUES("^TMP($J,""NURQPMA"",")
  1. . Q
  1. QPM ; Quit and exit PERFORM procedure
  1. K NURQPLOC,NURQX,NURQY,^TMP($J,"NURQPMA"),^TMP($J,"NURQPMS")
  1. Q NURQFXN
  1. LISTQUES(ARRAY) ; This procedure will list perfmance measures selected so far,
  1. ; or questions that can be selected. ARRAY will be set to the list
  1. ; of performance measures to print.
  1. N NURQQNO,NURQQUES,NURQTXT,NURQX
  1. W # S NURQQNO=0 F S NURQQNO=$O(@(ARRAY_NURQQNO_")")) Q:NURQQNO'>0 D
  1. . S NURQSEQ=+$G(@(ARRAY_NURQQNO_")")) Q:NURQSEQ=""
  1. . S NURQX=0 F S NURQX=$O(@(ARRAY_"""WRITE"","_NURQSEQ_","_NURQX_")")) Q:NURQX'>0 D
  1. . . S NURQTXT=$G(@(ARRAY_"""WRITE"","_NURQSEQ_","_NURQX_")"))
  1. . . W !,NURQTXT
  1. . . I $Y>(IOSL-3) S DIR(0)="E" D ^DIR S:Y NURQOUT=1
  1. . . Q
  1. . Q
  1. Q
  1. GETQUES(NURQIENS) ; This procedure will get the Questions from 748.26
  1. ; sub-file for the entry defined by NURQIENS (FM DB IENS format).
  1. ; Data will be returned in the ^TMP($J,"NURQPMA", array.
  1. K ^TMP("DILIST",$J),^TMP($J,"NURQSEQ")
  1. D LIST^DIC(748.26,NURQIENS,"","","","","","","","D QUESID^NURQUTL(Y1)")
  1. K ^TMP($J,"NURQPMA") M ^TMP($J,"NURQPMA")=^TMP($J,"NURQSEQ")
  1. M ^TMP($J,"NURQPMA","WRITE")=^TMP("DILIST",$J,"ID","WRITE")
  1. M ^TMP($J,"NURQPMA","DA")=^TMP($J,"DILIST",$J,2)
  1. K ^TMP("DILIST",$J),^TMP($J,"NURQSEQ")
  1. Q
  1. GETPM(NURQIENS) ; This procedure will get the Performance Measures from 217.43
  1. ; sub-file for the entry defined by NURQIENS (FM DB IENS format).
  1. ; Data will be returned in the ^TMP($J,"NURQPMS", array.
  1. ;
  1. K ^TMP("DILIST",$J),^TMP($J,"NURQSEQ")
  1. D LIST^DIC(217.43,","_NURQLOC_","_NURQSURV_",","","","","","","","","D PMID^NURQUTL")
  1. K ^TMP($J,"NURQPMS") M ^TMP($J,"NURQPMS")=^TMP($J,"NURQSEQ")
  1. M ^TMP($J,"NURQPMS","WRITE")=^TMP("DILIST",$J,"ID","WRITE")
  1. M ^TMP($J,"NURQPMS","DA")=^TMP("DILIST",$J,2)
  1. K ^TMP("DILIST",$J),^TMP($J,"NURQSEQ")
  1. Q
  1. PMID ; This procedure is called by Identifier code in LIST^DIC call which
  1. ; is returning the printable text for the question to be listed for
  1. ; a particular entry in the Performance Measure (217.43) sub-file.
  1. ;
  1. N NURQIENS,NURQREF
  1. S NURQREF=$P(^(0),"^")
  1. S NURQIENS=$P(NURQREF,",",4)_","_$P(NURQREF,",",2)_","
  1. D QUESID(NURQIENS)
  1. Q
  1. QUESID(NURQIENS) ; This procedure is given the entry in the Question
  1. ; (748.26) sub-file defined by NURQIENS (in DBS IENS format), will
  1. ; set the printable text of that question for a LIST^DIC call.
  1. ;
  1. N NURQSURV,NURQQUES,NURQDAT,NURQQNO,NURQSEQ,NURQX,NURQY
  1. D GETS^DIQ(748.26,NURQIENS,".015;.05","","NURQDAT")
  1. S NURQQNO=$G(NURQDAT(748.26,NURQIENS,.015)) Q:NURQQNO=""
  1. S NURQSEQ=$O(^TMP("DILIST",$J,1,""),-1) Q:NURQSEQ=""
  1. S ^TMP($J,"NURQSEQ",NURQQNO)=NURQSEQ_"^"_$P(NURQIENS,",")
  1. S NURQ1ST=1 K ^UTILITY($J,"W")
  1. I $O(NURQDAT(748.26,NURQIENS,.05,0)) D
  1. . S NURQX=0 F S NURQX=$O(NURQDAT(748.26,NURQIENS,.05,NURQX)) Q:NURQX'>0 S X=$G(NURQDAT(748.26,NURQIENS,.05,NURQX)) I $G(X)]"" D
  1. . . I NURQ1ST S X=$J(NURQQNO,3)_" "_X
  1. . . E S %=$G(^UTILITY($J,"W",8)),X=$G(^UTILITY($J,"W",8,%,0))_X K ^UTILITY($J,"W",8,%,0) S ^UTILITY($J,"W",8)=%-1
  1. . . S DIWL=8,DIWR=IOM-2,DIWF="" D ^DIWP K DIWL,DIWR,DIWF S NURQ1ST=0
  1. . . Q
  1. . Q
  1. E D
  1. . S X=NURQQNO
  1. . S DIWL=8,DIWR=IOM-2,DIWF="" D ^DIWP K DIWL,DIWR,DIWF
  1. . Q
  1. S NURQX=0 F S NURQX=$O(^UTILITY($J,"W",8,NURQX)) Q:NURQX'>0 D
  1. . S NURQY=$G(^UTILITY($J,"W",8,NURQX,0))
  1. . I NURQY]"" D EN^DDIOL(NURQY,"",$S(NURQX=1:"!?0",1:"!?7"))
  1. . Q
  1. K ^UTILITY($J,"W")
  1. Q