fix message does not appear after decryption complete (#2209)
authorAjay Bura <32841439+ajbura@users.noreply.github.com>
Sat, 15 Feb 2025 07:58:57 +0000 (18:58 +1100)
committerGitHub <noreply@github.com>
Sat, 15 Feb 2025 07:58:57 +0000 (18:58 +1100)
* fix message does not appear after decryption complete

* update when event get decrypted before subscribing

src/app/features/room/message/EncryptedContent.tsx

index bf0fd199f8fc8fa7fc58b8fb8929f32a43c7f946..f3e614178479529c8ed6cf2f9e150e7559935b65 100644 (file)
@@ -1,5 +1,6 @@
 import { MatrixEvent, MatrixEventEvent, MatrixEventHandlerMap } from 'matrix-js-sdk';
 import React, { ReactNode, useEffect, useState } from 'react';
+import { MessageEvent } from '../../../../types/matrix/room';
 
 type EncryptedContentProps = {
   mEvent: MatrixEvent;
@@ -7,11 +8,12 @@ type EncryptedContentProps = {
 };
 
 export function EncryptedContent({ mEvent, children }: EncryptedContentProps) {
-  const [, toggleDecrypted] = useState(!mEvent.isBeingDecrypted());
+  const [, toggleEncrypted] = useState(mEvent.getType() === MessageEvent.RoomMessageEncrypted);
 
   useEffect(() => {
-    const handleDecrypted: MatrixEventHandlerMap[MatrixEventEvent.Decrypted] = () => {
-      toggleDecrypted((s) => !s);
+    toggleEncrypted(mEvent.getType() === MessageEvent.RoomMessageEncrypted);
+    const handleDecrypted: MatrixEventHandlerMap[MatrixEventEvent.Decrypted] = (event) => {
+      toggleEncrypted(event.getType() === MessageEvent.RoomMessageEncrypted);
     };
     mEvent.on(MatrixEventEvent.Decrypted, handleDecrypted);
     return () => {