Add delimiters to screen tab, make active gradient a translucent mask (#356)

* Add delimiters to screen tab, make active gradient a translucent mask

* make delimiter slightly shorter

* move end icon a bit to provide more separation

* fix zindex for tab contents

* fix magic layout

* make the tabs closer to the width they used to be
This commit is contained in:
Evan Simkowitz 2024-02-28 18:25:37 -08:00 committed by GitHub
parent 189e632ff7
commit 75be66bada
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 80 additions and 65 deletions

View File

@ -20,7 +20,7 @@ let MagicLayout = {
TermWidthBuffer: 15, TermWidthBuffer: 15,
TabWidth: 154, TabWidth: 155,
ScreenSidebarWidthPadding: 5, ScreenSidebarWidthPadding: 5,
ScreenSidebarMinWidth: 200, ScreenSidebarMinWidth: 200,

View File

@ -27,6 +27,7 @@
--screentabs-font-size: 12.5px; --screentabs-font-size: 12.5px;
--screentabs-font-weight: 300; --screentabs-font-weight: 300;
--screentabs-selected-font-weight: 300; --screentabs-selected-font-weight: 300;
--screen-tab-width: 11.4em;
// floating logo settings // floating logo settings
--floating-logo-width-darwin: 110px; --floating-logo-width-darwin: 110px;

View File

@ -85,6 +85,8 @@ class ScreenTab extends React.Component<
onContextMenu={(event) => this.openScreenSettings(event, screen)} onContextMenu={(event) => this.openScreenSettings(event, screen)}
onDragEnd={this.handleDragEnd} onDragEnd={this.handleDragEnd}
> >
<div className="background"></div>
<div className="screen-tab-inner">
<CenteredIcon className="front-icon"> <CenteredIcon className="front-icon">
<TabIcon icon={screen.getTabIcon()} color={screen.getTabColor()} /> <TabIcon icon={screen.getTabIcon()} color={screen.getTabColor()} />
</CenteredIcon> </CenteredIcon>
@ -96,6 +98,8 @@ class ScreenTab extends React.Component<
<StatusIndicator level={statusIndicatorLevel} runningCommands={runningCommands} /> <StatusIndicator level={statusIndicatorLevel} runningCommands={runningCommands} />
<ActionsIcon onClick={(e) => this.openScreenSettings(e, screen)} /> <ActionsIcon onClick={(e) => this.openScreenSettings(e, screen)} />
</div> </div>
</div>
<div className="vertical-line"></div>
</Reorder.Item> </Reorder.Item>
); );
} }

View File

@ -1,19 +1,16 @@
@import "@/common/icons/icons.less"; @import "@/common/icons/icons.less";
// Theming values
#main .screen-tabs .screen-tab { #main .screen-tabs .screen-tab {
border-top: 1px solid transparent;
font-size: var(--screentabs-font-size); font-size: var(--screentabs-font-size);
line-height: var(--screentabs-line-height); line-height: var(--screentabs-line-height);
font-family: var(--label-font-family); font-family: var(--label-font-family);
font-weight: var(--screentabs-font-weight); font-weight: var(--screentabs-font-weight);
&:not(:hover) .status-indicator { &.is-active {
.status-indicator-visible; .background {
} border-top: 1px solid var(--tab-color);
background-color: var(--tab-color);
&:hover {
.actions {
.positional-icon-visible;
} }
} }
@ -25,17 +22,6 @@
color: var(--tab-color); color: var(--tab-color);
} }
&.is-active {
border-top: 1px solid var(--tab-color);
background-color: var(--tab-color);
background-image: linear-gradient(
rgba(0, 0, 0, 0),
rgba(0, 0, 0, 0.5) 15%,
rgba(0, 0, 0, 0.7) 30%,
rgba(0, 0, 0, 1) 100%
);
}
&.color-green, &.color-green,
&.color-default { &.color-default {
--tab-color: var(--tab-green); --tab-color: var(--tab-green);
@ -76,15 +62,9 @@
&.color-pink { &.color-pink {
--tab-color: var(--tab-pink); --tab-color: var(--tab-pink);
} }
.web-share-icon {
position: relative;
top: 1px;
margin-right: 3px;
}
} }
// #main for selectivity // Layout values
#main .screen-tabs-container { #main .screen-tabs-container {
display: flex; display: flex;
position: relative; position: relative;
@ -113,17 +93,32 @@
.screen-tabs { .screen-tabs {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
align-items: center; height: 100%;
.screen-tab { .screen-tab {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
min-width: 13.6em; position: relative;
max-width: 13.6em; .background {
// This applies a transparency mask to the background color, as set above, so that it will blend with whatever the theme's background color is.
z-index: 1;
width: var(--screen-tab-width);
mask-image: linear-gradient(
rgba(0, 0, 0, 1),
rgba(0, 0, 0, 0.7) 15%,
rgba(0, 0, 0, 0.5) 30%,
rgba(0, 0, 0, 0) 100%
);
}
.screen-tab-inner {
display: flex;
flex-direction: row;
position: absolute;
z-index: 2;
min-width: var(--screen-tab-width);
max-width: var(--screen-tab-width);
align-items: center; align-items: center;
cursor: pointer; cursor: pointer;
padding: 8px 8px 4px 8px; // extra 4px of tab padding to account for horizontal scrollbar (to make tab text look centered) padding: 8px 8px 4px 8px; // extra 4px of tab padding to account for horizontal scrollbar (to make tab text look centered)
.front-icon { .front-icon {
.positional-icon-visible; .positional-icon-visible;
} }
@ -147,13 +142,28 @@
// Only one of these will be visible at a time // Only one of these will be visible at a time
.end-icons { .end-icons {
// This adjusts the position of the icon to account for the default 8px margin on the parent. We want the positional calculations for this icon to assume it is flush with the edge of the screen tab. // This adjusts the position of the icon to account for the default 8px margin on the parent. We want the positional calculations for this icon to assume it is flush with the edge of the screen tab.
margin: 0 -8px 0 0; margin: 0 -5px 0 0;
line-height: normal; line-height: normal;
.tab-index { .tab-index {
font-size: 12.5px; font-size: 12.5px;
} }
} }
} }
.vertical-line {
border-left: 1px solid var(--app-border-color);
margin: 10px 0 8px 0;
}
&:not(:hover) .status-indicator {
.status-indicator-visible;
}
&:hover {
.actions {
.positional-icon-visible;
}
}
}
} }
.new-screen { .new-screen {