Giter VIP home page Giter VIP logo

Comments (4)

pvictor avatar pvictor commented on May 23, 2024 1

Hello,

Yes you can HTML tags in the popup. The only tricky thing if you put multiple buttons is how to retrieve input values server-side, so i'll use Shiny.setInputValue to have one input for all buttons instead of as many inputs as buttons.

Here's an example:

library(tuicalendr)
library(htmltools)
library(shiny)

# Calendar properties ----
calendarProps <- data.frame(
  id = c("1", "2", "3"), 
  name = c("TODO", "Meetings", "Tasks"),
  color = c("#FFF", "#FFF", "#000"), 
  bgColor = c("#E41A1C", "#377EB8", "#4DAF4A"),
  borderColor = c("#a90000", "#005288", "#0a7f1c")
)

# Schedules data ---
n <- 20
date_start <- sample(
  seq(from = as.POSIXct(Sys.Date()-14), by = "1 hour", length.out = 24*7*4),
  n, TRUE
)
date_end <- date_start + sample(1:25, n, TRUE) * 3600
schedules <- data.frame(
  id = 1:n, 
  calendarId = as.character(sample(1:3, n, TRUE)),
  title = LETTERS[1:n],
  start = format(date_start, format = "%Y-%m-%dT%H:%00:%00"),
  end = format(date_end, format = "%Y-%m-%dT%H:%00:%00"),
  category = sample(c("allday", "time", "task"), n, TRUE),
  stringsAsFactors = FALSE
)

# HTML popup content
make_body <- function(title, id) {
  doRenderTags(tags$div(
    tags$h3("Title for", title),
    tags$p(
      "Yan can write", tags$em("custom"), tags$b("HTML"),
      "in a popup !"
    ),
    tags$p(
      style = "color: firebrick;",
      "For example write in red !"
    ),
    tags$ul(
      tags$li("Or make a bullet list!"),
      tags$li("With another item"),
      tags$li("And one more")
    ),
    actionButton(
      inputId = paste0("btn_input_", id), 
      label = paste("Label", id), 
      width = "100%",
      onclick = sprintf("Shiny.setInputValue('click_button', %s);", id)
    )
  ))
}
schedules$body <- unlist(mapply(FUN = make_body, title = schedules$title, id = schedules$id))


# App ----
ui <- fluidPage(
  fluidRow(
    column(
      width = 9,
      calendarOutput(outputId = "cal")
    ),
    column(
      width = 3,
      tags$b("Click:"),
      verbatimTextOutput("click")
    )
  )
)

server <- function(input, output, session) {
  output$cal <- renderCalendar({
    calendar(defaultView = "month", taskView = TRUE, scheduleView = c("time", "allday")) %>% 
      set_calendars_props_df(df = calendarProps) %>% 
      add_schedule_df(df = schedules)
  })
  output$click <- renderPrint({
    input$click_button
  })
}

shinyApp(ui, server)

Victor

from tuicalendr.

pvictor avatar pvictor commented on May 23, 2024 1

Not sure how to do that...
Otherwise there's the solution to use a custom popup : https://github.com/dreamRs/tuicalendr/blob/master/inst/calendar-examples/custom-popover.R

from tuicalendr.

fmmattioni avatar fmmattioni commented on May 23, 2024

Hey, @pvictor,

This is truly incredible! Thanks a lot for the tips!!!

from tuicalendr.

fmmattioni avatar fmmattioni commented on May 23, 2024

By the way, is there a specific JS command I could use to close the pop up once the button is clicked too?

from tuicalendr.

Related Issues (13)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.