Shiny_app/serien/serien_server.R

# ------------ PLOT SERIEN OVER TIME ----------
mod_server_serien <- function(input, output, session, all_shot_table){
  
  # ------------PLOT SERIEN OVER TIME -----------
  output$serien_over_time <- renderPlotly({
    
    serien <- get_series(all_shot_table())[
      ,':='(mean_dec = mean(ergebnis_dec),
            mean_full = mean(ergebnis_full)),
      by = day]
    
    p <- ggplot(data = serien)+
      geom_point(aes(x = day, y = mean_full),
                 color = "red", size = 3)+
      geom_point(aes(x = day, y = ergebnis_full))+
      geom_smooth(aes(x = day, y = ergebnis_full),
                  method ='lm',formula=y~x, se = F)+
      theme_bw()
    
    ggplotly(p)
    
  })
  # Plot Shots in a serie
  output$shots_in_serie <- renderPlotly({
    table_data <- all_shot_table()[, ':='(schuss = schuss)
                                   ][, mittel_y := median(dec), by = schuss]
    p <- ggplot(data = table_data)+
      geom_point(aes(x = schuss, y = dec))+
      geom_point(aes(x = schuss, y = mittel_y, colour = "red"))+
      geom_hline(yintercept = median(table_data[,unique(mittel_y)]))
    ggplotly(p)
  })
  
  # Plot Shots after a Shot
  output$shots_after_shot <- renderPlotly({
    table_data <- all_shot_table()[, ':='(schuss = schuss)
                                   ][, full_zuvor := c( NA, 
                                                          full[1:(length(full)-1)])]
    
    p <- ggplot(data = table_data)+
      geom_violin(aes(x = factor(full_zuvor), y = full))
    ggplotly(p)
  })
  return()
}
WeissenbergerSven/ShotAnalysis documentation built on May 21, 2019, 9:19 a.m.