Skip to content

Commit

Permalink
Merge pull request #205 from DillonHammill/cyto_spillover_edit
Browse files Browse the repository at this point in the history
Add close button to cyto_spillover_edit().
  • Loading branch information
djhammill authored Jun 4, 2024
2 parents 479f70e + d76f892 commit 61d6448
Show file tree
Hide file tree
Showing 2 changed files with 74 additions and 54 deletions.
1 change: 1 addition & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
# CytoExploreR 2.0.7

* Bug fixes to handling of `page_fill` and `page_fill_alpha` within the `cyto_plot()` family of functions.
* Add `close` button to `cyto_spillove_edit()` which saves the spillover matrix and then kills the application.

# CytoExploreR 2.0.6

Expand Down
127 changes: 73 additions & 54 deletions R/cyto_spillover_edit.R
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,9 @@ cyto_spillover_edit <- function(x,
viewer = FALSE,
...) {

# NOTE: We can't run the app in a loop as it listens to previous port and
# uses spillover matrix from previous run as pData input for next run.

# PREPARE DATA ---------------------------------------------------------------

# CYTOSET/GATINGSET
Expand Down Expand Up @@ -158,7 +161,7 @@ cyto_spillover_edit <- function(x,
} else {
channels <- cyto_channels_extract(x, channels)
}

# SAMPLE NAMES
nms <- cyto_names(x)

Expand All @@ -177,7 +180,7 @@ cyto_spillover_edit <- function(x,
}
)
pd <- pd[match(rownames(cyto_details(x)), rownames(pd)), , drop = FALSE]
# BYPASS CHANNEL_MATCH
# BYPASS CHANNEL_MATCH
} else {
# BYPASS CYTO_CHANNEL_MATCH TO ALLOW FULL STAINED SAMPLES
lapply(
Expand All @@ -193,7 +196,7 @@ cyto_spillover_edit <- function(x,
}
)
}

# UPDATE EXPERIMENT DETAILS
cyto_details(x) <- pd

Expand Down Expand Up @@ -245,7 +248,7 @@ cyto_spillover_edit <- function(x,
# NO SPILLOVER MATRIX FOUND
if(!is.null(spillover)) {
spillover <- spillover[!LAPPLY(spillover, "is.null")][[1]]
# TEMPLATE SPILLOVER MATRIX
# TEMPLATE SPILLOVER MATRIX
} else {
spillover <- matrix(
0,
Expand All @@ -258,7 +261,7 @@ cyto_spillover_edit <- function(x,
)
diag(spillover) <- 1
}
# PREPARE SUPPLIED SPILLOVER MATRIX
# PREPARE SUPPLIED SPILLOVER MATRIX
} else {
spillover <- .cyto_spillover_prepare(
x,
Expand Down Expand Up @@ -317,7 +320,7 @@ cyto_spillover_edit <- function(x,
# AVOID UNSTAINED CONTROL
if (any(grepl("Unstained", pd$channel))) {
ID_select <- pd$name[!grepl("Unstained",pd$channel,ignore.case = TRUE)][1]
# USE FIRST SAMPLE
# USE FIRST SAMPLE
} else {
ID_select <- pd$name[1]
}
Expand Down Expand Up @@ -406,7 +409,11 @@ cyto_spillover_edit <- function(x,
"line",
"tracker"
)),
spillSaveUI("editor_save")
spillSaveUI("editor_save"),
actionButton(
"close",
"Close"
)
),
mainPanel(
width = 9,
Expand Down Expand Up @@ -443,18 +450,18 @@ cyto_spillover_edit <- function(x,
),
optionsUI(
"plots_options",
label = NULL,
selected = plots_opts_select,
choiceNames = list(
"Overlay unstained control",
"Overlay compensated data",
"Fit robust linear models"
),
choiceValues = list(
"unstained",
"compensated",
"models"
)
label = NULL,
selected = plots_opts_select,
choiceNames = list(
"Overlay unstained control",
"Overlay compensated data",
"Fit robust linear models"
),
choiceValues = list(
"unstained",
"compensated",
"models"
)
)
),
mainPanel(
Expand Down Expand Up @@ -563,7 +570,7 @@ cyto_spillover_edit <- function(x,
quiet = TRUE
)
}
# NO UNSTAINED CONTROL SELECTED
# NO UNSTAINED CONTROL SELECTED
} else {
values$NIL_comp_trans <- NULL
}
Expand Down Expand Up @@ -626,7 +633,7 @@ cyto_spillover_edit <- function(x,
quiet = TRUE
)
}
# NO SAMPLE SELECTED
# NO SAMPLE SELECTED
} else {
values$ID_comp_trans <- NULL
}
Expand Down Expand Up @@ -812,6 +819,18 @@ cyto_spillover_edit <- function(x,
save_as = save_as
)

