R/IsoCorrectionGUI.R

Defines functions help showAbout openhelp AdvancedOptions finish correction initGUI IsoCorrectionGUI

Documented in IsoCorrectionGUI

#' Graphical User Interface for IsoCorrectoR
#'
#' @import IsoCorrectoR
#' @import tcltk
#' @import readxl
#' @importFrom tcltk2 tk2tip
#' @importFrom tcltk2 tk2frame
#' @importFrom utils browseURL
#' @importFrom utils packageVersion
#'
#' @export
#'
#' @examples
#'
#'  IsoCorrectionGUI()
#'
#' @return Calls internal function to display IsoCorrectoR's Graphical User Interface
IsoCorrectionGUI <- function() {
  initGUI()
}

baseEnvRef<-new.env()

# Main function of IsoCorrectoR GUI

initGUI <- function(advancedOptions = FALSE, filenameStartvalue = "", elementfileStartvalue = "", moleculefileStartvalue = "", DirOutStartvalue = "", FileOutStartvalue = "result",
                    UHRStartvalue = FALSE, CorrectTracerImpurityStartvalue = FALSE, CorrectTracerElementCoreStartvalue = TRUE, CalculateMeanEnrichmentStartvalue = TRUE, Calculation_thresholdStartvalue = 1e-08,
                    CalcThreshUHRStartvalue = 8, CalculateMonoisotopicProbStartvalue = FALSE, FileFormatStartvalue = "csv", testmode=NA) {

  # Set this base environment variable as a flag to determine if execution should continue or be aborted in the case of directly starting from a batch file

  #baseEnvRef <- baseenv()
  baseEnvRef$continueIsoCorrection <- TRUE

  # Define internal functions (must be defined within initGUI() to work)

  # Function to destroy top-level window

  windestroy <- function() {
    tcltk::tkdestroy(win)
    #baseEnvRef <- baseenv()
    baseEnvRef$continueIsoCorrection <- FALSE
  }

  # Functions for file/directory browsing

  # Function to select measurementfile via filechooser/browser

  filebrowser.filename <- function() {
    filename.global <<- tcltk::tclVar(tk_choose.files())
    tcltk::tkconfigure(entry.filename, textvariable = filename.global)
  }

  # Function to select elementfile via filechooser/browser

  filebrowser.elementfile <- function() {
    elementfile.global <<- tcltk::tclVar(tk_choose.files())
    tcltk::tkconfigure(entry.elementfile, textvariable = elementfile.global)
  }

  # Function to select moleculefile via filechooser/browser

  filebrowser.moleculefile <- function() {
    moleculefile.global <<- tcltk::tclVar(tk_choose.files())
    tcltk::tkconfigure(entry.moleculefile, textvariable = moleculefile.global)
  }

  # Function to select Output Directory via directorychooser/browser

  dirbrowser.DirOut <- function() {
    DirOut.global <<- tcltk::tclVar(tk_choose.dir())
    tcltk::tkconfigure(entry.DirOut, textvariable = DirOut.global)
  }

  # Specify styles and fonts

  .Tcl("ttk::style theme use default")

  fontset <- list()

  fontset$fontTextLabel <- tcltk::tkfont.create(family = "font", size = 12)
  fontset$fontHelptext <- tcltk::tkfont.create(family = "font", size = 13)
  fontset$fontErrortext <- tcltk::tkfont.create(family = "font", size = 12)
  fontset$fontSmall <- tcltk::tkfont.create(family = "font", size = 4)

  tcltk::tcl("ttk::style", "configure", "But.TButton", "-background", "cornflower blue", "-borderwidth", "5", font = "helvetica 12", padding = 0, focusthickness = 5)
  tcltk::tcl("ttk::style", "configure", "Select.TButton", "-background", "cornflower blue", "-borderwidth", "2", font = "helvetica 10", padding = 0, focusthickness = 5)
  tcltk::tcl("ttk::style", "configure", "Check.TCheckbutton",
    relief = "raised", shiftrelief = 0, padding = 0, background = "cornflower blue", indicatorcolor = "white",
    indicatorrelief = "sunken", indicatordiameter = 20, indicatormargin = 0, borderwidth = 4, focusthickness = 0, text = "test", justify = "left", foreground = "red"
  )
  tcltk::tcl("ttk::style", "configure", "Test.TFrame", "-background", "white", "-borderwidth", "10", relief = "raised")
  tcltk::tcl("ttk::style", "configure", "Gray.TButton", "-background", "lightgray", "-borderwidth", "5", font = "helvetica 12", padding = 0, focusthickness = 5)
  tcltk::tcl("ttk::style", "configure", "Rad.TRadiobutton", "-background", "SystemMenu",
    fg = "cornflower blue", shiftrelief = 0, padding = 0, bordercolor = "cornflower blue",
    indicatorcolor = "white", indicatorrelief = "sunken", indicatordiameter = 20, indicatormargin = 0, borderwidth = 3, focusthickness = 5, font = "helvetica 12"
  )

  # Create window
  win <- tcltk::tktoplevel()

  # Rewrite window manager function to call windestroy()

  tcltk::tcl("wm", "protocol", win, "WM_DELETE_WINDOW", windestroy)

  tcltk::tkwm.title(win, "IsoCorrectoR")
  tcltk::tkfocus(win)

  # Add help menu
  topMenu <- tcltk::tkmenu(win)
  tcltk::tkconfigure(win, menu = topMenu, bd = 0)
  helpMenu <- tcltk::tkmenu(topMenu, tearoff = FALSE, activebackground = "cornflower blue", bg = "white", bd = 0)
  tcltk::tkadd(helpMenu, "command", label = "How to use IsoCorrectoR", command = function() openhelp())
  tcltk::tkadd(helpMenu, "command", label = "About", command = function() showAbout())
  tcltk::tkadd(topMenu, "cascade", label = "Help", menu = helpMenu)

  # Enter measurement file
  filename.global <- tcltk::tclVar(filenameStartvalue)
  filename.tip <- tcltk::tklabel(win, text = "Measurement File:", font = fontset$fontTextLabel, justify = "left")
  entry.filename <- tcltk::tkentry(win, width = "60", textvariable = filename.global, bg = "white")
  browse.button.filename <- tcltk::ttkbutton(win, text = "Select", command = filebrowser.filename)
  tcltk::tkgrid(filename.tip, row = 0, column = 0, sticky = "w")
  tcltk::tkgrid(entry.filename, row = 0, column = 2)
  tcltk::tkgrid(browse.button.filename, row = 0, column = 3)
  tcltk2::tk2tip(filename.tip, "Please enter or choose file with measured data")

  # Enter Molecule File
  moleculefile.global <- tcltk::tclVar(moleculefileStartvalue)
  moleculefile.tip <- tcltk::tklabel(win, text = "Molecule File:", font = fontset$fontTextLabel, justify = "left")
  entry.moleculefile <- tcltk::tkentry(win, width = "60", textvariable = moleculefile.global, bg = "white")
  browse.button.moleculefile <- tcltk::ttkbutton(win, text = "Select", command = filebrowser.moleculefile)
  tcltk::tkgrid(moleculefile.tip, row = 1, column = 0, sticky = "w")
  tcltk::tkgrid(entry.moleculefile, row = 1, column = 2)
  tcltk::tkgrid(browse.button.moleculefile, row = 1, column = 3)
  tcltk2::tk2tip(moleculefile.tip, "Please enter or choose file with molecule data")

  # Enter Element File
  elementfile.global <- tcltk::tclVar(elementfileStartvalue)
  elementfile.tip <- tcltk::tklabel(win, text = "Element File:", font = fontset$fontTextLabel, justify = "left")
  entry.elementfile <- tcltk::tkentry(win, width = "60", textvariable = elementfile.global, bg = "white")
  browse.button.elementfile <- tcltk::ttkbutton(win, text = "Select", command = filebrowser.elementfile)
  tcltk::tkgrid(elementfile.tip, row = 2, column = 0, sticky = "w")
  tcltk::tkgrid(entry.elementfile, row = 2, column = 2)
  tcltk::tkgrid(browse.button.elementfile, row = 2, column = 3)
  tcltk2::tk2tip(elementfile.tip, "Please enter or choose file with element data")

  # Enter DirOut

  DirOut.global <- tcltk::tclVar(DirOutStartvalue)
  DirOut.tip <- tcltk::tklabel(win, text = "Output Directory:", font = fontset$fontTextLabel, justify = "left")
  entry.DirOut <- tcltk::tkentry(win, width = "60", textvariable = DirOut.global, bg = "white")
  browse.button.DirOut <- tcltk::ttkbutton(win, text = "Select", command = dirbrowser.DirOut)
  tcltk::tkgrid(DirOut.tip, row = 3, column = 0, sticky = "w")
  tcltk::tkgrid(entry.DirOut, row = 3, column = 2)
  tcltk::tkgrid(browse.button.DirOut, row = 3, column = 3)
  tcltk2::tk2tip(DirOut.tip, "Please enter or choose directory path to write results to")

  # Name Output file
  if (FileOutStartvalue == "") {
    FileOutStartvalue <- "result"
  }
  FileOut.global <- tcltk::tclVar(FileOutStartvalue)
  FileOut.tip <- tcltk::tklabel(win, text = "Name Outputfile:", font = fontset$fontTextLabel, justify = "left")
  entry.FileOut <- tcltk::tkentry(win, width = "60", textvariable = FileOut.global, bg = "white")
  tcltk::tkgrid(FileOut.tip, row = 4, column = 0, sticky = "w")
  tcltk::tkgrid(entry.FileOut, row = 4, column = 2)
  tcltk2::tk2tip(FileOut.tip, "Please enter name for your output file")

  # Choose output file format via radiobuttons
  if (FileFormatStartvalue == "") {
    FileFormatStartvalue <- "csv"
  }
  FileFormatValue <- tcltk::tclVar(FileFormatStartvalue)
  FileFormat.tip <- tcltk::tklabel(win, text = "Format Outputfile:", font = fontset$fontTextLabel, justify = "left")
  frame <- tcltk2::tk2frame(win, borderwidth = 0)
  tcltk::tkgrid(frame, row = 5, column = 2)
  win$env$rb1 <- tcltk::ttkradiobutton(frame, text = ".csv  ")
  win$env$rb2 <- tcltk::ttkradiobutton(frame, text = ".xls")
  tcltk::tkconfigure(win$env$rb1, variable = FileFormatValue, value = "csv")
  tcltk::tkconfigure(win$env$rb2, variable = FileFormatValue, value = "xls")
  tcltk::tkgrid(FileFormat.tip, row = 5, column = 0, sticky = "w")
  tcltk::tkgrid(win$env$rb1, win$env$rb2)

  UltraHighResvalue <- tcltk::tclVar(as.character(as.integer(UHRStartvalue)))
  CorrectTracerImpurityvalue <- tcltk::tclVar(as.character(as.integer(CorrectTracerImpurityStartvalue)))
  CorrectTracerElementCorevalue <- tcltk::tclVar(as.character(as.integer(CorrectTracerElementCoreStartvalue)))
  CalculateMeanEnrichmentvalue <- tcltk::tclVar(as.character(as.integer(CalculateMeanEnrichmentStartvalue)))
  Calculation_thresholdvalue <- tcltk::tclVar(as.character(Calculation_thresholdStartvalue))
  CalcThreshUHRvalue <- tcltk::tclVar(as.character(CalcThreshUHRStartvalue))
  CalcMonoisotopicProbabilitiesvalue <- tcltk::tclVar(as.character(as.integer(CalculateMonoisotopicProbStartvalue)))

  # Check Button CorrectTracerImpurity
  check.CorrectTracerImpurity <- tcltk::ttkcheckbutton(win)
  CorrectTracerImpurity.tip <- tcltk::tklabel(win, text = "Correct Tracer Impurity:", font = fontset$fontTextLabel, justify = "left")
  tcltk::tkgrid(CorrectTracerImpurity.tip, sticky = "w")
  tcltk::tkgrid(check.CorrectTracerImpurity, row = 6, column = 1)
  tcltk::tkconfigure(check.CorrectTracerImpurity, variable = CorrectTracerImpurityvalue)
  tcltk2::tk2tip(CorrectTracerImpurity.tip, "Correct for isotopic impurity of the tracer substrate?")

  # Check Button CorrectTracerElementCore
  check.CorrectTracerElementCore <- tcltk::ttkcheckbutton(win)
  CorrectTracerElementCore.tip <- tcltk::tklabel(win, text = "Corr. Tracer Element Core:", font = fontset$fontTextLabel, justify = "left")
  tcltk::tkgrid(CorrectTracerElementCore.tip, sticky = "w")
  tcltk::tkgrid(check.CorrectTracerElementCore, row = 7, column = 1)
  tcltk::tkconfigure(check.CorrectTracerElementCore, variable = CorrectTracerElementCorevalue)
  tcltk2::tk2tip(CorrectTracerElementCore.tip, "Take into account the natural isotope abundance of the tracer element atoms in the core molecule when correcting?")

  # Check Button CalculateMeanEnrichment
  check.CalculateMeanEnrichment <- tcltk::ttkcheckbutton(win)
  CalculateMeanEnrichment.tip <- tcltk::tklabel(win, text = "Calculate Mean Enrichment:   ", font = fontset$fontTextLabel, justify = "left")
  tcltk::tkgrid(CalculateMeanEnrichment.tip, sticky = "w")
  tcltk::tkgrid(check.CalculateMeanEnrichment, row = 8, column = 1)
  tcltk::tkconfigure(check.CalculateMeanEnrichment, variable = CalculateMeanEnrichmentvalue)
  tcltk2::tk2tip(CalculateMeanEnrichment.tip, "Calculate mean enrichment?")

  # Check Button UltraHighRes
  check.UltraHighRes <- tcltk::ttkcheckbutton(win)
  UltraHighRes.tip <- tcltk::tklabel(win, text = "High Resolution Mode:", font = fontset$fontTextLabel, justify = "left")
  tcltk::tkgrid(UltraHighRes.tip, sticky = "w")
  tcltk::tkgrid(check.UltraHighRes, row = 9, column = 1)
  tcltk::tkconfigure(check.UltraHighRes, variable = UltraHighResvalue)
  tcltk2::tk2tip(UltraHighRes.tip, "Perform correction of high resolution MS data (high resolution data allows handling of multiple different tracer elements in the same measurement)?")

  # Advanced options

  if (advancedOptions == FALSE) {
    AdvancedOptionsText <- "Advanced Options"
  } else {
    AdvancedOptionsText <- "Hide Advanced Options"

    # Check Monoisotopic Probability
    check.CalcMonoisotopicProbabilities <- tcltk::ttkcheckbutton(win)
    CalcMonoisotopicProbabilities.tip <- tcltk::tklabel(win, text = "Monoisotopic Results:", font = fontset$fontTextLabel, justify = "left")
    tcltk::tkgrid(CalcMonoisotopicProbabilities.tip, sticky = "w")
    tcltk::tkgrid(check.CalcMonoisotopicProbabilities, row = 10, column = 1)
    tcltk::tkconfigure(check.CalcMonoisotopicProbabilities, variable = CalcMonoisotopicProbabilitiesvalue)
    tcltk2::tk2tip(CalcMonoisotopicProbabilities.tip, "Get monoisotopic correction results in addition to normal results, see Help for more information.")

    # Enter Calculation threshold
    Calculation_threshold.tip <- tcltk::tklabel(win, text = "Calculation Threshold:", font = fontset$fontTextLabel, justify = "left")
    entry.Calculation_threshold <- tcltk::tkentry(win, width = "20", textvariable = Calculation_thresholdvalue, bg = "white")
    tcltk::tkgrid(Calculation_threshold.tip, sticky = "w")
    tcltk::tkgrid(entry.Calculation_threshold, row = 11, column = 2)
    tcltk2::tk2tip(Calculation_threshold.tip, "Usually, this parameter should not be changed. See Help for further information")

    # Enter Calculation threshold regarding UHR
    CalcThreshUHR.tip <- tcltk::tklabel(win, text = "Calc. Thresh. UHR:", font = fontset$fontTextLabel, justify = "left")
    entry.CalcThreshUHR <- tcltk::tkentry(win, width = "20", textvariable = CalcThreshUHRvalue, bg = "white")
    tcltk::tkgrid(CalcThreshUHR.tip, sticky = "w")
    tcltk::tkgrid(entry.CalcThreshUHR, row = 12, column = 2)
    tcltk2::tk2tip(CalcThreshUHR.tip, "Usually, this parameter should not be changed. See Help for further information")
  }

  AO.button <- tcltk::ttkbutton(win,
    text = AdvancedOptionsText,
    command = function() AdvancedOptions(
        win = win, advancedOptions = !advancedOptions, filenameStartvalue = tclvalue(filename.global), elementfileStartvalue = tclvalue(elementfile.global), moleculefileStartvalue = tclvalue(moleculefile.global),
        DirOutStartvalue = tclvalue(DirOut.global), FileOutStartvalue = tclvalue(FileOut.global), UHRStartvalue = as.logical(as.integer(tclvalue(UltraHighResvalue))),
        CorrectTracerImpurityStartvalue = as.logical(as.integer(tclvalue(CorrectTracerImpurityvalue))), CorrectTracerElementCoreStartvalue = as.logical(as.integer(tclvalue(CorrectTracerElementCorevalue))),
        CalculateMeanEnrichmentStartvalue = as.logical(as.integer(tclvalue(CalculateMeanEnrichmentvalue))), Calculation_thresholdStartvalue = as.double(tclvalue(Calculation_thresholdvalue)),
        CalcThreshUHRStartvalue = as.double(tclvalue(CalcThreshUHRvalue)), CalculateMonoisotopicProbStartvalue = as.logical(as.integer(tclvalue(CalcMonoisotopicProbabilitiesvalue))),
        FileFormatStartvalue = tclvalue(FileFormatValue)
      )
  )
  tcltk::tkgrid(AO.button, row = 9, column = 2)

  blankspace <- tcltk::tklabel(win, text = " ", font = fontset$fontSmall)
  tcltk::tkgrid(blankspace)

  Correct.button <- tcltk::ttkbutton(win,
    text = "Start Correction",
    command = function() correction(
        win = win, filename = filename.global, elementfile = elementfile.global,
        moleculefile = moleculefile.global, FileOut = FileOut.global,
        UltraHighResvalue = UltraHighResvalue,
        CorrectTracerImpurityvalue = CorrectTracerImpurityvalue,
        CorrectTracerElementCorevalue = CorrectTracerElementCorevalue,
        CalculateMeanEnrichmentvalue = CalculateMeanEnrichmentvalue,
        Calculation_thresholdvalue = Calculation_thresholdvalue,
        CalcThreshUHRvalue = CalcThreshUHRvalue,
        CalcMonoisotopicProbabilitiesvalue = CalcMonoisotopicProbabilitiesvalue,
        DirOut = DirOut.global,
        FileFormatValue = FileFormatValue,
        fontset = fontset
      )
  )

  tcltk::tkgrid(Correct.button, column = 2)

  tcltk::tkfocus(win)
  
  if(!is.na(testmode)) {
    
    #Imitate functions that assign parameters upon user input in the GUI
    
    if(testmode == "modified_input" || (testmode == "modified_input_advanced_options" && !advancedOptions)) {
      
      filename.global <- tcltk::tclVar("MeasurementFileTest.csv")
      
      moleculefile.global <- tcltk::tclVar("MoleculeFileTest.csv")
      
      elementfile.global <- tcltk::tclVar("ElementFileTest.csv")
      
      DirOut.global <- tcltk::tclVar("DirOutTest")
      
      FileOut.global <- tcltk::tclVar("resultTest")
      
      FileFormatValue <- tcltk::tclVar("xls")
      
      UltraHighResvalue <- tcltk::tclVar(as.character(as.integer(TRUE)))
      
      CorrectTracerImpurityvalue <- tcltk::tclVar(as.character(as.integer(TRUE)))
      
      CorrectTracerElementCorevalue <- tcltk::tclVar(as.character(as.integer(FALSE)))
      
      CalculateMeanEnrichmentvalue <- tcltk::tclVar(as.character(as.integer(FALSE)))
      
      CalcMonoisotopicProbabilitiesvalue <- tcltk::tclVar(as.character(as.integer(TRUE)))
      
      Calculation_thresholdvalue <- tcltk::tclVar(as.character(10^(-6)))
      
      CalcThreshUHRvalue <- tcltk::tclVar(as.character(6))
      
    }
    
    if((testmode == "default_input_advanced_options" || testmode == "modified_input_advanced_options") && !advancedOptions) {
      
      correctionValues <- AdvancedOptions(
        win = win, advancedOptions = !advancedOptions, filenameStartvalue = tclvalue(filename.global), elementfileStartvalue = tclvalue(elementfile.global), moleculefileStartvalue = tclvalue(moleculefile.global),
        DirOutStartvalue = tclvalue(DirOut.global), FileOutStartvalue = tclvalue(FileOut.global), UHRStartvalue = as.logical(as.integer(tclvalue(UltraHighResvalue))),
        CorrectTracerImpurityStartvalue = as.logical(as.integer(tclvalue(CorrectTracerImpurityvalue))), CorrectTracerElementCoreStartvalue = as.logical(as.integer(tclvalue(CorrectTracerElementCorevalue))),
        CalculateMeanEnrichmentStartvalue = as.logical(as.integer(tclvalue(CalculateMeanEnrichmentvalue))), Calculation_thresholdStartvalue = as.double(tclvalue(Calculation_thresholdvalue)),
        CalcThreshUHRStartvalue = as.double(tclvalue(CalcThreshUHRvalue)), CalculateMonoisotopicProbStartvalue = as.logical(as.integer(tclvalue(CalcMonoisotopicProbabilitiesvalue))),
        FileFormatStartvalue = tclvalue(FileFormatValue), testmode = testmode
      )
      
    } else {
    
      correctionValues <- correction(
        win = win, filename = filename.global, elementfile = elementfile.global,
        moleculefile = moleculefile.global, FileOut = FileOut.global,
        UltraHighResvalue = UltraHighResvalue,
        CorrectTracerImpurityvalue = CorrectTracerImpurityvalue,
        CorrectTracerElementCorevalue = CorrectTracerElementCorevalue,
        CalculateMeanEnrichmentvalue = CalculateMeanEnrichmentvalue,
        Calculation_thresholdvalue = Calculation_thresholdvalue,
        CalcThreshUHRvalue = CalcThreshUHRvalue,
        CalcMonoisotopicProbabilitiesvalue = CalcMonoisotopicProbabilitiesvalue,
        DirOut = DirOut.global,
        FileFormatValue = FileFormatValue,
        fontset = fontset,
        testmode = testmode
      )
      
    }
    
    return(correctionValues)
    
  }
}

