Skip to content
This repository was archived by the owner on Oct 22, 2024. It is now read-only.

Commit 5985277

Browse files
authored
Unlabs feature pinning (#22)
1 parent 74885c9 commit 5985277

File tree

18 files changed

+166
-99
lines changed

18 files changed

+166
-99
lines changed

src/TextForEvent.tsx

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -561,7 +561,6 @@ const onPinnedMessagesClick = (): void => {
561561
};
562562

563563
function textForPinnedEvent(event: MatrixEvent, client: MatrixClient, allowJSX: boolean): (() => Renderable) | null {
564-
if (!SettingsStore.getValue("feature_pinning")) return null;
565564
const senderName = getSenderName(event);
566565
const roomId = event.getRoomId()!;
567566

src/components/structures/RightPanel.tsx

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,6 @@ import RightPanelStore from "../../stores/right-panel/RightPanelStore";
1717
import MatrixClientContext from "../../contexts/MatrixClientContext";
1818
import RoomSummaryCard from "../views/right_panel/RoomSummaryCard";
1919
import WidgetCard from "../views/right_panel/WidgetCard";
20-
import SettingsStore from "../../settings/SettingsStore";
2120
import MemberList from "../views/rooms/MemberList";
2221
import UserInfo from "../views/right_panel/UserInfo";
2322
import ThirdPartyMemberInfo from "../views/rooms/ThirdPartyMemberInfo";
@@ -220,7 +219,7 @@ export default class RightPanel extends React.Component<Props, IState> {
220219
break;
221220

222221
case RightPanelPhases.PinnedMessages:
223-
if (!!this.props.room && SettingsStore.getValue("feature_pinning")) {
222+
if (!!this.props.room) {
224223
card = (
225224
<PinnedMessagesCard
226225
room={this.props.room}

src/components/structures/RoomView.tsx

Lines changed: 3 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -2408,13 +2408,9 @@ export class RoomView extends React.Component<IRoomProps, IRoomState> {
24082408
</AuxPanel>
24092409
);
24102410

2411-
const isPinningEnabled = SettingsStore.getValue<boolean>("feature_pinning");
2412-
let pinnedMessageBanner;
2413-
if (isPinningEnabled) {
2414-
pinnedMessageBanner = (
2415-
<PinnedMessageBanner room={this.state.room} permalinkCreator={this.permalinkCreator} />
2416-
);
2417-
}
2411+
const pinnedMessageBanner = (
2412+
<PinnedMessageBanner room={this.state.room} permalinkCreator={this.permalinkCreator} />
2413+
);
24182414

24192415
let messageComposer;
24202416
const showComposer =

src/components/structures/grouper/MainGrouper.tsx

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,6 @@ import DateSeparator from "../../views/messages/DateSeparator";
1818
import HistoryTile from "../../views/rooms/HistoryTile";
1919
import EventListSummary from "../../views/elements/EventListSummary";
2020
import { SeparatorKind } from "../../views/messages/TimelineSeparator";
21-
import SettingsStore from "../../../settings/SettingsStore";
2221

2322
const groupedStateEvents = [
2423
EventType.RoomMember,
@@ -91,7 +90,7 @@ export class MainGrouper extends BaseGrouper {
9190
return;
9291
}
9392

94-
if (ev.getType() === EventType.RoomPinnedEvents && !SettingsStore.getValue("feature_pinning")) {
93+
if (ev.getType() === EventType.RoomPinnedEvents) {
9594
// If pinned messages are disabled, don't show the summary
9695
return;
9796
}

src/components/views/context_menus/RoomContextMenu.tsx

Lines changed: 2 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,6 @@ import { EchoChamber } from "../../../stores/local-echo/EchoChamber";
2626
import { RoomNotifState } from "../../../RoomNotifs";
2727
import Modal from "../../../Modal";
2828
import ExportDialog from "../dialogs/ExportDialog";
29-
import { useFeatureEnabled } from "../../../hooks/useSettings";
3029
import { RightPanelPhases } from "../../../stores/right-panel/RightPanelStorePhases";
3130
import { RoomSettingsTab } from "../dialogs/RoomSettingsDialog";
3231
import { useEventEmitterState } from "../../../hooks/useEventEmitter";
@@ -261,11 +260,10 @@ const RoomContextMenu: React.FC<IProps> = ({ room, onFinished, ...props }) => {
261260
);
262261
}
263262

264-
const pinningEnabled = useFeatureEnabled("feature_pinning");
265-
const pinCount = usePinnedEvents(pinningEnabled ? room : undefined)?.length;
263+
const pinCount = usePinnedEvents(room).length;
266264

267265
let pinsOption: JSX.Element | undefined;
268-
if (pinningEnabled && !isVideoRoom) {
266+
if (!isVideoRoom) {
269267
pinsOption = (
270268
<IconizedContextMenuOption
271269
onClick={(ev: ButtonEvent) => {

src/components/views/right_panel/LegacyRoomHeaderButtons.tsx

Lines changed: 10 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,6 @@ import { RightPanelPhases } from "../../../stores/right-panel/RightPanelStorePha
2121
import { ActionPayload } from "../../../dispatcher/payloads";
2222
import RightPanelStore from "../../../stores/right-panel/RightPanelStore";
2323
import { showThreadPanel } from "../../../dispatcher/dispatch-actions/threads";
24-
import SettingsStore from "../../../settings/SettingsStore";
2524
import {
2625
RoomNotificationStateStore,
2726
UPDATE_STATUS_INDICATOR,
@@ -245,17 +244,16 @@ export default class LegacyRoomHeaderButtons extends HeaderButtons<IProps> {
245244

246245
const rightPanelPhaseButtons: Map<RightPanelPhases, any> = new Map();
247246

248-
if (SettingsStore.getValue("feature_pinning")) {
249-
rightPanelPhaseButtons.set(
250-
RightPanelPhases.PinnedMessages,
251-
<PinnedMessagesHeaderButton
252-
key="pinnedMessagesButton"
253-
room={this.props.room}
254-
isHighlighted={this.isPhase(RightPanelPhases.PinnedMessages)}
255-
onClick={this.onPinnedMessagesClicked}
256-
/>,
257-
);
258-
}
247+
rightPanelPhaseButtons.set(
248+
RightPanelPhases.PinnedMessages,
249+
<PinnedMessagesHeaderButton
250+
key="pinnedMessagesButton"
251+
room={this.props.room}
252+
isHighlighted={this.isPhase(RightPanelPhases.PinnedMessages)}
253+
onClick={this.onPinnedMessagesClicked}
254+
/>,
255+
);
256+
259257
rightPanelPhaseButtons.set(
260258
RightPanelPhases.Timeline,
261259
<TimelineCardHeaderButton

src/components/views/right_panel/RoomSummaryCard.tsx

Lines changed: 11 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,6 @@ import { useEventEmitterState } from "../../../hooks/useEventEmitter";
4949
import { E2EStatus } from "../../../utils/ShieldUtils";
5050
import { RoomPermalinkCreator } from "../../../utils/permalinks/Permalinks";
5151
import RoomContext, { TimelineRenderingType } from "../../../contexts/RoomContext";
52-
import { useFeatureEnabled } from "../../../hooks/useSettings";
5352
import RoomName from "../elements/RoomName";
5453
import ExportDialog from "../dialogs/ExportDialog";
5554
import RightPanelStore from "../../../stores/right-panel/RightPanelStore";
@@ -314,8 +313,7 @@ const RoomSummaryCard: React.FC<IProps> = ({
314313
</header>
315314
);
316315

317-
const pinningEnabled = useFeatureEnabled("feature_pinning");
318-
const pinCount = usePinnedEvents(pinningEnabled ? room : undefined)?.length;
316+
const pinCount = usePinnedEvents(room).length;
319317

320318
const roomTags = useEventEmitterState(RoomListStore.instance, LISTS_UPDATE_EVENT, () =>
321319
RoomListStore.instance.getTagsForRoom(room),
@@ -382,17 +380,16 @@ const RoomSummaryCard: React.FC<IProps> = ({
382380

383381
{!isVideoRoom && (
384382
<>
385-
{pinningEnabled && (
386-
<MenuItem
387-
Icon={PinIcon}
388-
label={_t("right_panel|pinned_messages_button")}
389-
onSelect={onRoomPinsClick}
390-
>
391-
<Text as="span" size="sm">
392-
{pinCount}
393-
</Text>
394-
</MenuItem>
395-
)}
383+
<MenuItem
384+
Icon={PinIcon}
385+
label={_t("right_panel|pinned_messages_button")}
386+
onSelect={onRoomPinsClick}
387+
>
388+
<Text as="span" size="sm">
389+
{pinCount}
390+
</Text>
391+
</MenuItem>
392+
396393
<MenuItem Icon={FilesIcon} label={_t("right_panel|files_button")} onSelect={onRoomFilesClick} />
397394
</>
398395
)}

src/components/views/settings/tabs/room/RolesRoomSettingsTab.tsx

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -267,15 +267,13 @@ export default class RolesRoomSettingsTab extends React.Component<IProps> {
267267
[EventType.RoomServerAcl]: _td("room_settings|permissions|m.room.server_acl"),
268268
[EventType.Reaction]: _td("room_settings|permissions|m.reaction"),
269269
[EventType.RoomRedaction]: _td("room_settings|permissions|m.room.redaction"),
270+
[EventType.RoomPinnedEvents]: _td("room_settings|permissions|m.room.pinned_events"),
270271

271272
// TODO: Enable support for m.widget event type (https://github.com/vector-im/element-web/issues/13111)
272273
"im.vector.modular.widgets": isSpaceRoom ? null : _td("room_settings|permissions|m.widget"),
273274
[VoiceBroadcastInfoEventType]: _td("room_settings|permissions|io.element.voice_broadcast_info"),
274275
};
275276

276-
if (SettingsStore.getValue("feature_pinning")) {
277-
plEventsToLabels[EventType.RoomPinnedEvents] = _td("room_settings|permissions|m.room.pinned_events");
278-
}
279277
// MSC3401: Native Group VoIP signaling
280278
if (SettingsStore.getValue("feature_group_calls")) {
281279
plEventsToLabels[ElementCall.CALL_EVENT_TYPE.name] = _td("room_settings|permissions|m.call");

src/i18n/strings/en_EN.json

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1468,7 +1468,6 @@
14681468
"notifications": "Enable the notifications panel in the room header",
14691469
"oidc_native_flow": "OIDC native authentication",
14701470
"oidc_native_flow_description": "⚠ WARNING: Experimental. Use OIDC native authentication when supported by the server.",
1471-
"pinning": "Message Pinning",
14721471
"release_announcement": "Release announcement",
14731472
"render_reaction_images": "Render custom images in reactions",
14741473
"render_reaction_images_description": "Sometimes referred to as \"custom emojis\".",

src/settings/Settings.tsx

Lines changed: 0 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -275,14 +275,6 @@ export const SETTINGS: { [setting: string]: ISetting } = {
275275
supportedLevelsAreOrdered: true,
276276
default: false,
277277
},
278-
"feature_pinning": {
279-
isFeature: true,
280-
labsGroup: LabGroup.Messaging,
281-
displayName: _td("labs|pinning"),
282-
supportedLevels: LEVELS_DEVICE_ONLY_SETTINGS_WITH_CONFIG_PRIORITISED,
283-
supportedLevelsAreOrdered: true,
284-
default: true,
285-
},
286278
"feature_wysiwyg_composer": {
287279
isFeature: true,
288280
labsGroup: LabGroup.Messaging,

0 commit comments

Comments
 (0)