Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Add unread indicator to the timelineCard header icon #7156

Merged
merged 110 commits into from
Nov 30, 2021
Merged
Show file tree
Hide file tree
Changes from 102 commits
Commits
Show all changes
110 commits
Select commit Hold shift + click to select a range
0a6c20c
add maximise widget functionality
toger5 Nov 8, 2021
a9a2c41
fix linter issues
toger5 Nov 8, 2021
cb4ae5f
fix style lint issues
toger5 Nov 8, 2021
e68c8f1
Update src/components/structures/RoomView.tsx
toger5 Nov 9, 2021
8608c59
fix typo
toger5 Nov 9, 2021
bb543a2
typo
toger5 Nov 9, 2021
4cc316d
Remove caps "AND "
toger5 Nov 10, 2021
4a3b48d
fix spelling
toger5 Nov 10, 2021
5d14783
improove readibility for continue in for
toger5 Nov 10, 2021
74f9b93
review fixes
toger5 Nov 10, 2021
cfbdf40
reuse already added icons
toger5 Nov 10, 2021
ffb0af8
more container comment fixes
toger5 Nov 10, 2021
1155ae9
fix app options button
toger5 Nov 10, 2021
cd9d193
remove error message
toger5 Nov 10, 2021
a76e7ec
fix issue not beeing able to maximise
toger5 Nov 10, 2021
04e0b42
remove maxmimisedDrawer
toger5 Nov 10, 2021
21b9549
fix centering and overflow of appDrawer
toger5 Nov 10, 2021
38f8cfe
fix hover label "Minimise widget"->"Close"
toger5 Nov 11, 2021
4aa18f7
right panel chat timeline
toger5 Nov 10, 2021
0df2b82
automatically switch to TimelineCard on maximise
toger5 Nov 10, 2021
bddb05f
fix style and compile errors
toger5 Nov 10, 2021
2ffd836
fix highlighting and labels
toger5 Nov 11, 2021
c3a6409
rename timelinePanel-> timelineCard
toger5 Nov 11, 2021
6fb6e6d
simplify previous phase access
toger5 Nov 11, 2021
98adc21
close right panel chat if no widget is maximised
toger5 Nov 11, 2021
7d8879f
fix linter
toger5 Nov 11, 2021
1fac898
only show core elements if a widget is maximised
toger5 Nov 11, 2021
1bff7f0
hide timeline card button
toger5 Nov 11, 2021
0831b60
review fixes
toger5 Nov 11, 2021
fdf7b9f
add jest test for WidgetLayoutStore
toger5 Nov 12, 2021
afef1d0
Merge branch 'develop' into toger5/maximised_widgets
toger5 Nov 12, 2021
b06490e
change accent-color
toger5 Nov 12, 2021
b3c6526
another try
toger5 Nov 12, 2021
03ec030
Merge branch 'develop' into toger5/maximised_widgets
toger5 Nov 12, 2021
a23931b
I think I have it now...(accent related commit)
toger5 Nov 12, 2021
0bcb881
fix room state always overriding user settings
toger5 Nov 15, 2021
b1ef33b
fix container border width
toger5 Nov 15, 2021
ba4d09c
change icons, change border width
toger5 Nov 15, 2021
26d5cd1
Merge branch 'toger5/widget_container_border_width' into toger5/maxim…
toger5 Nov 15, 2021
2a8bba6
use $container-border-width where needed
toger5 Nov 15, 2021
6f3a1c0
fix style lint
toger5 Nov 15, 2021
fa35b44
add !important for widget card AppTileFullWidth
toger5 Nov 15, 2021
7f0c5d6
fix bug where a widget can be open twice
toger5 Nov 15, 2021
a8d2e5e
review fixes
toger5 Nov 15, 2021
3743b74
fix awkward ternary stack
toger5 Nov 15, 2021
c6e9c82
Merge branch 'develop' into toger5/maximised_widgets
toger5 Nov 15, 2021
704ddc8
remove the now deprecated collapse button url after merge
toger5 Nov 15, 2021
0b9a544
Merge branch 'toger5/maximised_widgets' into toger5/maximised_widgets…
toger5 Nov 16, 2021
ad183fb
fix styling and move TimelineCard to the views
toger5 Nov 16, 2021
d3218f3
Merge branch 'develop' into toger5/maximised_widgets_rightPanel_timeline
toger5 Nov 16, 2021
6e1f1fe
clean up TimelinCard class
toger5 Nov 16, 2021
585ffa8
fix maximised state being loaded correctly
toger5 Nov 16, 2021
583d754
enable Read Receipts and sendReadReceiptOnLoad for timelineCard
toger5 Nov 17, 2021
d782c06
Merge branch 'develop' into toger5/maximised_widgets_rightPanel_timeline
toger5 Nov 17, 2021
f8c1388
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 17, 2021
fe1e3fa
add unreadIndicator to the timelineCard icon
toger5 Nov 17, 2021
d66a411
Update src/components/structures/RightPanel.tsx
toger5 Nov 17, 2021
6aa2e9b
fix position of dispatcher
toger5 Nov 17, 2021
596af16
fix header styles (make them prettier and simpler)
toger5 Nov 17, 2021
90e331f
fix up event tile
toger5 Nov 17, 2021
8dfa940
rename RightPanelPhases.TimelineCard -> Timeline
toger5 Nov 17, 2021
89b6266
Merge remote-tracking branch 'origin/toger5/maximised_widgets_rightPa…
toger5 Nov 17, 2021
304e788
fix style
toger5 Nov 17, 2021
d6ad1ae
code cleanup for previous phase logic
toger5 Nov 17, 2021
658eb7e
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 17, 2021
e8eafac
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 17, 2021
65c752d
remove artifacts from the previousPhase logic.
toger5 Nov 17, 2021
756630e
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 17, 2021
fb2fcca
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 17, 2021
5a3cf2b
remove unecassary imports
toger5 Nov 17, 2021
d6e80f1
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 17, 2021
495925d
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 17, 2021
20ff205
Merge branch 'develop' into toger5/maximised_widgets_rightPanel_timeline
toger5 Nov 18, 2021
3acb7a3
fix settings layout path
toger5 Nov 18, 2021
786cff8
timeline panel header fixups
toger5 Nov 18, 2021
842150c
only enable new back button behaviour if feature enabled
toger5 Nov 18, 2021
23e9fb3
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 18, 2021
f8ae27e
prevent double timeline
toger5 Nov 18, 2021
6e4bcf0
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 18, 2021
03262fe
coreElementOnly -> excludedRighPanelPhaseButtons
toger5 Nov 19, 2021
77b9c03
disable RR's
toger5 Nov 19, 2021
d097136
remove unread indicator fragments HeaderButton
toger5 Nov 19, 2021
1e3b157
dont go to room info when widget gets closed
toger5 Nov 19, 2021
7999cdf
styling stuff
toger5 Nov 19, 2021
92d8895
solve "never show two timelines" more properly
toger5 Nov 19, 2021
d5a0652
hello linter ;)
toger5 Nov 19, 2021
10f4143
fix typo(s)
toger5 Nov 19, 2021
1bf0704
Update src/components/structures/RoomView.tsx
toger5 Nov 19, 2021
f03de71
Update src/components/structures/RoomView.tsx
toger5 Nov 19, 2021
692ce50
Update res/css/structures/_RightPanel.scss
toger5 Nov 19, 2021
658362b
Update res/css/structures/_RightPanel.scss
toger5 Nov 19, 2021
91b4173
Update src/components/views/right_panel/RoomHeaderButtons.tsx
toger5 Nov 19, 2021
bd0d989
Merge branch 'develop' into toger5/maximised_widgets_rightPanel_timeline
toger5 Nov 22, 2021
e881053
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 22, 2021
f17f9f4
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 22, 2021
7c9cb5a
Merge remote-tracking branch 'origin/toger5/maximised_widgets_unread_…
toger5 Nov 22, 2021
16e414a
reveiw fixes
toger5 Nov 22, 2021
4f4b185
remove unused var (showNewMessages)
toger5 Nov 22, 2021
9251b03
add comment about RR's
toger5 Nov 22, 2021
7ea9f54
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 22, 2021
d25f73b
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 22, 2021
b1bdb2c
types should be interfaces
toger5 Nov 22, 2021
d21dc8f
fix feature flag check
toger5 Nov 24, 2021
bfdb6d1
remove viewInRoom button if a widget is maximised
toger5 Nov 29, 2021
c2f854b
Merge branch 'toger5/maximised_widgets_rightPanel_timeline' into toge…
toger5 Nov 29, 2021
0ba8f76
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 29, 2021
0bd570d
Merge branch 'develop' into toger5/maximised_widgets_only_core_nav
toger5 Nov 29, 2021
c5e23f0
Fix tricky way to still get two timelines
toger5 Nov 29, 2021
265134c
Merge branch 'toger5/maximised_widgets_only_core_nav' into toger5/max…
toger5 Nov 29, 2021
5bb6672
Merge branch 'develop' into toger5/maximised_widgets_unread_badge
toger5 Nov 29, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions res/css/_components.scss
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,7 @@
@import "./views/right_panel/_PinnedMessagesCard.scss";
@import "./views/right_panel/_RoomSummaryCard.scss";
@import "./views/right_panel/_ThreadPanel.scss";
@import "./views/right_panel/_TimelineCard.scss";
@import "./views/right_panel/_UserInfo.scss";
@import "./views/right_panel/_VerificationPanel.scss";
@import "./views/right_panel/_WidgetCard.scss";
Expand Down
78 changes: 51 additions & 27 deletions res/css/structures/_RightPanel.scss
Original file line number Diff line number Diff line change
Expand Up @@ -103,44 +103,68 @@ limitations under the License.
mask-position: center;
}