# SUBFUNCTIONS OF initGUI()

# Function of the 'Correct' button

correction <- function(win, filename, elementfile, moleculefile, FileOut,
                       UltraHighResvalue, CorrectTracerImpurityvalue,
                       CorrectTracerElementCorevalue, CalculateMeanEnrichmentvalue,
                       Calculation_thresholdvalue, CalcThreshUHRvalue,
                       CalcMonoisotopicProbabilitiesvalue, DirOut,
                       FileFormatValue, fontset, testmode=NA) {

  # Function for creating the error-pop-up-windows
  errorwindow <- function(text, fontset) {

    # Function of the 'OK' button in error-pop-up-windows
    destroy <- function() {
      tcltk::tkdestroy(errwin)
    }

    errwin <- tcltk::tktoplevel()
    tcltk::tkwm.title(errwin, "Error")
    errtext <- tcltk::tklabel(errwin, text = text, font = fontset$fontErrortext)
    tcltk::tkgrid(errtext)
    OK.button <- tcltk::ttkbutton(errwin, text = "OK", command = destroy)
    tcltk::tkgrid(OK.button)
  }

  # Changing from tclvalues to R classes
  filenameVal <- tcltk::tclvalue(filename)
  elementfileVal <- tcltk::tclvalue(elementfile)
  moleculefileVal <- tcltk::tclvalue(moleculefile)
  FileOutVal <- tcltk::tclvalue(FileOut)
  UltraHighResVal <- as.logical(as.integer(tcltk::tclvalue(UltraHighResvalue)))
  CorrectTracerImpurityVal <- as.logical(as.integer(tcltk::tclvalue(CorrectTracerImpurityvalue)))
  CorrectTracerElementCoreVal <- as.logical(as.integer(tcltk::tclvalue(CorrectTracerElementCorevalue)))
  CalculateMeanEnrichmentVal <- as.logical(as.integer(tcltk::tclvalue(CalculateMeanEnrichmentvalue)))
  Calculation_thresholdVal <- as.double(tcltk::tclvalue(Calculation_thresholdvalue))
  CalcThreshUHRVal <- as.integer(tcltk::tclvalue(CalcThreshUHRvalue))
  CalcMonoisotopicProbabilitiesVal <- as.logical(as.integer(tcltk::tclvalue(CalcMonoisotopicProbabilitiesvalue)))
  DirOutVal <- tcltk::tclvalue(DirOut)
  FileFormatVal <- tcltk::tclvalue(FileFormatValue)
  
  if(is.na(testmode)) {

    # Intercept input errors
  
    errorConditionNames <- c(
      "filenameValGiven", "elementfileValGiven", "moleculefileValGiven",
      "DirOutValGiven", "FileOutValGiven", "filenameValFileExists",
      "elementfileValFileExists", "moleculefileValFileExists",
      "DirOutValDirExists", "Calculation_thresholdVal", "CalcThreshUHRVal"
    )
  
    errorConditions <- vector(mode = "logical", length = length(errorConditionNames))
  
    names(errorConditions) <- errorConditionNames
  
    errorConditions["filenameValGiven"] <- filenameVal != ""
    errorConditions["elementfileValGiven"] <- elementfileVal != ""
    errorConditions["moleculefileValGiven"] <- moleculefileVal != ""
    errorConditions["DirOutValGiven"] <- DirOutVal != ""
    errorConditions["FileOutValGiven"] <- FileOutVal != ""
  
    errorConditions["filenameValFileExists"] <- file.exists(filenameVal)
    errorConditions["elementfileValFileExists"] <- file.exists(elementfileVal)
    errorConditions["moleculefileValFileExists"] <- file.exists(moleculefileVal)
    errorConditions["DirOutValDirExists"] <- dir.exists(DirOutVal)
  
    errorConditions["Calculation_thresholdVal"] <- !is.na(Calculation_thresholdVal)
    errorConditions["CalcThreshUHRVal"] <- !is.na(CalcThreshUHRVal)
  
    errorMessages <- vector(mode = "character", length = length(errorConditions))
  
    names(errorMessages) <- names(errorConditions)
  
    errorMessages["filenameValGiven"] <- "Please choose measurement file"
    errorMessages["elementfileValGiven"] <- "Please choose element file"
    errorMessages["moleculefileValGiven"] <- "Please choose molecule file"
    errorMessages["DirOutValGiven"] <- "Please choose output directory"
    errorMessages["FileOutValGiven"] <- "Please enter name of the output file"
  
    errorMessages["filenameValFileExists"] <- "Measurement File does not exist"
    errorMessages["elementfileValFileExists"] <- "Element File does not exist"
    errorMessages["moleculefileValFileExists"] <- "Molecule File does not exist"
    errorMessages["DirOutValDirExists"] <- "Output directory does not exist"
  
    errorMessages["Calculation_thresholdVal"] <- "Please enter numeric value for Calculation threshold"
    errorMessages["CalcThreshUHRVal"] <- "Please enter numeric value for Calculation threshold UHR"
  
    errorFlag <- FALSE
  
    for (errorCondition in names(errorConditions)) {
      if (errorFlag == FALSE && errorConditions[errorCondition] == FALSE) {
        errorwindow(text = errorMessages[errorCondition], fontset = fontset)
        errorFlag <- TRUE
      }
    }
  
    if (errorFlag == FALSE) {
      print("Correction")
      tcltk::tkdestroy(win)
      results <- IsoCorrectoR::IsoCorrection(
        MeasurementFile = filenameVal, ElementFile = elementfileVal, FileOutFormat = FileFormatVal, MoleculeFile = moleculefileVal,
        UltraHighRes = UltraHighResVal, CorrectTracerImpurity = CorrectTracerImpurityVal, CorrectTracerElementCore = CorrectTracerElementCoreVal,
        CalculateMeanEnrichment = CalculateMeanEnrichmentVal, CorrectAlsoMonoisotopic = CalcMonoisotopicProbabilitiesVal, DirOut = DirOutVal,
        CalculationThreshold = Calculation_thresholdVal, CalculationThreshold_UHR = CalcThreshUHRVal, FileOut = FileOutVal, ReturnResultsObject = FALSE
      )
  
      finish(results = results, fontset = fontset)
    }
    
  } else {
    
    correctionValues <- list()
    
    #Files and directories
    
    correctionValues["MeasurementFile"] <- filenameVal
    correctionValues["ElementFile"] <- elementfileVal
    correctionValues["MoleculeFile"] <- moleculefileVal
    correctionValues["DirOut"] <- DirOutVal
    correctionValues["FileOut"] <- FileOutVal
    correctionValues["FileOutFormat"] <- FileFormatVal
    
    #Logical values
    
    correctionValues["UltraHighRes"] <- UltraHighResVal
    correctionValues["CorrectTracerImpurity"] <- CorrectTracerImpurityVal
    correctionValues["CorrectTracerElementCore"] <- CorrectTracerElementCoreVal
    correctionValues["CalculateMeanEnrichment"] <- CalculateMeanEnrichmentVal
    correctionValues["CorrectAlsoMonoisotopic"] <- CalcMonoisotopicProbabilitiesVal
    
    #Numeric values
    
    correctionValues["CalculationThreshold"] <- Calculation_thresholdVal
    correctionValues["CalculationThreshold_UHR"] <- CalcThreshUHRVal
    
    tcltk::tkdestroy(win)
    
    return(correctionValues)
    
  }
}

