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/2a1c0/2a1c0b6bd04935bdd837a7d3c5be2bc79199999e" alt="" ] .panel[.panel-name[flatly] data:image/s3,"s3://crabby-images/cb803/cb803be53aedf39d147159bd2280dc8f99237571" alt="" ] .panel[.panel-name[darkly] data:image/s3,"s3://crabby-images/c39d2/c39d27f4b6940dcaf34336390c31fa52e9de32e5" 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/6e7ee/6e7ee485472776e88f224d2692b36e516ebdcd04" 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/52dd4/52dd423312a995e38fc949dcdc8ce332cd0efb9b" 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/10008/1000894c3202b93a311189ba02ad9b098163dc76" alt="" ] .panel[.panel-name[20%] data:image/s3,"s3://crabby-images/6fa39/6fa39a973bdb77ade18db43f1d439d82cd1f0ace" alt="" ] .panel[.panel-name[100px] data:image/s3,"s3://crabby-images/29e28/29e28672bd3d22453852293578dbf1a186bee74c" alt="" ] .panel[.panel-name[100px (small window)] data:image/s3,"s3://crabby-images/a8989/a89895142831a9a29c85d53d43867da3c3fe0df6" 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>.