mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-18 20:51:51 +03:00
eae9d9e248
* [create-pull-request] automated change (#12966) Co-authored-by: github-merge-queue <github-merge-queue@users.noreply.github.com> * Add timezone to right panel profile. * Add setting to publish timezone * Add string for timezone publish * Automatically update timezone when setting changes. * Refactor to using a hook And automatically refresh the timezone every minute. * Check for feature support for extended profiles. * lint * Add timezone * Remove unintentional changes * Use browser default timezone. * lint * tweaks * Set timezone publish at the device level to prevent all devices writing to the timezone field. * Update hook to use external client. * Add test for user timezone. * Update snapshot for preferences tab. * Hide timezone info if not provided. * Stablize test * Fix date test types. * prettier * Add timezone tests * Add test for invalid timezone. * Update screenshot * Remove check for profile. --------- Co-authored-by: ElementRobot <releases@riot.im> Co-authored-by: github-merge-queue <github-merge-queue@users.noreply.github.com>
234 lines
5.7 KiB
Text
234 lines
5.7 KiB
Text
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2019 The Matrix.org Foundation C.I.C.
|
|
Copyright 2015, 2016 OpenMarket Ltd
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
.mx_UserInfo.mx_BaseCard {
|
|
/* UserInfo has a circular image at the top so it fits between the back & close buttons */
|
|
padding-top: 0;
|
|
overflow-y: auto;
|
|
font-size: var(--cpd-font-size-body-sm);
|
|
|
|
.mx_UserInfo_cancel {
|
|
cursor: pointer;
|
|
position: absolute;
|
|
top: 0;
|
|
border-radius: 4px;
|
|
background-color: $dark-panel-bg-color;
|
|
margin: 9px;
|
|
z-index: 1; /* render on top of the right panel */
|
|
|
|
div {
|
|
height: 16px;
|
|
width: 16px;
|
|
padding: 4px;
|
|
mask-image: url("$(res)/img/minimise.svg");
|
|
mask-repeat: no-repeat;
|
|
mask-position: 7px center;
|
|
background-color: $header-panel-text-primary-color;
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_container {
|
|
padding: var(--cpd-space-4x) 0;
|
|
margin: 0 var(--cpd-space-4x);
|
|
|
|
.mx_UserInfo_container_verifyButton {
|
|
margin-top: $spacing-8;
|
|
}
|
|
|
|
& + .mx_UserInfo_container {
|
|
border-top: 1px solid $separator;
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_memberDetailsContainer {
|
|
padding-top: 0;
|
|
padding-bottom: 0;
|
|
margin-bottom: $spacing-8;
|
|
}
|
|
|
|
.mx_RoomTile_titleContainer {
|
|
width: 154px;
|
|
}
|
|
|
|
.mx_RoomTile_badge {
|
|
display: none;
|
|
}
|
|
|
|
.mx_RoomTile_title {
|
|
width: 160px;
|
|
}
|
|
|
|
.mx_UserInfo_avatar {
|
|
margin: $spacing-24 $spacing-32 0 $spacing-32;
|
|
|
|
.mx_UserInfo_avatar_transition {
|
|
max-width: 120px;
|
|
aspect-ratio: 1 / 1;
|
|
margin: 0 auto;
|
|
transition: 0.5s;
|
|
|
|
.mx_BaseAvatar {
|
|
/* Override the calculated font-size so that the letter isn't tiny */
|
|
font-size: 4rem;
|
|
}
|
|
|
|
.mx_BaseAvatar,
|
|
.mx_BaseAvatar img {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
}
|
|
|
|
h2 {
|
|
text-transform: uppercase;
|
|
color: $tertiary-content;
|
|
font: var(--cpd-font-body-md-semibold);
|
|
font-weight: var(--cpd-font-weight-semibold);
|
|
margin: $spacing-4 0;
|
|
}
|
|
|
|
p {
|
|
margin: 5px 0;
|
|
}
|
|
|
|
.mx_UserInfo_profile {
|
|
h1 {
|
|
font-size: $font-20px;
|
|
line-height: $font-25px;
|
|
|
|
/* limit to 2 lines, show an ellipsis if it overflows */
|
|
/* this looks webkit specific but is supported by Firefox 68+ */
|
|
display: -webkit-box;
|
|
-webkit-box-orient: vertical;
|
|
-webkit-line-clamp: 2;
|
|
|
|
overflow: hidden;
|
|
word-break: break-all;
|
|
text-overflow: ellipsis;
|
|
|
|
/* E2E icon wrapper */
|
|
.mx_Flex > span {
|
|
display: inline-block;
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_profileStatus {
|
|
margin: var(--cpd-space-1x) 0;
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_timezone {
|
|
margin: var(--cpd-space-1x) 0;
|
|
}
|
|
|
|
.mx_PresenceLabel {
|
|
font: var(--cpd-font-body-sm-regular);
|
|
opacity: 1;
|
|
}
|
|
|
|
.mx_UserInfo_memberDetails {
|
|
.mx_UserInfo_profileField {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
|
|
margin: 6px 0;
|
|
|
|
.mx_UserInfo_roleDescription {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
/* try to make it the same height as the dropdown */
|
|
margin: 11px 0 12px 0;
|
|
}
|
|
|
|
.mx_Field {
|
|
margin: 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_field {
|
|
line-height: $font-16px;
|
|
}
|
|
|
|
.mx_UserInfo_statusMessage {
|
|
$statusNumberOfLines: 3;
|
|
|
|
font: var(--cpd-font-body-sm-regular);
|
|
font-size: $font-11px;
|
|
line-height: 1rem;
|
|
opacity: 0.5;
|
|
overflow: hidden;
|
|
word-break: break-word;
|
|
text-overflow: ellipsis;
|
|
display: -webkit-box;
|
|
max-height: calc(1rem * $statusNumberOfLines);
|
|
-webkit-line-clamp: $statusNumberOfLines;
|
|
-webkit-box-orient: vertical;
|
|
}
|
|
|
|
.mx_AutoHideScrollbar {
|
|
flex: 1 1 0;
|
|
}
|
|
|
|
.mx_UserInfo_devices {
|
|
.mx_UserInfo_device {
|
|
display: flex;
|
|
margin: $spacing-8 0;
|
|
|
|
&.mx_UserInfo_device_verified {
|
|
.mx_UserInfo_device_trusted {
|
|
color: $accent;
|
|
}
|
|
}
|
|
&.mx_UserInfo_device_unverified {
|
|
.mx_UserInfo_device_trusted {
|
|
color: $alert;
|
|
}
|
|
}
|
|
|
|
.mx_UserInfo_device_name {
|
|
flex: 1;
|
|
margin: 0 5px;
|
|
word-break: break-word;
|
|
}
|
|
}
|
|
|
|
/* both for icon in expand button and device item */
|
|
.mx_E2EIcon {
|
|
/* don't squeeze */
|
|
flex: 0 0 auto;
|
|
margin: 0;
|
|
width: 12px;
|
|
height: 12px;
|
|
}
|
|
|
|
.mx_UserInfo_expand {
|
|
column-gap: 5px; /* cf: mx_UserInfo_device_name */
|
|
margin-bottom: 11px;
|
|
align-items: initial; /* Cancel the default property */
|
|
}
|
|
}
|
|
|
|
&.mx_UserInfo_smallAvatar {
|
|
.mx_UserInfo_avatar {
|
|
.mx_UserInfo_avatar_transition {
|
|
max-width: 72px;
|
|
margin: 0 auto;
|
|
}
|
|
|
|
.mx_BaseAvatar {
|
|
/* Override the calculated font-size so that the letter isn't tiny */
|
|
font-size: 2rem;
|
|
}
|
|
}
|
|
}
|
|
}
|