inst/shotGroups_AngularSize/app.R

#####---------------------------------------------------------------------------
#####---------------------------------------------------------------------------
## shotGroups shiny App
## Daniel Wollschlaeger <dwoll@kuci.org>
#####---------------------------------------------------------------------------
#####---------------------------------------------------------------------------

library(shiny)
library(shotGroups)
library(bs4Dash)

source("global.R", encoding="UTF8")

#####---------------------------------------------------------------------------
## app code
#####---------------------------------------------------------------------------

shinyApp(
    #####-----------------------------------------------------------------------
    ## UI
    #####-----------------------------------------------------------------------
    ui=dashboardPage(
        # theme = "custom.css",
        title="Angular - absolute size conversion using shotGroups",
        sidebar=source("app_ui_sidebar.R", encoding="UTF8")$value,
        header=dashboardHeader(
            tags$code(tags$h3("Angular <-> absolute size conversion using 'shotGroups'"))
        ),
        body=dashboardBody(
            withMathJax(),
            tabItems(
                tabItem(
                    tabName="tab_math",
                    source("app_ui_tab_math.R", local=TRUE, encoding="UTF8")$value
                ),
                tabItem(
                    tabName="tab_angular",
                    source("app_ui_tab_angular.R", local=TRUE, encoding="UTF8")$value
                ),
                tabItem(
                    tabName="tab_absolute",
                    source("app_ui_tab_absolute.R", local=TRUE, encoding="UTF8")$value
                ),
                tabItem(
                    tabName="tab_distance",
                    source("app_ui_tab_distance.R", local=TRUE, encoding="UTF8")$value
                ),
                tabItem(
                    tabName="tab_about",
                    source("app_ui_tab_about.R", local=TRUE, encoding="UTF8")$value
                )
            )
        )
    ),
    #####-----------------------------------------------------------------------
    ## server
    #####-----------------------------------------------------------------------
    server=function(input, output, session) {
        session$onSessionEnded(stopApp)
        
        #####---------------------------------------------------------------------------
        ## distance to target, unit distance, unit xy-coords - UI element
        #####---------------------------------------------------------------------------
        output$unitDstXY <- renderUI({
            dstTarget <- 100
            ## angular size -> dst to target, and unit dst, but not unit xy
            inputPanel()
        })
        
        #####---------------------------------------------------------------------------
        ## string for conversion argument - unit distance to unit xy-coords
        ## reactive conductor
        #####---------------------------------------------------------------------------
        conversionStr <- reactive({
            paste0(unitsDstInv[input$unitDst], "2",
                   unitsXYInv[input$unitXY], collapse="")
        })
        
        #####---------------------------------------------------------------------------
        ## absolute to angular size
        #####---------------------------------------------------------------------------
        
        output$abs2Ang <- renderPrint({
            dstTrgt1     <- input$dstTrgt1
            unitDstTrgt1 <- unitsDstInv[input$unitDst1]
            szeAbs1      <- as.numeric(strsplit(input$angszeAbs1, "[[:blank:]]")[[1]])
            unitAbs1     <- unitsAbsInv[input$angszeUnitAbs1]
            unitAngOut1  <- unitsAngInv[input$angszeUnitAngOut1]
            
            getMOAmult <- function(uao) {
                x <- getMOA(szeAbs1, dst=dstTrgt1,
                            conversion=paste0(unitDstTrgt1, "2", unitAbs1, collapse=""),
                            type=uao)
                signif(x, 4)
            }
            
            values <- Map(getMOAmult, unitAngOut1)
            x <- setNames(as.data.frame(values), unitAngOut1)
            if(!any(is.na(szeAbs1)) && !any(duplicated(szeAbs1))) {
                rownames(x) <- szeAbs1
            } else {
                NULL
            }
            
            x
        })
        
        #####---------------------------------------------------------------------------
        ## angular to absolute size
        #####---------------------------------------------------------------------------
        
        output$ang2Abs <- renderPrint({
            dstTrgt2     <- input$dstTrgt2
            unitDstTrgt2 <- unitsDstInv[input$unitDst2]
            szeAng2     <- as.numeric(strsplit(input$angszeAng2, "[[:blank:]]")[[1]])
            unitAng2    <- unitsAngInv[input$angszeUnitAng2]
            unitAbsOut2 <- unitsAbsInv[input$angszeUnitAbsOut2]
            
            fromMOAmult <- function(uao) {
                x <- fromMOA(szeAng2, dst=dstTrgt2,
                             conversion=paste0(unitDstTrgt2, "2", uao, collapse=""),
                             type=unitAng2)
                signif(x, 4)
            }
            
            values <- Map(fromMOAmult, unitAbsOut2)
            x <- setNames(as.data.frame(values), unitAbsOut2)
            if(!any(is.na(szeAng2)) && !any(duplicated(szeAng2))) {
                rownames(x) <- szeAng2
            } else {
                NULL
            }
            
            x
        })
        
        output$angAbs2Dist <- renderPrint({
            szeAbs3     <- as.numeric(strsplit(input$angszeAbs3, "[[:blank:]]")[[1]])
            szeAng3     <- as.numeric(strsplit(input$angszeAng3, "[[:blank:]]")[[1]])
            unitAbs3    <- unitsAbsInv[input$angszeUnitAbs3]
            unitAng3    <- unitsAngInv[input$angszeUnitAng3]
            unitDstOut3 <- unitsAbsInv[input$angszeUnitDstOut3]
            
            getDistMult <- function(udo) {
                x <- getDistance(szeAbs3,
                                 angular=szeAng3,
                                 conversion=paste0(udo, "2", unitAbs3),
                                 type=unitAng3)
                signif(x, 4)
            }
            
            values <- Map(getDistMult, unitDstOut3)
            x <- setNames(as.data.frame(values), unitDstOut3)
            rNames <- paste0(szeAbs3, "_", szeAng3)
            if(!any(is.na(szeAbs3) | is.na(szeAng3)) && !any(duplicated(rNames))) {
                rownames(x) <- rNames
            } else {
                NULL
            }
            
            x
        })
    }
)
dwoll/shotGroups documentation built on Feb. 16, 2024, 2:21 p.m.