aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDziurwa <54191536+Dziurwa14@users.noreply.github.com>2023-09-23 03:50:14 +0200
committerGitHub <noreply@github.com>2023-09-23 03:50:14 +0200
commit83bfe28fa48067ce925afd9d0755295d604a47f4 (patch)
treea43e607768c906812097fbfc0e7c594636221fc5 /src
parent08c5d23636e89626454cd9a58a473c31a6721cb4 (diff)
downloadVencord-83bfe28fa48067ce925afd9d0755295d604a47f4.tar.gz
Vencord-83bfe28fa48067ce925afd9d0755295d604a47f4.tar.bz2
Vencord-83bfe28fa48067ce925afd9d0755295d604a47f4.zip
FriendInvites: Add picking uses (1 or 5) (#1727)
Co-authored-by: V <vendicated@riseup.net>
Diffstat (limited to 'src')
-rw-r--r--src/plugins/friendInvites.ts59
-rw-r--r--src/utils/constants.ts2
2 files changed, 39 insertions, 22 deletions
diff --git a/src/plugins/friendInvites.ts b/src/plugins/friendInvites.ts
index fc59efa..9220998 100644
--- a/src/plugins/friendInvites.ts
+++ b/src/plugins/friendInvites.ts
@@ -1,6 +1,6 @@
/*
* Vencord, a modification for Discord's desktop app
- * Copyright (c) 2022 Vendicated and contributors
+ * Copyright (c) 2023 Vendicated and contributors
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -16,7 +16,7 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
-import { ApplicationCommandInputType, sendBotMessage } from "@api/Commands";
+import { ApplicationCommandInputType, ApplicationCommandOptionType, findOption, sendBotMessage } from "@api/Commands";
import { Devs } from "@utils/constants";
import definePlugin from "@utils/types";
import { findByPropsLazy } from "@webpack";
@@ -35,30 +35,47 @@ export default definePlugin({
name: "create friend invite",
description: "Generates a friend invite link.",
inputType: ApplicationCommandInputType.BOT,
- execute: async (_, ctx) => {
- if (!UserStore.getCurrentUser().phone)
+ options: [{
+ name: "Uses",
+ description: "How many uses?",
+ choices: [
+ { label: "1", name: "1", value: "1" },
+ { label: "5", name: "5", value: "5" }
+ ],
+ required: false,
+ type: ApplicationCommandOptionType.INTEGER
+ }],
+
+ execute: async (args, ctx) => {
+ const uses = findOption<number>(args, "Uses", 5);
+
+ if (uses === 1 && !UserStore.getCurrentUser().phone)
return sendBotMessage(ctx.channel.id, {
- content: "You need to have a phone number connected to your account to create a friend invite!"
+ content: "You need to have a phone number connected to your account to create a friend invite with 1 use!"
});
- const random = uuid.v4();
- const invite = await RestAPI.post({
- url: "/friend-finder/find-friends",
- body: {
- modified_contacts: {
- [random]: [1, "", ""]
- },
- phone_contact_methods_count: 1
- }
- }).then(res =>
- FriendInvites.createFriendInvite({
- code: res.body.invite_suggestions[0][3],
+ let invite: any;
+ if (uses === 1) {
+ const random = uuid.v4();
+ const { body: { invite_suggestions } } = await RestAPI.post({
+ url: "/friend-finder/find-friends",
+ body: {
+ modified_contacts: {
+ [random]: [1, "", ""]
+ },
+ phone_contact_methods_count: 1
+ }
+ });
+ invite = await FriendInvites.createFriendInvite({
+ code: invite_suggestions[0][3],
recipient_phone_number_or_email: random,
contact_visibility: 1,
filter_visibilities: [],
filtered_invite_suggestions_index: 1
- })
- );
+ });
+ } else {
+ invite = await FriendInvites.createFriendInvite();
+ }
sendBotMessage(ctx.channel.id, {
content: `
@@ -67,7 +84,7 @@ export default definePlugin({
Max uses: \`${invite.max_uses}\`
`.trim().replace(/\s+/g, " ")
});
- },
+ }
},
{
name: "view friend invites",
@@ -95,7 +112,7 @@ export default definePlugin({
execute: async (_, ctx) => {
await FriendInvites.revokeFriendInvites();
- return void sendBotMessage(ctx.channel.id, {
+ sendBotMessage(ctx.channel.id, {
content: "All friend invites have been revoked."
});
},
diff --git a/src/utils/constants.ts b/src/utils/constants.ts
index 80f0787..7264c40 100644
--- a/src/utils/constants.ts
+++ b/src/utils/constants.ts
@@ -265,7 +265,7 @@ export const Devs = /* #__PURE__*/ Object.freeze({
},
Dziurwa: {
name: "Dziurwa",
- id: 1034579679526526976n
+ id: 1001086404203389018n
},
AutumnVN: {
name: "AutumnVN",