-
-
Notifications
You must be signed in to change notification settings - Fork 4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
20 changed files
with
480 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* eslint-disable jsdoc/check-param-names */ | ||
|
||
import { makeURLSearchParams, type RequestData, type REST } from '@discordjs/rest'; | ||
import type { Snowflake } from 'discord-api-types/v10'; | ||
|
||
type RESTGetAPIPollAnswerVotersQuery = any; | ||
type RESTGetAPIPollAnswerVotersResult = any; | ||
type RESTPostAPIPollExpireResult = any; | ||
|
||
export class PollAPI { | ||
public constructor(private readonly rest: REST) {} | ||
|
||
/** | ||
* Gets the list of users that voted for a specific answer in a poll | ||
* | ||
* @see {@link https://discord.com/developers/docs/resources/poll#get-answer-voters} | ||
* @param channelId - The id of the channel containing the message | ||
* @param messageId - The id of the message containing the poll | ||
* @param answerId - The id of the answer to get voters for | ||
* @param query - The query for getting the list of voters | ||
* @param options - The options for getting the list of voters | ||
*/ | ||
public async getAnswerVoters( | ||
channelId: Snowflake, | ||
messageId: Snowflake, | ||
answerId: number, | ||
query: RESTGetAPIPollAnswerVotersQuery, | ||
{ signal }: Pick<RequestData, 'signal'> = {}, | ||
) { | ||
return this.rest.get(`/channels/${channelId}/polls/${messageId}/answers/${answerId}`, { | ||
signal, | ||
query: makeURLSearchParams(query), | ||
}) as Promise<RESTGetAPIPollAnswerVotersResult>; | ||
} | ||
|
||
/** | ||
* Immediately expires (i.e. ends) a poll | ||
* | ||
* @see {@link https://discord.com/developers/docs/resources/poll#expire-poll} | ||
* @param channelId - The id of the channel containing the message | ||
* @param messageId - The id of the message containing the poll | ||
* @param options - The options for expiring the poll | ||
*/ | ||
public async expirePoll(channelId: Snowflake, messageId: Snowflake, { signal }: Pick<RequestData, 'signal'> = {}) { | ||
return this.rest.post(`/channels/${channelId}/polls/${messageId}/expire`, { | ||
signal, | ||
}) as Promise<RESTPostAPIPollExpireResult>; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
34 changes: 34 additions & 0 deletions
34
packages/discord.js/src/client/actions/MessagePollVoteAdd.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
'use strict'; | ||
|
||
const Action = require('./Action'); | ||
const Events = require('../../util/Events'); | ||
|
||
class MessagePollVoteAddAction extends Action { | ||
handle(data) { | ||
const channel = this.getChannel(data); | ||
if (!channel?.isTextBased()) return false; | ||
|
||
const message = this.getMessage(data, channel); | ||
if (!message) return false; | ||
|
||
const { poll } = message; | ||
|
||
const answer = poll.answers.get(data.answer_id); | ||
if (!answer) { | ||
console.log('???'); | ||
return false; | ||
} | ||
|
||
/** | ||
* Emitted whenever a user votes in a poll. | ||
* @event Client#messagePollVoteAdd | ||
* @param {PollAnswer} pollAnswer The answer that was voted on | ||
* @param {Snowflake} userId The id of the user that voted | ||
*/ | ||
this.client.emit(Events.MessagePollVoteAdd, answer, data.user_id); | ||
|
||
return { poll }; | ||
} | ||
} | ||
|
||
module.exports = MessagePollVoteAddAction; |
34 changes: 34 additions & 0 deletions
34
packages/discord.js/src/client/actions/MessagePollVoteRemove.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
'use strict'; | ||
|
||
const Action = require('./Action'); | ||
const Events = require('../../util/Events'); | ||
|
||
class MessagePollVoteRemoveAction extends Action { | ||
handle(data) { | ||
const channel = this.getChannel(data); | ||
if (!channel?.isTextBased()) return false; | ||
|
||
const message = this.getMessage(data, channel); | ||
if (!message) return false; | ||
|
||
const { poll } = message; | ||
|
||
const answer = poll.answers.get(data.answer_id); | ||
if (!answer) { | ||
console.log('???'); | ||
return false; | ||
} | ||
|
||
/** | ||
* Emitted whenever a user removes their vote in a poll. | ||
* @event Client#messagePollVoteRemove | ||
* @param {PollAnswer} pollAnswer The answer where the vote was removed | ||
* @param {Snowflake} userId The id of the user that removed their vote | ||
*/ | ||
this.client.emit(Events.MessagePollVoteRemove, answer, data.user_id); | ||
|
||
return { poll }; | ||
} | ||
} | ||
|
||
module.exports = MessagePollVoteRemoveAction; |
5 changes: 5 additions & 0 deletions
5
packages/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
'use strict'; | ||
|
||
module.exports = (client, packet) => { | ||
client.actions.MessagePollVoteAdd.handle(packet.d); | ||
}; |
5 changes: 5 additions & 0 deletions
5
packages/discord.js/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
'use strict'; | ||
|
||
module.exports = (client, packet) => { | ||
client.actions.MessagePollVoteRemove.handle(packet.d); | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
'use strict'; | ||
|
||
const { Collection } = require('@discordjs/collection'); | ||
const Base = require('./Base'); | ||
const { PollAnswer } = require('./PollAnswer'); | ||
const { PollAnswerResult } = require('./PollAnswerResult'); | ||
const { DiscordjsError } = require('../errors/DJSError'); | ||
const { ErrorCodes } = require('../errors/index'); | ||
|
||
/** | ||
* Represents a Poll | ||
* @extends {Base} | ||
*/ | ||
class Poll extends Base { | ||
constructor(client, data, message) { | ||
super(client); | ||
|
||
/** | ||
* The message that started this poll | ||
* @name Poll#message | ||
* @type {Message} | ||
* @readonly | ||
*/ | ||
|
||
Object.defineProperty(this, 'message', { value: message }); | ||
|
||
this._patch(data); | ||
} | ||
|
||
_patch(data) { | ||
/** | ||
* The question text of this poll | ||
* @type {string} | ||
*/ | ||
this.question = data.question.text; | ||
|
||
/** | ||
* The answers of this poll | ||
* @type {Collection<number, PollAnswer>} | ||
*/ | ||
this.answers = data.answers.reduce( | ||
(acc, answer) => acc.set(answer.answer_id, new PollAnswer(this.client, answer, this)), | ||
new Collection(), | ||
); | ||
|
||
/** | ||
* The timestamp when this poll expires | ||
* @type {number} | ||
*/ | ||
this.expiresTimestamp = Date.parse(data.expiry); | ||
|
||
/** | ||
* Whether this poll allows multiple answers | ||
* @type {boolean} | ||
*/ | ||
this.allowMultiselect = data.allow_multiselect; | ||
|
||
/** | ||
* The layout type of this poll | ||
* @type {PollLayoutType} | ||
*/ | ||
this.layoutType = data.layout_type; | ||
|
||
if (data.results) { | ||
/** | ||
* @typedef {Object} PollResults | ||
* @property {Collection<number, PollAnswerResult>} answerCounts The counts of each answer | ||
* @property {boolean} isFinalized Whether the results are finalized | ||
*/ | ||
|
||
/** | ||
* The results of this poll | ||
* @type {?PollResults} | ||
*/ | ||
this.results = { | ||
answerCounts: data.results.answer_counts.reduce( | ||
(acc, result) => acc.set(result.id, new PollAnswerResult(result)), | ||
new Collection(), | ||
), | ||
isFinalized: data.results.is_finalized, | ||
}; | ||
} else { | ||
this.results = null; | ||
} | ||
} | ||
|
||
/** | ||
* The date when this poll expires | ||
* @type {Date} | ||
* @readonly | ||
*/ | ||
get expiresAt() { | ||
return new Date(this.expiresTimestamp); | ||
} | ||
|
||
/** | ||
* End this poll | ||
* @returns {Promise<Message>} | ||
*/ | ||
async end() { | ||
if (Date.now() > this.expiresTimestamp) { | ||
throw new DiscordjsError(ErrorCodes.PollAlreadyExpired); | ||
} | ||
|
||
const message = await this.client.rest.post(`/channels/${this.message.channel.id}/poll/${this.message.id}/expire`); | ||
|
||
this.message._patch(message); | ||
|
||
return this.message; | ||
} | ||
} | ||
|
||
exports.Poll = Poll; |
Oops, something went wrong.