38a913488f
* Improve clickability of view source event toggle button Signed-off-by: Suguru Hirahara <luixxiul@users.noreply.github.com> * Fix compression Signed-off-by: Suguru Hirahara <luixxiul@users.noreply.github.com> * Make it easy to select subsequent events Signed-off-by: Suguru Hirahara <luixxiul@users.noreply.github.com>
191 lines
6.3 KiB
Text
191 lines
6.3 KiB
Text
/*
|
|
Copyright 2019 New Vector Ltd
|
|
Copyright 2019 The Matrix.org Foundation C.I.C.
|
|
|
|
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.
|
|
*/
|
|
|
|
.mx_MessageActionBar {
|
|
--MessageActionBar-size-button: 28px;
|
|
--MessageActionBar-size-box: 32px; // 28px + 2px (margin) * 2
|
|
--MessageActionBar-item-hover-background: $panel-actions;
|
|
--MessageActionBar-item-hover-borderRadius: 6px;
|
|
--MessageActionBar-item-hover-zIndex: 1;
|
|
--MessageActionBar-star-button-color: #ffa534;
|
|
|
|
position: absolute;
|
|
visibility: hidden;
|
|
cursor: pointer;
|
|
display: flex;
|
|
height: var(--MessageActionBar-size-box);
|
|
line-height: $font-24px;
|
|
border-radius: 8px;
|
|
background: $background;
|
|
border: 1px solid $input-border-color;
|
|
top: -32px;
|
|
right: 8px;
|
|
user-select: none;
|
|
// Ensure the action bar appears above other things like the read marker
|
|
// and sender avatar (for small screens)
|
|
z-index: 10;
|
|
|
|
// Adds a previous event safe area so that you can't accidentally hover the
|
|
// previous event while trying to mouse into the action bar or from the
|
|
// react button to its tooltip.
|
|
&::before {
|
|
content: '';
|
|
position: absolute;
|
|
// tooltip safe mousing area + tooltip overhang +
|
|
// action bar + action bar offset from event
|
|
width: calc(10px + 48px + 100% + 8px);
|
|
// safe area + action bar
|
|
height: calc(20px + 100%);
|
|
top: -12px;
|
|
left: -58px;
|
|
z-index: -1;
|
|
cursor: initial;
|
|
|
|
/* stylelint-disable-next-line max-line-length */
|
|
.mx_GenericEventListSummary[data-layout="bubble"] .mx_GenericEventListSummary_toggle ~ .mx_GenericEventListSummary_unstyledList .mx_EventTile_info:first-of-type & {
|
|
// improve clickability of "collapse" link button on bubble layout by reducing width and height values
|
|
// mx_GenericEventListSummary_toggle ~: to apply rules to action bar when "collapse" button is available
|
|
// mx_EventTile_info:first-of-type: to apply rules to the info event tile just under "collapse" button
|
|
// TODO: use a new class name instead
|
|
width: 100%;
|
|
height: 100%;
|
|
top: 0;
|
|
left: 0;
|
|
}
|
|
|
|
.mx_EventTile_info .mx_ViewSourceEvent ~ & {
|
|
// improve clickability of view source event toggle button by removing vertical safe area
|
|
width: 100%;
|
|
height: 100%;
|
|
top: 0;
|
|
left: 0;
|
|
}
|
|
}
|
|
|
|
>* {
|
|
white-space: nowrap;
|
|
display: inline-block;
|
|
position: relative;
|
|
margin: 2px;
|
|
|
|
&:hover {
|
|
background: var(--MessageActionBar-item-hover-background);
|
|
border-radius: var(--MessageActionBar-item-hover-borderRadius);
|
|
z-index: var(--MessageActionBar-item-hover-zIndex);
|
|
}
|
|
}
|
|
|
|
.mx_MessageActionBar_maskButton {
|
|
width: var(--MessageActionBar-size-button);
|
|
height: var(--MessageActionBar-size-button);
|
|
|
|
&:disabled,
|
|
&[disabled] {
|
|
cursor: not-allowed;
|
|
opacity: .75;
|
|
}
|
|
|
|
&::after {
|
|
content: '';
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
height: 100%;
|
|
width: 100%;
|
|
mask-size: 18px;
|
|
mask-repeat: no-repeat;
|
|
mask-position: center;
|
|
background-color: $secondary-content;
|
|
}
|
|
|
|
&:hover::after {
|
|
background-color: $primary-content;
|
|
}
|
|
|
|
&.mx_MessageActionBar_reactButton::after {
|
|
mask-image: url('$(res)/img/element-icons/room/message-bar/emoji.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_replyButton::after {
|
|
mask-image: url('$(res)/img/element-icons/room/message-bar/reply.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_threadButton {
|
|
&::after {
|
|
mask-image: url('$(res)/img/element-icons/message/thread.svg');
|
|
}
|
|
|
|
.mx_Indicator {
|
|
background: $links;
|
|
animation-iteration-count: infinite;
|
|
}
|
|
}
|
|
|
|
&.mx_MessageActionBar_favouriteButton::after {
|
|
mask-image: url('$(res)/img/element-icons/room/message-bar/star.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_favouriteButton_fillstar::after {
|
|
background-color: var(--MessageActionBar-star-button-color);
|
|
}
|
|
|
|
&.mx_MessageActionBar_editButton::after {
|
|
mask-image: url('$(res)/img/element-icons/room/message-bar/edit.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_optionsButton::after {
|
|
mask-image: url('$(res)/img/element-icons/context-menu.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_resendButton::after {
|
|
mask-image: url('$(res)/img/element-icons/retry.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_cancelButton::after {
|
|
mask-image: url('$(res)/img/element-icons/trashcan.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_downloadButton {
|
|
&::after {
|
|
mask-size: 14px;
|
|
mask-image: url('$(res)/img/download.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_downloadSpinnerButton::after {
|
|
background-color: transparent; // hide the download icon mask
|
|
}
|
|
}
|
|
|
|
&.mx_MessageActionBar_expandMessageButton::after {
|
|
mask-size: 12px;
|
|
mask-image: url('$(res)/img/element-icons/expand-message.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_collapseMessageButton::after {
|
|
mask-size: 12px;
|
|
mask-image: url('$(res)/img/element-icons/collapse-message.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_viewInRoomButton::after {
|
|
mask-image: url('$(res)/img/element-icons/view-in-room.svg');
|
|
}
|
|
|
|
&.mx_MessageActionBar_copyLinkButton::after {
|
|
mask-image: url('$(res)/img/element-icons/link.svg');
|
|
}
|
|
}
|
|
}
|