Skip to content

Commit

Permalink
feat: allow emoji strings to be passed through constructors (#7718)
Browse files Browse the repository at this point in the history
* feat: allow strings to be passed through constructors

* fix: don't overwrite emoji with raw data
  • Loading branch information
ImRodry committed Apr 12, 2022
1 parent 9ff5425 commit 0faac04
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 6 deletions.
6 changes: 4 additions & 2 deletions packages/discord.js/src/structures/ButtonBuilder.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ const Transformers = require('../util/Transformers');
const Util = require('../util/Util');

class ButtonBuilder extends BuildersButtonComponent {
constructor(data) {
super(Transformers.toSnakeCase(data));
constructor({ emoji, ...data }) {
super(
Transformers.toSnakeCase({ ...data, emoji: emoji && typeof emoji === 'string' ? Util.parseEmoji(emoji) : emoji }),
);
}

/**
Expand Down
13 changes: 11 additions & 2 deletions packages/discord.js/src/structures/SelectMenuBuilder.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,19 @@

const { SelectMenuBuilder: BuildersSelectMenuComponent, isJSONEncodable } = require('@discordjs/builders');
const Transformers = require('../util/Transformers');
const Util = require('../util/Util');

class SelectMenuBuilder extends BuildersSelectMenuComponent {
constructor(data) {
super(Transformers.toSnakeCase(data));
constructor({ options, ...data }) {
super(
Transformers.toSnakeCase({
options: options.map(({ emoji, ...option }) => ({
...option,
emoji: emoji && typeof emoji === 'string' ? Util.parseEmoji(emoji) : emoji,
})),
...data,
}),
);
}

/**
Expand Down
4 changes: 2 additions & 2 deletions packages/discord.js/typings/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4685,7 +4685,7 @@ export interface MessageActivity {

export interface BaseButtonComponentData extends BaseComponentData {
disabled?: boolean;
emoji?: APIMessageComponentEmoji;
emoji?: ComponentEmojiResolvable;
label?: string;
}

Expand Down Expand Up @@ -4819,7 +4819,7 @@ export interface MessageSelectOption {
export interface SelectMenuComponentOptionData {
default?: boolean;
description?: string;
emoji?: APIMessageComponentEmoji;
emoji?: ComponentEmojiResolvable;
label: string;
value: string;
}
Expand Down

0 comments on commit 0faac04

Please sign in to comment.