mirror of
https://github.com/emailerfacu-spec/minix-front.git
synced 2026-04-01 13:10:44 -03:00
fix: Arregladas updates del panel de admin
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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}`,
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user