diff --git a/src/components/views/messages/MPollBody.tsx b/src/components/views/messages/MPollBody.tsx index 55c4b672bd4..10f43938edf 100644 --- a/src/components/views/messages/MPollBody.tsx +++ b/src/components/views/messages/MPollBody.tsx @@ -223,10 +223,13 @@ export default class MPollBody extends React.Component { }; private selectOption(answerId: string) { - if (answerId === this.state.selected) { + if (this.isEnded()) { return; } - if (this.isEnded()) { + const userVotes = this.collectUserVotes(); + const userId = this.context.getUserId(); + const myVote = userVotes.get(userId)?.answers[0]; + if (answerId === myVote) { return; } diff --git a/test/components/views/messages/MPollBody-test.tsx b/test/components/views/messages/MPollBody-test.tsx index d57137c566b..ff62c26c714 100644 --- a/test/components/views/messages/MPollBody-test.tsx +++ b/test/components/views/messages/MPollBody-test.tsx @@ -497,6 +497,28 @@ describe("MPollBody", () => { ]); }); + it("sends no vote event when I click what I already chose", () => { + const receivedEvents = []; + MatrixClientPeg.matrixClient.sendEvent = ( + roomId: string, + eventType: string, + content: IContent, + txnId?: string, + callback?: Callback, + ): Promise => { + receivedEvents.push( { roomId, eventType, content, txnId, callback } ); + return Promise.resolve({ "event_id": "fake_tracked_send_id" }); + }; + + const votes = [responseEvent("@me:example.com", "wings")]; + const body = newMPollBody(votes); + clickRadio(body, "wings"); + clickRadio(body, "wings"); + clickRadio(body, "wings"); + clickRadio(body, "wings"); + expect(receivedEvents).toEqual([]); + }); + it("sends several events when I click different options", () => { const receivedEvents = []; MatrixClientPeg.matrixClient.sendEvent = (