inst/chooser/app.R

library(rrtable)

require(moonBook)


ui=fluidPage(
    h4("Dynamic control of leftChoices of chooserInput()"),
    radioButtons("dataname","Select data",choices=c("acs","mtcars","iris","radial")),
    p("You can see the vars in Exclude1 and Exclude2 being excluded from the Choices"),
    fluidRow(

        column(5,
               chooser2UI("chooser")
        ),
        column(5,
               br(),
               br(),
               fluidRow(
                   column(2,
                          br(),
                          actionButton("toGroup1","",icon=icon("arrow-right"))
                   ),
                   column(8,
                          selectInput("group1","Exclude1",choices=c("",1:5),multiple=FALSE)
                   ),
                   column(2,
                          br(),
                          actionButton("resetGroup1","Reset")
                   )
               ),
               fluidRow(
                   column(2,
                          br(),
                          actionButton("toGroup2","",icon=icon("arrow-right"))
                   ),
                   column(8,
                          selectInput("group2","Exclude2",choices=c("None",1:5),multiple=TRUE)
                   ),
                   column(2,
                          br(),
                          actionButton("resetGroup2","Reset")
                   )
               )

        )),
    br(),
    verbatimTextOutput("text")
)


server=function(input,output,session){

    data=reactive({eval(parse(text=input$dataname))})

    observe({
        groupvar<-groupvar1<-groupvar2<-colnames(data())
        if(length(input$group2)>0) groupvar1=setdiff(groupvar,input$group2)
        updateSelectInput(session,"group1",choices=c("",groupvar1),selected=input$group1)
        if(length(input$group1)>0) groupvar2=setdiff(groupvar,input$group1)
        updateSelectInput(session,"group2",choices=c(groupvar2),selected=input$group2)

    })

    choices1=reactive({
        groups=union(input$group1,input$group2)
        setdiff(colnames(data()),groups)
    })

    result=callModule(chooser2,"chooser",leftChoices=choices1)


    observeEvent(input$toGroup1,{
        temp=c(input$group1,result()$right)
        updateSelectInput(session,"group1",selected=temp[length(temp)])
    })
    observeEvent(input$toGroup2,{
        updateSelectInput(session,"group2",selected=c(input$group2,result()$right))
    })
    observeEvent(input$resetGroup1,{
        groupvar<-groupvar1<-colnames(data())
        if(length(input$group2)>0) groupvar1=setdiff(groupvar,input$group2)
        updateSelectInput(session,"group1",choices=c("",groupvar1),selected="")
    })
    observeEvent(input$resetGroup2,{
        updateSelectInput(session,"group2",selected="")
    })

    output$text=renderPrint({
        cat("str(result())\n")
        str(result())
        cat("input$group1\n")
        str(input$group1)
        cat("input$group2\n")
        str(input$group2)
    })

}

shinyApp(ui,server)

Try the rrtable package in your browser

Any scripts or data that you put into this service are public.

rrtable documentation built on April 5, 2022, 9:08 a.m.