Fomantic (Semantic) UI wrapper for Shiny
With this library it is easy to wrap Shiny with Fomantic UI (previously Semantic). Add a few simple lines of code to give your UI a fresh, modern and highly interactive look.
library(shiny) ui <- fluidPage( div( div( a("Link"), p("Lorem ipsum, lorem ipsum, lorem ipsum"), actionButton("button", "Click") ) ) )
library(shiny.semantic) ui <- semanticPage( div(class = "ui raised segment", div( a(class="ui green ribbon label", "Link"), p("Lorem ipsum, lorem ipsum, lorem ipsum"), actionButton("button", "Click") ) ) )
🔗 Churn analytics | 🔗 Fraud detection |
---|---|
![]() |
![]() |
We show how shiny.semantic
can be used to style an app and change it’s look.
🔗 BEFORE Utah Division of Water Quality (DWQ) | 🔗 AFTER Utah Division of Water Quality (DWQ) |
---|---|
![]() |
![]() |
See more examples with code in the examples
folder:
You can install a stable shiny.semantic
release from CRAN repository:
install.packages("shiny.semantic")
and the latest version with remotes
:
remotes::install_github("Appsilon/shiny.semantic@develop")
(master
branch contains the stable version. Use develop
branch for latest features)
To install previous versions you can run:
remotes::install_github("Appsilon/shiny.semantic", ref = "0.1.0")
Firstly, you will have to invoke shinyUI()
with semanticPage()
instead of standard Shiny UI definitions like e.g. bootstrapPage()
. From now on, all components can be annotated with Fomantic UI specific CSS classes and also you will be able to use shiny.semantic components.
Basic example for rendering a simple button. will look like this:
library(shiny) library(shiny.semantic) ui <- semanticPage( title = "My page", div(class = "ui button", icon("user"), "Icon button") ) server <- function(input, output) {} shinyApp(ui, server)
For better understanding it’s good to check Fomantic UI documentation.
Note #1
At the moment you have to pass page title in semanticPage()
Note #2
The shiny
package works with Bootstrap library under the hood. shiny.semantic
uses Fomantic UI. Sometimes using both of these libraries may cause troubles with rendering specific UI elements. That is why by default we turn off Bootstrap dependencies.
However, you can switch off suppressing bootstrap by calling semanticPage(suppress_bootstrap = FALSE, ...)
We welcome contributions of all types!
We encourage typo corrections, bug reports, bug fixes and feature requests. Feedback on the clarity of the documentation and examples is especially valuable.
If you want to contribute to this project please submit a regular PR, once you’re done with new feature or bug fix.
Changes in documentation
Both repository README.md file and an official documentation page are generated with Rmarkdown, so if there is a need to update them, please modify accordingly a README.Rmd file and use “Knit”.
Documentation is rendered with pkgdown
. Just run pkgdown::build_site()
after rendering new README.md.
Changes in vignettes
If you modified or added a new vignette, please rebuild them with devtools::build_vignettes()
.
Important:
1) Please follow the code style from out styleguide.
2) We have a Contributor Code of Conduct. Make sure to check it and to follow it.
We used the latest versions of dependencies for this library, so please update your R environment before installation.
However, if you encounter any problems, try the following:
install.packages("shiny", version='0.14.2.9001')
dsl.R
to make using this package smootherAppsilon is the Full Service Certified RStudio Partner. Learn more at appsilon.com.
Get in touch dev@appsilon.com