fix: Arregladas updates del panel de admin

This commit is contained in:
2026-02-16 18:41:21 -03:00
parent c96df5af92
commit 022623e22c
5 changed files with 46 additions and 23 deletions

View File

@@ -25,6 +25,7 @@
import AgregarUsuario from './admin/AgregarUsuario.svelte'; import AgregarUsuario from './admin/AgregarUsuario.svelte';
import DarAdmin from './admin/DarAdmin.svelte'; import DarAdmin from './admin/DarAdmin.svelte';
import { busquedaAdminUsuarios } from '@/hooks/busquedaAdminUsuarios'; import { busquedaAdminUsuarios } from '@/hooks/busquedaAdminUsuarios';
import { invalidate, replaceState } from '$app/navigation';
interface Props { interface Props {
usuarios: UserResponseDto[]; usuarios: UserResponseDto[];
@@ -33,7 +34,17 @@
let { usuarios = $bindable(), hayMas }: Props = $props(); let { usuarios = $bindable(), hayMas }: Props = $props();
let hayMass = $state(hayMas); let paginaActual = $derived.by(() => {
const url = new URL(window.location.href);
return Number(url.searchParams.get('p')) || 1;
});
let search = $derived.by(() => {
const url = new URL(window.location.href);
let ret = url.searchParams.get('q') || '';
return ret;
});
let hayMass = $derived(hayMas);
let open = $state(false); let open = $state(false);
let openModificarUsuario = $state(false); let openModificarUsuario = $state(false);
let openDarAdmin = $state(false); let openDarAdmin = $state(false);
@@ -45,13 +56,11 @@
let usuarioModificar: UserResponseDto | null = $state(null); let usuarioModificar: UserResponseDto | null = $state(null);
let usuarioDarAdmin: UserResponseDto | null = $state(null); let usuarioDarAdmin: UserResponseDto | null = $state(null);
let search = $state('');
type SortKey = 'username' | 'displayName' | 'postsCount' | 'createdAt'; type SortKey = 'username' | 'displayName' | 'postsCount' | 'createdAt';
let sortBy = $state<SortKey | null>(null); let sortBy = $state<SortKey | null>(null);
let sortDirection = $state<'asc' | 'desc'>('asc'); let sortDirection = $state<'asc' | 'desc'>('asc');
let usuariosFiltrados = $state(usuarios); let usuariosFiltrados = $derived(usuarios);
function ordenarPor(campo: SortKey) { function ordenarPor(campo: SortKey) {
if (sortBy === campo) { if (sortBy === campo) {
@@ -95,11 +104,17 @@
} }
timeoutId = setTimeout(async () => { timeoutId = setTimeout(async () => {
if (search === '') { const url = new URL(window.location.href);
search = ''; if (!search.trim()) {
url.searchParams.delete('q');
} else {
url.searchParams.set('q', search);
} }
replaceState(url, {});
let ret = await busquedaAdminUsuarios(search, ITEMS_POR_PAGINA, paginaActual); let ret = await busquedaAdminUsuarios(search, ITEMS_POR_PAGINA, paginaActual);
usuariosFiltrados = ret.usuarios; usuariosFiltrados = ret.usuarios;
// invalidate('admin:load');
hayMass = ret.hayMas; hayMass = ret.hayMas;
}, 200); }, 200);
@@ -109,8 +124,6 @@
} }
const ITEMS_POR_PAGINA = 5; const ITEMS_POR_PAGINA = 5;
let paginaActual = $state(1);
// const usuariosPaginados = $derived( // const usuariosPaginados = $derived(
// usuariosFiltrados.slice((paginaActual - 1) * ITEMS_POR_PAGINA, paginaActual * ITEMS_POR_PAGINA) // usuariosFiltrados.slice((paginaActual - 1) * ITEMS_POR_PAGINA, paginaActual * ITEMS_POR_PAGINA)
// ); // );
@@ -245,7 +258,9 @@
<Button <Button
disabled={paginaActual === 1} disabled={paginaActual === 1}
onclick={() => { onclick={() => {
paginaActual--; const url = new URL(window.location.href);
url.searchParams.set('p', String(--paginaActual));
replaceState(url, {});
buscarUsuarios(); buscarUsuarios();
}} }}
variant="secondary" variant="secondary"
@@ -256,7 +271,9 @@
<Button <Button
disabled={!hayMass} disabled={!hayMass}
onclick={() => { onclick={() => {
paginaActual++; const url = new URL(window.location.href);
url.searchParams.set('p', String(++paginaActual));
replaceState(url, {});
buscarUsuarios(); buscarUsuarios();
}} }}
variant="secondary">Siguiente</Button variant="secondary">Siguiente</Button

View File

@@ -10,6 +10,7 @@
import Label from '../ui/label/label.svelte'; import Label from '../ui/label/label.svelte';
import Spinner from '../ui/spinner/spinner.svelte'; import Spinner from '../ui/spinner/spinner.svelte';
import { updateUsuario } from '@/hooks/updateUsuario'; import { updateUsuario } from '@/hooks/updateUsuario';
import { invalidate } from '$app/navigation';
interface Prop { interface Prop {
open: boolean; open: boolean;
@@ -38,6 +39,7 @@
error = ret; error = ret;
} else { } else {
usuario!.displayName = ret.displayName; usuario!.displayName = ret.displayName;
invalidate('admin:load');
open = false; open = false;
} }
cargando = false; cargando = false;

View File

@@ -2,9 +2,10 @@ import { apiBase } from '@/stores/url';
import { sesionStore } from '@/stores/usuario'; import { sesionStore } from '@/stores/usuario';
import { get } from 'svelte/store'; import { get } from 'svelte/store';
export async function busquedaAdminUsuarios(q: string, limit = 5, page = 1) { export async function busquedaAdminUsuarios(q: string, limit = 5, page = 1, fetch2?: Function) {
try { try {
const response = await fetch( const fetchFn = fetch2 ? fetch2 : fetch;
const response = await fetchFn(
get(apiBase) + get(apiBase) +
`/api/admin/users${q ? `?q=${q}` : ''}${q ? '&' : '?'}page=${page}&pageSize=${limit}`, `/api/admin/users${q ? `?q=${q}` : ''}${q ? '&' : '?'}page=${page}&pageSize=${limit}`,
{ {

View File

@@ -1,7 +1,6 @@
<script lang="ts"> <script lang="ts">
import CardContent from '@/components/ui/card/card-content.svelte'; import CardContent from '@/components/ui/card/card-content.svelte';
import Card from '@/components/ui/card/card.svelte'; import Card from '@/components/ui/card/card.svelte';
import CardDescription from '@/components/ui/card/card-description.svelte';
import TablaUsuarios from '@/components/TablaUsuarios.svelte'; import TablaUsuarios from '@/components/TablaUsuarios.svelte';
import CardTitle from '@/components/ui/card/card-title.svelte'; import CardTitle from '@/components/ui/card/card-title.svelte';
import CardHeader from '@/components/ui/card/card-header.svelte'; import CardHeader from '@/components/ui/card/card-header.svelte';
@@ -9,7 +8,7 @@
interface Prop { interface Prop {
data: { data: {
usuarios?: UserResponseDto[]; usuarios: UserResponseDto[];
hayMas: boolean; hayMas: boolean;
error: boolean; error: boolean;
}; };
@@ -29,11 +28,7 @@
</CardTitle> </CardTitle>
</CardHeader> </CardHeader>
<CardContent> <CardContent>
{#if data.usuarios?.length === 0} <TablaUsuarios usuarios={data.usuarios} hayMas={data.hayMas}></TablaUsuarios>
<CardDescription>No hay usuarios que mostar</CardDescription>
{:else}
<TablaUsuarios usuarios={data.usuarios || []} hayMas={data.hayMas}></TablaUsuarios>
{/if}
</CardContent> </CardContent>
</Card> </Card>
</div> </div>

View File

@@ -1,19 +1,27 @@
import { busquedaAdminUsuarios } from '@/hooks/busquedaAdminUsuarios.js';
import type { PageLoad } from './$types.js'; import type { PageLoad } from './$types.js';
import { fetchUsuariosAdmin } from '@/hooks/UsuariosAdmin.js'; import { fetchUsuariosAdmin } from '@/hooks/UsuariosAdmin.js';
export const ssr = false; export const ssr = false;
export const load: PageLoad = async ({ depends }) => { export const load: PageLoad = async ({ depends, fetch }) => {
depends('admin:load'); depends('admin:load');
const result = await fetchUsuariosAdmin(1, 5); let url = new URL(location.href);
let query = url.searchParams.get('q') ?? '';
let page = Number(url.searchParams.get('p'));
if (isNaN(page) || page < 1) {
page = 1;
}
const result = await busquedaAdminUsuarios(query, 5, page, fetch);
if (result.error) { if (result.error) {
return { error: true }; return { error: true };
} }
return { return {
usuarios: result.ret?.usuarios, usuarios: result.usuarios,
hayMas: result.ret?.hayMas, hayMas: result.hayMas,
error: false error: false
}; };
}; };