// DEFAULTS $shiny-disconnected-bg: #999 !default; $shiny-table-na: #909090 !default; $shiny-error-color: red !default; $shiny-error-validated-color: #888 !default; $shiny-progress-text-bg-color: #eef8ff !default; // TODO: what is this actually for? $shiny-input-width: 300px !default; $shiny-input-panel-bg: #f5f5f5 !default; $shiny-input-panel-border: 1px solid #e3e3e3 !default; $shiny-input-panel-border-radius: 2px !default; $shiny-text-output-border-radius: null !default; $notification-bg-color: #e8e8e8 !default; $notification-color: #333 !default; $notification-border: 1px solid #ccc !default; $notification-border-radius: 3px !default; $notification-padding: 10px 2rem 10px 10px !default; $notification-message-bg: #d9edf7 !default; $notification-message-color: #31708f !default; $notification-message-border: 1px solid #bce8f1 !default; $notification-warning-bg: #fcf8e3 !default; $notification-warning-color: #8a6d3b !default; $notification-warning-border: 1px solid #faebcc !default; $notification-error-bg: #f2dede !default; $notification-error-color: #a94442 !default; $notification-error-border: 1px solid #ebccd1 !default; $notification-close-color: #444 !default; $notification-close-hover-color: #000 !default; $notification-content-action-color: #337ab7 !default; $datepicker-disabled-color: #aaa !default; $shiny-file-active-shadow: inset 0 1px 1px rgba(black, .075), 0 0 8px rgba(102, 175, 233, .6) !default; $shiny-file-over-shadow: inset 0 1px 1px rgba(black, .075), 0 0 8px rgba(76, 174, 76, .6) !default; // DECLARATIONS @mixin table-padding($top: null, $right: null, $bottom: null, $left: null) { > thead, > tbody, > tfoot { > tr { > th, > td { padding-top: $top; padding-right: $right; padding-bottom: $bottom; padding-left: $left; } } } } // Both BS3 and BS4 define a border radius mixin, but just in case // we're trying to compile this without bootstrapSass @mixin border-radius-shim($radius) { @if mixin-exists("border-radius") { @include border-radius($radius); } @else { border-radius: $radius; } } // RULES /* This is necessary so that an empty verbatimTextOutput slot is the same height as a non-empty one (only important when * placeholder = TRUE) */ pre.shiny-text-output:empty::before { content: " "; } pre.shiny-text-output.noplaceholder:empty { margin: 0; padding: 0; border-width: 0; height: 0; } /* Some browsers (like Safari) will wrap text in
tags with Bootstrap's CSS. This changes the behavior to not wrap. */ pre.shiny-text-output { word-wrap: normal; @include border-radius-shim($shiny-text-output-border-radius); } .shiny-image-output, .shiny-plot-output { img.shiny-scalable { max-width: 100%; max-height: 100%; } } #shiny-disconnected-overlay { position: fixed; inset: 0; background-color: $shiny-disconnected-bg; opacity: 0.5; overflow: hidden; z-index: 99998; pointer-events: none; } html.autoreload-enabled #shiny-disconnected-overlay.reloading { opacity: 0; animation: fadeIn 250ms forwards; animation-delay: 1s; } @keyframes fadeIn { to { opacity: 0.1; } } .table.shiny-table { @include table-padding($left: 12px, $right: 12px); } .shiny-table { &.spacing { &-xs { @include table-padding($top: 3px, $bottom: 3px); } &-s { @include table-padding($top: 5px, $bottom: 5px); } &-m { @include table-padding($top: 8px, $bottom: 8px); } &-l { @include table-padding($top: 10px, $bottom: 10px); } } .NA { color: $shiny-table-na; } } .shiny-output-error { color: $shiny-error-color; white-space: pre-wrap; &:before { content: 'Error: '; font-weight: bold; } &-validation { color: $shiny-error-validated-color; } &-validation:before { content: ''; font-weight: inherit; } } /* Work around MS Edge transition bug (issue #1637) */ @supports (-ms-ime-align:auto) { .shiny-bound-output { transition: 0; } } .recalculating { --_shiny-fade-opacity: var(--shiny-fade-opacity, 0.3); opacity: var(--_shiny-fade-opacity); transition: opacity 250ms ease 500ms; } .slider-animate-container { text-align: right; margin-top: -9px; } .slider-animate-button { /* Ensure controls above slider line touch target */ position: relative; z-index: 1; opacity: 0.5; .pause { display: none; } &.playing .pause { display: inline; } .play { display: inline; } &.playing .play { display: none; } } .progress { &.shiny-file-input-progress { visibility: hidden; .progress-bar.bar-danger { transition: none; } } } // fileInput()'s button should never have a top-right or bottom-right border-radius .btn-file { border-top-right-radius: 0 !important; border-bottom-right-radius: 0 !important; } /* Make sure the filename doesn't extend past the bounds of the container */ .shiny-input-container input[type=file] { overflow: hidden; max-width: 100%; } /* Old-style progress */ .shiny-progress-container { position: fixed; top: 0px; width: 100%; /* Make sure it draws above all Bootstrap components */ z-index: 2000; } // TODO: should respect more Bootstrap Sass vars? .shiny-progress { .progress { position: absolute; width: 100%; top: 0px; height: 3px; margin: 0px; } .bar { opacity: 0.6; transition-duration: 250ms; } .progress-text { position: absolute; right: 10px; width: 240px; background-color: $shiny-progress-text-bg-color; margin: 0px; padding: 2px 3px; opacity: 0.85; .progress-message { padding: 0px 3px; font-weight: bold; font-size: 90%; } .progress-detail { padding: 0px 3px; font-size: 80%; } } } /* New-style progress (uses notifications API) */ .shiny-progress-notification { .progress { margin-bottom: 5px; height: 10px; } .progress-text { .progress-message { font-weight: bold; font-size: 90%; } .progress-detail { font-size: 80%; } } } .shiny-label-null { display: none; } .crosshair { cursor: crosshair; } .grabbable { cursor: grab; cursor: -moz-grab; cursor: -webkit-grab; } .grabbing { cursor: grabbing; cursor: -moz-grabbing; cursor: -webkit-grabbing; } .ns-resize { cursor: ns-resize; } .ew-resize { cursor: ew-resize; } .nesw-resize { cursor: nesw-resize; } .nwse-resize { cursor: nwse-resize; } /* Workaround for Qt, which doesn't use font fallbacks */ .qt pre, .qt code { font-family: monospace !important; } /* Workaround for Qt 5, which draws its own margins around checks and radios; overrides the top margin on these elements set by Bootstrap */ .qt5 .radio input[type="radio"], .qt5 .checkbox input[type="checkbox"] { margin-top: 0px; } /* Workaround for radio buttons and checkboxes not showing on Qt on Mac. This occurs in the RStudio IDE on macOS 11.5. https://github.com/rstudio/shiny/issues/3484 */ .qtmac input[type="radio"], .qtmac input[type="checkbox"] { zoom: 1.0000001; } .shiny-frame { border: none; } .shiny-flow-layout { > div { display: inline-block; vertical-align: top; padding-right: 12px; width: 220px; } } .shiny-split-layout { width: 100%; white-space: nowrap; > div { display: inline-block; vertical-align: top; box-sizing: border-box; overflow: auto; } } .shiny-input-panel { padding: 6px 8px; margin-top: 6px; margin-bottom: 6px; background-color: $shiny-input-panel-bg; border: $shiny-input-panel-border; @include border-radius-shim($shiny-input-panel-border-radius); } /* For checkbox groups and radio buttons, bring the options closer to label, if label is present. */ .shiny-input-checkboxgroup label ~ .shiny-options-group, .shiny-input-radiogroup label ~ .shiny-options-group { margin-top: -10px; } /* Checkbox groups and radios that are inline need less negative margin to separate from label. */ .shiny-input-checkboxgroup.shiny-input-container-inline label ~ .shiny-options-group, .shiny-input-radiogroup.shiny-input-container-inline label ~ .shiny-options-group { margin-top: -1px; } /* Limit the width of inputs in the general case. */ .shiny-input-container:not(.shiny-input-container-inline) { width: $shiny-input-width; max-width: 100%; } /* Don't limit the width of inputs in a sidebar. */ .well .shiny-input-container { width: auto; } /* Width of non-selectize select inputs */ .shiny-input-container > div > select:not(.selectized) { width: 100%; } #shiny-notification-panel { position: fixed; bottom: 0; right: 0; background-color: rgba(0,0,0,0); padding: 2px; width: 300px; max-width: 100%; z-index: 99999; } .shiny-notification { position: relative; background-color: $notification-bg-color; color: $notification-color; border: $notification-border; @include border-radius-shim($notification-border-radius); opacity: 0.85; padding: $notification-padding; margin: 5px; &-message { color: $notification-message-color; background-color: $notification-message-bg; border: $notification-message-border; } &-warning { color: $notification-warning-color; background-color: $notification-warning-bg; border: $notification-warning-border; } &-error { color: $notification-error-color; background-color: $notification-error-bg; border: $notification-error-border; } &-close { position: absolute; width: 2rem; height: 2rem; top: 0; right: 0; display: flex; align-items: center; justify-content: center; font-weight: normal; font-size: 1.125em; padding: 0.25rem; color: $notification-close-color; cursor: pointer; } &-close:hover { color: $notification-close-hover-color; font-weight: bold; } &-content-action a { color: $notification-content-action-color; text-decoration: underline; font-weight: bold; } } .shiny-file-input { &-active { box-shadow: $shiny-file-active-shadow; } &-over { box-shadow: $shiny-file-over-shadow; } } /* Overrides bootstrap-datepicker3.css styling for invalid date ranges. See https://github.com/rstudio/shiny/issues/2042 for details. */ .datepicker table tbody tr td.disabled, .datepicker table tbody tr td.disabled:hover, .datepicker table tbody tr td span.disabled, .datepicker table tbody tr td span.disabled:hover { color: $datepicker-disabled-color; cursor: not-allowed; } /* Hidden tabPanels */ .nav-hidden { /* override anything bootstrap sets for `.nav` */ display: none !important; }