mirror of
https://github.com/emailerfacu-spec/minix-front.git
synced 2026-04-12 15:00:43 -03:00
hecha functionalidad para seguir usuarios desde los posts
This commit is contained in:
96
src/lib/components/BotonSeguir.svelte
Normal file
96
src/lib/components/BotonSeguir.svelte
Normal file
@@ -0,0 +1,96 @@
|
||||
<script lang="ts">
|
||||
import { sesionStore } from '@/stores/usuario';
|
||||
import { Tooltip } from './ui/tooltip';
|
||||
import TooltipTrigger from './ui/tooltip/tooltip-trigger.svelte';
|
||||
import Button from './ui/button/button.svelte';
|
||||
import UserX from '@lucide/svelte/icons/user-x';
|
||||
import UserPlus from '@lucide/svelte/icons/user-plus';
|
||||
import Spinner from './ui/spinner/spinner.svelte';
|
||||
import TooltipContent from './ui/tooltip/tooltip-content.svelte';
|
||||
import { esSeguido } from '@/hooks/esSeguido';
|
||||
import { seguirUsuario } from '@/hooks/seguirUsuario';
|
||||
import type { Post } from '../../types';
|
||||
import CardError from './CardError.svelte';
|
||||
import { cacheSeguidos } from '@/stores/cacheSeguidos.svelte';
|
||||
import DialogContent from './ui/dialog/dialog-content.svelte';
|
||||
import Dialog from './ui/dialog/dialog.svelte';
|
||||
|
||||
let { post }: { post: Post } = $props();
|
||||
let seguido: Boolean | null = $state(null);
|
||||
|
||||
if (typeof window !== 'undefined') {
|
||||
window.addEventListener('followCacheUpdated', ((
|
||||
event: CustomEvent<{ userId: string; isFollowed: boolean }>
|
||||
) => {
|
||||
if (event.detail.userId === post.authorId) {
|
||||
seguido = event.detail.isFollowed;
|
||||
}
|
||||
}) as EventListener);
|
||||
}
|
||||
|
||||
$effect(() => {
|
||||
(async () => {
|
||||
await cargarSeguido();
|
||||
})();
|
||||
});
|
||||
|
||||
async function cargarSeguido() {
|
||||
let a = cacheSeguidos.get(post.authorId);
|
||||
if (a === undefined) {
|
||||
const seguidoStatus = await esSeguido(post);
|
||||
cacheSeguidos.set(post.authorId, seguidoStatus.isFollowing || false);
|
||||
seguido = seguidoStatus.isFollowing || false;
|
||||
return;
|
||||
}
|
||||
seguido = a;
|
||||
}
|
||||
|
||||
let mensajeError: string | null = $state(null);
|
||||
</script>
|
||||
|
||||
{#if mensajeError}
|
||||
<CardError {mensajeError} />
|
||||
{/if}
|
||||
|
||||
{#if post.authorName !== $sesionStore?.username && post.authorName !== '[deleted]'}
|
||||
<Tooltip>
|
||||
<TooltipTrigger>
|
||||
<Button
|
||||
variant={seguido == true ? 'destructive' : 'default'}
|
||||
disabled={seguido == null}
|
||||
size="icon-sm"
|
||||
class="ml-auto rounded-full p-1 text-sm"
|
||||
onclick={async () => {
|
||||
if (seguido == null) return;
|
||||
const anteriorEstado = seguido;
|
||||
let ret = seguirUsuario(post.authorId, seguido);
|
||||
seguido = null;
|
||||
|
||||
let [res] = await Promise.all([
|
||||
await ret,
|
||||
new Promise((resolve) => setTimeout(resolve, 300))
|
||||
]);
|
||||
|
||||
if (res === null) mensajeError = 'Fallo al intentar seguir el usuario';
|
||||
if (res === true) seguido = !anteriorEstado;
|
||||
cacheSeguidos.set(post.authorId, seguido == null ? false : Boolean(seguido));
|
||||
}}
|
||||
>
|
||||
{#if seguido == true}
|
||||
<UserX />
|
||||
{:else if seguido == false}
|
||||
<UserPlus />
|
||||
{:else}
|
||||
<Spinner />
|
||||
{/if}
|
||||
</Button>
|
||||
</TooltipTrigger>
|
||||
<TooltipContent>
|
||||
{#if seguido == true}
|
||||
Dejar de seguir
|
||||
{:else}
|
||||
Seguir
|
||||
{/if}
|
||||
</TooltipContent>
|
||||
</Tooltip>
|
||||
{/if}
|
||||
@@ -32,6 +32,7 @@
|
||||
import { likePost } from '@/hooks/likePost';
|
||||
import { goto } from '$app/navigation';
|
||||
import { resolve } from '$app/paths';
|
||||
import BotonSeguir from './BotonSeguir.svelte';
|
||||
|
||||
interface postProp {
|
||||
post: Post;
|
||||
@@ -43,7 +44,6 @@
|
||||
|
||||
let cargandoBorrar = $state(false);
|
||||
let mensajeError = $state('');
|
||||
let cargandoEditar = $state(false);
|
||||
let cargandoLike = $state(false);
|
||||
let errorLike = $state(false);
|
||||
|
||||
@@ -123,6 +123,7 @@
|
||||
<span class="text-lg text-muted-foreground">@{post.authorName}</span>
|
||||
</div>
|
||||
</div>
|
||||
<BotonSeguir {post} />
|
||||
{#if post.authorName === $sesionStore?.username}
|
||||
<DropdownMenu>
|
||||
<DropdownMenuTrigger>
|
||||
|
||||
Reference in New Issue
Block a user