2024-06-17 19:18:38 +02:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2024-08-24 03:12:40 +02:00
|
|
|
.connection-btn {
|
|
|
|
min-height: 0;
|
|
|
|
overflow: hidden;
|
|
|
|
line-height: 1;
|
2024-12-04 22:49:14 +01:00
|
|
|
display: flex;
|
|
|
|
background-color: orangered;
|
|
|
|
justify-content: flex-start;
|
|
|
|
width: 200px;
|
|
|
|
}
|
2024-08-24 03:12:40 +02:00
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.view-term {
|
2024-06-17 19:18:38 +02:00
|
|
|
display: flex;
|
2024-11-11 22:11:09 +01:00
|
|
|
flex-direction: column;
|
2024-06-17 19:18:38 +02:00
|
|
|
width: 100%;
|
2024-12-04 22:49:14 +01:00
|
|
|
height: 100%;
|
2024-06-17 19:18:38 +02:00
|
|
|
overflow: hidden;
|
2024-12-04 22:49:14 +01:00
|
|
|
position: relative;
|
|
|
|
|
|
|
|
.term-header {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
padding: 4px 10px;
|
|
|
|
height: 35px;
|
|
|
|
gap: 10px;
|
|
|
|
align-items: center;
|
|
|
|
flex-shrink: 0;
|
|
|
|
border-bottom: 1px solid var(--border-color);
|
2024-11-11 22:11:09 +01:00
|
|
|
}
|
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.term-toolbar {
|
|
|
|
height: 20px;
|
|
|
|
border-bottom: 1px solid var(--border-color);
|
|
|
|
overflow: hidden;
|
2024-12-04 21:49:44 +01:00
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
|
Fix Term Widget not registering pointer events (#1614)
This is a bit janky. The problem is that we were placing the
`xterm-viewport` div, which contains the scroll observer for the xterm
contents, at a higher z-index than the xterm contents, meaning that the
contents couldn't register any pointer events. If we don't put a
z-index, though, the scroll bar can't accept pointer events. To get
around this, I've added two observer divs, which control whether the
contents or the viewport have pointer event priority. The first div, the
`term-scrollbar-show-observer`, sits above where the scrollbar will be
rendered. When the user hovers over it, it will cause the viewport div
to move to a z-index above the contents. It will also enable a second
div, the `term-scrollbar-hide-observer`, which sits above the viewport
and the term contents, but not blocking the scrollbar. When the user
hovers over this div (indicating their mouse has left the scrollbar),
the viewport div is moved back to its original z-index and the hide
observer is set to `display: none`. This gives pointer event priority
back to the contents div.
This resolves an issue where the user could not click links in the
terminal output.
Resolves #1357
2024-12-24 05:35:51 +01:00
|
|
|
.term-cmd-toolbar {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
height: 24px;
|
|
|
|
border-bottom: 1px solid var(--border-color);
|
|
|
|
overflow: hidden;
|
|
|
|
align-items: center;
|
|
|
|
|
|
|
|
.term-cmd-toolbar-text {
|
|
|
|
font: var(--fixed-font);
|
|
|
|
flex-grow: 1;
|
|
|
|
overflow: hidden;
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
white-space: nowrap;
|
|
|
|
padding: 0 5px;
|
|
|
|
}
|
|
|
|
}
|
2024-12-04 23:16:50 +01:00
|
|
|
|
2024-12-04 21:49:44 +01:00
|
|
|
.term-connectelem {
|
2024-12-04 22:49:14 +01:00
|
|
|
flex-grow: 1;
|
|
|
|
min-height: 0;
|
|
|
|
overflow: hidden;
|
|
|
|
line-height: 1;
|
|
|
|
margin: 5px;
|
|
|
|
margin-left: 4px;
|
2024-12-04 21:49:44 +01:00
|
|
|
}
|
2024-12-04 22:49:14 +01:00
|
|
|
|
2024-12-04 21:49:44 +01:00
|
|
|
.term-htmlelem {
|
2024-12-04 22:49:14 +01:00
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
width: 100%;
|
|
|
|
flex-grow: 1;
|
|
|
|
min-height: 0;
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
|
|
.block-content {
|
|
|
|
padding: 0;
|
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
}
|
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
&.term-mode-term {
|
|
|
|
.term-connectelem {
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
.term-htmlelem {
|
|
|
|
display: none;
|
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
}
|
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
&.term-mode-vdom {
|
|
|
|
.term-connectelem {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
.term-htmlelem {
|
|
|
|
display: flex;
|
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.ijson iframe {
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
border: none;
|
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
}
|
2024-06-18 07:38:48 +02:00
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.term-stickers {
|
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
left: 0;
|
2024-06-18 07:38:48 +02:00
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
2024-12-04 22:49:14 +01:00
|
|
|
z-index: var(--zindex-termstickers);
|
|
|
|
pointer-events: none;
|
|
|
|
|
|
|
|
.term-sticker-image {
|
|
|
|
img {
|
|
|
|
object-fit: contain;
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
}
|
2024-07-09 07:31:38 +02:00
|
|
|
}
|
2024-12-04 21:49:44 +01:00
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.term-sticker-svg {
|
|
|
|
svg {
|
|
|
|
object-fit: contain;
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
}
|
2024-12-04 21:49:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-29 22:30:32 +01:00
|
|
|
// The 18px width is the width of the scrollbar plus the margin
|
Fix Term Widget not registering pointer events (#1614)
This is a bit janky. The problem is that we were placing the
`xterm-viewport` div, which contains the scroll observer for the xterm
contents, at a higher z-index than the xterm contents, meaning that the
contents couldn't register any pointer events. If we don't put a
z-index, though, the scroll bar can't accept pointer events. To get
around this, I've added two observer divs, which control whether the
contents or the viewport have pointer event priority. The first div, the
`term-scrollbar-show-observer`, sits above where the scrollbar will be
rendered. When the user hovers over it, it will cause the viewport div
to move to a z-index above the contents. It will also enable a second
div, the `term-scrollbar-hide-observer`, which sits above the viewport
and the term contents, but not blocking the scrollbar. When the user
hovers over this div (indicating their mouse has left the scrollbar),
the viewport div is moved back to its original z-index and the hide
observer is set to `display: none`. This gives pointer event priority
back to the contents div.
This resolves an issue where the user could not click links in the
terminal output.
Resolves #1357
2024-12-24 05:35:51 +01:00
|
|
|
.term-scrollbar-show-observer {
|
|
|
|
z-index: calc(var(--zindex-xterm-viewport-overlay) - 1);
|
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
right: 0;
|
|
|
|
height: 100%;
|
2024-12-29 22:30:32 +01:00
|
|
|
width: 18px;
|
Fix Term Widget not registering pointer events (#1614)
This is a bit janky. The problem is that we were placing the
`xterm-viewport` div, which contains the scroll observer for the xterm
contents, at a higher z-index than the xterm contents, meaning that the
contents couldn't register any pointer events. If we don't put a
z-index, though, the scroll bar can't accept pointer events. To get
around this, I've added two observer divs, which control whether the
contents or the viewport have pointer event priority. The first div, the
`term-scrollbar-show-observer`, sits above where the scrollbar will be
rendered. When the user hovers over it, it will cause the viewport div
to move to a z-index above the contents. It will also enable a second
div, the `term-scrollbar-hide-observer`, which sits above the viewport
and the term contents, but not blocking the scrollbar. When the user
hovers over this div (indicating their mouse has left the scrollbar),
the viewport div is moved back to its original z-index and the hide
observer is set to `display: none`. This gives pointer event priority
back to the contents div.
This resolves an issue where the user could not click links in the
terminal output.
Resolves #1357
2024-12-24 05:35:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.term-scrollbar-hide-observer {
|
|
|
|
z-index: calc(var(--zindex-xterm-viewport-overlay) + 1);
|
|
|
|
display: none;
|
|
|
|
position: absolute;
|
|
|
|
top: 0;
|
|
|
|
left: 0;
|
|
|
|
height: 100%;
|
2024-12-29 22:30:32 +01:00
|
|
|
width: calc(100% - 18px);
|
Fix Term Widget not registering pointer events (#1614)
This is a bit janky. The problem is that we were placing the
`xterm-viewport` div, which contains the scroll observer for the xterm
contents, at a higher z-index than the xterm contents, meaning that the
contents couldn't register any pointer events. If we don't put a
z-index, though, the scroll bar can't accept pointer events. To get
around this, I've added two observer divs, which control whether the
contents or the viewport have pointer event priority. The first div, the
`term-scrollbar-show-observer`, sits above where the scrollbar will be
rendered. When the user hovers over it, it will cause the viewport div
to move to a z-index above the contents. It will also enable a second
div, the `term-scrollbar-hide-observer`, which sits above the viewport
and the term contents, but not blocking the scrollbar. When the user
hovers over this div (indicating their mouse has left the scrollbar),
the viewport div is moved back to its original z-index and the hide
observer is set to `display: none`. This gives pointer event priority
back to the contents div.
This resolves an issue where the user could not click links in the
terminal output.
Resolves #1357
2024-12-24 05:35:51 +01:00
|
|
|
}
|
|
|
|
|
2024-12-04 22:49:14 +01:00
|
|
|
.terminal {
|
|
|
|
.xterm-viewport {
|
|
|
|
&::-webkit-scrollbar {
|
|
|
|
width: 6px;
|
|
|
|
height: 6px;
|
|
|
|
}
|
|
|
|
|
|
|
|
&::-webkit-scrollbar-track {
|
|
|
|
background-color: var(--scrollbar-background-color);
|
|
|
|
}
|
|
|
|
|
|
|
|
&::-webkit-scrollbar-thumb {
|
|
|
|
display: none;
|
|
|
|
background-color: var(--scrollbar-thumb-color);
|
|
|
|
border-radius: 4px;
|
|
|
|
margin: 0 1px 0 1px;
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
background-color: var(--scrollbar-thumb-hover-color);
|
|
|
|
}
|
|
|
|
|
|
|
|
&:active {
|
|
|
|
background-color: var(--scrollbar-thumb-active-color);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
.xterm-viewport::-webkit-scrollbar-thumb {
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
}
|
2024-07-09 07:31:38 +02:00
|
|
|
}
|
2024-06-17 19:18:38 +02:00
|
|
|
}
|