# CLOSE
observeEvent(
input$close,
{
write_to_csv(
reactive(values$spill)(),
save_as
)
stopApp(read_from_csv(save_as))
}
)

# RETURN
onStop(function() {
stopApp(read_from_csv(save_as))
Expand Down Expand Up @@ -1068,33 +1087,33 @@ nodeSelectServer <- function(id,
moduleServer(
id,
function(input, output, session) {

# NAMESPACE
ns <- session$ns

# VALUES
values <- reactiveValues(
select = NULL
)

# UPDATE UI OPTIONS
observe({
if(cyto_class(data(), "GatingSet")) {
updateSelectInput(
session,
"select",
choices = cyto_nodes(data(), path = "auto"),
selected = selected()
)
}
})

observeEvent(input$select, {
values$select <- input$select

# NAMESPACE
ns <- session$ns

# VALUES
values <- reactiveValues(
select = NULL
)

# UPDATE UI OPTIONS
observe({
if(cyto_class(data(), "GatingSet")) {
updateSelectInput(
session,
"select",
choices = cyto_nodes(data(), path = "auto"),
selected = selected()
)
}
})

observeEvent(input$select, {
values$select <- input$select
})

return(reactive({values$select}))
})

return(reactive({values$select}))
})

}

Expand Down Expand Up @@ -1158,7 +1177,7 @@ spillEditServer <- function(id,
data.table = FALSE
)
}
# SPILLOVER MATRIX SUPPLIED
# SPILLOVER MATRIX SUPPLIED
} else {
sp <- spill()
}
Expand Down Expand Up @@ -1378,7 +1397,7 @@ editPlotServer <- function(id,
moduleServer(id, function(input,
output,
session){

# PLOTS
output$plot <- renderPlot({
# BYPASS PLOTS FOR MISSING DATA
Expand Down Expand Up @@ -1470,7 +1489,7 @@ editPlotServer <- function(id,
channel = chan,
inverse = TRUE
)
# NO TRANSFORMERS - LINEAR SCALE
# NO TRANSFORMERS - LINEAR SCALE
} else {
label_text_x <- min(lims) +
0.90 * diff(lims)
Expand Down Expand Up @@ -1644,7 +1663,7 @@ compPlotServer <- function(id,
cs <- cytoset(
cf_list
)
# STAINED ONLY
# STAINED ONLY
} else {
cs <- ID_comp_trans()
}
Expand Down Expand Up @@ -1750,10 +1769,10 @@ compPlotServer <- function(id,
function(z) {
if (z < n - 1) {
raw_data[raw_data[, channels[1]] >= chunks[z] &
raw_data[, channels[1]] < chunks[z + 1], ]
raw_data[, channels[1]] < chunks[z + 1], ]
} else {
raw_data[raw_data[, channels[1]] >= chunks[z] &
raw_data[, channels[1]] <= chunks[z + 1], ]
raw_data[, channels[1]] <= chunks[z + 1], ]
}
}
)
Expand Down Expand Up @@ -1807,4 +1826,4 @@ compPlotServer <- function(id,
)
}

}
}

0 comments on commit 61d6448

Please sign in to comment.