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

HLEVREP2.m

Go to the documentation of this file.
  1. HLEVREP2 ;O-OIFO/LJA - Event Monitor REPORTS ;02/04/2004 14:42
  1. ;;1.6;HEALTH LEVEL SEVEN;**109**;Oct 13, 1995
  1. ;
  1. CTRL ; Called by 'Display monitor details [HLEV MONITOR DETAILS]'
  1. N MONM
  1. ;
  1. KILL ^TMP($J)
  1. ;
  1. D HD
  1. D EX
  1. W !
  1. QUIT:$$BTE^HLCSMON("Press RETURN to collect data, or enter '^' to exit... ") ;->
  1. D MONVALL
  1. ;
  1. F D QUIT:MONM']""
  1. . D MONLIST
  1. . W !
  1. . S MONM=$$ASKMON QUIT:MONM']"" ;->
  1. . S WAY=$$ORDER I WAY'?1N S MONM="" QUIT ;->
  1. . I WAY=1 D SHOWR(MONM)
  1. . I WAY=2 D SHOWF(MONM)
  1. . D HD
  1. ;
  1. KILL ^TMP($J)
  1. ;
  1. Q
  1. ;
  1. SHOWF(MONM) ; Show monitors from oldest to newest
  1. N ABRT,HLEVIENJ,PMT
  1. W !
  1. S ABRT=0,HLEVIENJ=0
  1. F S HLEVIENJ=$O(^TMP($J,"HLMONL",MONM,HLEVIENJ)) Q:'HLEVIENJ!(ABRT) D
  1. . S X=$$NEXT,ABRT=$P(X,U,2),PRINT=+X QUIT:ABRT ;->
  1. . I PRINT D SHOW(HLEVIENJ) W !
  1. Q
  1. ;
  1. SHOWR(MONM) ; Show monitors from newest to oldest
  1. N ABRT,HLEVIENJ,PRINT,X
  1. W !
  1. S ABRT=0,HLEVIENJ=":"
  1. F S HLEVIENJ=$O(^TMP($J,"HLMONL",MONM,HLEVIENJ),-1) Q:'HLEVIENJ!(ABRT) D
  1. . S X=$$NEXT,ABRT=$P(X,U,2),PRINT=+X QUIT:ABRT ;->
  1. . I PRINT D SHOW(HLEVIENJ) W !
  1. Q
  1. ;
  1. NEXT() ; Show next entry?
  1. N ANS
  1. S ANS=$$YN^HLEVUTIL("Display monitor ""run"" started at "_$P(^TMP($J,"HLMON",+HLEVIENJ,"START"),U,3),"No")
  1. I ANS=1 QUIT "1^0" ;-> Display^Abort
  1. I ANS="" QUIT "0^0" ;->
  1. Q "0^1"
  1. ;
  1. SHOW(HLEVIENJ) ; Ask if want to view...
  1. N GBL,LINES,MONM
  1. ;
  1. S GBL=$NA(^TMP($J,"HLMON",HLEVIENJ))
  1. ;
  1. ;
  1. S LINES=$O(@GBL@("VIEW",":"),-1)
  1. S MONM=$P($G(@GBL@("MONM")),U,3) QUIT:MONM']"" ;->
  1. S MONM=MONM_"[#"_HLEVIENJ_"]"
  1. ;
  1. I LINES<22 D QUIT ;->
  1. . W @IOF,$$CJ^XLFSTR(MONM,IOM),!,$$REPEAT^XLFSTR("=",IOM)
  1. . S NO=0
  1. . F S NO=$O(^TMP($J,"HLMON",+HLEVIENJ,"VIEW",NO)) Q:NO'>0 D
  1. . . W !,^TMP($J,"HLMON",+HLEVIENJ,"VIEW",NO)
  1. ;
  1. D BROWSE^DDBR($NA(^TMP($J,"HLMON",+HLEVIENJ,"VIEW")),"N",MONM)
  1. ;
  1. Q
  1. ;
  1. ORDER() ; $ORDER direction...
  1. N DIR,DIRUT,DTOUT,DUOUT
  1. S DIR(0)="S^1:Show entries from newest to oldest;2:Show entries from oldest to newest;3:Exit"
  1. S DIR("A")="Select display direction"
  1. S DIR("B")=1
  1. D ^DIR
  1. Q $S(+Y=1!(+Y=2):+Y,1:"")
  1. ;
  1. ASKMON() ; Ask user to select a monitor...
  1. N DIC,X,Y
  1. S DIC=776.1,DIC(0)="AEMQ",DIC("A")="Select MONITOR: "
  1. S DIC("S")="S HLEV=$P($G(^HLEV(776.1,+Y,0)),U) I HLEV]"""",$D(^TMP($J,""HLMONL"",HLEV))"
  1. D ^DIC
  1. Q $S(+Y>0:$P(Y,U,2),1:"")
  1. ;
  1. HD W @IOF,$$CJ^XLFSTR("Display Monitor Details",IOM)
  1. W !,$$REPEAT^XLFSTR("=",IOM)
  1. QUIT
  1. ;
  1. EX N I,T F I=1:1 S T=$T(EX+I) QUIT:T'[";;" W !,$P(T,";;",2,99)
  1. ;;This option displays a detailed view of monitor run-time data. You can loop
  1. ;;through all occurrences of a monitor from oldest to most recent, or from most
  1. ;;recent to oldest.
  1. QUIT
  1. ;
  1. MONLIST ; Create and print list of monitors...
  1. N DATA,HLEVIENJ
  1. ;
  1. I '$D(^TMP($J,"HLMONL")) D QUIT:'$D(^TMP($J,"HLMONL")) ;->
  1. . S HLEVIENJ=0
  1. . F S HLEVIENJ=$O(^TMP($J,"HLMON",HLEVIENJ)) Q:'HLEVIENJ D
  1. . . S MONM=$P($G(^TMP($J,"HLMON",+HLEVIENJ,"MONM")),U,3) QUIT:MONM']"" ;->
  1. . . S ^TMP($J,"HLMONL",MONM)=$G(^TMP($J,"HLMONL",MONM))+1
  1. . . S ^TMP($J,"HLMONL",MONM,+HLEVIENJ)=""
  1. ;
  1. W !!,"""Runs"" for the following monitors have been found..."
  1. W !!
  1. ;
  1. S MONM=""
  1. F S MONM=$O(^TMP($J,"HLMONL",MONM)) Q:MONM']"" D
  1. . S CT=^TMP($J,"HLMONL",MONM),MONM(1)=MONM_"[#"_CT_"]"
  1. . W:$X>40 ! W:$X>1 ?40
  1. . W MONM(1)
  1. ;
  1. Q
  1. ;
  1. MONVALL ; Collect and build screens for all HLEVIENJs...
  1. N CT,HLEVIENJ
  1. ;
  1. KILL ^TMP($J,"HLMON")
  1. ;
  1. ; Load here...
  1. S HLEVIENJ=0,CT=0
  1. F S HLEVIENJ=$O(^HLEV(776,HLEVIENJ)) Q:HLEVIENJ'>0 D
  1. . D MONALL(+HLEVIENJ)
  1. . S CT=CT+1 W:'(CT#50) "."
  1. ;
  1. Q
  1. ;
  1. MONALL(HLEVIENJ) ; Build screen for one entry...
  1. N GBL
  1. ;
  1. S GBL=$NA(^TMP($J,"HLMON",+HLEVIENJ))
  1. KILL @GBL
  1. ;
  1. D MONLOAD^HLEVREP3(+HLEVIENJ) QUIT:'$D(^TMP($J,"HLMON",+HLEVIENJ)) ;->
  1. D MONHHDR(+HLEVIENJ) ; Build HEADER portion of screen
  1. D MONVVAR(+HLEVIENJ) ; Build VARIABLE portion of screen
  1. D MONRRD(+HLEVIENJ) ; Build RUN DIARY portion of screen
  1. D MONMMT(+HLEVIENJ) ; Build MSG TEXT portion of screen
  1. ;
  1. Q
  1. ;
  1. ;
  1. MONHHDR(HLEVIENJ) ; Build header...
  1. ; ^TMP($J,"HLMON",+HLEVIENJ) -- req
  1. N TXT
  1. ;
  1. D ADDLINE("Start Timestamp Finish Status Appl Mail")
  1. D ADDLINE($$REPEAT^XLFSTR("=",IOM))
  1. ;
  1. S TXT=""
  1. D ADD("START",11),ADD("TIME",11),ADD("DONE",11),ADD("STATR",7)
  1. D ADD("MAIL",14)
  1. D ADDLINE(TXT)
  1. ;
  1. Q
  1. ;
  1. MONVVAR(HLEVIENJ) ; Create screens in ^TMP
  1. ; GBL,^TMP($J,"HLMON",+HLEVIENJ) -- req
  1. ;
  1. ;
  1. N NOPG,NOVAR
  1. ;
  1. S X=$G(@GBL@("VX")),NOVAR=$P(X,U),NOPG=$P(X,U,4)
  1. ;
  1. ; Vertical alignment?
  1. I NOPG>1!(NOVAR<6) D MVSCRNV QUIT ;->
  1. ;
  1. ; Horizontal alignment...
  1. D MVSCRNH
  1. ;
  1. Q
  1. ;
  1. MVSCRNV ; Create variable screen VERTICALly...
  1. ; Called by MONVSCRN - GBL,HLEVIENJ -- req
  1. N COL,DATA,EXPL,LEN,TXT,VAR,VARX
  1. ;
  1. ; Get widest variable...
  1. S COL=$O(@GBL@("VY",":"),-1) QUIT:COL'>0 ;->
  1. S VAR=$O(@GBL@("VY",+COL,"ZZZZZZZZZ"),-1) QUIT:VAR']"" ;->
  1. S EXPL=$O(@GBL@("VY",+COL,VAR,"ZZZZZZZZZ"),-1) QUIT:EXPL']"" ;->
  1. S DATA=@GBL@("VD",VAR,EXPL)
  1. S VARX=$S(VAR'=EXPL:EXPL,1:VAR)
  1. ;
  1. ; Find where 'legend: ' should be...
  1. S TXT=$$CJ^XLFSTR(VARX_"~^~"_DATA,IOM)
  1. S LEN=$L($P(TXT,"~^~"))-2 ; this is critical number...
  1. ;
  1. D ADDLINE("")
  1. D ADDLINE($$CJ^XLFSTR("-------------------- Variables ----------------------",IOM))
  1. ;
  1. ; Loop thru fields now...
  1. S VAR=""
  1. F S VAR=$O(@GBL@("VD",VAR)) Q:VAR']"" D
  1. . S EXPL=""
  1. . F S EXPL=$O(@GBL@("VD",VAR,EXPL)) Q:EXPL']"" D
  1. . . S DATA=@GBL@("VD",VAR,EXPL)
  1. . . S TXT=$$PAD($S(EXPL=VAR:VAR,1:EXPL),LEN)_DATA
  1. . . D ADDLINE(TXT)
  1. ;
  1. Q
  1. ;
  1. MVSCRNH ; Create variable screen HORIZONTALly... (Only called if PAGE=1)
  1. ; Called by MONVSCRN - GBL,HLEVIENJ -- req
  1. N DATA,EXPL,HDR,NO,TXTHDR,TXTVAR
  1. ;
  1. D ADDLINE("")
  1. D ADDLINE($$CJ^XLFSTR("-------------------- Variables ----------------------",IOM))
  1. ;
  1. ; Header
  1. S VAR="",TXTHDR="",NO=0
  1. F S VAR=$O(@GBL@("VD",VAR)) Q:VAR']"" D
  1. . S EXPL=""
  1. . F S EXPL=$O(@GBL@("VD",VAR,EXPL)) Q:EXPL']"" D
  1. . . S HDR=$S(EXPL'=VAR:EXPL,1:VAR)
  1. . . S DATA=@GBL@("VD",VAR,EXPL)
  1. . . S X=$L(HDR),Y=$L(DATA),LEN=$S(X>Y:X,1:Y)
  1. . . S NO=NO+1,NO(NO)=LEN_U_HDR_U_DATA
  1. ;
  1. ; Header line...
  1. S NO=0,TXTHDR=""
  1. F S NO=$O(NO(NO)) Q:NO'>0 D
  1. . S DATA=NO(+NO)
  1. . S LEN=+DATA,DATA=$P(DATA,U,2)
  1. . S TXTHDR=TXTHDR_$S(TXTHDR]"":" ",1:"")
  1. . S TXTHDR=TXTHDR_$E(DATA_$$REPEAT^XLFSTR(" ",LEN),1,LEN)
  1. D ADDLINE(TXTHDR)
  1. ;
  1. D ADDLINE($$REPEAT^XLFSTR("=",IOM))
  1. ;
  1. ; Variables...
  1. S NO=0,TXTVAR=""
  1. F S NO=$O(NO(NO)) Q:NO'>0 D
  1. . S DATA=NO(+NO)
  1. . S LEN=+DATA,DATA=$P(DATA,U,3)
  1. . S TXTVAR=TXTVAR_$S(TXTVAR]"":" ",1:"")
  1. . S TXTVAR=TXTVAR_$E(DATA_$$REPEAT^XLFSTR(" ",LEN),1,LEN)
  1. D ADDLINE(TXTVAR)
  1. ;
  1. Q
  1. ;
  1. MONRRD(HLEVIENJ) ; Build RUN DIARY...
  1. ; GBL,^TMP($J,"HLMON",+HLEVIENJ) -- req
  1. N NO
  1. ;
  1. QUIT:'$D(@GBL@("RUN")) ;->
  1. ;
  1. D ADDLINE("")
  1. D ADDLINE($$CJ^XLFSTR("---------------------- Run Diary ------------------------",IOM))
  1. ;
  1. S NO=0
  1. S NO=$O(@GBL@("RUN",NO)) Q:NO'>0 D
  1. . D ADDLINE(@GBL@("RUN",+NO))
  1. ;
  1. Q
  1. ;
  1. ;
  1. MONMMT(HLEVIENJ) ; Build MSG TEXT...
  1. ; ^TMP($J,"HLMON",+HLEVIENJ) -- req
  1. N NO
  1. ;
  1. QUIT:'$D(@GBL@("MSG")) ;->
  1. ;
  1. D ADDLINE("")
  1. D ADDLINE($$CJ^XLFSTR("-------------------- Message Text ----------------------",IOM))
  1. ;
  1. S NO=0
  1. S NO=$O(@GBL@("MSG",NO)) Q:NO'>0 D
  1. . D ADDLINE(@GBL@("MSG",+NO))
  1. ;
  1. Q
  1. ;
  1. ;
  1. PAD(VAR,COL) ; Make " var: "
  1. QUIT:$L(VAR)>(COL-3) VAR_": " ;->
  1. Q $$REPEAT^XLFSTR(" ",COL-$L(VAR))_VAR_": "
  1. ;
  1. ADDLINE(TXT) ; Add line of text...
  1. N NO
  1. S NO=$O(@GBL@("VIEW",":"),-1)+1
  1. S @GBL@("VIEW",+NO)=TXT
  1. Q
  1. ;
  1. ;
  1. ADD(VAR,COL) ; Add to TXT...
  1. N VAL
  1. S VAL=$P($G(@GBL@(VAR)),U,$S(VAR="STATR":4,1:3))
  1. S TXT=TXT_$S(TXT]"":" ",1:"")_$E(VAL_$$REPEAT^XLFSTR(" ",COL),1,COL)
  1. Q
  1. ;
  1. EOR ;HLEVREP2 - Event Monitor REPORTS ;5/16/03 14:42