// Copyright 2024, Command Line Inc. // SPDX-License-Identifier: Apache-2.0 @import "../mixins.less"; .block { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: 100%; overflow: hidden; min-height: 0; border-radius: var(--block-border-radius); .block-frame-icon { margin-right: 0.5em; } .block-content { position: relative; display: flex; flex-grow: 1; width: 100%; overflow: hidden; min-height: 0; padding: 5px; } .block-focuselem { height: 0; width: 0; input { width: 0; height: 0; opacity: 0; pointer-events: none; } } .block-header-animation-wrap { max-height: 0; transition: max-height 0.3s ease-out, opacity 0.3s ease-out; overflow: hidden; position: absolute; top: 0; width: 100%; height: 30px; z-index: var(--zindex-header-hover); &.is-showing { max-height: 30px; } } &.block-preview.block-frame-default .block-frame-default-inner .block-frame-default-header { background-color: rgba(0, 0, 0, 0.7); } &.block-frame-default { position: relative; padding: 1px; .block-frame-default-inner { background-color: var(--block-bg-color); width: 100%; height: 100%; border-radius: var(--block-border-radius); display: flex; flex-direction: column; .block-frame-default-header { max-height: var(--header-height); min-height: var(--header-height); display: flex; padding: 4px 5px 4px 10px; align-items: center; gap: 8px; font: var(--header-font); border-bottom: 1px solid var(--border-color); border-radius: var(--block-border-radius) var(--block-border-radius) 0 0; .block-frame-default-header-iconview { display: flex; flex-shrink: 3; min-width: 17px; align-items: center; gap: 8px; overflow-x: hidden; .block-frame-view-icon { font-size: var(--header-icon-size); opacity: 0.5; width: var(--header-icon-width); i { margin-right: 0; } } .block-frame-view-type { overflow-x: hidden; text-wrap: nowrap; text-overflow: ellipsis; flex-shrink: 1; min-width: 0; } .block-frame-blockid { opacity: 0.5; } } .block-frame-text { .ellipsis(); font: var(--fixed-font); font-size: 11px; opacity: 0.7; flex-grow: 1; &.preview-filename { direction: rtl; text-align: left; span { cursor: pointer; &:hover { background: var(--highlight-bg-color); } } } } .connection-button { display: flex; align-items: center; flex-wrap: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; font-weight: 400; color: var(--main-text-color); border-radius: 2px; padding: auto; &:hover { background-color: var(--highlight-bg-color); } .connection-icon-box { flex: 1 1 auto; overflow: hidden; } .connection-name { flex: 1 2 auto; overflow: hidden; padding-right: 4px; } .connecting-svg { position: relative; top: 5px; left: 9px; svg { fill: var(--warning-color); } } } .block-frame-textelems-wrapper { display: flex; flex: 1 2 auto; min-width: 0; gap: 8px; align-items: center; .block-frame-div { display: flex; width: 100%; height: 100%; justify-content: space-between; align-items: center; .input-wrapper { flex-grow: 1; input { background-color: transparent; outline: none; border: none; color: var(--main-text-color); width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; box-sizing: border-box; opacity: 0.7; font-weight: 500; } } .button { margin-left: 3px; } // webview specific. for refresh button .iconbutton { height: 100%; width: 27px; display: flex; align-items: center; justify-content: center; } } .menubutton { .button { font-size: 11px; } } } .block-frame-end-icons { display: flex; flex-shrink: 0; .iconbutton { display: flex; width: 24px; padding: 4px 6px; align-items: center; } .block-frame-magnify { justify-content: center; align-items: center; padding: 0; svg { #arrow1, #arrow2 { fill: var(--main-text-color); } } } } } .block-frame-preview { background-color: rgba(0, 0, 0, 0.7); width: 100%; flex-grow: 1; border-bottom-left-radius: var(--block-border-radius); border-bottom-right-radius: var(--block-border-radius); display: flex; align-items: center; justify-content: center; .iconbutton { opacity: 0.7; font-size: 45px; margin: -30px 0 0 0; } } } .connstatus-overlay { position: absolute; top: calc(var(--header-height) + 6px); left: 6px; right: 6px; z-index: var(--zindex-block-mask-inner); display: flex; align-items: center; justify-content: flex-start; flex-direction: column; overflow: hidden; background: rgba(230, 186, 30, 0.2); backdrop-filter: blur(50px); border-radius: 6px; box-shadow: 0px 13px 16px 0px rgba(0, 0, 0, 0.4); .connstatus-content { display: flex; flex-direction: row; justify-content: space-between; padding: 10px 8px 10px 12px; width: 100%; font: var(--base-font); color: var(--secondary-text-color); gap: 12px; .connstatus-status-icon-wrapper { display: flex; flex-direction: row; align-items: center; gap: 12px; flex-grow: 1; min-width: 0; &.has-error { align-items: flex-start; } > i { color: #e6ba1e; font-size: 16px; } .connstatus-status { .ellipsis(); display: flex; flex-direction: column; align-items: flex-start; gap: 4px; flex-grow: 1; width: 100%; .connstatus-status-text { .ellipsis(); max-width: 100%; font-size: 11px; font-style: normal; font-weight: 600; line-height: 16px; letter-spacing: 0.11px; color: white; } .connstatus-error { .ellipsis(); width: 94%; font-size: 11px; font-style: normal; font-weight: 400; line-height: 15px; letter-spacing: 0.11px; } } } .connstatus-actions { display: flex; align-items: flex-start; justify-content: center; gap: 6px; button { i { font-size: 11px; opacity: 0.7; } } .button:last-child { margin-top: 1.5px; } } } } .block-mask { position: absolute; top: 0; left: 0; right: 0; bottom: 0; border: 2px solid transparent; pointer-events: none; padding: 2px; border-radius: calc(var(--block-border-radius) + 2px); z-index: var(--zindex-block-mask-inner); &.show-block-mask { user-select: none; pointer-events: auto; } &.show-block-mask .block-mask-inner { margin-top: var(--header-height); // TODO fix this magic background-color: rgba(0, 0, 0, 0.5); height: calc(100% - var(--header-height)); width: 100%; display: flex; align-items: center; justify-content: center; .bignum { margin-top: -15%; font-size: 60px; font-weight: bold; opacity: 0.7; } } } &.block-focused { .block-mask { border: 2px solid var(--accent-color); } &.block-no-highlight, &.block-preview { .block-mask { border: 2px solid rgba(255, 255, 255, 0.1); } } } } }