162 lines
3.3 KiB
R
Raw Normal View History

2025-01-12 00:52:51 +08:00
library(shiny)
output_css <- "theme.css"
scss <- "
// Color themes
$themes: (
default: #666,
banana: #f1c40f,
cherry: #c0392b,
blueberry: #8e44ad,
leaf: #27ae60,
nightsky: #2980b9
);
// Helper theme mixin
// @param $name: name of the theme (HTML class)
// @param $color: color of the theme
@mixin theme($name, $color) {
.#{$name} {
.component{
border-color: darken($color, 10%);
h2 {
color: $color;
}
li {
background: lighten($color, 45%);
}
}
}
// matches button id: #default, #banana, #cherry, ...
##{$name} {
background: $color;
// #banana:hover
&:hover {
background: darken($color, 10%);
}
// #banana[disabled]
&[disabled] {
background: desaturate($color, 40%);
}
}
}
// Including themes
// By looping through the $themes map
@each $key, $value in $themes {
@include theme($key, $value);
}
// Default styles
.component {
background: #EFEFEF;
padding: 1em;
margin-bottom: 1em;
border-top: .5em solid;
ul {
list-style: none;
padding: 0;
overflow: hidden;
}
li {
float: left;
width: 24%;
height: 10em;
margin-right: 1%;
}
}
.controls > button {
border: none;
color: white;
padding: .5em;
border-radius: .15em;
font-weight: bold;
margin-bottom: .5em;
}
body {
padding: 1em;
}
* {
box-sizing: border-box;
}
"
css_value <- sass::sass(scss)
ui <- withTags(fluidPage(
# script to change the class in the browser
head(
# make sure to include the compiled css!
style(HTML(css_value)),
# watch for the button clicks to change the theme within the browser
script(HTML("
// when the document is ready...
$(function() {
// when a shiny input changes...
$(document).on('shiny:inputchanged', function(event) {
switch (event.name) {
// if the event name matches one of...
case 'default':
case 'banana':
case 'cherry':
case 'blueberry':
case 'leaf':
case 'nightsky':
$('.demo') // select the main body
.removeClass() // remove the class
.addClass('demo ' + event.name); // add the themed class
$('.controls button').removeAttr('disabled'); // make all buttons active
$('#' + event.name).attr('disabled', true); // disable the most recent button
break;
}
});
});
"))
),
div(class = "demo nightsky",
div(class = "component",
h2("Sass Color Themes"),
ul(
li(),
li(),
li(),
li()
)
)
),
div(class = "controls",
actionButton("default", "Default"),
actionButton("banana", "Funny Banana"),
actionButton("cherry", "Hot Chery"),
actionButton("blueberry", "Deep Purple"),
actionButton("leaf", "Smooth Leaf"),
actionButton("nightsky", "Night sky", disabled = "true")
)
))
server <- function(input, output) {
hit <- function(button, name) {
if (button == 0) return()
cat("Button: '", name, "' was pressed! Value: ", button, "\n", sep = "")
}
observe({ hit(input$default, "Default") })
observe({ hit(input$banana, "Funny Banana") })
observe({ hit(input$cherry, "Hot Cherry") })
observe({ hit(input$blueberry, "Deep Purple") })
observe({ hit(input$leaf, "Smooth Leaf") })
observe({ hit(input$nightsky, "Night Sky") })
}
shinyApp(ui, server)