From 78b66d0fab2557cd4e0a13244eb371e6d521c9d3 Mon Sep 17 00:00:00 2001 From: Johannes Ranke Date: Fri, 23 Oct 2015 07:05:48 +0200 Subject: Remove the current selections from the gmkin workspace --- inst/GUI/gmkin.R | 268 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 264 insertions(+), 4 deletions(-) (limited to 'inst/GUI') diff --git a/inst/GUI/gmkin.R b/inst/GUI/gmkin.R index 0b615c4..45d04ad 100644 --- a/inst/GUI/gmkin.R +++ b/inst/GUI/gmkin.R @@ -83,7 +83,7 @@ update_f.df <- function() { if (!is.na(ftmp[1])) { f.df[1, "Name"] <- c("Temporary (not fitted)") } - if (!is.na(ws$f)) { + if (!is.na(ws$f[1])) { f.df.ws <- data.frame(Name = names(ws$f), stringsAsFactors = FALSE) f.df <- rbind(f.df, f.df.ws) } @@ -141,7 +141,7 @@ addHandlerClicked(p.gtable, p.switcher) ds.switcher <- function(h, ...) { ws$ds.cur <<- h$row_index svalue(c.ds) <- ds.df[ws$ds.cur, "Title"] - #update_ds_editor() + update_ds_editor() svalue(center) <- 2 } ds.gtable <- gtable(ds.df, cont = ds.gf, width = left_width - 10, height = 160) @@ -180,6 +180,22 @@ c.conf <- gbutton("Configure fit", cont = c.gf, handler = function(h, ...) svalu # center: Project editor {{{1 p.editor <- gframe("", horizontal = FALSE, cont = center, label = "Project") +# New project {{{2 +p.line.clear <- ggroup(cont = p.editor, horizontal = TRUE) +p.line.clear.b <- gbutton("New project", cont = p.line.clear, + handler = function(h, ...) { + project_name <- "New project" + svalue(p.name) <- project_name + svalue(p.filename) <- file.path(getwd(), paste0(project_name, ".gmkinws")) + p.delete$call_Ext("disable") + ws <<- gmkinws$new() + update_ds.df() + ds.gtable[,] <- ds.df + update_m.df() + m.gtable[,] <- m.df + update_f.df() + f.gtable[,] <- f.df + }) # Working directory {{{2 p.line.wd <- ggroup(cont = p.editor, horizontal = TRUE) wd_handler <- function(h, ...) { @@ -306,15 +322,259 @@ p.line.import.mb <- gbutton("Import selected", cont = p.line.import.mf, m.gtable[,] <- m.df } ) - - # center: Dataset editor {{{1 ds.editor <- gframe("", horizontal = FALSE, cont = center, label = "Dataset editor") +# # Handler functions {{{2 +# ds.empty <- list( +# study_nr = 1, +# title = "", +# sampling_times = c(0, 1), +# time_unit = "", +# observed = "parent", +# unit = "", +# replicates = 1, +# data = data.frame( +# name = "parent", +# time = c(0, 1), +# value = c(100, NA), +# override = "NA", +# err = 1, +# stringsAsFactors = FALSE)) + +# copy_dataset_handler <- function(h, ...) { +# ds.old <- ds.cur +# ds.cur <<- as.character(1 + length(ds)) +# svalue(ds.editor) <- paste("Dataset", ds.cur) +# ds[[ds.cur]] <<- ds[[ds.old]] +# update_ds.df() +# ds.gtable[,] <- ds.df +# } +# +# delete_dataset_handler <- function(h, ...) { +# if (length(ds) > 1) { +# ds[[ds.cur]] <<- NULL +# names(ds) <<- as.character(1:length(ds)) +# ds.cur <<- names(ds)[[1]] +# update_ds.df() +# ds.gtable[,] <- ds.df +# update_ds_editor() +# } else { +# galert("Deleting the last dataset is not supported", parent = w) +# } +# } +# +# new_dataset_handler <- function(h, ...) { +# ds.cur <<- as.character(1 + length(ds)) +# ds[[ds.cur]] <<- ds.empty +# update_ds.df() +# ds.gtable[,] <- ds.df +# update_ds_editor() +# } + +# tmptextheader <- character(0) +# load_text_file_with_data <- function(h, ...) { +# tmptextfile <<- normalizePath(svalue(h$obj), winslash = "/") +# tmptext <- readLines(tmptextfile, warn = FALSE) +# tmptextskip <<- 0 +# for (tmptextline in tmptext) { +# if (grepl(":|#|/", tmptextline)) tmptextskip <<- tmptextskip + 1 +# else break() +# } +# svalue(ds.e.up.skip) <- tmptextskip +# if (svalue(ds.e.up.header)) { +# tmptextheader <<- strsplit(tmptext[tmptextskip + 1], +# " |\t|;|,")[[1]] +# } +# svalue(ds.e.up.wide.time) <- tmptextheader[[1]] +# svalue(ds.e.up.long.time) <- tmptextheader[[2]] +# svalue(ds.e.up.text) <- c("
", tmptext, "
") +# svalue(ds.e.stack) <- 2 +# } +# +# new_ds_from_csv_handler <- function(h, ...) { +# tmpd <- try(read.table(tmptextfile, +# skip = as.numeric(svalue(ds.e.up.skip)), +# dec = svalue(ds.e.up.dec), +# sep = switch(svalue(ds.e.up.sep), +# whitespace = "", +# ";" = ";", +# "," = ","), +# header = svalue(ds.e.up.header), +# stringsAsFactors = FALSE)) +# if(svalue(ds.e.up.widelong) == "wide") { +# tmpdl <- mkin_wide_to_long(tmpd, time = as.character(svalue(ds.e.up.wide.time))) +# } else { +# tmpdl <- data.frame( +# name = tmpd[[svalue(ds.e.up.long.name)]], +# time = tmpd[[svalue(ds.e.up.long.time)]], +# value = tmpd[[svalue(ds.e.up.long.value)]]) +# tmpderr <- tmpd[[svalue(ds.e.up.long.err)]] +# if (!is.null(tmpderr)) tmpdl$err <- tmpderr +# } +# if (class(tmpd) != "try-error") { +# ds.cur <<- as.character(1 + length(ds)) +# ds[[ds.cur]] <<- list( +# study_nr = NA, +# title = "New import", +# sampling_times = sort(unique(tmpdl$time)), +# time_unit = "", +# observed = unique(tmpdl$name), +# unit = "", +# replicates = max(aggregate(tmpdl$time, +# list(tmpdl$time, +# tmpdl$name), +# length)$x), +# data = tmpdl) +# ds[[ds.cur]]$data$override <<- as.numeric(NA) +# if (is.null(ds[[ds.cur]]$data$err)) ds[[ds.cur]]$data$err <<- 1 +# update_ds.df() +# ds.gtable[,] <- ds.df +# update_ds_editor() +# } else { +# galert("Uploading failed", parent = "w") +# } +# } +# +# empty_grid_handler <- function(h, ...) { +# obs <- strsplit(svalue(ds.e.obs), ", ")[[1]] +# sampling_times <- strsplit(svalue(ds.e.st), ", ")[[1]] +# replicates <- as.numeric(svalue(ds.e.rep)) +# new.data = data.frame( +# name = rep(obs, each = replicates * length(sampling_times)), +# time = as.numeric(rep(sampling_times, each = replicates, times = length(obs))), +# value = as.numeric(NA), +# override = as.numeric(NA), +# err = 1, +# stringsAsFactors = FALSE +# ) +# ds.e.gdf[,] <- new.data +# } + +# keep_ds_changes_handler <- function(h, ...) { +# ds[[ds.cur]]$title <<- svalue(ds.title.ge) +# ds[[ds.cur]]$study_nr <<- as.numeric(gsub("Study ", "", svalue(ds.study.gc))) +# update_ds.df() +# ds.gtable[,] <- ds.df +# tmpd <- ds.e.gdf[,] +# ds[[ds.cur]]$data <<- tmpd +# ds[[ds.cur]]$sampling_times <<- sort(unique(tmpd$time)) +# ds[[ds.cur]]$time_unit <<- svalue(ds.e.stu) +# ds[[ds.cur]]$observed <<- unique(tmpd$name) +# ds[[ds.cur]]$unit <<- svalue(ds.e.obu) +# ds[[ds.cur]]$replicates <<- max(aggregate(tmpd$time, +# list(tmpd$time, tmpd$name), length)$x) +# update_ds_editor() +# observed.all <<- union(observed.all, ds[[ds.cur]]$observed) +# update_m_editor() +# } +# +# Widget setup {{{2 +# Line 1 {{{3 +ds.e.1 <- ggroup(cont = ds.editor, horizontal = TRUE) +ds.title.ge <- gedit("", label = "Title", width = 50, cont = ds.e.1) + +# # Line 2 {{{3 +# ds.e.2 <- ggroup(cont = ds.editor, horizontal = TRUE) +# ds.e.2a <- ggroup(cont = ds.e.2, horizontal = FALSE) +# gbutton("Copy dataset", cont = ds.e.2a, handler = copy_dataset_handler) +# gbutton("Delete dataset", cont = ds.e.2a, handler = delete_dataset_handler) +# gbutton("New dataset", cont = ds.e.2a, handler = new_dataset_handler) + +# ds.e.2b <- ggroup(cont = ds.e.2) +# tmptextfile <- "" # Initialize file name for imported data +# tmptextskip <- 0 # Initialize number of lines to be skipped +# tmptexttime <- "V1" # Initialize name of time variable if no header row +# upload_dataset.gf <- gfile(text = "Upload text file", cont = ds.e.2b, +# handler = load_text_file_with_data) + +# gbutton("Keep changes", cont = ds.e.2, handler = keep_ds_changes_handler) + +# # Line 3 with forms or upload area {{{3 +# ds.e.stack <- gstackwidget(cont = ds.editor) +# # Forms for meta data {{{4 +# ds.e.forms <- ggroup(cont = ds.e.stack, horizontal = TRUE) + +# ds.e.3a <- gvbox(cont = ds.e.forms) +# ds.e.3a.gfl <- gformlayout(cont = ds.e.3a) +# ds.e.st <- gedit(paste(ds[[ds.cur]]$sampling_times, collapse = ", "), +# width = 40, +# label = "Sampling times", +# cont = ds.e.3a.gfl) +# ds.e.stu <- gedit(ds[[ds.cur]]$time_unit, +# width = 20, +# label = "Unit", cont = ds.e.3a.gfl) +# ds.e.rep <- gedit(ds[[ds.cur]]$replicates, +# width = 20, +# label = "Replicates", cont = ds.e.3a.gfl) + +# ds.e.3b <- gvbox(cont = ds.e.forms) +# ds.e.3b.gfl <- gformlayout(cont = ds.e.3b) +# ds.e.obs <- gedit(paste(ds[[ds.cur]]$observed, collapse = ", "), +# width = 50, +# label = "Observed", cont = ds.e.3b.gfl) +# ds.e.obu <- gedit(ds[[ds.cur]]$unit, +# width = 20, label = "Unit", +# cont = ds.e.3b.gfl) +# generate_grid.gb <- gbutton("Generate empty grid for kinetic data", cont = ds.e.3b, +# handler = empty_grid_handler) +# tooltip(generate_grid.gb) <- "Overwrites the kinetic data shown below" +# # Data upload area {{{4 +# ds.e.upload <- ggroup(cont = ds.e.stack, horizontal = TRUE) +# ds.e.up.text <- ghtml("
", cont = ds.e.upload, width = 400, height = 400)
+# ds.e.up.options <- ggroup(cont = ds.e.upload, horizontal = FALSE)
+# ds.e.up.import <- gbutton("Import using options specified below", cont = ds.e.up.options,
+#                           handler = new_ds_from_csv_handler)
+# ds.e.up.skip <- gedit(tmptextskip, label = "Comment lines", cont = ds.e.up.options)
+# ds.e.up.header <- gcheckbox(cont = ds.e.up.options, label = "Column names", 
+#                             checked = TRUE)
+# ds.e.up.sep <- gcombobox(c("whitespace", ";", ","), cont = ds.e.up.options,
+#                          selected = 1, label = "Separator")
+# ds.e.up.dec <- gcombobox(c(".", ","), cont = ds.e.up.options,
+#                          selected = 1, label = "Decimal")
+# ds.e.up.widelong <- gradio(c("wide", "long"), horizontal = TRUE, 
+#                            label = "Format", cont = ds.e.up.options,
+#                            handler = function(h, ...) {
+#                              widelong = svalue(h$obj, index = TRUE)
+#                              svalue(ds.e.up.wlstack) <- widelong
+#                            })
+# ds.e.up.wlstack <- gstackwidget(cont = ds.e.up.options)
+# ds.e.up.wide <- ggroup(cont = ds.e.up.wlstack, horizontal = FALSE, width = 300)
+# ds.e.up.wide.time <- gedit(tmptexttime, cont = ds.e.up.wide, label = "Time column")
+# ds.e.up.long <- ggroup(cont = ds.e.up.wlstack, horizontal = FALSE, width = 300)
+# ds.e.up.long.name <- gedit("name", cont = ds.e.up.long, label = "Observed variables")
+# ds.e.up.long.time <- gedit(tmptexttime, cont = ds.e.up.long, label = "Time column")
+# ds.e.up.long.value <- gedit("value", cont = ds.e.up.long, label = "Value column")
+# ds.e.up.long.err <- gedit("err", cont = ds.e.up.long, label = "Relative errors")
+# svalue(ds.e.up.wlstack) <- 1
+
+# svalue(ds.e.stack) <- 1
+
+# # Kinetic Data {{{3
+# ds.e.gdf <- gdf(ds[[ds.cur]]$data, name = "Kinetic data", 
+#                 width = 500, height = 700, cont = ds.editor)
+# ds.e.gdf$set_column_width(2, 70)
+
+# # Update the dataset editor {{{3
+update_ds_editor <- function() {
+  svalue(ds.title.ge) <- ws$ds[[ws$ds.cur]]$title
+#   svalue(ds.study.gc, index = TRUE) <- ds[[ds.cur]]$study_nr
+
+#   svalue(ds.e.st) <- paste(ds[[ds.cur]]$sampling_times, collapse = ", ")
+#   svalue(ds.e.stu) <- ds[[ds.cur]]$time_unit
+#   svalue(ds.e.obs) <- paste(ds[[ds.cur]]$observed, collapse = ", ")
+#   svalue(ds.e.obu) <- ds[[ds.cur]]$unit
+#   svalue(ds.e.rep) <- ds[[ds.cur]]$replicates
+#   svalue(ds.e.stack) <- 1
+#   ds.e.gdf[,] <- ds[[ds.cur]]$data
+}
+# center: Model editor {{{1
 m.editor  <- gframe("", horizontal = FALSE, cont = center, 
                     label = "Model editor")
+# center: Fit configuration {{{1
 f.config  <- gframe("", horizontal = FALSE, cont = center, 
                     label = "Fit configuration")
+# center: Results viewer {{{1
 r.viewer  <- gframe("", horizontal = FALSE, cont = center, 
                     label = "Result viewer")
 svalue(center) <- 1
-- 
cgit v1.2.1