Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 854 | Rev 856 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
5 stevensc 1
import React, { useEffect, useState } from 'react'
2
import { axios } from '../../../utils'
3
import { Link } from 'react-router-dom'
853 stevensc 4
import { Avatar, IconButton } from '@mui/material'
5 stevensc 5
import { useSelector } from 'react-redux'
6
import ExpandLessIcon from '@mui/icons-material/ExpandLess'
7
import ExpandMoreIcon from '@mui/icons-material/ExpandMore'
854 stevensc 8
import styled, { css } from 'styled-components'
5 stevensc 9
 
10
import EmptySection from '../../UI/EmptySection'
853 stevensc 11
import StyledContainer from '../../widgets/WidgetLayout'
5 stevensc 12
 
854 stevensc 13
const HelperContainer = styled(StyledContainer)`
853 stevensc 14
  padding: 10px;
15
`
16
 
854 stevensc 17
const HelperItem = styled.div`
853 stevensc 18
  cursor: pointer;
19
  display: flex;
20
  align-items: center;
21
  justify-content: space-between;
22
  width: 100%;
23
`
24
 
854 stevensc 25
const HelperList = styled.ul`
26
  display: flex;
27
  flex-direction: column;
28
  gap: 0.5rem;
29
  overflow-y: auto;
30
  height: 0;
31
  max-height: 250px;
32
  transition: all 0.2s ease-in-out;
33
  ${(props) =>
34
    props.show &&
35
    css`
36
      height: auto;
37
    `}
38
`
39
 
5 stevensc 40
const Groups = () => {
41
  const labels = useSelector(({ intl }) => intl.labels)
42
 
43
  return (
854 stevensc 44
    <HelperContainer>
5 stevensc 45
      <Groups.Item
851 stevensc 46
        url='/helpers/my-groups'
5 stevensc 47
        title={labels.my_groups}
48
        display={true}
49
      />
50
      <Groups.Item
851 stevensc 51
        url='/helpers/groups-suggestion'
5 stevensc 52
        title={labels.suggest_groups}
53
      />
854 stevensc 54
    </HelperContainer>
5 stevensc 55
  )
56
}
57
 
58
const Item = ({
59
  url = '/helpers/my-groups',
60
  title = 'Mis grupos',
851 stevensc 61
  display = false
5 stevensc 62
}) => {
63
  const [widgetData, setWidgetData] = useState([])
64
  const [displayMenu, setDisplayMenu] = useState(display)
854 stevensc 65
  const [lookMore, setLookMore] = useState(false)
5 stevensc 66
  const labels = useSelector(({ intl }) => intl.labels)
67
 
68
  const getData = () => {
69
    axios.get(url).then((response) => {
70
      const { success, data } = response.data
71
 
72
      if (success) {
73
        setWidgetData(data.sort((a, b) => a.priority - b.priority).reverse())
74
      }
75
    })
76
  }
77
 
78
  const toggleMenu = () => {
79
    setDisplayMenu(!displayMenu)
80
  }
81
 
82
  const dataSlice = () => {
83
    let infoFollows = [...widgetData]
84
    if (!lookMore) {
85
      infoFollows = infoFollows.slice(0, 3)
86
    }
87
    return infoFollows
88
  }
89
 
90
  useEffect(() => {
91
    getData()
92
  }, [])
93
 
94
  return (
853 stevensc 95
    <>
854 stevensc 96
      <HelperItem>
853 stevensc 97
        <span>{title}</span>
98
        <IconButton onClick={toggleMenu}>
5 stevensc 99
          {displayMenu ? <ExpandLessIcon /> : <ExpandMoreIcon />}
853 stevensc 100
        </IconButton>
854 stevensc 101
      </HelperItem>
5 stevensc 102
 
855 stevensc 103
      <HelperList show={displayMenu}>
5 stevensc 104
        {widgetData.length ? (
105
          dataSlice().map(({ id, name, profile, image }) => (
106
            <li key={id}>
107
              <Link
517 stevensc 108
                to={profile}
851 stevensc 109
                className='helper__list-item'
110
                target='secondary'
5 stevensc 111
              >
112
                <Avatar
113
                  src={image}
114
                  alt={`${name} group image`}
115
                  sx={{ width: '40px', height: '40px' }}
116
                />
117
                <span>{name}</span>
118
              </Link>
119
            </li>
120
          ))
121
        ) : (
122
          <EmptySection message={labels.datatable_empty} />
123
        )}
124
 
125
        {widgetData.length >= 3 && (
126
          <li
851 stevensc 127
            className='helper__list-item justify-content-center cursor-pointer py-2'
5 stevensc 128
            onClick={() => setLookMore(!lookMore)}
129
          >
130
            <span>{lookMore ? labels.view_less : labels.view_more}</span>
131
          </li>
132
        )}
854 stevensc 133
      </HelperList>
853 stevensc 134
    </>
5 stevensc 135
  )
136
}
137
 
138
Groups.Item = Item
139
 
140
export default Groups