inst/shiny-examples/cluster_explorer/ui.R

#' @title Set the violin plot pannel
#'
#' @description A simple function to prepare the violin plot pannel
#' @param n The number of plots
#' @param nr The number of rows
#' @param nc The number of columns
#' @keywords interal
#' @examples
#' #This is an internal function, no example provided
violinplots_ui <- function(n, nr, nc){
  fulltxt <- "wellPanel("
  cnt <- 1
  colwidth <- 12 / nc
  for(i in 1:nr){
    new_row <-"fluidRow("
    for(j in 1:nc){
      new_col <- paste("column(plotlyOutput('violinplots",cnt,"'), width = ",colwidth,"),",sep="")
      new_row <- paste(new_row, new_col, sep = "")
      cnt <- cnt + 1
    }
    new_row <- paste(substr(new_row,1,nchar(new_row)-1),")",sep="")
    fulltxt <- paste(fulltxt, new_row, ",", sep = "")
  }
  fulltxt <- paste(substr(fulltxt,1,nchar(fulltxt)-1),")",sep="")
  return(eval(parse(text=fulltxt)))
}


#' @title Set the box plot pannel
#'
#' @description A simple function to prepare the box plot pannel in uncertainty
#' analysis
#' @param n The number of plots
#' @keywords interal
#' @examples
#' #This is an internal function, no example provided
boxplots_ui <- function(n){
  nc <- 6
  nr <- ceiling(n / nc)
  # NOTE : each plot will have a width of 2
  fulltxt <- "wellPanel("
  cnt <- 1
  for(i in 1:nr){
    new_row <-"fluidRow("
    for(j in 1:nc){
      new_col <- paste("column(plotlyOutput('boxplots",cnt,"'), width = 2),",sep="")
      new_row <- paste(new_row, new_col, sep = "")
      cnt <- cnt + 1
    }
    new_row <- paste(substr(new_row,1,nchar(new_row)-1),")",sep="")
    fulltxt <- paste(fulltxt, new_row, ",", sep = "")
  }
  fulltxt <- paste(substr(fulltxt,1,nchar(fulltxt)-1),")",sep="")
  return(eval(parse(text=fulltxt)))
}


#' @title Shiny App UI
#'
#' @description Set the UI for the Shiny App
#'
#' @importFrom shiny fluidPage tabsetPanel tabPanel titlePanel fluidRow wellPanel column selectInput checkboxInput sliderInput
#' @importFrom leaflet leafletOutput
#' @importFrom plotly plotlyOutput
#' @importFrom utils installed.packages
#'

## extracting all the variables from the shiny_data object
geocmeans_env <- geocmeans::geocmeans_env
shiny_data <- geocmeans_env$shiny_data
for (name in names(shiny_data)){
  assign(name, shiny_data[[name]])
}

## selecting the right number of columns and rows for the violinplots
nv <- length(variables)
nc <- floor(16 / ncol(belongings))
rest <-  nv %% nc
nr <- (nv-rest) / nc
if(rest > 0){
  nr <- nr + 1
}

library(shiny)
library(leaflet)
library(plotly)

welcome_message <- "Welcome in the classification explorer! Click on a feature on the map to start exploring the results of your classification,
The application is designed to help you to investigate the meaning of the groups obtained after a spatial fuzzy classification."

## check here if the shiny helper is ready !
add_helper <- "shinyhelper" %in% installed.packages()

if(add_helper){
  library(shinyhelper)
  helper_folder <- system.file("shiny-examples/cluster_explorer/www/help_mds",
                               package = "geocmeans", mustWork = TRUE)


  # loading the helper documentation
  filname <- paste(helper_folder, "map1", sep = "/")
  map1_string <- readChar(filname, file.info(filname)$size)
  filname <- paste(helper_folder, "radarchart", sep = "/")
  radar_string <- readChar(filname, file.info(filname)$size)
  filname <- paste(helper_folder, "bivariatechart", sep = "/")
  bivariate_string <- readChar(filname, file.info(filname)$size)
  filname <- paste(helper_folder, "uncertainpanel", sep = "/")
  uncertain_string <- readChar(filname, file.info(filname)$size)
}

## check here if the shiny helper is ready !
add_waiter <- "waiter" %in% installed.packages()

if(add_waiter){
  library(waiter)
}

