mirror of
https://github.com/BluemediaDev/muse.git
synced 2025-06-27 01:02:41 +02:00
feat: add setting for default queue page size
This commit is contained in:
parent
c46153f620
commit
0912d95791
5 changed files with 58 additions and 3 deletions
|
@ -8,6 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
- An optional `page-size` to `/queue` command
|
- An optional `page-size` to `/queue` command
|
||||||
|
- Add `default-queue-page-size` setting
|
||||||
|
|
||||||
## [2.9.3] - 2024-08-19
|
## [2.9.3] - 2024-08-19
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
-- RedefineTables
|
||||||
|
PRAGMA foreign_keys=OFF;
|
||||||
|
CREATE TABLE "new_Setting" (
|
||||||
|
"guildId" TEXT NOT NULL PRIMARY KEY,
|
||||||
|
"playlistLimit" INTEGER NOT NULL DEFAULT 50,
|
||||||
|
"secondsToWaitAfterQueueEmpties" INTEGER NOT NULL DEFAULT 30,
|
||||||
|
"leaveIfNoListeners" BOOLEAN NOT NULL DEFAULT true,
|
||||||
|
"queueAddResponseEphemeral" BOOLEAN NOT NULL DEFAULT false,
|
||||||
|
"autoAnnounceNextSong" BOOLEAN NOT NULL DEFAULT false,
|
||||||
|
"defaultVolume" INTEGER NOT NULL DEFAULT 100,
|
||||||
|
"defaultQueuePageSize" INTEGER NOT NULL DEFAULT 10,
|
||||||
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
"updatedAt" DATETIME NOT NULL
|
||||||
|
);
|
||||||
|
INSERT INTO "new_Setting" ("autoAnnounceNextSong", "createdAt", "defaultVolume", "guildId", "leaveIfNoListeners", "playlistLimit", "queueAddResponseEphemeral", "secondsToWaitAfterQueueEmpties", "updatedAt") SELECT "autoAnnounceNextSong", "createdAt", "defaultVolume", "guildId", "leaveIfNoListeners", "playlistLimit", "queueAddResponseEphemeral", "secondsToWaitAfterQueueEmpties", "updatedAt" FROM "Setting";
|
||||||
|
DROP TABLE "Setting";
|
||||||
|
ALTER TABLE "new_Setting" RENAME TO "Setting";
|
||||||
|
PRAGMA foreign_key_check;
|
||||||
|
PRAGMA foreign_keys=ON;
|
|
@ -31,6 +31,7 @@ model Setting {
|
||||||
queueAddResponseEphemeral Boolean @default(false)
|
queueAddResponseEphemeral Boolean @default(false)
|
||||||
autoAnnounceNextSong Boolean @default(false)
|
autoAnnounceNextSong Boolean @default(false)
|
||||||
defaultVolume Int @default(100)
|
defaultVolume Int @default(100)
|
||||||
|
defaultQueuePageSize Int @default(10)
|
||||||
createdAt DateTime @default(now())
|
createdAt DateTime @default(now())
|
||||||
updatedAt DateTime @updatedAt
|
updatedAt DateTime @updatedAt
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,15 @@ export default class implements Command {
|
||||||
.setMinValue(0)
|
.setMinValue(0)
|
||||||
.setMaxValue(100)
|
.setMaxValue(100)
|
||||||
.setRequired(true)))
|
.setRequired(true)))
|
||||||
|
.addSubcommand(subcommand => subcommand
|
||||||
|
.setName('set-default-queue-page-size')
|
||||||
|
.setDescription('set the default page size of the /queue command')
|
||||||
|
.addIntegerOption(option => option
|
||||||
|
.setName('page-size')
|
||||||
|
.setDescription('page size of the /queue command')
|
||||||
|
.setMinValue(1)
|
||||||
|
.setMaxValue(50)
|
||||||
|
.setRequired(true)))
|
||||||
.addSubcommand(subcommand => subcommand
|
.addSubcommand(subcommand => subcommand
|
||||||
.setName('get')
|
.setName('get')
|
||||||
.setDescription('show all settings'));
|
.setDescription('show all settings'));
|
||||||
|
@ -171,6 +180,23 @@ export default class implements Command {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case 'set-default-queue-page-size': {
|
||||||
|
const value = interaction.options.getInteger('page-size')!;
|
||||||
|
|
||||||
|
await prisma.setting.update({
|
||||||
|
where: {
|
||||||
|
guildId: interaction.guild!.id,
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
defaultQueuePageSize: value,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
await interaction.reply('👍 default queue page size updated');
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case 'get': {
|
case 'get': {
|
||||||
const embed = new EmbedBuilder().setTitle('Config');
|
const embed = new EmbedBuilder().setTitle('Config');
|
||||||
|
|
||||||
|
@ -185,6 +211,7 @@ export default class implements Command {
|
||||||
'Auto announce next song in queue': config.autoAnnounceNextSong ? 'yes' : 'no',
|
'Auto announce next song in queue': config.autoAnnounceNextSong ? 'yes' : 'no',
|
||||||
'Add to queue reponses show for requester only': config.autoAnnounceNextSong ? 'yes' : 'no',
|
'Add to queue reponses show for requester only': config.autoAnnounceNextSong ? 'yes' : 'no',
|
||||||
'Default Volume': config.defaultVolume,
|
'Default Volume': config.defaultVolume,
|
||||||
|
'Default queue page size': config.defaultQueuePageSize,
|
||||||
};
|
};
|
||||||
|
|
||||||
let description = '';
|
let description = '';
|
||||||
|
|
|
@ -5,6 +5,7 @@ import {TYPES} from '../types.js';
|
||||||
import PlayerManager from '../managers/player.js';
|
import PlayerManager from '../managers/player.js';
|
||||||
import Command from './index.js';
|
import Command from './index.js';
|
||||||
import {buildQueueEmbed} from '../utils/build-embed.js';
|
import {buildQueueEmbed} from '../utils/build-embed.js';
|
||||||
|
import {getGuildSettings} from '../utils/get-guild-settings.js';
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export default class implements Command {
|
export default class implements Command {
|
||||||
|
@ -17,7 +18,9 @@ export default class implements Command {
|
||||||
.setRequired(false))
|
.setRequired(false))
|
||||||
.addIntegerOption(option => option
|
.addIntegerOption(option => option
|
||||||
.setName('page-size')
|
.setName('page-size')
|
||||||
.setDescription('how many items to display per page [default: 10]')
|
.setDescription('how many items to display per page [default: 10, max: 50]')
|
||||||
|
.setMinValue(1)
|
||||||
|
.setMaxValue(50)
|
||||||
.setRequired(false));
|
.setRequired(false));
|
||||||
|
|
||||||
private readonly playerManager: PlayerManager;
|
private readonly playerManager: PlayerManager;
|
||||||
|
@ -27,12 +30,16 @@ export default class implements Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
public async execute(interaction: ChatInputCommandInteraction) {
|
public async execute(interaction: ChatInputCommandInteraction) {
|
||||||
const player = this.playerManager.get(interaction.guild!.id);
|
const guildId = interaction.guild!.id;
|
||||||
|
const player = this.playerManager.get(guildId);
|
||||||
|
|
||||||
|
const pageSizeFromOptions = interaction.options.getInteger('page-size');
|
||||||
|
const pageSize = pageSizeFromOptions ?? (await getGuildSettings(guildId)).defaultQueuePageSize;
|
||||||
|
|
||||||
const embed = buildQueueEmbed(
|
const embed = buildQueueEmbed(
|
||||||
player,
|
player,
|
||||||
interaction.options.getInteger('page') ?? 1,
|
interaction.options.getInteger('page') ?? 1,
|
||||||
interaction.options.getInteger('page-size') ?? 10,
|
pageSize,
|
||||||
);
|
);
|
||||||
|
|
||||||
await interaction.reply({embeds: [embed]});
|
await interaction.reply({embeds: [embed]});
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue