class: center, middle, inverse, title-slide .title[ # Theme a shiny app ] .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 ] --- # Theming your Shiny App - `bslib` has many options available for theming and customizing your app <br/><br/> - We'll cover the easily available options here<br/><br/> - Exponentially more powerful with CSS and a bit of tinkering --- # Preset Themes .pull-left[ - Bootswatch provides preset themes - `bs_themer()` lets you choose interactively .center.large[`bs_themer.R`] ].pull-right[ .panelset.sideways[ .panel[.panel-name[default] data:image/s3,"s3://crabby-images/7a89c/7a89c4ef53e4725adebfa208d37d220fea0e300c" alt="" ] .panel[.panel-name[flatly] data:image/s3,"s3://crabby-images/bf5f1/bf5f168abb19b74c0ddfab0bf27c836d69e9ddde" alt="" ] .panel[.panel-name[darkly] data:image/s3,"s3://crabby-images/42e06/42e06667c79d3c5e459d2c9f25644c607707f958" alt="" ] ] ] --- class: inverse middle # Your Turn Run the code in `bs_themer.R` and pick a theme you like. Get the console output corresponding to that theme and modify `bs_themed.R` to use your theme code. Hint: Use the `theme = ...` argument in one of the `page_xxx` functions.
−
+
05
:
00
--- # Customizing Your Navbar - You may want to add a logo to your title area - pictures should be placed in the `www/` folder .pull-left[ ``` r title = div( img(src = "wave.gif", width = "40px"), img(src = "globe.png", width = "40px"), "Hello World", style = "display: inline;"), ``` ].pull-right[ data:image/s3,"s3://crabby-images/24613/24613fc57f3e08cdff933da74e8bbb8715b0db4d" alt="" ] --- # Adding Icons - You can add icons to your `nav_panels()` with the `icon` argument - [Bootstrap Icons](https://icons.getbootstrap.com/) - Match the version of Bootstrap your app uses .pull-left[ ``` r nav_panel( title = "Dashboard", body, icon = bs_icon("bar-chart", a11y = "deco") # marks icon as decorative for screen readers ), ``` ].pull-right[ data:image/s3,"s3://crabby-images/7a0de/7a0de3ecc33e50cdd40fea0ce0dc65f59135bb52" alt="" ] --- class: inverse middle # Your Turn Customize the title and icons on the `nav_panels` in `title_customization.R`. Choose appropriate icons and decide if they are decorative or semantic.
−
+
05
:
00
--- # Change the width of the sidebar ``` r side <- sidebar( width = "20%", h2("Inputs"), sliderInput( "mpg", label = "MPG range", min = min(floor(mtcars$mpg), na.rm = T), max = max(ceiling(mtcars$mpg), na.rm = T), step = 1, value = range(mtcars$mpg)) ) ``` .panelset.sideways[ .panel[.panel-name[10%] data:image/s3,"s3://crabby-images/b37ca/b37cad2137c9a136db29c31967dd3a213cad0137" alt="" ] .panel[.panel-name[20%] data:image/s3,"s3://crabby-images/c90dc/c90dccb41e868dc92e822c083912f1331cff2d2b" alt="" ] .panel[.panel-name[100px] data:image/s3,"s3://crabby-images/8e64d/8e64d217aed064d4fc67878afb5581cd787b27cc" alt="" ] .panel[.panel-name[100px (small window)] data:image/s3,"s3://crabby-images/e6f39/e6f396e4afd0ac6af50dad254cf8751ee9ff7d59" alt="" ] ] --- # Share and share alike <a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by-nc-sa/4.0/88x31.png" /></a><br />This work is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/">Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License</a>.