ui <- fluidPage(
    {
      if(add_waiter){use_waiter(spinners = 4)}
    },
    {
      if(add_waiter){waiter_preloader(html =  spin_hexdots())}
    },
    tabsetPanel(
      tabPanel("Interactive map", fluid = TRUE,
               ##------------------- PANNEL 1 : for the interactive map------------------
               titlePanel('Interactive map'),
               # Grid Layout
               {if(is.null(light)){
                 fluidRow(
                   column(width = 4, wellPanel(welcome_message)),
                   column(width = 1, sliderInput("bg_opacity", label = "maps background opacity", min = 0, max = 1, value = 1)),
                   column(width = 7, img(src = "images/logo.png", height = 150, style = "float: right;")),

                 )
               }else{
                 fluidRow(column(width = 4, wellPanel(welcome_message)),
                          column(width = 1,{
                                   if("shinyWidgets" %in% installed.packages()){
                                     shinyWidgets::materialSwitch(inputId = "dark_mode", label = "Dark mode", status = "primary")
                                   }else{
                                     checkboxInput("dark_mode", "Dark mode")
                                   }}
                          ),
                          column(width = 1, sliderInput("bg_opacity", label = "maps background opacity", min = 0, max = 1, value = 1)),
                          column(width = 6, img(src = "images/logo.png", height = 150, style = "float: right;")),
                 )
               }},
               fluidRow(column(width = 8, wellPanel(
                 {
                   if(add_helper){
                     helper(leafletOutput("mymap"), type = "inline", content = map1_string)
                   }else{
                     leafletOutput("mymap")
                   }
                 }
                 )),
                        column(width = 4,
                               tabsetPanel(
                                 tabPanel("membership values", fluid = TRUE,
                                          wellPanel(plotlyOutput("barplot1", height = "360px"))
                                 ),
                                 tabPanel("radar chart", fluid = TRUE,
                                          {
                                            if(add_helper){
                                              helper(wellPanel(plotlyOutput("radarchart", height = "360px")), type = "inline", content = radar_string)
                                            }else{
                                              wellPanel(plotlyOutput("radarchart", height = "360px"))
                                            }
                                          }

                                 ),
                                 tabPanel("general informations", fluid = TRUE,
                                          tableOutput("general_infos")
                                 )
                               ))
               ),
               ## for the violin plots, with have to build a more complex environment
               fluidRow(violinplots_ui(n, nr, nc), height = paste(200*nc,"px",sep="")),
      ),

      tabPanel("Bivariate plot", fluid = TRUE,
               ##------------------- PANNEL 2 : for the bivariate plots------------------
               titlePanel('Interactive bivariate plots'),

               # Grid Layout
               fluidRow(wellPanel("In this panel, you can explore bivariate relationships for the different groups obtained")),
               {
                 if(add_helper){
                   helper(fluidRow(column(width = 2,
                                   selectInput("var1_biplot", "X axis variable", variables, selected = variables[[1]]),
                                   selectInput("var2_biplot", "Y axis variable", variables, selected = variables[[2]]),
                                   selectInput("group_biplot", "group membership for color", paste("group ", 1:ncol(belongings), sep = "")),
                                   {
                                     if("car" %in% installed.packages()){
                                       if("shinyWidgets" %in% installed.packages()){
                                         shinyWidgets::materialSwitch(inputId = "show_ellipsis", label = "show ellipsis", status = "primary")
                                       }else{
                                         checkboxInput("show_ellipsis", "show ellipsis")
                                       }
                                     }
                                   },
                   ),
                   column(width = 10,plotlyOutput("bivar_plot", height = "800px")),
                   ), type = "inline", content = bivariate_string)

                 }else{
                   fluidRow(column(width = 2,
                                   selectInput("var1_biplot", "X axis variable", variables, selected = variables[[1]]),
                                   selectInput("var2_biplot", "Y axis variable", variables, selected = variables[[2]]),
                                   selectInput("group_biplot", "group membership for color", paste("group ", 1:ncol(belongings), sep = "")),
                                   {
                                     if("car" %in% installed.packages()){
                                       if("shinyWidgets" %in% installed.packages()){
                                         shinyWidgets::materialSwitch(inputId = "show_ellipsis", label = "show ellipsis", status = "primary")
                                       }else{
                                         checkboxInput("show_ellipsis", "show ellipsis")
                                       }
                                     }
                                   },
                   ),
                   column(width = 10,plotlyOutput("bivar_plot", height = "800px")),
                   )
                 }
               },
      ),

      tabPanel("Uncertain observations", fluid = TRUE,
               ##------------------- PANNEL 3 : Uncertainty analysis------------------
               titlePanel('Analysis of uncertain observations'),

               # Grid Layout
               fluidRow(wellPanel("In this panel, you can explore the observations that are not well classified")),
               {
                 if(add_helper){
                   helper(fluidRow(column(width = 2,sliderInput("uncertain1", "minimum probability", min = 0, max = 1, value = 0.45))), type = "inline", content = uncertain_string)
                 }else{
                   fluidRow(column(width = 2,sliderInput("uncertain1", "minimum probability", min = 0, max = 1, value = 0.45)))
                 }
               },
               fluidRow(column(width = 5, leafletOutput("uncertainmap", height = "600px")),
                        column(width = 1,
                               selectInput("var1_biplot2", "X axis variable", variables, selected = variables[[1]]),
                               selectInput("var2_biplot2", "Y axis variable", variables, selected = variables[[2]]),
                        ),
                        column(width = 6, plotlyOutput("bivar_plot2", height = "600px")),
               ),
               fluidRow(boxplots_ui(nv)),
      )

    ),
    theme = light
  )

Try the geocmeans package in your browser

Any scripts or data that you put into this service are public.

geocmeans documentation built on Sept. 12, 2023, 9:06 a.m.