Rev 4814 | Rev 4952 | 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 axios from '../../../utils/axios'import { connect } from 'react-redux'import { addNotification } from '../../../redux/notification/notification.actions'import DeleteOutlineIcon from '@mui/icons-material/DeleteOutline'import useOutsideClick from '../../../hooks/useOutsideClick'const NotificationsOption = ({ addNotification, sessionLink, Icon, title, url, }) => {const [notifications, setNotifications] = useState([])const [displayMenu, setDisplayMenu] = useState(false)const [notificationsCount, setNotificationsCount] = useState(0)const [loading, setLoading] = useState(false)const menu = useRef(null)const outsideClick = useOutsideClick(menu)const checkSession = async () => {try {setLoading(true)const { data: response } = await axios.get(sessionLink)const { total_notifications } = response.dataif (response.success) {setNotificationsCount(Number(total_notifications))}setLoading(false)} catch (error) {console.log(error)}}const readNotification = (link_read, link_notification) => {axios.post(link_read).then(({ data }) =>data.success? window.open(link_notification, '_blank').focus(): addNotification({ style: 'danger', msg: data.data }))}const deleteNotification = (link_delete) => {axios.post(link_delete).then(({ data }) => {!data.success && addNotification({ style: 'danger', msg: data.data })setNotificationsCount(prev => prev - 1)setNotifications(notifications.filter(notification => notification.link_delete !== link_delete))addNotification({ style: 'success', msg: data.data })})}const handleNotifications = () => {axios.get('/notifications/unreads').then(({ data }) => {if (data.success) {let notifications = new Set(data.data.notifications)setNotifications([...notifications])}}).catch(err => {addNotification({style: "error",msg: 'Disculpe, ha ocurrido un error buscando notificaciones',})console.log('>>: err > ', err)})}const handleClick = (e) => {if (window.innerWidth > 768) {e.preventDefault()setDisplayMenu(!displayMenu)}}useEffect(() => {if (outsideClick) setDisplayMenu(false)}, [outsideClick])useEffect(() => {handleNotifications()}, [notificationsCount])useEffect(() => {let timerif (!loading) {timer = setTimeout(() => checkSession(), 1000)}return () => {clearTimeout(timer)}}, [loading])return (<li ref={menu}><a href={url} className={`header__option mobile ${displayMenu && 'active'}`} target='framename' onClick={handleClick}>{Icon && <Icon className="header__option-icon" />}<span>{title}</span><span className={`badge ${notificationsCount ? 'd-block' : 'd-none'}`} style={{ top: '10px' }}>{notificationsCount}</span></a>{!!notifications.length &&<nav className={`nav__options-dropdown d-none d-md-block ${displayMenu && 'show'}`} style={{ maxHeight: '300px', overflow: 'auto' }}><ul>{notifications.map(({ message, link_mark_read, link, link_delete, time_elapsed }, index) =><li key={index}><div className="d-flex align-items-center" style={{ gap: '.5rem' }}><ahref={link}target='secondary'onClick={(e) => {e.preventDefault()readNotification(link_mark_read, link)}}>{message}</a><DeleteOutlineIcon onClick={() => deleteNotification(link_delete)} /></div><small style={{ fontSize: '.85rem' }}>{time_elapsed}</small></li>)}</ul></nav>}</li>)}const mapDispatchToProps = {addNotification: (notification) => addNotification(notification),}export default connect(null, mapDispatchToProps)(NotificationsOption)