From d1e2a448f7bffb5d0a548c8f2bfde7fa19804190 Mon Sep 17 00:00:00 2001 From: Jiralite <33201955+Jiralite@users.noreply.github.com> Date: Mon, 18 Sep 2023 08:26:22 +0100 Subject: [PATCH] fix(GuildScheduledEvent): Use `if...else` pattern and handle partials (#9802) fix: handle partial case Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com> --- .../src/structures/GuildScheduledEvent.js | 109 +++++++++++++----- packages/discord.js/typings/index.d.ts | 22 +++- 2 files changed, 94 insertions(+), 37 deletions(-) diff --git a/packages/discord.js/src/structures/GuildScheduledEvent.js b/packages/discord.js/src/structures/GuildScheduledEvent.js index e9a37b2b0b867..66f189eeedf19 100644 --- a/packages/discord.js/src/structures/GuildScheduledEvent.js +++ b/packages/discord.js/src/structures/GuildScheduledEvent.js @@ -50,11 +50,16 @@ class GuildScheduledEvent extends Base { this.creatorId ??= null; } - /** - * The name of the guild scheduled event - * @type {string} - */ - this.name = data.name; + if ('name' in data) { + /** + * The name of the guild scheduled event + * @type {?string} + */ + this.name = data.name; + } else { + // Only if partial. + this.name ??= null; + } if ('description' in data) { /** @@ -66,37 +71,59 @@ class GuildScheduledEvent extends Base { this.description ??= null; } - /** - * The timestamp the guild scheduled event will start at - * This can be potentially `null` only when it's an {@link AuditLogEntryTarget} - * @type {?number} - */ - this.scheduledStartTimestamp = data.scheduled_start_time ? Date.parse(data.scheduled_start_time) : null; + if ('scheduled_start_time' in data) { + /** + * The timestamp the guild scheduled event will start at + * @type {?number} + */ + this.scheduledStartTimestamp = Date.parse(data.scheduled_start_time); + } else { + this.scheduledStartTimestamp ??= null; + } - /** - * The timestamp the guild scheduled event will end at, - * or `null` if the event does not have a scheduled time to end - * @type {?number} - */ - this.scheduledEndTimestamp = data.scheduled_end_time ? Date.parse(data.scheduled_end_time) : null; + if ('scheduled_end_time' in data) { + /** + * The timestamp the guild scheduled event will end at + * or `null` if the event does not have a scheduled time to end + * @type {?number} + */ + this.scheduledEndTimestamp = data.scheduled_end_time ? Date.parse(data.scheduled_end_time) : null; + } else { + this.scheduledEndTimestamp ??= null; + } - /** - * The privacy level of the guild scheduled event - * @type {GuildScheduledEventPrivacyLevel} - */ - this.privacyLevel = data.privacy_level; + if ('privacy_level' in data) { + /** + * The privacy level of the guild scheduled event + * @type {?GuildScheduledEventPrivacyLevel} + */ + this.privacyLevel = data.privacy_level; + } else { + // Only if partial. + this.privacyLevel ??= null; + } - /** - * The status of the guild scheduled event - * @type {GuildScheduledEventStatus} - */ - this.status = data.status; + if ('status' in data) { + /** + * The status of the guild scheduled event + * @type {?GuildScheduledEventStatus} + */ + this.status = data.status; + } else { + // Only if partial. + this.status ??= null; + } - /** - * The type of hosting entity associated with the scheduled event - * @type {GuildScheduledEventEntityType} - */ - this.entityType = data.entity_type; + if ('entity_type' in data) { + /** + * The type of hosting entity associated with the scheduled event + * @type {?GuildScheduledEventEntityType} + */ + this.entityType = data.entity_type; + } else { + // Only if partial. + this.entityType ??= null; + } if ('entity_id' in data) { /** @@ -164,6 +191,15 @@ class GuildScheduledEvent extends Base { } } + /** + * Whether this guild scheduled event is partial. + * @type {boolean} + * @readonly + */ + get partial() { + return this.name === null; + } + /** * The URL of this scheduled event's cover image * @param {BaseImageURLOptions} [options={}] Options for image URL @@ -276,6 +312,15 @@ class GuildScheduledEvent extends Base { return this.guild.scheduledEvents.edit(this.id, options); } + /** + * Fetches this guild scheduled event. + * @param {boolean} [force=true] Whether to skip the cache check and request the API + * @returns {Promise} + */ + fetch(force = true) { + return this.guild.scheduledEvents.fetch({ guildScheduledEvent: this.id, force }); + } + /** * Deletes this guild scheduled event. * @returns {Promise} diff --git a/packages/discord.js/typings/index.d.ts b/packages/discord.js/typings/index.d.ts index e5c85cf457497..fd39f9a97c156 100644 --- a/packages/discord.js/typings/index.d.ts +++ b/packages/discord.js/typings/index.d.ts @@ -1670,11 +1670,13 @@ export class GuildScheduledEvent): string | null; public createInviteURL(options?: GuildScheduledEventInviteURLCreateOptions): Promise; public edit>( options: GuildScheduledEventEditOptions, ): Promise>; + public fetch(force?: boolean): Promise>; public delete(): Promise>; public setName(name: string, reason?: string): Promise>; public setScheduledStartTime(scheduledStartTime: DateResolvable, reason?: string): Promise>; @@ -4359,7 +4361,14 @@ export interface AddGuildMemberOptions { fetchWhenExisting?: boolean; } -export type AllowedPartial = User | Channel | GuildMember | Message | MessageReaction | ThreadMember; +export type AllowedPartial = + | User + | Channel + | GuildMember + | Message + | MessageReaction + | GuildScheduledEvent + | ThreadMember; export type AllowedThreadTypeForNewsChannel = ChannelType.AnnouncementThread; @@ -4929,12 +4938,12 @@ export interface ClientEvents { stickerUpdate: [oldSticker: Sticker, newSticker: Sticker]; guildScheduledEventCreate: [guildScheduledEvent: GuildScheduledEvent]; guildScheduledEventUpdate: [ - oldGuildScheduledEvent: GuildScheduledEvent | null, + oldGuildScheduledEvent: GuildScheduledEvent | PartialGuildScheduledEvent | null, newGuildScheduledEvent: GuildScheduledEvent, ]; - guildScheduledEventDelete: [guildScheduledEvent: GuildScheduledEvent]; - guildScheduledEventUserAdd: [guildScheduledEvent: GuildScheduledEvent, user: User]; - guildScheduledEventUserRemove: [guildScheduledEvent: GuildScheduledEvent, user: User]; + guildScheduledEventDelete: [guildScheduledEvent: GuildScheduledEvent | PartialGuildScheduledEvent]; + guildScheduledEventUserAdd: [guildScheduledEvent: GuildScheduledEvent | PartialGuildScheduledEvent, user: User]; + guildScheduledEventUserRemove: [guildScheduledEvent: GuildScheduledEvent | PartialGuildScheduledEvent, user: User]; } export interface ClientFetchInviteOptions { @@ -6149,6 +6158,9 @@ export interface PartialMessage export interface PartialMessageReaction extends Partialize {} +export interface PartialGuildScheduledEvent + extends Partialize {} + export interface PartialThreadMember extends Partialize {} export interface PartialOverwriteData {