root { --block-focus-color: lightyellow; counter-reset: block; } [class^='leader-line'] { z-index: 9999; } @keyframes fade-in { from { opacity: 0; } to { opacity: 1; } } @keyframes fade-out { from { opacity: 1; } to { visibility: hidden; opacity: 0; } } @keyframes map-fade-in { from { opacity: 0.3; } to { opacity: 1; } } @keyframes map-fade-out { from { opacity: 1; } to { opacity: 0.3; } } a[href^='http']:not(:has(img))::after, .external::after { content: ''; display: inline-block; width: 8px; height: 8px; margin-right: 4px; margin-left: 2px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M8.636 3.5a.5.5 0 0 0-.5-.5H1.5A1.5 1.5 0 0 0 0 4.5v10A1.5 1.5 0 0 0 1.5 16h10a1.5 1.5 0 0 0 1.5-1.5V7.864a.5.5 0 0 0-1 0V14.5a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h6.636a.5.5 0 0 0 .5-.5z'/%3E%3Cpath fill-rule='evenodd' d='M16 .5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h3.793L6.146 9.146a.5.5 0 1 0 .708.708L15 1.707V5.5a.5.5 0 0 0 1 0v-5z'/%3E%3C/svg%3E"); background-position: center; background-size: contain; } .mapclay { position: relative; transform-origin: top left; transition: flex-basis 300ms ease-in-out; &.focus::after { content: 'Map-ID: ' attr(id); padding: 0.3rem 0.5rem; position: absolute; left: 50%; top: 50%; z-index: 9999; border: solid transparent; border-radius: 5px; background: gray; color: white; font-size: 1.5rem; font-weight: bold; line-height: 1.2; transform: translate(-50%, -50%); opacity: 0; animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } &[data-report*='/'] { &::after { content: attr(data-report); padding: 0.3rem 0.5rem; position: absolute; left: 50%; top: 50%; z-index: 9999; border: solid transparent; border-radius: 5px; background: gray; color: white; font-size: 1.2rem; font-weight: bold; line-height: 1.2; transform: translate(-50%, -50%); } &[data-render='fulfilled'][data-report$='\20']::after { content: '\2714 ' attr(data-report); animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } &[data-render='unfulfilled'][data-report$='\20']::after { content: '\2716 ' attr(data-report); animation: 2.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } } .marker { background-color: transparent; border-color: transparent; } } .with-leader-line:not(:has(> *)) { display: inline-block; padding-right: 15px; padding-left: 6px; background-image: url('data:image/svg+xml;charset=utf-8;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0Ij48cG9seWdvbiBwb2ludHM9IjI0LDAgMCw4IDgsMTEgMCwxOSA1LDI0IDEzLDE2IDE2LDI0IiBmaWxsPSJjb3JhbCIvPjwvc3ZnPg=='); background-repeat: no-repeat; background-position: right 2px top 2px; color: #555; background-size: 12px 12px; &.geolink { background-color: rgb(248 248 129); } &.doclink { background-color: #9ee7ea; } &:hover { background-image: none; font-weight: bolder; text-decoration: none; } } *:has(> nav) { /* FIXME Hide nav at proper time */ display: none; min-width: 120px; padding: 0.5rem; position: absolute; right: 10px; bottom: 10px; z-index: 500; border: 2px solid gray; border-radius: 0.5rem; background-color: white; &:has(> nav:empty) { display: none; } ol { margin-top: 0; margin-bottom: 0.5rem; } } .dumby-block { padding: 1rem 1rem 1rem 2rem; position: relative; counter-increment: block; &::before { content: ''; height: calc(100% - 2rem); position: absolute; left: 0.8rem; border-left: 0.5em solid #e0e0e0; transition: border-color 0.5s linear; } &.focus { /* Dress up when block is focus */ /* background: var(--block-focus-color); */ &::before { border-color: chocolate; } &::after { content: counter(block) '/' attr(data-total); padding: 0.3rem 0.5rem; position: absolute; left: 50%; top: 50%; z-index: 9999; border: solid transparent; border-radius: 5px; background: gray; color: white; font-size: 1.5em; font-weight: bold; transform: translate(-50%, -50%); opacity: 0; animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } } } .menu { display: block; overflow: visible; width: fit-content; min-width: 10rem; position: absolute; z-index: 9999; border: 2px solid gray; border-radius: 6px; background: white; & > *:first-child { border-top: 2px solid transparent; border-top-left-radius: 5px; border-top-right-radius: 5px; } & > *:last-child { border-bottom: 2px solid transparent; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; } &.editor-menu { max-height: 40vh; overflow-y: scroll; } } .menu-item { justify-content: space-between; padding: 0.5rem; position: relative; cursor: pointer; text-wrap: nowrap; &:hover { background: rgb(226 232 240); } .info { float: right; padding-inline: .5em; color: steelblue; font-weight: bold; } &.folder::before { content: '⏵'; display: inline-block; float: right; } &.unchecked::before { content: '\2610'; float: right; margin-left: 0.5em; } &.checked::before { content: '\2611'; float: right; margin-left: 0.5em; } } .sub-menu { overflow: scroll; width: fit-content; min-width: 6rem; max-height: 40vh; position: absolute; z-index: 10000; border: 2px solid gray; border-radius: 6px; background: white; .menu-item { min-width: 5em; margin: 0 auto; padding-inline: 0.5em; } } .plainoverlay-body { position: absolute; } .plainmodal-content { width: 700px; height: 80%; padding: 1em; position: absolute; left: 50vw; top: 50vh; background: white; transform: translate(-50%, -50%); overflow-y: scroll; white-space: pre; h3 { margin-top: 1em; } details { margin-bottom: 0.5em; } summary { max-width: 60%; cursor: pointer; } details > :not(summary) { padding-left: 2em; } p { margin: 0.3em; white-space: nowrap; overflow-x: scroll; } pre { padding: 0.5em; background: #f0f0f0; } } .Dumby { overflow: visible; width: 100%; height: 100%; margin: 0 auto; padding: 0; position: relative; &::after { content: 'Layout: ' attr(data-layout); padding: 0.3rem 0.5rem; position: absolute; left: 50%; top: 50%; z-index: 9999; border: solid transparent; border-radius: 5px; background: gray; color: white; font-size: 1.5rem; font-weight: bold; line-height: 1.2; transform: translate(-50%, -50%); opacity: 0; } } .SemanticHtml { display: flex; flex-direction: column; justify-content: flex-start; height: 100%; gap: 1rem; overflow-y: auto; /* Trivial: gray out text not focused */ &:has(.dumby-block.focus) { color: gray; .dumby-block.focus { color: initial; } } :has(> .mapclay, > [data-placeholder]) { display: flex; gap: 0.5em; background-color: white; } /* if Map not in showcase, add border when focused */ .mapclay { border: 3px solid white; &.focus { border: 3px solid gray; } &[data-render='unfulfilled'] { border: 3px solid crimson; opacity: 0.6; } } [data-placeholder] { border: 3px solid gray; flex-grow: 0; & > * { opacity: 0.3; } /* animation: map-fade-out 1s; */ } } .Showcase { display: none; overflow: visible; width: 100%; height: 100%; position: relative; .mapclay { width: 100%; height: 100%; position: absolute; left: 0; top: 0; } .focus { z-index: 1; } } .Dumby[data-layout='normal'] { max-width: 60em; &::after { animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } } .Dumby[data-layout='side-by-side'] { &::after { animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } .SemanticHtml, .Showcase { width: 50%; min-width: 20%; position: absolute; top: 0; } .SemanticHtml { left: 0; } .Showcase { display: block; right: 0; } .bar { display: flex; overflow: visible; width: 1px; height: 100%; position: absolute; left: 50%; top: 0; z-index: 5; border: 2px black solid; .bar-handle { display: inline-block; width: 60px; height: 60px; position: absolute; left: -30px; top: calc(50% - 30px); border-radius: 50%; background-color: #3887be; background-image: url(''); transition: transform 0.3s ease-in-out; transform: scale(0.5, 0.5); cursor: grab; box-shadow: inset 0 0 0 4px white; &:hover { transform: unset; } } } } .Dumby[data-layout='overlay'] { &::after { animation: 1.5s forwards fade-out cubic-bezier(0.44, 0.18, 0.86, -0.21); } .SemanticHtml, .Showcase { display: block; width: 100%; height: 100%; margin: 0; padding: 0; position: fixed; left: 0; top: 0; } .Showcase { z-index: 0; } .SemanticHtml { pointer-events: none; z-index: 1; } } .utils { display: flex; padding-block: 1rem; padding-inline: 1rem; position: absolute; left: 100%; top: calc(-1rem - 3px); font-size: 1.5rem; visibility: hidden; gap: 6px; &:hover { visibility: visible; opacity: 1; } [id] { padding: 0.2rem 0.4rem; border: 3px gray solid; border-radius: 5px; background: white; user-select: none; } #close { cursor: pointer; } #plus-font-size { cursor: zoom-in; } #minus-font-size { cursor: zoom-out; } } .draggable-block { /* TODO transition for display */ display: none; overflow: visible; width: fit-content; position: absolute; border: solid gray 3px; border-radius: 0.5rem; background: white; font-size: 0.8rem; pointer-events: auto; &:has(.dumby-block.focus) { display: block; outline: solid #505050 1px; border-color: #505050; } &:has(pre:only-child [data-placeholder]:only-child) { display: none; } /* Fade out top of contents scrolling */ &::before { content: ''; display: block; height: 1.5rem; position: absolute; left: 0; top: 0; right: 0; z-index: 1; border-radius: 5px; background: linear-gradient(0deg, rgb(255 255 255 / 0%), white 60%); } .dumby-block { overflow: scroll; min-width: 5rem; max-width: 25vw; min-height: 5rem; max-height: 50vh; margin: 0; padding-block: 1rem 0; padding-inline: 1rem; position: relative; /* Don't make corner overflow! */ border: solid transparent 2px; border-radius: 0.5rem; resize: both; /* Remove indicator when inside draggable-block */ &::before { display: none; } /* allow random width/height after resize */ &[style*='height'], &[style*='width'] { max-width: unset; max-height: unset; } .mapclay { min-width: 200px; } } .draggable-part { display: block; overflow: clip; width: 100%; padding-bottom: 0.5em; position: absolute; left: 0; top: 0; z-index: 1; border-top-left-radius: 0.3rem; border-top-right-radius: 0.3rem; } .handle { font-size: 1.1rem; text-align: center; transition: all 0.3s ease-in-out; /* background: white; */ transform: translate(0, -0.6rem); } &.drag, &:has(.draggable-part:hover) { .handle { background: #e1e1e1; transform: unset; } .utils { visibility: visible; animation: fade-in 0.5s; } > *:not(.draggable-part, .utils) { color: gray; opacity: 0.7; } } } .dumby-block:has(pre:only-child [data-placeholder]:only-child) { overflow: clip; [data-placeholder] { height: 50px !important; scale: 0.9; transition-duration: 0.4s; transition-timing-function: ease-out; } } .bold-options { font-weight: bold; }