From 6b253c1eabe6117ad7aa09c22c183be2dfd655ce Mon Sep 17 00:00:00 2001 From: Michael Telatynski <7t3chguy@gmail.com> Date: Thu, 10 Mar 2022 13:46:17 +0000 Subject: [PATCH 1/2] Extract utility function --- .../views/rooms/SendMessageComposer.tsx | 31 +------------------ src/utils/Reply.ts | 29 +++++++++++++++++ 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/src/components/views/rooms/SendMessageComposer.tsx b/src/components/views/rooms/SendMessageComposer.tsx index 35a956f09db..7ea637ccb76 100644 --- a/src/components/views/rooms/SendMessageComposer.tsx +++ b/src/components/views/rooms/SendMessageComposer.tsx @@ -57,36 +57,7 @@ import { ComposerType } from "../../../dispatcher/payloads/ComposerInsertPayload import { getSlashCommand, isSlashCommand, runSlashCommand, shouldSendAnyway } from "../../../editor/commands"; import { KeyBindingAction } from "../../../accessibility/KeyboardShortcuts"; import { PosthogAnalytics } from "../../../PosthogAnalytics"; -import { getNestedReplyText, makeReplyMixIn } from '../../../utils/Reply'; - -interface IAddReplyOpts { - permalinkCreator?: RoomPermalinkCreator; - includeLegacyFallback?: boolean; - inThread?: boolean; -} - -function addReplyToMessageContent( - content: IContent, - replyToEvent: MatrixEvent, - opts: IAddReplyOpts = { - includeLegacyFallback: true, - }, -): void { - const replyContent = makeReplyMixIn(replyToEvent, opts.inThread); - Object.assign(content, replyContent); - - if (opts.includeLegacyFallback) { - // Part of Replies fallback support - prepend the text we're sending - // with the text we're replying to - const nestedReply = getNestedReplyText(replyToEvent, opts.permalinkCreator); - if (nestedReply) { - if (content.formatted_body) { - content.formatted_body = nestedReply.html + content.formatted_body; - } - content.body = nestedReply.body + content.body; - } - } -} +import { addReplyToMessageContent } from '../../../utils/Reply'; export function attachRelation( content: IContent, diff --git a/src/utils/Reply.ts b/src/utils/Reply.ts index d8b6abc5eea..ad8de3de1b6 100644 --- a/src/utils/Reply.ts +++ b/src/utils/Reply.ts @@ -180,3 +180,32 @@ export function shouldDisplayReply(event: MatrixEvent, inThread = false): boolea const isFallingBack = inReplyTo?.is_falling_back ?? inReplyTo?.["io.element.is_falling_back"]; return !isFallingBack; } + +interface IAddReplyOpts { + permalinkCreator?: RoomPermalinkCreator; + includeLegacyFallback?: boolean; + inThread?: boolean; +} + +export function addReplyToMessageContent( + content: IContent, + replyToEvent: MatrixEvent, + opts: IAddReplyOpts = { + includeLegacyFallback: true, + }, +): void { + const replyContent = makeReplyMixIn(replyToEvent, opts.inThread); + Object.assign(content, replyContent); + + if (opts.includeLegacyFallback) { + // Part of Replies fallback support - prepend the text we're sending + // with the text we're replying to + const nestedReply = getNestedReplyText(replyToEvent, opts.permalinkCreator); + if (nestedReply) { + if (content.formatted_body) { + content.formatted_body = nestedReply.html + content.formatted_body; + } + content.body = nestedReply.body + content.body; + } + } +} From 1f795e59b23480265d2044e44994aacf7d68b844 Mon Sep 17 00:00:00 2001 From: Michael Telatynski <7t3chguy@gmail.com> Date: Thu, 10 Mar 2022 13:49:45 +0000 Subject: [PATCH 2/2] Allow sending files as replies as per MSC3676 --- ...ContentMessages.tsx => ContentMessages.ts} | 45 +++++++++---------- src/i18n/strings/en_EN.json | 4 +- 2 files changed, 23 insertions(+), 26 deletions(-) rename src/{ContentMessages.tsx => ContentMessages.ts} (96%) diff --git a/src/ContentMessages.tsx b/src/ContentMessages.ts similarity index 96% rename from src/ContentMessages.tsx rename to src/ContentMessages.ts index 8b0ddc83688..d6611af3ae3 100644 --- a/src/ContentMessages.tsx +++ b/src/ContentMessages.ts @@ -16,7 +16,6 @@ See the License for the specific language governing permissions and limitations under the License. */ -import React from "react"; import { MatrixClient } from "matrix-js-sdk/src/client"; import { IUploadOpts } from "matrix-js-sdk/src/@types/requests"; import { MsgType, RelationType } from "matrix-js-sdk/src/@types/event"; @@ -24,14 +23,13 @@ import encrypt from "browser-encrypt-attachment"; import extractPngChunks from "png-chunks-extract"; import { IAbortablePromise, IImageInfo } from "matrix-js-sdk/src/@types/partials"; import { logger } from "matrix-js-sdk/src/logger"; -import { IEventRelation, ISendEventResponse } from "matrix-js-sdk/src/matrix"; +import { IEventRelation, ISendEventResponse, MatrixEvent } from "matrix-js-sdk/src/matrix"; import { IEncryptedFile, IMediaEventInfo } from "./customisations/models/IMediaEventContent"; import dis from './dispatcher/dispatcher'; import * as sdk from './index'; import { _t } from './languageHandler'; import Modal from './Modal'; -import RoomViewStore from './stores/RoomViewStore'; import Spinner from "./components/views/elements/Spinner"; import { Action } from "./dispatcher/actions"; import { @@ -46,6 +44,8 @@ import { BlurhashEncoder } from "./BlurhashEncoder"; import SettingsStore from "./settings/SettingsStore"; import { decorateStartSendingTime, sendRoundTripMetric } from "./sendTimePerformanceMetrics"; import { TimelineRenderingType } from "./contexts/RoomContext"; +import RoomViewStore from "./stores/RoomViewStore"; +import { addReplyToMessageContent } from "./utils/Reply"; const MAX_WIDTH = 800; const MAX_HEIGHT = 600; @@ -456,25 +456,7 @@ export default class ContentMessages { return; } - const isQuoting = Boolean(RoomViewStore.getQuotingEvent()); - if (isQuoting) { - // FIXME: Using an import will result in Element crashing - const QuestionDialog = sdk.getComponent("dialogs.QuestionDialog"); - const { finished } = Modal.createTrackedDialog<[boolean]>('Upload Reply Warning', '', QuestionDialog, { - title: _t('Replying With Files'), - description: ( -