Как получить параметр из callModule () в R - PullRequest
1 голос
/ 07 марта 2019

Я разрабатываю блестящую приборную панель.Мне нужно получить имя пользователя в одиночку из модуля входа в систему.Я использую callModule () для выполнения аутентификации панели инструментов.

Код ui.R выглядит следующим образом:

library(shiny)
library(shinyauthr)
library(shinyjs)
shinyUI(
    fluidPage(
  # must turn shinyjs on
  shinyjs::useShinyjs(),
  # add logout button UI 
  div(class = "pull-right", shinyauthr::logoutUI(id = "logout")),
  # add login panel UI function
  shinyauthr::loginUI(id = "login"),
  # setup table output to show user info after login
  tableOutput("user_table")
)
)

Код server.R выглядит следующим образом:

library(shiny)
library(shinyauthr)
library(shinyjs)
library(DBI)
library(RMySQL)
library(dplyr)

# dataframe that holds usernames, passwords and other user data

user_base <- data.frame(
  user = c("user1", "user2"),
  password = c("pass1", "pass2"), 
  permissions = c("admin", "standard"),
  name = c("User One", "User Two"),
  stringsAsFactors = FALSE)

shinyServer(function(input, output, session) {

  # call the logout module with reactive trigger to hide/show
  logout_init <- callModule(shinyauthr::logout, 
                            id = "logout", 
                            active = reactive(credentials()$user_auth))


  # call login module supplying user and password cols
  # and reactive trigger
  credentials <- callModule(shinyauthr::login, 
                            id = "login", 
                            data = user_base,
                            user_col = user,
                            pwd_col = password,
                            log_out = reactive(logout_init()))

  print(class(credentials))
  # pulls out the user information returned from login module
  user_data <- reactive({credentials()$info})
  #user_name <- reactive({credentials()$user_col})
  print(user_data)

  output$user_table <- renderTable({
    # use req to only render results when credentials()$user_auth is TRUE
    req(credentials()$user_auth)
    user_data()
  })
})

Когда я пытаюсь использовать приведенный выше код, я получаю следующий вывод output.

Однако я не уверен в том, чтобы отображать только пользователя , а только пароль, разрешения и имя. Есть ли способ решить эту проблему?

1 Ответ

0 голосов
/ 07 марта 2019

Вы можете легко манипулировать данными, которые хотите отобразить: Вот несколько:

  1. user_data возвращает вам только имя пользователя

user_data <- reactive({credentials()$info[1]}) Потому что credentials()$info это просто массив символов, вы можете выбрать только первый: имя пользователя

renderTable показывает только имя пользователя: Вы можете сделать:

output$user_table <- renderTable({ req(credentials()$user_auth) user_data()[1] })

или

output$user_table <- renderTable({ # use req to only render results when credentials()$user_auth is TRUE req(credentials()$user_auth) userData <-user_data() userData[1] })

По той же логике, что и первая: в конце user_data это только какой-то символ, который вы хотите отфильтровать

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...