View source: R/lottie_addEventListener.R
lottie_addEventListener | R Documentation |
Adds an event listener to a 'Lottie' animation within a 'shiny' application. It is also possible to apply multiple event listeners to a single animation.
lottie_addEventListener(
animation,
event,
target,
...,
session = shiny::getDefaultReactiveDomain()
)
animation |
A 'Lottie' animation object created by the |
event |
The event to listen for (e.g. |
target |
The target for the event listener, either |
... |
Additional optional event listener properties, including:
|
session |
The 'shiny' session object. Defaults to the current reactive domain. |
This function has several usage options:
Supplying an animation object created by the lottie_animation
function, and placing the resultant list object in the 'shiny' UI.
Outside of a reactive context, supplying the name of the animation and placing the resultant script
object in the 'shiny' UI.
Within a reactive context, supplying the name of the animation.
When run within a reactive context, sends a custom session message "lottie_js_runJS"
containing the function arguments.
Target Options
"animation"
: Attaches the event listener directly to the 'Lottie' animation instance. This is necessary when using a Lottie-specific event (e.g. "onComplete"). See https://airbnb.io/lottie/#/web for further details.
"container"
: Attaches the event listener to the container div of the 'Lottie' animation. This should be used when using a generic HTML event, such as "mouseenter" or "mouseleave".
If used within a reactive context, the function will execute the necessary 'JavaScript'. Otherwise, it will return a script
tag containing the 'JavaScript'.
Using the custom_js
argument, it is possible to assign 'shiny' input values when an event is triggered, see lottie_removeEventListener
for an example.
library(shiny)
library(shinyLottie)
ui <- fluidPage(
include_lottie(),
# Create an 'animation' event listener that prints a message to the
# browser console after each loop
lottie_animation(
path = "shinyLottie/example.json",
name = "my_animation"
) |>
lottie_addEventListener(
event = "loopComplete",
target = "animation",
custom_js = "console.log('Animation Complete!');"
),
# Create a 'container' event listener that plays an animation when
# hovering over the button, and another that pauses the animation
# when hovering stops
lottie_animation(
path = "shinyLottie/example.json",
name = "button",
width = "200px",
height = "100px",
loop = TRUE,
autoplay = FALSE,
) |> lottie_button(inputId = "lottieButton", label = "Lottie",
height = "200px", width = "200px") |>
lottie_addEventListener("mouseenter", "container", state = "play") |>
lottie_addEventListener("mouseleave", "container", state = "pause")
)
server <- function(input, output, session) {}
shinyApp(ui, server)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.