Rev 3818 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
/* eslint-disable react/prop-types */import React, { useEffect, useRef, useState } from 'react'import { BiDotsVerticalRounded } from 'react-icons/bi'import { BsTrash } from 'react-icons/bs';import { useDispatch } from 'react-redux';import { deleteFeed } from '../../../redux/feed/feed.actions';import { addNotification } from '../../../redux/notification/notification.actions';import ConfirmModal from '../../../shared/confirm-modal/ConfirmModal';import { axios } from '../../../utils';const FeedHeader = ({ownerName,ownerImage,ownerTimeElapse,ownerUrl,feedDeleteUrl,feedUnique}) => {const [showConfirmModal, setShowConfirmModal] = useState(false);const [displayOption, setDisplayOption] = useState(false)const deleteButton = useRef();const dispatch = useDispatch()const handleShowConfirmModal = () => setShowConfirmModal(!showConfirmModal);const deleteFeedHandler = () => {axios.post(feedDeleteUrl).then((res) => {const { data } = resif (data.success) {dispatch(addNotification({style: "danger",msg: data.data,}))return}dispatch(deleteFeed(feedUnique));dispatch(addNotification({style: "success",msg: data.data,}))});};useEffect(() => {const handleClickOutside = (event) => {if (deleteButton.current && !deleteButton.current.contains(event.target)) {setDisplayOption(false)}}document.addEventListener("mousedown", handleClickOutside);return () => {document.removeEventListener("mousedown", handleClickOutside);};}, [deleteButton]);return (<><div className="post_topbar" ><div className="usy-dt"><a href={ownerUrl}><imgsrc={ownerImage}alt=""style={{ width: "50px", height: "auto", }}/></a><div className="usy-name"><a href={ownerUrl}><h3>{ownerName}</h3></a><span>{ownerTimeElapse}</span></div></div>{feedDeleteUrl &&<div className="cursor-pointer d-flex align-items-center"><BiDotsVerticalRoundedonClick={() => setDisplayOption(!displayOption)}style={{ fontSize: '1.5rem' }}/><div className={`feed-options ${displayOption ? 'active' : ''}`}><ul><li><buttonclassName="option-btn"onClick={handleShowConfirmModal}ref={deleteButton}><BsTrash className="mr-1" />Borrar</button></li></ul></div></div>}</div ><ConfirmModalshow={showConfirmModal}onClose={() => setShowConfirmModal(false)}onAccept={deleteFeedHandler}acceptLabel="Aceptar"/></>)}export default FeedHeader