# Function creating the window after hitting the Correct-Button

finish <- function(results, fontset) {
  continuewindow <- tcltk::tktoplevel()
  tcltk::tkwm.title(continuewindow, "Continue")
  tcltk::tkfocus(continuewindow)

  contdestroy <- function() {
    tcltk::tkdestroy(continuewindow)
    #baseEnvRef <- baseenv()
    baseEnvRef$continueIsoCorrection <- FALSE
  }

  # Rewrite window manager function to call contdestroy()

  tcltk::tcl("wm", "protocol", continuewindow, "WM_DELETE_WINDOW", contdestroy)

  # Function to start a completely new correction
  newcorrection <- function() {
    tcltk::tkdestroy(continuewindow)
    initGUI()
  }

  if (results$success == "TRUE") {
    
    Headtext <- tcltk::tklabel(continuewindow, text = "Correction successful!", font = fontset$fontErrortext)
    tcltk::tkgrid(Headtext)
    newcorrection.button <- tcltk::ttkbutton(continuewindow, text = "Start new correction", command = newcorrection)
    tcltk::tkgrid(newcorrection.button)
    
  } else if (results$success == "WARNINGS") {
    
    Headtext <- tcltk::tklabel(continuewindow,
                               text = "Correction successful with warnings.\nPlease see the logfile for more information",
                               font = fontset$fontErrortext)
    
    tcltk::tkgrid(Headtext)
    newcorrection.button <- tcltk::ttkbutton(continuewindow, text = "Start new correction", command = newcorrection)
    tcltk::tkgrid(newcorrection.button)
    
  } else if (results$success == "FALSE") {
    
    Headtext <- tcltk::tklabel(continuewindow,
      text = paste0("Correction was aborted because an error has occured. Error:\n\n", results$error, "\n"),
      font = fontset$fontErrortext)
    
    tcltk::tkgrid(Headtext)
    newcorrection.button <- tcltk::ttkbutton(continuewindow, text = "Start new correction", command = newcorrection)
    tcltk::tkgrid(newcorrection.button)
    
  }
  blankspace <- tcltk::tklabel(continuewindow, text = " ", font = fontset$fontSmall)
  tcltk::tkgrid(blankspace)
  OK.button <- tcltk::ttkbutton(continuewindow, text = "Close", command = contdestroy)
  tcltk::tkgrid(OK.button)
}

