knitr::opts_chunk$set(echo = FALSE, message = FALSE, error = FALSE, warning = FALSE)

names_first_to_capital <- function(x, fun) {
    setNames(x, var2fc(if (missing(fun)) names(x) else vapply(names(x), fun, FUN.VALUE = "", USE.NAMES = FALSE)))
}

var2fc <- function(x) {
    vapply(x, function(z) gsub("_", " ", paste0(toupper(substr(z, 1, 1)), substr(z, 2, nchar(z)))), FUN.VALUE = "", USE.NAMES = FALSE)
}

if (!is.null(params$css)) tags$style(params$css)
jsstuff <- ovideo::ov_video_js(youtube = params$playlist$playlist_type %in% "youtube", twitch = params$playlist$playlist_type %in% "twitch", version = 2)
print(jsstuff$children[[1]][[1]])
print(jsstuff$children[[1]][[2]])
playlist <- params$playlist$playlist
plays_cols_to_show <- if (length(params$playlist$table_cols) > 0) params$playlist$table_cols else c("video_time", "code", "set_number", "home_team_score", "visiting_team_score")
plays_cols_to_show <- intersect(names(playlist), plays_cols_to_show)
if ("code" %in% plays_cols_to_show) playlist$code <- vapply(playlist$code, function(x) paste0("<strong style=\"background-color:#73AD21; border-radius:5px; padding:3px; border:2px solid #73AD21;\">", x ,"</strong>"), FUN.VALUE = "", USE.NAMES = FALSE)
if("home_team_score" %in% plays_cols_to_show)  playlist$home_team_score <- vapply(playlist$home_team_score, function(x) paste0("<strong style=\"background-color:grey; border-radius:5px; padding:3px;\">", x ,"</strong>"), FUN.VALUE = "", USE.NAMES = FALSE)
if("visiting_team_score" %in% plays_cols_to_show)  playlist$visiting_team_score <- vapply(playlist$visiting_team_score, function(x) paste0("<strong style=\"background-color:grey; border-radius:5px; padding:3px;\">", x ,"</strong>"), FUN.VALUE = "", USE.NAMES = FALSE)


playstable <- DT::datatable(names_first_to_capital(playlist[, plays_cols_to_show, drop = FALSE]), rownames = FALSE,
                            width = "100%", extensions = "Scroller", selection = list(mode = "single", selected = 1, target = "row"),
                            escape = FALSE,
                            options = list(sDom = '<"top">t<"bottom">rlp', scrollY = 200, scroller = TRUE, ordering = FALSE)) ## no column sorting deferRender = TRUE, 
        if (!is.null(params$ui_header)) {
            params$ui_header
        } else {
            fluidRow(id = "headerblock", column(6, tags$h2("Volleyball Video Player")),
                     column(3, offset = 3, tags$div(style = "text-align: center;", "Part of the", tags$br(), tags$img(src = "", style = "max-height:3em;"), tags$br(), tags$a(href = "https://github.com/openvolley", "openvolley", target = "_blank"), "project")))
        }

vargs <- list(id = "dv_player", type = if (params$playlist$playlist_type %in% c("youtube", "twitch")) params$playlist$playlist_type else "local", style = "border: 1px solid black; width: 90%; height: 480px; background-color: black;", controls = FALSE)
if (vargs$type == "local") {
    vargs$muted <- "muted"
    vargs$poster <- "data:image/gif,AAAA"
}
mutejs <- if (vargs$type == "youtube") {
              "dvpl.yt_player.isMuted() ? dvpl.yt_player.unMute() : dvpl.yt_player.mute();"
           } else if (vargs$type == "twitch") {
               "dvpl.yt_player.setMuted(!dvpl.yt_player.getMuted());"
           } else {
               "$('#dv_player').prop('muted', !$('#dv_player').prop('muted'));"
           }
have_sub <- "subtitle" %in% names(playlist) && any(!is.na(playlist$subtitle) & nzchar(playlist$subtitle))
have_subskill <- "subtitleskill" %in% names(playlist) && any(!is.na(playlist$subtitleskill) & nzchar(playlist$subtitleskill))
fluidRow(column(8, do.call(ovideo::ov_video_player, vargs),
                tags$div(style = "margin-top: 12px;",
                         tags$button("Play", onclick = "dvpl.video_play();"),
                         tags$button("Prev", onclick = "dvpl.video_prev();"),
                         tags$button("Next", onclick = "dvpl.video_next(false);"),
                         tags$button("Pause", onclick = "dvpl.video_pause();"),
                         tags$button("Back 1s", onclick = "dvpl.jog(-1);"),
                         tags$button(id = "restart_button", "Restart", onclick = ov_playlist_as_onclick(playlist, "dv_player", controller_var = "dvpl")),
                         tags$button("Toggle mute", onclick = mutejs)),
                tags$div(style = "margin-top:10px;", if (have_sub) tags$span(id = "subtitle", "Score"), if (have_subskill) tags$span(id = "subtitleskill", "Skill"))
                ),
         column(4, tags$h4(params$playlist$name),
                playstable))


openvolley/ovideo documentation built on March 19, 2024, 9:52 p.m.