$dot-size: 8px;
$dot-size: 7px;
$pulse-color: $alert;

.mx_RightPanel_pinnedMessagesButton {
&::before {
mask-image: url('$(res)/img/element-icons/room/pin.svg');
mask-position: center;
}
}
.mx_RightPanel_headerButton_unreadIndicator_bg {
position: absolute;
right: 0;
top: 0;
margin: 4px;
width: $dot-size;
height: $dot-size;
border-radius: 50%;
transform: scale(1.6);
transform-origin: center center;
background: rgba($background, 1);
}

.mx_RightPanel_pinnedMessagesButton_unreadIndicator {
.mx_RightPanel_headerButton_unreadIndicator {
toger5 marked this conversation as resolved.
Show resolved Hide resolved
position: absolute;
right: 0;
top: 0;
margin: 4px;
width: $dot-size;
height: $dot-size;
border-radius: 50%;
transform: scale(1);
background: rgba($pulse-color, 1);
box-shadow: 0 0 0 0 rgba($pulse-color, 1);
animation: mx_RightPanel_indicator_pulse 2s infinite;
animation-iteration-count: 1;

&.mx_Indicator_gray {
background: rgba($input-darker-fg-color, 1);
box-shadow: rgba($input-darker-fg-color, 1);
}

&::after {
content: "";
position: absolute;
right: 0;
width: inherit;
height: inherit;
top: 0;
margin: 4px;
width: $dot-size;
height: $dot-size;
border-radius: 50%;
left: 0;
transform: scale(1);
background: rgba($pulse-color, 1);
box-shadow: 0 0 0 0 rgba($pulse-color, 1);
animation: mx_RightPanel_indicator_pulse 2s infinite;
animation-iteration-count: 1;

&::after {
content: "";
position: absolute;
width: inherit;
height: inherit;
top: 0;
left: 0;
transform: scale(1);
transform-origin: center center;
animation-name: mx_RightPanel_indicator_pulse_shadow;
animation-duration: inherit;
animation-iteration-count: inherit;
border-radius: 50%;
background: rgba($pulse-color, 1);
}
transform-origin: center center;
animation-name: mx_RightPanel_indicator_pulse_shadow;
animation-duration: inherit;
animation-iteration-count: inherit;
border-radius: 50%;
background: inherit;
}
}

.mx_RightPanel_timelineCardButton {
&::before {
mask-image: url('$(res)/img/element-icons/feedback.svg');
mask-position: center;
}
}

Expand Down
36 changes: 36 additions & 0 deletions res/css/views/right_panel/_TimelineCard.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
Copyright 2021 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_TimelineCard {
.mx_TimelineCard__header {
margin-left: 6px;

span:first-of-type {
font-weight: 600;
font-size: 15px;
line-height: 18px;
color: $secondary-content;
}
}

.mx_BaseCard_header {
margin: 5px 0 9px 0;
.mx_BaseCard_close {
margin: 8px;
right: 0;
}
}
}
9 changes: 8 additions & 1 deletion src/components/structures/RightPanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ import SpaceStore from "../../stores/spaces/SpaceStore";
import { RoomPermalinkCreator } from '../../utils/permalinks/Permalinks';
import { E2EStatus } from '../../utils/ShieldUtils';
import { dispatchShowThreadsPanelEvent } from '../../dispatcher/dispatch-actions/threads';
import TimelineCard from '../views/right_panel/TimelineCard';

interface IProps {
room?: Room; // if showing panels for a given room, this is set
Expand Down Expand Up @@ -334,7 +335,13 @@ export default class RightPanel extends React.Component<IProps, IState> {
panel = <PinnedMessagesCard room={this.props.room} onClose={this.onClose} />;
}
break;

case RightPanelPhases.Timeline:
if (!SettingsStore.getValue("feature_maximised_widgets")) break;
panel = <TimelineCard
room={this.props.room}
resizeNotifier={this.props.resizeNotifier}
onClose={this.onClose} />;
break;
case RightPanelPhases.FilePanel:
panel = <FilePanel roomId={roomId} resizeNotifier={this.props.resizeNotifier} onClose={this.onClose} />;
break;
Expand Down
51 changes: 47 additions & 4 deletions src/components/structures/RoomView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,8 @@ import { dispatchShowThreadEvent } from '../../dispatcher/dispatch-actions/threa
import { fetchInitialEvent } from "../../utils/EventUtils";
import { ComposerType } from "../../dispatcher/payloads/ComposerInsertPayload";
import AppsDrawer from '../views/rooms/AppsDrawer';
import { SetRightPanelPhasePayload } from '../../dispatcher/payloads/SetRightPanelPhasePayload';
import { RightPanelPhases } from '../../stores/RightPanelStorePhases';

const DEBUG = false;
let debuglog = function(msg: string) {};
Expand Down Expand Up @@ -327,7 +329,15 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {

private onWidgetLayoutChange = () => {
if (!this.state.room) return;
if (WidgetLayoutStore.instance.hasMaximisedWidget(this.state.room)) {
// Show chat in right panel when a widget is maximised
dis.dispatch<SetRightPanelPhasePayload>({
action: Action.SetRightPanelPhase,
phase: RightPanelPhases.Timeline,
});
}
this.checkWidgets(this.state.room);
this.checkRightPanel(this.state.room);
};

private checkWidgets = (room) => {
Expand All @@ -345,6 +355,22 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
: MainSplitContentType.Timeline;
};

private checkRightPanel = (room) => {
// This is a hack to hide the chat. This should not be necessary once the right panel
// phase is stored per room. (need to be done after check widget so that mainSplitContentType is updated)
if (
RightPanelStore.getSharedInstance().roomPanelPhase === RightPanelPhases.Timeline &&
this.state.showRightPanel &&
!WidgetLayoutStore.instance.hasMaximisedWidget(this.state.room)
) {
// Two timelines are shown prevent this by hiding the right panel
dis.dispatch({
action: Action.ToggleRightPanel,
type: "room",
});
}
};

private onReadReceiptsChange = () => {
this.setState({
showReadReceipts: SettingsStore.getValue("showReadReceipts", this.state.roomId),
Expand Down Expand Up @@ -999,6 +1025,7 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
this.updateE2EStatus(room);
this.updatePermissions(room);
this.checkWidgets(room);
this.checkRightPanel(room);

this.setState({
liveTimeline: room.getLiveTimeline(),
Expand Down Expand Up @@ -2094,6 +2121,7 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
}

const showRightPanel = this.state.room && this.state.showRightPanel;

const rightPanel = showRightPanel
? <RightPanel
room={this.state.room}
Expand Down Expand Up @@ -2143,7 +2171,21 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
// TODO-video MainSplitContentType.Video:
// break;
}

let excludedRightPanelPhaseButtons = [RightPanelPhases.Timeline];
let onAppsClick = this.onAppsClick;
let onForgetClick = this.onForgetClick;
let onSearchClick = this.onSearchClick;
if (this.state.mainSplitContentType === MainSplitContentType.MaximisedWidget) {
// Disable phase buttons and action button to have a simplified header when a widget is maximised
// and enable (not disable) the RightPanelPhases.Timeline button
excludedRightPanelPhaseButtons = [
RightPanelPhases.ThreadPanel,
RightPanelPhases.PinnedMessages,
];
onAppsClick = null;
onForgetClick = null;
onSearchClick = null;
}
return (
<RoomContext.Provider value={this.state}>
<main className={mainClasses} ref={this.roomView} onKeyDown={this.onReactKeyDown}>
Expand All @@ -2156,12 +2198,13 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
searchInfo={searchInfo}
oobData={this.props.oobData}
inRoom={myMembership === 'join'}
onSearchClick={this.onSearchClick}
onForgetClick={(myMembership === "leave") ? this.onForgetClick : null}
onSearchClick={onSearchClick}
onForgetClick={(myMembership === "leave") ? onForgetClick : null}
e2eStatus={this.state.e2eStatus}
onAppsClick={this.state.hasPinnedWidgets ? this.onAppsClick : null}
onAppsClick={this.state.hasPinnedWidgets ? onAppsClick : null}
appsShown={this.state.showApps}
onCallPlaced={this.onCallPlaced}
excludedRightPanelPhaseButtons={excludedRightPanelPhaseButtons}
/>
<MainSplit panel={rightPanel} resizeNotifier={this.props.resizeNotifier}>
<div className="mx_RoomView_body">
Expand Down
18 changes: 16 additions & 2 deletions src/components/structures/ThreadView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ import ContentMessages from '../../ContentMessages';
import UploadBar from './UploadBar';
import { _t } from '../../languageHandler';
import ThreadListContextMenu from '../views/context_menus/ThreadListContextMenu';
import RightPanelStore from '../../stores/RightPanelStore';
import SettingsStore from '../../settings/SettingsStore';

interface IProps {
room: Room;
Expand Down Expand Up @@ -203,6 +205,18 @@ export default class ThreadView extends React.Component<IProps, IState> {
event_id: this.state.thread?.id,
};

let previousPhase = RightPanelStore.getSharedInstance().previousPhase;
if (SettingsStore.getValue("feature_maximised_widgets")) {
previousPhase = RightPanelPhases.ThreadPanel;
}
// Make sure the previous Phase is always one of the two: Timeline or ThreadPanel
if (![RightPanelPhases.ThreadPanel, RightPanelPhases.Timeline].includes(previousPhase)) {
previousPhase = RightPanelPhases.ThreadPanel;
}
const previousPhaseLabels = {};
previousPhaseLabels[RightPanelPhases.ThreadPanel] = _t("All threads");
previousPhaseLabels[RightPanelPhases.Timeline] = _t("Chat");

return (
<RoomContext.Provider value={{
...this.context,
Expand All @@ -213,8 +227,8 @@ export default class ThreadView extends React.Component<IProps, IState> {
<BaseCard
className="mx_ThreadView mx_ThreadPanel"
onClose={this.props.onClose}
previousPhase={RightPanelPhases.ThreadPanel}
previousPhaseLabel={_t("All threads")}
previousPhase={previousPhase}
previousPhaseLabel={previousPhaseLabels[previousPhase]}
withoutScrollContainer={true}
header={this.renderThreadViewHeader()}
>
Expand Down
7 changes: 2 additions & 5 deletions src/components/structures/TimelinePanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -475,10 +475,7 @@ class TimelinePanel extends React.Component<IProps, IState> {
};

private onMessageListScroll = e => {
if (this.props.onScroll) {
this.props.onScroll(e);
}

this.props.onScroll?.(e);
if (this.props.manageReadMarkers) {
this.doManageReadMarkers();
}
Expand Down Expand Up @@ -593,7 +590,7 @@ class TimelinePanel extends React.Component<IProps, IState> {
this.setState<null>(updatedState, () => {
this.messagePanel.current.updateTimelineMinHeight();
if (callRMUpdated) {
this.props.onReadMarkerUpdated();
this.props.onReadMarkerUpdated?.();
}
});
});
Expand Down
6 changes: 3 additions & 3 deletions src/components/views/elements/AppTile.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -402,9 +402,9 @@ export default class AppTile extends React.Component<IProps, IState> {

private onMaxMinWidgetClick = (): void => {
const targetContainer =
WidgetLayoutStore.instance.isInContainer(this.props.room, this.props.app, Container.Center)
? Container.Right
: Container.Center;
WidgetLayoutStore.instance.isInContainer(this.props.room, this.props.app, Container.Center)
? Container.Right
: Container.Center;
WidgetLayoutStore.instance.moveToContainer(this.props.room, this.props.app, targetContainer);
};

Expand Down
Loading