class: center, middle, inverse, title-slide .title[ # Reactivity ] .subtitle[ ## SISBID 2024
https://github.com/dicook/SISBID
] .author[ ### Di Cook (
dicook@monash.edu
)
Heike Hofmann (
hhhofmann4@unl.edu
)
Susan Vanderplas (
susan.vanderplas@unl.edu
) ] .date[ ### 08/14-16/2024 ] --- # Elements of Reactivity .pull-left[ - Sources - Any input widget is a source<br/><br/> - Conductors - Use input and pass values to another component<br/><br/> - Observers - Any output is an observer ] .pull-right[ data:image/s3,"s3://crabby-images/08045/08045501301ec0e795bf6ad25cd3d4faa633229c" alt="" ] --- # Two Conductors - Reactive expressions and reactive events are two types of conductors<br/><br/> - Reactive expressions are the archetypical conductor: <br/><br/> - envelope functionality used in multiple places of an app - run evaluations only once - store current values - update when inputs change<br/><br/> - Reactive events are only triggered by specific events (e.g. click on an action button) --- # Reactive Expressions ``` r rval <- reactive({ ... }) ``` Called like a function as `rval()` - Reactive expressions are executed **lazily** and values are **cached**<br/><br/> - **Lazy**: Evaluated on demand as requested by a reactive endpoint<br/><br/> - **Cached**: (re-)evaluated only when the value of a dependency changed --- # Reactive Events ``` r rval <- eventReactive(actionbutton, { ... }) ``` Called like a function as `rval()` - reactive events are executed even more **lazily**<br/><br/> - only on demand<br/><br/> - requested by an actionButton (usually) --- # Example: Submission Form .pull-left[ - In RStudio open file `app.R` in `03_submission`<br/><br/> - Run the app (a couple of times) <br/><br/> - Turn on showcase mode: ``` r runApp("03_submission/", display.mode = "showcase") ``` ] .pull-right[ data:image/s3,"s3://crabby-images/1dd2a/1dd2a99912f3abac3cc192b3840b14cee650cb38" alt="Submission form applet screenshot" ] --- class: inverse middle # Your turn .pull-left[ - Open the file `03_submission.R` - The package `colourpicker` implements a color wheel as an input widget - Allow users to change the color of the dots in the dot plot - What other interactive elements can you think of adding? Answers are in `03b_submission.R` ] .pull-right[ data:image/s3,"s3://crabby-images/71800/718008c63cde0eb2b21043e100e1fca4593fbdff" alt="Screenshot of completed app" ]
−
+
05
:
00
--- # Conditional Panels .left-column[ data:image/s3,"s3://crabby-images/0b331/0b331e9968b2a65203ca40bab0d1e620eb07774c" alt="Screenshot of the inputs without a conditional panel" data:image/s3,"s3://crabby-images/8c5ec/8c5ecb71094f8b0148ce053fd4f4cfb37b0d7cbf" alt="Screenshot of the inputs with a conditional panel" ] .right-column[ - Showing a color picker before it is needed could confuse app users <br/><br/> - `conditionalPanel(condition, ...)` allows us to encapsulate elements of the UI and only show them when `condition` is fulfilled<br/><br/> - Here, a condition of `condition = 'input.submit > 0'` is true when the submit button was pressed at least once.<br/><br/> - This is implemented in `03c_submission.R` ] --- .pull-left[ # App Layout - The body is laid out using a responsive grid - responsive: adapts to different screen sizes - different on a cell phone than a laptop - boxes are rearranged automatically - Structure is introduced by cards ``` r card1 <- card( card_header("Hi, I'm a card"), class = "bg-primary", "I contain some information - ", "text, plot, image, input area...", "your choice!") ``` ] .pull-right[ .move-up[.move-up[data:image/s3,"s3://crabby-images/27073/27073d8801f2d2985587f9477416b38d3503a195" alt="The app layout has 12 columns (width) and you can specify rows as well."]] data:image/s3,"s3://crabby-images/aa077/aa077c98b11cb27b8e79fd9c5fb1a1b8c29c9759" alt="Row heights can be specified as well" ] --- # Cards .pull-left[ .move-up.center.huge[`04_layout.R`] - Cards help with structuring output<br/><br/> - Cards have a `class` parameter - `bg-xxx` produces a colored box - `border-xxx` produces a box with a colored outline - `card_header(..., class = "bg-xxx")` produces a box with a colored header - `?validStatuses`, represented by `xxx` above, are `primary`, `secondary`, `success`, `info`, `warning`, `danger`, `light`, `dark` ] .pull-right[ .move-up[data:image/s3,"s3://crabby-images/26338/26338e5bdd6128ecbd8f2c2d750bc1bcc0586d95" alt="Demonstration of an app with different box statuses"] ] --- # Nested Layouts .pull-left[ - Body is wrapped in a `page_fillable` function<br/><br/> - Cards are aligned using columns<br/><br/> - Additional rows can be created by nesting `layout_columns()` functions<br/><br/> ``` r body <- page_fillable( layout_columns( col_widths = c(2, 4, 4, 2), # 12 cols per row row_heights = "600px", card1, layout_columns(card2, card3, card5, col_widths = c(12, 12, 12), row_heights = "auto"), card4, card6) ) ``` ] .pull-right[ .move-up.center.huge[`04_layout2.R`] data:image/s3,"s3://crabby-images/82050/82050a559942512479b58be3f1aa1b1551edb128" alt="Nesting rows and columns" ] --- # Nested Layouts .pull-left[ - Body is wrapped in a `page_fillable` function<br/><br/> - Cards are aligned using columns<br/><br/> - Additional rows can be created by nesting `layout_columns()` functions<br/><br/> ``` r body <- page_fillable( layout_columns( col_widths = c(2, 4, 4, 2), # 12 cols per row row_heights = "600px", card1, layout_columns(card2, card3, card5, col_widths = c(12, 12, 12), row_heights = "auto"), card4, card6) ) ``` ] .pull-right[ .move-up.center.huge[`04_layout2.R`] data:image/s3,"s3://crabby-images/e94c0/e94c0726917cd4b5adfdf6803b48a6e7a79a2a48" alt="Nesting rows and columns" ] --- # Other Layouts - `page_fillable()` has different behavior from `page_fluid()` and `page_fixed()` - see [this article](https://rstudio.github.io/bslib/articles/filling.html) for more information about fillable containers. - `page_navbar()` can be used to create tabs across the top (more on this in a minute) - `sidebar()` allows for common inputs across all tabs - `layout_column_wrap()` can accomplish some [very neat tricks](https://rstudio.github.io/bslib/articles/column-layout.html) ``` r layout_column_wrap( width = NULL, height = 300, fill = FALSE, style = css(grid_template_columns = "2fr 1fr 2fr"), card1, card2, card3 ) ``` - [Shiny UI Editor](https://rstudio.github.io/shinyuieditor/) is currently in Alpha but allows UI creation without writing code --- # Tab Layouts Code: 05_tabsets.R .panelset.sideways[ .panel[.panel-name[tab1] data:image/s3,"s3://crabby-images/f13f5/f13f51358fa690889be530a99bdb3ea1fab25912" alt="" ] .panel[.panel-name[tab2] data:image/s3,"s3://crabby-images/45ccd/45ccdaf31670628a5e4ad42ce7f028f6d7d21bae" alt="" ] .panel[.panel-name[tab3] data:image/s3,"s3://crabby-images/b94c3/b94c3bd796540ac3fd6817f55fdf6dfc5bf71306" alt="" ] ] --- # Tabs - Different options for multi-page applets: .panelset.sideways[ .panel[.panel-name[`navset_tab()`] data:image/s3,"s3://crabby-images/1ce60/1ce60024392dbb6f683e0af222625207cd2e9227" alt="" ] .panel[.panel-name[`navset_pill()`] data:image/s3,"s3://crabby-images/877d9/877d9aca2c5fed6806010bdec11077f5e21eb351" alt="" ] .panel[.panel-name[`navset_bar()`] data:image/s3,"s3://crabby-images/d9965/d9965ceb66b0c9434c5ae5e11af1fe59473e24e3" alt="" ] .panel[.panel-name[`navset_pill_list()`] data:image/s3,"s3://crabby-images/7d54f/7d54f1dce054216495d1ca6251a7881c550c2af1" alt="" ] .panel[.panel-name[`navset_card_tab()`] data:image/s3,"s3://crabby-images/a4d64/a4d64066f40b9eb065bab87ea34934ba3f97eec0" alt="" ].panel[.panel-name[`navset_card_pill()`] data:image/s3,"s3://crabby-images/ce566/ce5668c843c00c4f2d887dcebc0490b0ee142957" alt="" ] ] --- class: inverse middle # Your Turn Modify the code in 05_tabsets.R to use a `page_navbar()`. - What modifications do you have to make? - Can you add a sidebar using the `sidebar()` function?
−
+
05
:
00
--- # Resources - RStudio Tutorial: https://shiny.rstudio.com/articles/reactivity-overview.html<br/><br/> - Shiny Cheat Sheet: https://raw.githubusercontent.com/rstudio/cheatsheets/master/shiny.pdf<br/><br/> - Gallery of Shiny Apps: https://shiny.rstudio.com/gallery/ - bslib documentation: https://rstudio.github.io/bslib/