Files
danbooru/app/javascript/src/styles/specific/notes.scss
evazion 206a4b5de5 docker: avoid rebuilding CSS/JS assets on every commit.
Restructure the Dockerfile and the CSS/JS files so that we only rebuild
the CSS and JS when they change, not on every commit.

Before it took several minutes to rebuild the Docker image after every
commit, even when the JS/CSS files didn't change. This also made pulling
images slower.

This requires refactoring the CSS and JS to not use embedded Ruby (ERB)
templates, since this made the CSS and JS dependent on the Ruby
codebase, which is why we had to rebuild the assets after every Ruby
change.
2021-10-13 02:48:30 -05:00

188 lines
3.7 KiB
SCSS

.note-container {
display: inline-block;
position: relative;
box-sizing: content-box;
&.hide-notes .note-box {
visibility: hidden;
}
div.note-body {
display: none;
position: absolute;
font-size: 14px;
border: 1px solid var(--note-body-border-color);
background: var(--note-body-background);
color: var(--note-body-text-color);
box-shadow: var(--shadow-lg);
min-width: 140px;
width: min-content;
min-height: 1em;
line-height: 1.25;
cursor: pointer;
padding: 4px;
z-index: 150;
overflow-wrap: break-word;
overflow-y: hidden;
}
div.note-body, div.note-box.embedded div.note-box-inner-border {
box-sizing: content-box;
h1, h2, h3, h4, h5, h6, a, span, div, blockquote, p, ul, li, ol, em, strong, small, big, b, i, font, u, s, code, center {
line-height: 1.25;
}
> :last-child {
margin-bottom: 0;
}
b, strong {
font-weight: bold;
}
i, em {
font-style: italic;
}
small {
font-size: 0.8em;
}
code {
font: var(--monospace-font);
}
a[rel*="external"] {
word-break: initial;
}
.tn {
font-size: 0.8em;
color: var(--note-tn-color);
}
ruby {
rt {
font-size: 0.8em;
}
}
ul {
margin-left: 1em;
margin-bottom: 1em;
ul {
margin-bottom: 0;
}
li {
list-style-type: disc;
+ br {
display: none;
}
}
}
}
div.note-box {
display: flex;
justify-content: center;
align-items: center;
text-align: center;
position: absolute !important;
border: 1px solid var(--note-box-border-color);
min-width: 5px;
min-height: 5px;
width: 100px;
height: 100px;
cursor: move;
background: var(--note-body-background);
box-shadow: var(--shadow-lg);
line-height: 1.25;
opacity: 0.5;
z-index: 100;
box-sizing: content-box;
/* Raise notes on hover so overlapping embedded notes are readable. */
&:hover {
z-index: 200;
}
&.unsaved {
border: 1px solid var(--unsaved-note-box-border-color);
}
&.movable {
border: 1px solid var(--movable-note-box-border-color);
}
&.embedded {
color: var(--note-body-text-color);
border: 1px solid transparent;
opacity: 1;
box-shadow: none;
&:hover {
border: 1px solid var(--note-box-border-color);
box-shadow: var(--note-box-shadow);
&.editing,
&.movable {
opacity: 1;
}
}
&.editing,
&.movable {
opacity: 0.4;
}
&.unsaved,
&.out-of-bounds {
border: 1px solid var(--unsaved-note-box-border-color);
}
&.movable {
border: 1px solid var(--movable-note-box-border-color);
}
&:not(:hover).level-1 { z-index: 101; }
&:not(:hover).level-2 { z-index: 102; }
&:not(:hover).level-3 { z-index: 103; }
&:not(:hover).level-4 { z-index: 104; }
&:not(:hover).level-5 { z-index: 105; }
&:not(:hover) div.ui-resizable-handle {
display: none !important;
}
}
&.note-box-highlighted {
outline: 1px solid var(--note-highlight-color);
}
div.ui-resizable-handle {
position: absolute;
}
}
}
/* the box that appears when dragging to create a new note. */
div#note-preview {
position: absolute;
cursor: crosshair;
border: 1px solid var(--note-preview-border-color);
opacity: 0.6;
display: none;
background: var(--note-preview-background);
box-shadow: var(--shadow-lg);
z-index: 250;
box-sizing: content-box;
}
div.note-edit-dialog {
font-size: 0.8em;
}