Restore action bar

pull/21833/head
Germain Souquet 2021-07-07 12:04:28 +02:00
parent b0a1fc7b97
commit 7d946ee0db
3 changed files with 35 additions and 10 deletions

View File

@ -69,18 +69,32 @@ limitations under the License.
} }
.mx_EventTile_line { .mx_EventTile_line {
position: relative;
padding: var(--gutterSize); padding: var(--gutterSize);
border-radius: var(--cornerRadius); border-top-left-radius: var(--cornerRadius);
border-top-right-radius: var(--cornerRadius);
border-bottom-right-radius: var(--cornerRadius);
background: var(--backgroundColor); background: var(--backgroundColor);
display: flex; display: flex;
gap: var(--gutterSize); gap: var(--gutterSize);
margin: 0 -12px 0 -22px; margin: 0 -12px 0 -22px;
> a { > a {
position: absolute; position: absolute;
left: -57px; left: -35px;
} }
} }
&.mx_EventTile_continuation .mx_EventTile_line {
border-top-left-radius: 0;
}
&.mx_EventTile_lastInSection .mx_EventTile_line {
border-bottom-left-radius: var(--cornerRadius);
}
.mx_EventTile_avatar { .mx_EventTile_avatar {
position: absolute; position: absolute;
top: 0; top: 0;
@ -94,6 +108,10 @@ limitations under the License.
&[data-self=true] { &[data-self=true] {
.mx_EventTile_line { .mx_EventTile_line {
float: right; float: right;
> a {
left: auto;
right: -35px;
}
} }
.mx_SenderProfile { .mx_SenderProfile {
display: none; display: none;
@ -153,6 +171,11 @@ limitations under the License.
left: calc(-1 * var(--avatarSize)); left: calc(-1 * var(--avatarSize));
} }
.mx_MessageActionBar {
right: 0;
transform: translate3d(50%, 50%, 0);
}
--backgroundColor: $eventbubble-others-bg; --backgroundColor: $eventbubble-others-bg;
} }

View File

@ -123,13 +123,6 @@ $hover-select-border: 4px;
left: calc(-$hover-select-border); left: calc(-$hover-select-border);
} }
.mx_EventTile:hover .mx_MessageActionBar,
.mx_EventTile.mx_EventTile_actionBarFocused .mx_MessageActionBar,
[data-whatinput='keyboard'] .mx_EventTile:focus-within .mx_MessageActionBar,
.mx_EventTile.focus-visible:focus-within .mx_MessageActionBar {
visibility: visible;
}
/* this is used for the tile for the event which is selected via the URL. /* this is used for the tile for the event which is selected via the URL.
* TODO: ultimately we probably want some transition on here. * TODO: ultimately we probably want some transition on here.
*/ */
@ -626,6 +619,13 @@ $hover-select-border: 4px;
} }
} }
.mx_EventTile:hover .mx_MessageActionBar,
.mx_EventTile.mx_EventTile_actionBarFocused .mx_MessageActionBar,
[data-whatinput='keyboard'] .mx_EventTile:focus-within .mx_MessageActionBar,
.mx_EventTile.focus-visible:focus-within .mx_MessageActionBar {
visibility: visible;
}
@media only screen and (max-width: 480px) { @media only screen and (max-width: 480px) {
.mx_EventTile_line, .mx_EventTile_reply { .mx_EventTile_line, .mx_EventTile_reply {
padding-left: 0; padding-left: 0;

View File

@ -644,8 +644,10 @@ export default class MessagePanel extends React.Component<IProps, IState> {
} }
let willWantDateSeparator = false; let willWantDateSeparator = false;
let lastInSection = true;
if (nextEvent) { if (nextEvent) {
willWantDateSeparator = this.wantsDateSeparator(mxEv, nextEvent.getDate() || new Date()); willWantDateSeparator = this.wantsDateSeparator(mxEv, nextEvent.getDate() || new Date());
lastInSection = willWantDateSeparator || mxEv.getSender() !== nextEvent.getSender();
} }
// is this a continuation of the previous message? // is this a continuation of the previous message?
@ -702,7 +704,7 @@ export default class MessagePanel extends React.Component<IProps, IState> {
isTwelveHour={this.props.isTwelveHour} isTwelveHour={this.props.isTwelveHour}
permalinkCreator={this.props.permalinkCreator} permalinkCreator={this.props.permalinkCreator}
last={last} last={last}
lastInSection={willWantDateSeparator} lastInSection={lastInSection}
lastSuccessful={isLastSuccessful} lastSuccessful={isLastSuccessful}
isSelectedEvent={highlight} isSelectedEvent={highlight}
getRelationsForEvent={this.props.getRelationsForEvent} getRelationsForEvent={this.props.getRelationsForEvent}