Skip to content

Commit

Permalink
fix: update gallery on message deleted
Browse files Browse the repository at this point in the history
Closes #4318.
  • Loading branch information
WofWca committed Jan 6, 2025
1 parent 37451fa commit 18fdbaa
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

## Fixed
- fix "incoming message background color" being used for quotes of outgoing sticker messages #4456
- when deleting a message from gallery, update gallery items to remove the respective item #4457

## [1.50.1] - 2024-12-18

Expand Down
31 changes: 30 additions & 1 deletion packages/frontend/src/components/Gallery.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import {
WebxdcAttachment,
} from './attachment/mediaAttachment'
import { getLogger } from '../../../shared/logger'
import { BackendRemote, Type } from '../backend-com'
import { BackendRemote, onDCEvent, Type } from '../backend-com'
import { selectedAccountId } from '../ScreenController'
import SettingsStoreInstance, { SettingsStoreState } from '../stores/settings'
import FullscreenMedia, {
Expand Down Expand Up @@ -84,6 +84,7 @@ export default class Gallery extends Component<
dateHeader = createRef<HTMLDivElement>()
tabListRef = createRef<HTMLUListElement>()
galleryItemsRef = createRef<HTMLDivElement>()
cleanup: Array<() => void> = []
constructor(props: Props) {
super(props)

Expand Down Expand Up @@ -121,10 +122,38 @@ export default class Gallery extends Component<
SettingsStoreInstance.state?.desktopSettings
.galleryImageKeepAspectRatio,
})

// It's possible to delete messages right from the gallery,
// so let's handle this.
// If we also want to handle newly arriving messages, `MsgsChanged`
// is probably the way to go.
const toCleanup = onDCEvent(
selectedAccountId(),
'MsgDeleted',
({ chatId, msgId: deletedMsgId }) => {
if (chatId !== this.props.chatId) {
return
}

// There is not really a point to also delete it from
// `mediaLoadResult` except for removing it from RAM, but let's do it.
const newMediaLoadResult = { ...this.state.mediaLoadResult }
delete newMediaLoadResult[deletedMsgId]

this.setState({
mediaMessageIds: this.state.mediaMessageIds.filter(
id => id !== deletedMsgId
),
mediaLoadResult: newMediaLoadResult,
})
}
)
this.cleanup.push(toCleanup)
}

componentWillUnmount() {
SettingsStoreInstance.unsubscribe(this.settingsStoreListener)
this.cleanup.forEach(f => f())
}

settingsStoreListener(state: SettingsStoreState | null) {
Expand Down

0 comments on commit 18fdbaa

Please sign in to comment.