forked from ianartmor/shiny-phyloseq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.R
executable file
·94 lines (93 loc) · 3.33 KB
/
server.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
################################################################################
# Options, default settings, and load packages
################################################################################
# By default, the file size limit is 5MB. It can be changed by
# setting this option. Here we'll raise limit to 9MB.
options(shiny.maxRequestSize = 100*1024^2)
# Set Shiny Reaction Log to TRUE
options(shiny.reactlog=TRUE)
# Default ggplot2 theme (Only relevant if panel-specific theme missing or NULL)
theme_set(theme_bw())
################################################################################
# Begin Shiny Server definition.
################################################################################
# First store the inventory of objects (for provenance record)
shinyPhyloseqServerObjectsList = ls()
shinyServer(function(input, output){
# Data panel
source("panels/panel-server-data.R", local = TRUE)
# Filtering
source("panels/panel-server-filter.R", local = TRUE)
########################################
# Reactive UI Definition of Variables
########################################
# Define data-reactive variable lists
rankNames = reactive({
rankNames = as.list(rank_names(physeq(), errorIfNULL=FALSE))
names(rankNames) <- rankNames
return(rankNames)
})
variNames = reactive({
variNames = as.list(sample_variables(physeq(), errorIfNULL=FALSE))
names(variNames) <- variNames
return(variNames)
})
vars = function(type="both", withnull=TRUE, singles=FALSE){
if(!type %in% c("both", "taxa", "samples")){
stop("incorrect `type` specification when accessing variables for UI.")
}
returnvars = NULL
if(type=="samples"){
if(singles){
returnvars <- c(list(Sample="Sample"), variNames())
} else {
returnvars <- variNames()
}
}
if(type=="taxa"){
if(singles){
returnvars <- c(rankNames(), list(OTU="OTU"))
} else {
returnvars <- rankNames()
}
}
if(type=="both"){
# Include all variables
if(singles){
returnvars <- c(rankNames(), variNames(), list(OTU="OTU", Sample="Sample"))
} else {
returnvars <- c(rankNames(), variNames())
}
}
if(withnull){
# Put NULL first so that it is default when `select` not specified
returnvars <- c(list("NULL"="NULL"), returnvars)
}
return(returnvars)
}
# A generic selectInput UI. Plan is to pass a reactive argument to `choices`.
uivar = function(id, label="Variable:", choices, selected="NULL"){
selectInput(inputId=id, label=label, choices=choices, selected=selected)
}
# Bar
source("panels/panel-server-bar.R", local = TRUE)
# Tree
source("panels/panel-server-tree.R", local = TRUE)
# Heatmap
source("panels/panel-server-heatmap.R", local = TRUE)
# Richness
source("panels/panel-server-richness.R", local = TRUE)
# Ordination
source("panels/panel-server-ordination.R", local = TRUE)
# Network
source("panels/panel-server-net.R", local = TRUE)
# d3
source("panels/panel-server-d3.R", local = TRUE)
# Scatter
source("panels/panel-server-scatter.R", local = TRUE)
# Palette
source("panels/panel-server-palette.R", local = TRUE)
# Provenance
source("panels/panel-server-provenance.R", local = TRUE)
})
################################################################################