diff --git a/src/TextForEvent.tsx b/src/TextForEvent.tsx
index 82c094ef484..09bc2105f99 100644
--- a/src/TextForEvent.tsx
+++ b/src/TextForEvent.tsx
@@ -13,6 +13,7 @@ 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.
*/
+
import React from 'react';
import { _t } from './languageHandler';
import * as Roles from './Roles';
@@ -25,7 +26,10 @@ import { Action } from './dispatcher/actions';
import defaultDispatcher from './dispatcher/dispatcher';
import { SetRightPanelPhasePayload } from './dispatcher/payloads/SetRightPanelPhasePayload';
import { MatrixEvent } from "matrix-js-sdk/src/models/event";
+import { GuestAccess, HistoryVisibility, JoinRule } from "matrix-js-sdk/src/@types/partials";
+import { EventType, MsgType } from "matrix-js-sdk/src/@types/event";
import { MatrixClientPeg } from "./MatrixClientPeg";
+import { ROOM_SECURITY_TAB } from "./components/views/dialogs/RoomSettingsDialog";
import { logger } from "matrix-js-sdk/src/logger";
import { removeDirectionOverrideChars } from 'matrix-js-sdk/src/utils';
@@ -201,17 +205,38 @@ function textForTombstoneEvent(ev: MatrixEvent): () => string | null {
return () => _t('%(senderDisplayName)s upgraded this room.', { senderDisplayName });
}
-function textForJoinRulesEvent(ev: MatrixEvent): () => string | null {
+const onViewJoinRuleSettingsClick = () => {
+ defaultDispatcher.dispatch({
+ action: "open_room_settings",
+ initial_tab_id: ROOM_SECURITY_TAB,
+ });
+};
+
+function textForJoinRulesEvent(ev: MatrixEvent, allowJSX: boolean): () => string | JSX.Element | null {
const senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();
switch (ev.getContent().join_rule) {
- case "public":
+ case JoinRule.Public:
return () => _t('%(senderDisplayName)s made the room public to whoever knows the link.', {
senderDisplayName,
});
- case "invite":
+ case JoinRule.Invite:
return () => _t('%(senderDisplayName)s made the room invite only.', {
senderDisplayName,
});
+ case JoinRule.Restricted:
+ if (allowJSX) {
+ return () =>
+ { _t('%(senderDisplayName)s changed who can join this room. View settings.', {
+ senderDisplayName,
+ }, {
+ "a": (sub) =>
+ { sub }
+ ,
+ }) }
+ ;
+ }
+
+ return () => _t('%(senderDisplayName)s changed who can join this room.', { senderDisplayName });
default:
// The spec supports "knock" and "private", however nothing implements these.
return () => _t('%(senderDisplayName)s changed the join rule to %(rule)s', {
@@ -224,9 +249,9 @@ function textForJoinRulesEvent(ev: MatrixEvent): () => string | null {
function textForGuestAccessEvent(ev: MatrixEvent): () => string | null {
const senderDisplayName = ev.sender && ev.sender.name ? ev.sender.name : ev.getSender();
switch (ev.getContent().guest_access) {
- case "can_join":
+ case GuestAccess.CanJoin:
return () => _t('%(senderDisplayName)s has allowed guests to join the room.', { senderDisplayName });
- case "forbidden":
+ case GuestAccess.Forbidden:
return () => _t('%(senderDisplayName)s has prevented guests from joining the room.', { senderDisplayName });
default:
// There's no other options we can expect, however just for safety's sake we'll do this.
@@ -312,11 +337,11 @@ function textForMessageEvent(ev: MatrixEvent): () => string | null {
|| redactedBecauseUserId });
}
}
- if (ev.getContent().msgtype === "m.emote") {
+ if (ev.getContent().msgtype === MsgType.Emote) {
message = "* " + senderDisplayName + " " + message;
- } else if (ev.getContent().msgtype === "m.image") {
+ } else if (ev.getContent().msgtype === MsgType.Image) {
message = _t('%(senderDisplayName)s sent an image.', { senderDisplayName });
- } else if (ev.getType() == "m.sticker") {
+ } else if (ev.getType() == EventType.Sticker) {
message = _t('%(senderDisplayName)s sent a sticker.', { senderDisplayName });
} else {
// in this case, parse it as a plain text message
@@ -396,15 +421,15 @@ function textForThreePidInviteEvent(event: MatrixEvent): () => string | null {
function textForHistoryVisibilityEvent(event: MatrixEvent): () => string | null {
const senderName = event.sender ? event.sender.name : event.getSender();
switch (event.getContent().history_visibility) {
- case 'invited':
+ case HistoryVisibility.Invited:
return () => _t('%(senderName)s made future room history visible to all room members, '
+ 'from the point they are invited.', { senderName });
- case 'joined':
+ case HistoryVisibility.Joined:
return () => _t('%(senderName)s made future room history visible to all room members, '
+ 'from the point they joined.', { senderName });
- case 'shared':
+ case HistoryVisibility.Shared:
return () => _t('%(senderName)s made future room history visible to all room members.', { senderName });
- case 'world_readable':
+ case HistoryVisibility.WorldReadable:
return () => _t('%(senderName)s made future room history visible to anyone.', { senderName });
default:
return () => _t('%(senderName)s made future room history visible to unknown (%(visibility)s).', {
@@ -695,25 +720,25 @@ interface IHandlers {
}
const handlers: IHandlers = {
- 'm.room.message': textForMessageEvent,
- 'm.sticker': textForMessageEvent,
- 'm.call.invite': textForCallInviteEvent,
+ [EventType.RoomMessage]: textForMessageEvent,
+ [EventType.Sticker]: textForMessageEvent,
+ [EventType.CallInvite]: textForCallInviteEvent,
};
const stateHandlers: IHandlers = {
- 'm.room.canonical_alias': textForCanonicalAliasEvent,
- 'm.room.name': textForRoomNameEvent,
- 'm.room.topic': textForTopicEvent,
- 'm.room.member': textForMemberEvent,
- "m.room.avatar": textForRoomAvatarEvent,
- 'm.room.third_party_invite': textForThreePidInviteEvent,
- 'm.room.history_visibility': textForHistoryVisibilityEvent,
- 'm.room.power_levels': textForPowerEvent,
- 'm.room.pinned_events': textForPinnedEvent,
- 'm.room.server_acl': textForServerACLEvent,
- 'm.room.tombstone': textForTombstoneEvent,
- 'm.room.join_rules': textForJoinRulesEvent,
- 'm.room.guest_access': textForGuestAccessEvent,
+ [EventType.RoomCanonicalAlias]: textForCanonicalAliasEvent,
+ [EventType.RoomName]: textForRoomNameEvent,
+ [EventType.RoomTopic]: textForTopicEvent,
+ [EventType.RoomMember]: textForMemberEvent,
+ [EventType.RoomAvatar]: textForRoomAvatarEvent,
+ [EventType.RoomThirdPartyInvite]: textForThreePidInviteEvent,
+ [EventType.RoomHistoryVisibility]: textForHistoryVisibilityEvent,
+ [EventType.RoomPowerLevels]: textForPowerEvent,
+ [EventType.RoomPinnedEvents]: textForPinnedEvent,
+ [EventType.RoomServerAcl]: textForServerACLEvent,
+ [EventType.RoomTombstone]: textForTombstoneEvent,
+ [EventType.RoomJoinRules]: textForJoinRulesEvent,
+ [EventType.RoomGuestAccess]: textForGuestAccessEvent,
'm.room.related_groups': textForRelatedGroupsEvent,
// TODO: Enable support for m.widget event type (https://github.com/vector-im/element-web/issues/13111)
diff --git a/src/i18n/strings/en_EN.json b/src/i18n/strings/en_EN.json
index dd6f48af7ec..4554d848e4f 100644
--- a/src/i18n/strings/en_EN.json
+++ b/src/i18n/strings/en_EN.json
@@ -517,6 +517,8 @@
"%(senderDisplayName)s upgraded this room.": "%(senderDisplayName)s upgraded this room.",
"%(senderDisplayName)s made the room public to whoever knows the link.": "%(senderDisplayName)s made the room public to whoever knows the link.",
"%(senderDisplayName)s made the room invite only.": "%(senderDisplayName)s made the room invite only.",
+ "%(senderDisplayName)s changed who can join this room. View settings.": "%(senderDisplayName)s changed who can join this room. View settings.",
+ "%(senderDisplayName)s changed who can join this room.": "%(senderDisplayName)s changed who can join this room.",
"%(senderDisplayName)s changed the join rule to %(rule)s": "%(senderDisplayName)s changed the join rule to %(rule)s",
"%(senderDisplayName)s has allowed guests to join the room.": "%(senderDisplayName)s has allowed guests to join the room.",
"%(senderDisplayName)s has prevented guests from joining the room.": "%(senderDisplayName)s has prevented guests from joining the room.",