# Function of the 'Advanced Options' button

AdvancedOptions <- function(win, advancedOptions, filenameStartvalue, elementfileStartvalue, moleculefileStartvalue,
                            DirOutStartvalue, FileOutStartvalue, UHRStartvalue,
                            CorrectTracerImpurityStartvalue, CorrectTracerElementCoreStartvalue,
                            CalculateMeanEnrichmentStartvalue, Calculation_thresholdStartvalue,
                            CalcThreshUHRStartvalue, CalculateMonoisotopicProbStartvalue,
                            FileFormatStartvalue, testmode = NA) {
  
  tcltk::tkdestroy(win)
    
  correctionValues <- initGUI(
    advancedOptions = advancedOptions, filenameStartvalue = filenameStartvalue,
    elementfileStartvalue = elementfileStartvalue,
    moleculefileStartvalue = moleculefileStartvalue,
    DirOutStartvalue = DirOutStartvalue,
    FileOutStartvalue = FileOutStartvalue,
    UHRStartvalue = UHRStartvalue,
    CorrectTracerImpurityStartvalue = CorrectTracerImpurityStartvalue,
    CorrectTracerElementCoreStartvalue = CorrectTracerElementCoreStartvalue,
    CalculateMeanEnrichmentStartvalue = CalculateMeanEnrichmentStartvalue,
    Calculation_thresholdStartvalue = Calculation_thresholdStartvalue,
    CalcThreshUHRStartvalue = CalcThreshUHRStartvalue,
    CalculateMonoisotopicProbStartvalue = CalculateMonoisotopicProbStartvalue,
    FileFormatStartvalue = FileFormatStartvalue, testmode = testmode
  )
  
  if(!is.na(testmode)) {
    
    return(correctionValues)
    
  }
  
}

