livebook/assets/css/js_interop.css
2021-12-08 16:30:52 +01:00

174 lines
4.3 KiB
CSS

/*
Conditional elements display.
Verious hooks and callbacks dynamically set attributes
based on which we hide/show certain elements.
This way we don't have to engage the server in
solely client-side operations.
*/
/* === Global === */
[phx-hook="Highlight"][data-highlighted] > [data-source] {
@apply hidden;
}
/* === Session === */
[data-element="session"]:not([data-js-insert-mode])
[data-element="insert-mode-indicator"] {
@apply invisible;
}
[data-element="session"]
[data-element="cell"][data-type="markdown"]
[data-element="editor-box"] {
@apply hidden;
}
[data-element="session"][data-js-insert-mode]
[data-element="cell"][data-type="markdown"][data-js-focused]
[data-element="editor-box"] {
@apply block;
}
[data-element="session"][data-js-insert-mode]
[data-element="cell"][data-type="markdown"][data-js-focused]
[data-element="enable-insert-mode-button"] {
@apply hidden;
}
[data-element="session"]:not([data-js-insert-mode])
[data-element="cell"][data-type="markdown"][data-js-focused]
[data-element="insert-image-button"] {
@apply hidden;
}
[data-element="notebook-headline"]:hover [data-element="heading"],
[data-element="section-headline"]:hover [data-element="heading"] {
@apply border-blue-200;
}
[data-element="notebook-headline"][data-js-focused] [data-element="heading"],
[data-element="section-headline"][data-js-focused] [data-element="heading"] {
@apply border-blue-300;
}
[data-element="section-headline"]:not(:hover):not([data-js-focused])
[data-element="heading"]
+ [data-element="section-actions"]:not(:focus-within) {
@apply hidden;
}
[data-element="cell"][data-js-focused] {
@apply border-blue-300 border-opacity-100;
}
[data-element="cell"]:not([data-js-focused])
[data-element="actions"]:not(:focus-within) {
/* Note: using opacity, so the buttons are focusable (via tab navigation)
and when focused we show the actions back. */
@apply opacity-0;
}
[data-element="cell"]:not([data-js-focused])
[data-element="actions"]:not([data-primary]):not(:focus-within) {
@apply pointer-events-none;
}
[data-element="cell"]:not([data-js-focused]):hover
[data-element="actions"][data-primary] {
@apply opacity-100 pointer-events-auto;
}
[data-element="cell"] [data-element="cell-status"][data-js-changed] {
@apply italic;
}
[data-element="cell"]
[data-element="cell-status"]:not([data-js-changed])
[data-element="change-indicator"] {
@apply invisible;
}
[data-element="sections-list-item"][data-js-is-viewed] {
@apply text-gray-900;
}
[data-element="cell"]:not([data-js-focused]):hover
[data-element="cell-focus-indicator"] {
@apply bg-blue-200;
}
[data-element="cell"][data-js-focused] [data-element="cell-focus-indicator"] {
@apply bg-blue-300;
}
[data-element="cell"][data-js-amplified] [data-element="outputs-container"] {
@apply bg-white m-0 py-16;
width: 90vw;
position: relative;
left: calc(-45vw + 50%);
}
[data-element="cell"][data-js-amplified]
[data-element="amplify-outputs-button"]
[data-element="zoom-in-icon"] {
@apply hidden;
}
[data-element="cell"]:not([data-js-amplified])
[data-element="amplify-outputs-button"]
[data-element="zoom-out-icon"] {
@apply hidden;
}
[data-element="session"]:not([data-js-side-panel-content])
[data-element="side-panel"] {
@apply hidden;
}
[data-element="session"]:not([data-js-side-panel-content="sections-list"])
[data-element="sections-list"] {
@apply hidden;
}
[data-element="session"]:not([data-js-side-panel-content="clients-list"])
[data-element="clients-list"] {
@apply hidden;
}
[data-element="session"]:not([data-js-side-panel-content="runtime-info"])
[data-element="runtime-info"] {
@apply hidden;
}
[data-element="session"][data-js-side-panel-content="sections-list"]
[data-element="sections-list-toggle"] {
@apply text-gray-50 bg-gray-700;
}
[data-element="session"][data-js-side-panel-content="clients-list"]
[data-element="clients-list-toggle"] {
@apply text-gray-50 bg-gray-700;
}
[data-element="session"][data-js-side-panel-content="runtime-info"]
[data-element="runtime-info-toggle"] {
@apply text-gray-50 bg-gray-700;
}
[data-element="clients-list-item"]:not([data-js-followed])
[data-meta="unfollow"] {
@apply hidden;
}
[data-element="clients-list-item"][data-js-followed] [data-meta="follow"] {
@apply hidden;
}
[phx-hook="VirtualizedLines"]:not(:hover) [data-element="clipcopy"] {
@apply hidden;
}