mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-15 13:01:31 +03:00
191 lines
5 KiB
SCSS
191 lines
5 KiB
SCSS
/*
|
|
Copyright 2015, 2016 OpenMarket Ltd
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
/* a word of explanation about the flex-shrink values employed here:
|
|
there are 3 priotized categories of screen real-estate grabbing,
|
|
each with a flex-shrink difference of 4 order of magnitude,
|
|
so they ideally wouldn't affect each other.
|
|
lowest category: .mx_RoomSubList
|
|
flex-shrink: 10000000
|
|
distribute size of items within the same categery by their size
|
|
middle category: .mx_RoomSubList.resized-sized
|
|
flex-shrink: 1000
|
|
applied when using the resizer, will have a max-height set to it,
|
|
to limit the size
|
|
highest category: .mx_RoomSubList.resized-all
|
|
flex-shrink: 1
|
|
small flex-shrink value (1), is only added if you can drag the resizer so far
|
|
so in practice you can only assign this category if there is enough space.
|
|
*/
|
|
|
|
.mx_RoomSubList {
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
|
|
.mx_RoomSubList_nonEmpty .mx_AutoHideScrollbar_offset {
|
|
padding-bottom: 4px;
|
|
}
|
|
|
|
.mx_RoomSubList_labelContainer {
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
flex: 0 0 auto;
|
|
margin: 0 16px;
|
|
height: 36px;
|
|
}
|
|
|
|
.mx_RoomSubList_label {
|
|
flex: 1;
|
|
cursor: pointer;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 6px;
|
|
}
|
|
|
|
.mx_RoomSubList_label > span {
|
|
flex: 1 1 auto;
|
|
text-transform: uppercase;
|
|
color: $roomsublist-label-fg-color;
|
|
font-weight: 700;
|
|
font-size: 12px;
|
|
margin-left: 8px;
|
|
}
|
|
|
|
.mx_RoomSubList_badge {
|
|
flex: 0 0 auto;
|
|
border-radius: 8px;
|
|
color: $accent-fg-color;
|
|
font-weight: 600;
|
|
font-size: 12px;
|
|
padding: 0 5px;
|
|
background-color: $roomtile-name-color;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.mx_RoomSubList_addRoom, .mx_RoomSubList_badge {
|
|
margin-left: 7px;
|
|
}
|
|
|
|
.mx_RoomSubList_addRoom {
|
|
background-color: $roomheader-addroom-color;
|
|
color: $roomsublist-background;
|
|
background-image: url('$(res)/img/icons-room-add.svg');
|
|
background-repeat: no-repeat;
|
|
background-position: center;
|
|
border-radius: 10px; // 16/2 + 2 padding
|
|
height: 16px;
|
|
flex: 0 0 16px;
|
|
background-clip: content-box;
|
|
}
|
|
|
|
.mx_RoomSubList_badgeHighlight {
|
|
background-color: $warning-color;
|
|
}
|
|
|
|
.mx_RoomSubList_chevron {
|
|
pointer-events: none;
|
|
mask: url('$(res)/img/feather-icons/dropdown-arrow.svg');
|
|
mask-repeat: no-repeat;
|
|
transition: transform 0.2s ease-in;
|
|
width: 10px;
|
|
height: 6px;
|
|
margin-left: 2px;
|
|
background-color: $roomsublist-label-fg-color;
|
|
}
|
|
|
|
.mx_RoomSubList_chevronDown {
|
|
transform: rotateZ(0deg);
|
|
}
|
|
|
|
.mx_RoomSubList_chevronUp {
|
|
transform: rotateZ(180deg);
|
|
}
|
|
|
|
.mx_RoomSubList_chevronRight {
|
|
transform: rotateZ(-90deg);
|
|
}
|
|
|
|
.mx_RoomSubList_scroll {
|
|
/* let rooms list grab as much space as it needs (auto),
|
|
potentially overflowing and showing a scrollbar */
|
|
flex: 0 1 auto;
|
|
padding: 0 8px;
|
|
}
|
|
|
|
// overflow indicators
|
|
.mx_RoomSubList:not(.resized-all) > .mx_RoomSubList_scroll {
|
|
&.mx_IndicatorScrollbar_topOverflow::before,
|
|
&.mx_IndicatorScrollbar_bottomOverflow::after {
|
|
position: sticky;
|
|
left: 0;
|
|
right: 0;
|
|
height: 8px;
|
|
content: "";
|
|
display: block;
|
|
z-index: 100;
|
|
pointer-events: none;
|
|
}
|
|
|
|
&.mx_IndicatorScrollbar_topOverflow > .mx_AutoHideScrollbar_offset {
|
|
margin-top: -8px;
|
|
}
|
|
&.mx_IndicatorScrollbar_bottomOverflow > .mx_AutoHideScrollbar_offset {
|
|
margin-bottom: -8px;
|
|
}
|
|
|
|
&.mx_IndicatorScrollbar_topOverflow::before {
|
|
top: 0;
|
|
transition: background-image 0.1s ease-in;
|
|
background: linear-gradient(to top, rgba(242,245,248,0), rgba(242,245,248,1));
|
|
}
|
|
|
|
/*
|
|
// for now, we remove the bottomOverflow entirely as we don't want to
|
|
// lose the screen real-estate due to a bg-colored gradient, but we also
|
|
// don't want to use drop shadows and risk a confusing hierarchy of cards.
|
|
// so, instead, we hard-clip at the bottom but soft-clip at the top.
|
|
&.mx_IndicatorScrollbar_bottomOverflow::after {
|
|
bottom: 0;
|
|
transition: background-image 0.1s ease-in;
|
|
margin: 0px -8px;
|
|
background: linear-gradient(to bottom, rgba(0,0,0,0.1), rgba(0,0,0,0.0));
|
|
}
|
|
*/
|
|
}
|
|
|
|
.collapsed {
|
|
|
|
.mx_RoomSubList_scroll {
|
|
padding: 0;
|
|
}
|
|
|
|
.mx_RoomSubList_labelContainer {
|
|
margin-right: 14px;
|
|
margin-left: 2px;
|
|
}
|
|
|
|
.mx_RoomSubList_addRoom {
|
|
margin-left: 3px;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.mx_RoomSubList_label > span {
|
|
display: none;
|
|
}
|
|
}
|