mirror of
https://github.com/danog/sass-site.git
synced 2025-01-08 14:08:45 +01:00
322 lines
6.7 KiB
SCSS
322 lines
6.7 KiB
SCSS
@use 'sass:color';
|
|
@use '../breakpoints';
|
|
@use '../config/color/brand';
|
|
@use '../visual-design/typography';
|
|
|
|
.playground {
|
|
--sl-max-width--container: 100vw;
|
|
|
|
display: grid;
|
|
grid-template:
|
|
'header' min-content
|
|
'main' 1fr
|
|
'footer' min-content / 100%;
|
|
min-height: 100vh;
|
|
overflow: hidden auto;
|
|
|
|
@include breakpoints.sl-breakpoint--large {
|
|
height: 100vh;
|
|
overflow: hidden;
|
|
}
|
|
|
|
#main-content {
|
|
display: inherit;
|
|
overflow: inherit;
|
|
}
|
|
}
|
|
|
|
.sl-r-banner--playground-grid {
|
|
align-items: center;
|
|
display: grid;
|
|
grid-template:
|
|
'logo title copy' auto
|
|
'alert alert alert' minmax(0, auto) / 1fr 1fr 1fr;
|
|
|
|
@include breakpoints.sl-breakpoint--large {
|
|
grid-template: 'logo title copy' auto / 1fr 1fr 1fr;
|
|
}
|
|
}
|
|
|
|
// add padding to items in order for alert to be full width
|
|
.sl-r-banner--playground__brand {
|
|
padding-left: var(--sl-gutter);
|
|
|
|
@include breakpoints.sl-breakpoint--small {
|
|
padding-left: var(--sl-gutter--double);
|
|
}
|
|
}
|
|
|
|
.sl-l-section--playground {
|
|
--sl-inline-padding--container: 0;
|
|
--sl-inline-padding--container-large: 0;
|
|
|
|
border-bottom: 1px solid var(--sl-color--iron);
|
|
display: inherit;
|
|
overflow: inherit;
|
|
width: 100%;
|
|
}
|
|
|
|
.sl-r-banner__playground-title {
|
|
// Use smaller sizes for condensed header
|
|
--h1-size: var(--sl-font-size--xx-large);
|
|
--h1-size-lg: var(--sl-playground-heading);
|
|
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
// Playground banner actions area
|
|
.sl-r-banner__playground-actions {
|
|
gap: var(--sl-gutter);
|
|
display: contents;
|
|
|
|
@include breakpoints.sl-breakpoint--large {
|
|
display: grid;
|
|
grid-template: 'alert copy' auto / minmax(0, auto) max-content;
|
|
}
|
|
}
|
|
|
|
.sl-r-banner__playground-button {
|
|
grid-area: copy;
|
|
padding-right: var(--sl-gutter);
|
|
text-align: right;
|
|
|
|
@include breakpoints.sl-breakpoint--small {
|
|
padding-right: var(--sl-gutter--double);
|
|
}
|
|
}
|
|
|
|
// Playground banner actions alert message
|
|
.sl-r-banner__playground-alert {
|
|
--sl-padding-block--alert: 0;
|
|
|
|
grid-area: alert;
|
|
height: 0;
|
|
opacity: 0;
|
|
padding-left: var(--sl-gutter--half);
|
|
padding-right: var(--sl-gutter--half);
|
|
transition: opacity 0.3s 0.05s, visibility 0.3s;
|
|
visibility: hidden;
|
|
|
|
&.show {
|
|
--sl-padding-block--alert: var(--sl-gutter--minus);
|
|
|
|
height: 100%;
|
|
opacity: 1;
|
|
visibility: visible;
|
|
}
|
|
}
|
|
|
|
// Playground Editor area
|
|
.sl-c-playground {
|
|
--sl-block-margin--callout: 0;
|
|
--sl-block-padding--callout: var(--sl-gutter--quarter);
|
|
|
|
display: grid;
|
|
gap: var(--sl-gutter);
|
|
grid-template:
|
|
'sass' 1fr
|
|
'css' auto
|
|
'debug' auto / 100%;
|
|
|
|
@include breakpoints.sl-breakpoint--large {
|
|
// magic numbers, the layout is well balanced with these proportions
|
|
grid-template:
|
|
'sass css' minmax(20ex, 1fr)
|
|
'sass debug' minmax(0, 40%) / 1fr 1fr;
|
|
height: 100%;
|
|
overflow: inherit;
|
|
}
|
|
}
|
|
|
|
.sl-c-playground__panel {
|
|
display: grid;
|
|
overflow: inherit;
|
|
grid-template:
|
|
'editor-tabbar' min-content
|
|
'editor-error' min-content
|
|
'editor-code' 1fr / 1fr;
|
|
}
|
|
|
|
.sl-c-playground__panel-content {
|
|
grid-area: editor-code;
|
|
overflow: hidden auto;
|
|
}
|
|
|
|
// Precompiled and Compiled code container
|
|
.sl-c-playground__code-editor-wrapper {
|
|
background-color: var(--sl-background--editor);
|
|
border: var(--sl-border--small) solid var(--sl-color--code-background-darker);
|
|
}
|
|
|
|
[data-code='precompiled'] {
|
|
--sl-background--editor: var(--sl-color--white);
|
|
|
|
grid-area: sass;
|
|
}
|
|
|
|
[data-code='compiled'] {
|
|
--sl-background--editor: var(--sl-color--code-background);
|
|
}
|
|
|
|
// Codemirror overrides
|
|
.cm-editor {
|
|
background-color: var(--sl-background--editor);
|
|
color: var(--sl-color--code-base, var(--sl-color--code-text));
|
|
font-size: var(--sl-font-size--x-small);
|
|
height: 100%;
|
|
overflow-x: auto;
|
|
overflow-y: inherit;
|
|
|
|
.cm-gutters {
|
|
background-color: var(--sl-background--editor);
|
|
border-right: none;
|
|
}
|
|
|
|
.cm-lineNumbers .cm-gutterElement {
|
|
min-width: var(--sl-gutter--double);
|
|
}
|
|
|
|
.cm-content,
|
|
.cm-tooltip-lint {
|
|
font-family: typography.$sl-font-family--code;
|
|
}
|
|
|
|
.cm-scroller {
|
|
overflow: unset;
|
|
}
|
|
|
|
.cm-line {
|
|
padding-left: var(--sl-gutter);
|
|
}
|
|
|
|
.cm-activeLineGutter,
|
|
.cm-activeLine {
|
|
background-color: var(--sl-color--warning-highlight);
|
|
|
|
[data-code='compiled'] & {
|
|
background-color: var(--sl-color--code-background);
|
|
}
|
|
}
|
|
|
|
&.cm-focused {
|
|
[data-code='precompiled'] & {
|
|
outline: 1px solid var(--sl-color--warning-light);
|
|
}
|
|
|
|
[data-code='compiled'] & {
|
|
outline: 0;
|
|
}
|
|
}
|
|
|
|
.cm-diagnostic {
|
|
color: var(--sl-color--code-text);
|
|
background: var(--sl-color--code-background-darker);
|
|
}
|
|
|
|
.cm-diagnostic-error {
|
|
border-color: var(--sl-color--error);
|
|
}
|
|
|
|
.cm-diagnostic-warning {
|
|
border-color: var(--sl-color--warn);
|
|
}
|
|
|
|
.cm-diagnostic-info {
|
|
border-color: var(--sl-color--success);
|
|
}
|
|
|
|
.sl-code-is-precompiled & {
|
|
cursor: text;
|
|
}
|
|
}
|
|
|
|
// Compiled CSS error
|
|
.sl-c-playground__error {
|
|
display: none;
|
|
font-weight: typography.$sl-font-weight--bold;
|
|
grid-area: editor-error;
|
|
|
|
[data-compiler-has-error='true'] & {
|
|
display: block;
|
|
}
|
|
}
|
|
|
|
// Console specific styles
|
|
.sl-c-playground__console-wrapper {
|
|
grid-area: debug;
|
|
}
|
|
|
|
.sl-c-playground__console {
|
|
font-family: typography.$sl-font-family--code;
|
|
height: 100%;
|
|
margin: 0;
|
|
|
|
.console-line {
|
|
display: grid;
|
|
gap: var(--sl-gutter);
|
|
grid-template: 'location message' auto / 10ch 1fr;
|
|
}
|
|
|
|
.console-message {
|
|
display: grid;
|
|
}
|
|
|
|
$console-type-colors: (
|
|
'error': var(--sl-color--error),
|
|
'warn': var(--sl-color--warn),
|
|
'debug': var(--sl-color--success),
|
|
);
|
|
|
|
@each $name, $color in $console-type-colors {
|
|
.console-type-#{$name} {
|
|
color: $color;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Playground Tab Bar & Buttons
|
|
.sl-c-playground__editor-tabbar {
|
|
background-color: var(--sl-color--code-background-darker);
|
|
display: flex;
|
|
grid-area: editor-tabbar;
|
|
|
|
[data-active='true'] {
|
|
--sl-color--button: var(--sl-color--pale-sky);
|
|
}
|
|
|
|
[data-code='precompiled'] & {
|
|
[data-active='true'] {
|
|
--sl-background--button: var(--sl-color--white);
|
|
--sl-background--button-state: var(--sl-color--white);
|
|
}
|
|
}
|
|
|
|
[data-code='compiled'] & {
|
|
[data-active='true'] {
|
|
--sl-background--button: var(--sl-color--code-background);
|
|
--sl-background--button-state: var(--sl-color--code-background);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Make sure all tab bar buttons and text get the same padding
|
|
[data-tabbar~='item'] {
|
|
padding: var(--sl-gutter--half) var(--sl-gutter);
|
|
}
|
|
|
|
.sl-c-playground__tabbar-title {
|
|
// For nested caps in tab title, reset a few styles
|
|
.caps {
|
|
--sl-font-size--caps: var(--sl-font-size--medium);
|
|
|
|
font-weight: normal;
|
|
letter-spacing: 0;
|
|
}
|
|
|
|
// align the code editor titles to the right of the panel header area
|
|
.sl-c-playground__code-editor-wrapper & {
|
|
margin-left: auto;
|
|
text-align: right;
|
|
}
|
|
}
|