Proyectos de Subversion LeadersLinked - SPA

Rev

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

Rev Autor Línea Nro. Línea
2880 stevensc 1
import React from 'react'
2
import { useSelector } from 'react-redux'
2864 stevensc 3
import { Search } from '@mui/icons-material'
4
 
2880 stevensc 5
import { debounce } from '@utils'
6
import { useFetch, useSearchQuery } from '@hooks'
5 stevensc 7
 
2880 stevensc 8
import Input from '@components/UI/inputs/Input'
9
import TitleSection from '@components/UI/TitleSection'
10
import MyConnectionsList from '@components/connections/MyConnectionsList'
11
import PaginationComponent from '@components/UI/PaginationComponent'
5 stevensc 12
 
13
const MyConnectionsPage = () => {
14
  const labels = useSelector(({ intl }) => intl.labels)
15
 
2880 stevensc 16
  const { getParam, setParam } = useSearchQuery()
17
  const { data, isLoading, refetch } = useFetch(
18
    `/connection/my-connections?search=${getParam('search')}?page=${getParam(
19
      'page'
20
    )}`
21
  )
5 stevensc 22
 
2880 stevensc 23
  const handleSearch = debounce((e) => setParam('search', e.target.value), 500)
5 stevensc 24
 
25
  return (
2880 stevensc 26
    <>
5 stevensc 27
      <TitleSection title={labels.first_level_persons} />
2875 stevensc 28
      <Input icon={<Search />} onChange={handleSearch} variant='search' />
2880 stevensc 29
      <MyConnectionsList
2886 stevensc 30
        connections={data.current?.items}
2880 stevensc 31
        loading={isLoading}
32
        onComplete={refetch}
33
      />
5 stevensc 34
      <PaginationComponent
35
        isRow
2886 stevensc 36
        pages={data.total?.pages}
37
        currentActivePage={data.current?.page}
2880 stevensc 38
        onChangePage={(page) => setParam('page', page)}
5 stevensc 39
      />
2880 stevensc 40
    </>
5 stevensc 41
  )
42
}
43
 
44
export default MyConnectionsPage