# Function to open general help html-file

openhelp <- function() {
  utils::browseURL(system.file("doc/IsoCorrectoR.html", package = "IsoCorrectoR"))
}

# Function to show information on IsoCorrectoR

showAbout <- function() {

  # Function of the 'OK' button in error-pop-up-windows
  destroy <- function() {
    tcltk::tkdestroy(aboutwin)
  }

  aboutwin <- tcltk::tktoplevel()
  tcltk::tkwm.title(aboutwin, "About")
  abouttext <- tcltk::tklabel(aboutwin, text = paste0(
    "IsoCorrectoRGUI version ", packageVersion("IsoCorrectoRGUI"), "\n", "Institute of Functional Genomics , University of Regensburg\n",
    "IsoCorrectoRGUI is licensed under ", packageDescription("IsoCorrectoRGUI", fields = "License"), ". It is free software and comes without any warranty.\n Please run 'citation(\"IsoCorrectoRGUI\")' for correct citation when using IsoCorrectoRGUI for your research."
  ))
  tcltk::tkgrid(abouttext)
  OK.button <- tcltk::ttkbutton(aboutwin, text = "OK", command = destroy)
  tcltk::tkgrid(OK.button)
}

# Function of the different categories in the help menu (currently not in use)

help <- function(text, fontset) {
  # Function of the 'OK' button in helpmenu window
  destroy <- function() {
    tcltk::tkdestroy(helpwin)
  }
  helpwin <- tcltk::tktoplevel(background = "white")
  tcltk::tkwm.title(helpwin, "Help")
  helptext <- tcltk::tklabel(helpwin, text = text, justify = "left", font = fontset$fontHelptext, background = "white")
  tcltk::tkgrid(helptext)
  OK.button <- tcltk::ttkbutton(helpwin, text = "OK", command = destroy)
  tcltk::tkgrid(OK.button)
}
chkohler/IsoCorrectoRGUI documentation built on May 8, 2021, 1:09 a.m.