forked from rstudio/shiny
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreactiveTimer.Rd
68 lines (61 loc) · 1.97 KB
/
reactiveTimer.Rd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
\name{reactiveTimer}
\alias{reactiveTimer}
\title{Timer}
\usage{
reactiveTimer(intervalMs = 1000, session)
}
\arguments{
\item{intervalMs}{How often to fire, in milliseconds}
\item{session}{A session object. This is needed to cancel
any scheduled invalidations after a user has ended the
session. If \code{NULL}, then this invalidation will not
be tied to any session, and so it will still occur.}
}
\value{
A no-parameter function that can be called from a
reactive context, in order to cause that context to be
invalidated the next time the timer interval elapses.
Calling the returned function also happens to yield the
current time (as in \code{\link{Sys.time}}).
}
\description{
Creates a reactive timer with the given interval. A
reactive timer is like a reactive value, except reactive
values are triggered when they are set, while reactive
timers are triggered simply by the passage of time.
}
\details{
\link[=reactive]{Reactive expressions} and observers that
want to be invalidated by the timer need to call the
timer function that \code{reactiveTimer} returns, even if
the current time value is not actually needed.
See \code{\link{invalidateLater}} as a safer and simpler
alternative.
}
\examples{
\dontrun{
shinyServer(function(input, output, session) {
# Anything that calls autoInvalidate will automatically invalidate
# every 2 seconds.
autoInvalidate <- reactiveTimer(2000, session)
observe({
# Invalidate and re-execute this reactive expression every time the
# timer fires.
autoInvalidate()
# Do something each time this is invalidated.
# The isolate() makes this observer _not_ get invalidated and re-executed
# when input$n changes.
print(paste("The value of input$n is", isolate(input$n)))
})
# Generate a new histogram each time the timer fires, but not when
# input$n changes.
output$plot <- renderPlot({
autoInvalidate()
hist(isolate(input$n))
})
})
}
}
\seealso{
invalidateLater
}