feat: Obtener roles de guild desde la API de Discord y actualizar la interfaz de configuración

This commit is contained in:
Shni
2025-10-15 01:13:26 -05:00
parent 51d1ac70b7
commit fda1b0c5c4
2 changed files with 47 additions and 9 deletions

View File

@@ -1167,6 +1167,30 @@ export const server = createServer(
} catch {
guildConfig = null;
}
// Attempt to fetch guild roles via Discord Bot API if token available
let guildRoles: Array<{ id: string; name: string }> = [];
try {
const botToken = process.env.DISCORD_BOT_TOKEN;
if (botToken) {
const rolesRes = await fetch(
`https://discord.com/api/guilds/${encodeURIComponent(
String(guildId)
)}/roles`,
{ headers: { Authorization: `Bot ${botToken}` } }
);
if (rolesRes.ok) {
const rolesJson = await rolesRes.json();
if (Array.isArray(rolesJson)) {
guildRoles = rolesJson.map((r: any) => ({
id: String(r.id),
name: String(r.name || r.id),
}));
}
}
}
} catch (err) {
// ignore; fallback to no roles
}
// Render dashboard with selected guild context; show dashboard nav
await renderTemplate(req, res, "dashboard", {
appName: pkg.name ?? "Amayo Bot",
@@ -1176,6 +1200,7 @@ export const server = createServer(
selectedGuildId: guildId,
selectedGuildName,
guildConfig,
guildRoles,
page,
hideNavbar: false,
useDashboardNav: true,

View File

@@ -58,8 +58,18 @@
<textarea name="aiRolePrompt" id="aiRoleInput" rows="4" class="w-full rounded p-2 bg-transparent border border-white/6" placeholder="E.g. Actúa como un moderador amigable..."><%= (guildConfig && guildConfig.aiRolePrompt) || '' %></textarea>
</div>
<div>
<label class="block text-sm text-slate-200 mb-1">Roles de staff (IDs separadas por coma)</label>
<label class="block text-sm text-slate-200 mb-1">Roles de staff</label>
<% if (typeof guildRoles !== 'undefined' && guildRoles && guildRoles.length) { %>
<select id="staffSelect" name="staffSelect" multiple class="w-full rounded p-2 bg-transparent border border-white/6 h-36">
<% const selectedStaff = (guildConfig && Array.isArray(guildConfig.staff) ? guildConfig.staff.map(String) : (guildConfig && guildConfig.staff ? String(guildConfig.staff).split(',') : [])) || []; %>
<% guildRoles.forEach(r => { %>
<option value="<%= r.id %>" <%= selectedStaff.includes(String(r.id)) ? 'selected' : '' %>><%= r.name %> — <%= r.id %></option>
<% }) %>
</select>
<% } else { %>
<input type="text" name="staff" id="staffInput" value="<%= (guildConfig && (Array.isArray(guildConfig.staff) ? guildConfig.staff.join(',') : guildConfig.staff)) || '' %>" class="w-full rounded p-2 bg-transparent border border-white/6" placeholder="123... , 456..." />
<div class="text-xs text-slate-300 mt-1">No se pudo obtener roles desde la API. Introduce IDs manualmente separadas por coma.</div>
<% } %>
</div>
<div class="flex items-center gap-3">
<button type="submit" class="pixel-btn">Guardar</button>
@@ -77,12 +87,15 @@
status.textContent = 'Guardando...';
const prefix = document.getElementById('prefixInput').value.trim();
const aiRolePrompt = document.getElementById('aiRoleInput').value.trim();
const staffRaw = document.getElementById('staffInput').value.trim();
const payload = {
prefix: prefix,
aiRolePrompt: aiRolePrompt.length ? aiRolePrompt : null,
staff: staffRaw ? staffRaw.split(',').map(s=>s.trim()).filter(Boolean) : [],
};
let staffArr = [];
const staffSelect = document.getElementById('staffSelect');
if (staffSelect) {
for (const o of staffSelect.selectedOptions) staffArr.push(o.value);
} else {
const staffRaw = (document.getElementById('staffInput') && document.getElementById('staffInput').value) ? document.getElementById('staffInput').value.trim() : '';
staffArr = staffRaw ? staffRaw.split(',').map(s=>s.trim()).filter(Boolean) : [];
}
const payload = { prefix: prefix, aiRolePrompt: aiRolePrompt.length ? aiRolePrompt : null, staff: staffArr };
try {
const res = await fetch(`/api/dashboard/${encodeURIComponent('<%= selectedGuild %>')}/settings`, {
method: 'POST',