shiny-bslib

安装量: 82
排名: #9595

安装

npx skills add https://github.com/posit-dev/skills --skill shiny-bslib

Modern Shiny Apps with bslib Build professional Shiny dashboards using bslib's Bootstrap 5 components and layouts. This skill focuses on modern UI/UX patterns that replace legacy Shiny approaches. Quick Start Single-page dashboard: library ( shiny ) library ( bslib ) ui <- page_sidebar ( title = "My Dashboard" , theme = bs_theme ( version = 5 ) ,

"shiny" preset by default

sidebar

sidebar
(
selectInput
(
"variable"
,
"Variable"
,
choices
=
names
(
mtcars
)
)
)
,
layout_column_wrap
(
width
=
1
/
3
,
fill
=
FALSE
,
value_box
(
title
=
"Users"
,
value
=
"1,234"
,
theme
=
"primary"
)
,
value_box
(
title
=
"Revenue"
,
value
=
"$56K"
,
theme
=
"success"
)
,
value_box
(
title
=
"Growth"
,
value
=
"+18%"
,
theme
=
"info"
)
)
,
card
(
full_screen
=
TRUE
,
card_header
(
"Plot"
)
,
plotOutput
(
"plot"
)
)
)
server
<-
function
(
input
,
output
,
session
)
{
output
$
plot
<-
renderPlot
(
{
hist
(
mtcars
[
[
input
$
variable
]
]
,
main
=
input
$
variable
)
}
)
}
shinyApp
(
ui
,
server
)
Multi-page dashboard:
ui
<-
page_navbar
(
title
=
"Analytics Platform"
,
theme
=
bs_theme
(
version
=
5
)
,
nav_panel
(
"Overview"
,
overview_ui
)
,
nav_panel
(
"Analysis"
,
analysis_ui
)
,
nav_panel
(
"Reports"
,
reports_ui
)
)
Core Concepts
Page Layouts
page_sidebar()
-- Single-page dashboard with sidebar (most common)
page_navbar()
-- Multi-page app with top navigation bar
page_fillable()
-- Viewport-filling layout for custom arrangements
page_fluid()
-- Scrolling layout for long-form content
See
page-layouts.md
for detailed guidance.
Grid Systems
layout_column_wrap()
-- Uniform grid with auto-wrapping (recommended for most cases)
layout_columns()
-- 12-column Bootstrap grid with precise control
See
grid-layouts.md
for detailed guidance.
Cards
Primary container for dashboard content. Support headers, footers, multiple body sections, and full-screen expansion.
See
cards.md
for detailed guidance.
Value Boxes
Display key metrics and KPIs with optional icons, sparklines, and built-in theming.
See
value-boxes.md
for detailed guidance.
Navigation
Page-level
:
page_navbar()
for multi-page apps
Component-level
:
navset_card_underline()
,
navset_tab()
,
navset_pill()
for tabbed content
See
navigation.md
for detailed guidance.
Sidebars
Page-level
:
page_sidebar()
or
page_navbar(sidebar = ...)
Component-level
:
layout_sidebar()
within cards
Supports conditional content, dynamic open/close, accordions
See
sidebars.md
for detailed guidance.
Filling Layouts
The fill system controls how components resize to fill available space. Key concepts: fillable containers, fill items, fill carriers. Fill activates when containers have defined heights.
See
filling.md
for detailed guidance.
Theming
bs_theme()
with Bootswatch themes for quick styling
Custom colors
:
bg
,
fg
,
primary
affect hundreds of CSS rules
Fonts
:
font_google()
for typography
Dynamic theming
:
input_dark_mode()
+
session$setCurrentTheme()
See
theming.md
for detailed guidance.
UI Components
Accordions
-- Collapsible sections, especially useful in sidebars
Tooltips
-- Hover-triggered help text
Popovers
-- Click-triggered containers for secondary UI/inputs
Toasts
-- Temporary notification messages
See
accordions.md
,
tooltips-popovers.md
, and
toasts.md
.
Icons
Recommended:
bsicons
package
(Bootstrap Icons, designed for bslib):
bsicons
::
bs_icon
(
"graph-up"
)
bsicons
::
bs_icon
(
"people"
,
size
=
"2em"
)
Browse icons:
https://icons.getbootstrap.com/
Alternative:
fontawesome
package:
fontawesome
::
fa
(
"envelope"
)
Accessibility for icon-only triggers:
When an icon is used as the sole trigger for a tooltip, popover, or similar interactive element (no accompanying text), it must be accessible to screen readers. By default, icon packages mark icons as decorative (
aria-hidden="true"
), which hides them from assistive technology.
bsicons::bs_icon()
Provide
title
— this automatically sets
a11y = "sem"
tooltip
(
bs_icon
(
"info-circle"
,
title
=
"More information"
)
,
"Tooltip content here"
)
fontawesome::fa()
Set
a11y = "sem"
and provide
title
tooltip
(
fa
(
"circle-info"
,
a11y
=
"sem"
,
title
=
"More information"
)
,
"Tooltip content here"
)
The
title
should describe the purpose of the trigger (e.g., "More information", "Settings"), not the icon itself (e.g., not "info circle icon").
Special Inputs
input_switch()
-- Toggle switch (modern checkbox alternative)
input_dark_mode()
-- Dark mode toggle
input_task_button()
-- Button for long-running operations
input_code_editor()
-- Code editor with syntax highlighting
input_submit_textarea()
-- Textarea with explicit submission
See
inputs.md
for detailed guidance.
Common Workflows
Building a Dashboard
Choose page layout:
page_sidebar()
(single-page) or
page_navbar()
(multi-page)
Add theme with
bs_theme()
(consider Bootswatch for quick start)
Create sidebar with inputs for filtering/controls
Add value boxes at top for key metrics (set
fill = FALSE
on container)
Arrange cards with
layout_column_wrap()
or
layout_columns()
Enable
full_screen = TRUE
on all visualization cards
Add
thematic::thematic_shiny()
for plot theming
Modernizing an Existing App
See
migration.md
for a complete mapping of legacy patterns to modern equivalents. Key steps:
Replace
fluidPage()
with
page_sidebar()
or
page_navbar()
Replace
fluidRow()
/
column()
with
layout_columns()
Wrap outputs in
card(full_screen = TRUE)
Add
theme = bs_theme(version = 5)
Convert key metrics to
value_box()
components
Replace
tabsetPanel()
with
navset_card_underline()
Guidelines
Prefer bslib page functions
(
page_sidebar()
,
page_navbar()
,
page_fillable()
,
page_fluid()
) over legacy equivalents (
fluidPage()
,
navbarPage()
)
Use
layout_column_wrap()
or
layout_columns()
for grid layouts instead of
fluidRow()
/
column()
, which don't support filling layouts
Wrap outputs in
card(full_screen = TRUE)
when building dashboards -- full-screen expansion is a high-value feature
Set
fill = FALSE
on
layout_column_wrap()
containers holding value boxes (they shouldn't stretch to fill height)
Pin Bootstrap version
include theme = bs_theme(version = 5) or a preset theme Use thematic::thematic_shiny() in the server so base R and ggplot2 plots match the app theme Use responsive widths like width = "250px" in layout_column_wrap() for auto-adjusting columns Group sidebar inputs with accordion() when sidebars have many controls See migration.md for mapping legacy Shiny patterns to modern bslib equivalents Avoid Common Errors Avoid directly nesting card() containers. navset_card_() functions are already cards; nav_panel() content goes directly inside them without wrapping in card() Only use layout_columns() and layout_column_wrap() for laying out multiple elements. Single children should be passed directly to their container functions. Never nest page_() functions. Only use one top-level page function per app. Reference Files migration.md -- Legacy Shiny to modern bslib migration guide page-layouts.md -- Page-level layout functions and patterns grid-layouts.md -- Multi-column grid systems cards.md -- Card components and features value-boxes.md -- Value boxes for metrics and KPIs navigation.md -- Navigation containers and patterns sidebars.md -- Sidebar layouts and organization filling.md -- Fillable containers and fill items theming.md -- Basic theming (colors, fonts, Bootswatch). See shiny-bslib-theming skill for advanced theming accordions.md -- Collapsible sections and sidebar organization tooltips-popovers.md -- Hover tooltips and click-triggered popovers toasts.md -- Temporary notification messages inputs.md -- Special bslib input widgets best-practices.md -- bslib-specific patterns and common gotchas
返回排行榜