Невозможно скрыть / показать текучую страницу в приложении RShiny - PullRequest
1 голос
/ 09 октября 2019

Я в настоящее время разрабатываю блестящее приложение, и мне нужно скрыть страницу входа и показать блестящую панель мониторинга при успешном входе. В противном случае страница входа должна отображаться.

Я наткнулся на несколько сайтов и решил использовать пакет shinyjs для отображения и скрытия текущей страницы / страницы панели инструментов.

Используемая глобальная функция выглядит следующим образом:

`%AND%` <- function (x, y) {
  if (!is.null(x) && !anyNA(x))
    if (!is.null(y) && !anyNA(y))
      return(y)
  return(NULL)
}

passwordInputAddon <- function (inputId, label, value = "", placeholder = NULL, addon, width = NULL)
{
  value <- shiny::restoreInput(id = inputId, default = value)
  htmltools::tags$div(
    class = "form-group shiny-input-container",
    label %AND% htmltools::tags$label(label, `for` = inputId),
    style = if (!is.null(width)) paste0("width: ", htmltools::validateCssUnit(width), ";"),
    htmltools::tags$div(
      style = "margin-bottom: 5px;", class="input-group",
      addon %AND% htmltools::tags$span(class="input-group-addon", addon),
      htmltools::tags$input(
        id = inputId, type = "password", class = "form-control",
        value = value, placeholder = placeholder
      )
    )
  )
}

Используемый код пользовательского интерфейса выглядит следующим образом:

 ui <- shinyUI(fluidPage(
          tags$div(id = "login_page_ui",
          shinyjs::useShinyjs(),
          tags$style(".container-fluid {margin-top: 13%}"),
          setBackgroundColor(color = "#2d3c44"),
          fluidRow(
            column(8, align = "center", offset = 2,
                   textInputAddon("name", label = "", placeholder = "Username", addon = icon("user"),width = "25%"),
                   tags$style(type="text/css", "#string { height: 50px; width: 50%; text-align:center;
                        font-size: 30px; display: block;}")
            )
          ),
          fluidRow(
            column(8, align = "center", offset = 2,
                   passwordInputAddon("password", label = "", placeholder = "Password", addon = icon("key"),width = "25%"),               
                   tags$style(type="text/css", "#string { height: 50px; width: 50%; text-align:center;
                        font-size: 30px; display: block;}")
            )
          ),

          fluidRow(
            column(12, div(style = "height:20px;background-color: #2d3c44;")
            )

          ),

          fluidRow(
            column(6, align = "center", offset = 3,
                   actionButton("login",label = "Login", width = "35%", style = "color: #fff; background-color: #1bc3d7; border-color: #1bc3d7;")))


  )
  ),

  shinyjs::hidden(
    tags$div(
      id = "dashboard_page_ui",
    dashboardPage(
      dashboardHeader(
        title="Shiny Dashboard",
        tags$li(
          class="dropdown"
        )
      ),
      dashboardSidebar(
        sidebarMenu(
          id = 'dashboard_menu',
          sidebarMenuOutput("menu")

        )
      ),
      dashboardBody(
        tabItems(
          tabItem(tabName="Item1"),
          tabItem(tabName="Item2"),
          tabItem(tabName="Item3")
        )

      )

    )

   )
 )
)

Используемый код сервера:

server <- function(input, output,session){
  observeEvent(input$login,{

    if((input$name == "test") & (input$password == "test123")){

      shinyjs::show("dashboard_page_ui")
      shinyjs::hide("login_page_ui")

    }


  })


}

Когда я выполняю этот код, я получаю это сообщение об ошибке

Error in shinyUI(fluidPage(tags$div(id = "login_page_ui", shinyjs::useShinyjs(),  : 
  unused argument (shinyjs::hidden .....

Я не знаю, в чем именно заключается проблема. Может кто-нибудь помочь мне разобраться в этой проблеме?

1 Ответ

0 голосов
/ 09 октября 2019

shinyUI принимает один аргумент ui (определение взаимодействия с пользователем). Однако вы предоставили два аргумента: смотрите запятую перед shinyjs::hidden(...) в своем коде.

Пожалуйста, проверьте следующее:

library(shiny)
library(shinydashboard)

`%AND%` <- function (x, y) {
  if (!is.null(x) && !anyNA(x))
    if (!is.null(y) && !anyNA(y))
      return(y)
  return(NULL)
}

passwordInputAddon <-
  function (inputId,
            label,
            value = "",
            placeholder = NULL,
            addon,
            width = NULL)
  {
    value <- shiny::restoreInput(id = inputId, default = value)
    htmltools::tags$div(
      class = "form-group shiny-input-container",
      label %AND% htmltools::tags$label(label, `for` = inputId),
      style = if (!is.null(width))
        paste0("width: ", htmltools::validateCssUnit(width), ";"),
      htmltools::tags$div(
        style = "margin-bottom: 5px;",
        class = "input-group",
        addon %AND% htmltools::tags$span(class = "input-group-addon", addon),
        htmltools::tags$input(
          id = inputId,
          type = "password",
          class = "form-control",
          value = value,
          placeholder = placeholder
        )
      )
    )
  }

ui <- fluidPage(
  tags$div(
    id = "login_page_ui",
    shinyjs::useShinyjs(),
    tags$style(".container-fluid {margin-top: 13%}"),
    setBackgroundColor(color = "#2d3c44"),
    fluidRow(
      column(
        8,
        align = "center",
        offset = 2,
        textInputAddon(
          "name",
          label = "",
          placeholder = "Username",
          addon = icon("user"),
          width = "25%"
        ),
        tags$style(
          type = "text/css",
          "#string { height: 50px; width: 50%; text-align:center;
                        font-size: 30px; display: block;}"
        )
      )
    ),
    fluidRow(
      column(
        8,
        align = "center",
        offset = 2,
        passwordInputAddon(
          "password",
          label = "",
          placeholder = "Password",
          addon = icon("key"),
          width = "25%"
        ),
        tags$style(
          type = "text/css",
          "#string { height: 50px; width: 50%; text-align:center;
                        font-size: 30px; display: block;}"
        )
      )
    ),
    fluidRow(column(
      12, div(style = "height:20px;background-color: #2d3c44;")
    )),
    fluidRow(column(
      6,
      align = "center",
      offset = 3,
      actionButton(
        "login",
        label = "Login",
        width = "35%",
        style = "color: #fff; background-color: #1bc3d7; border-color: #1bc3d7;"
      )
    ))
  ),
  shinyjs::hidden(tags$div(
    id = "dashboard_page_ui",
    dashboardPage(
      dashboardHeader(title = "Shiny Dashboard",
                      tags$li(class = "dropdown")),
      dashboardSidebar(sidebarMenu(id = 'dashboard_menu',
                                   sidebarMenuOutput("menu"))),
      dashboardBody(tabItems(
        tabItem(tabName = "Item1"),
        tabItem(tabName = "Item2"),
        tabItem(tabName = "Item3")
      ))
    )
  ))
)

server <- function(input, output, session) {
  observeEvent(input$login, {
    if ((input$name == "test") & (input$password == "test123")) {
      shinyjs::show("dashboard_page_ui")
      shinyjs::hide("login_page_ui")
    }
  })
}

shinyApp(ui, server)
...