diff --git a/src/pages/UserActivity/index.js b/src/pages/UserActivity/index.js index cd0f26b..0ca205a 100644 --- a/src/pages/UserActivity/index.js +++ b/src/pages/UserActivity/index.js @@ -1,6 +1,6 @@ import React, { useState, useEffect, useRef } from 'react'; import { __ } from '@wordpress/i18n'; -import { isEmpty, isNil } from 'ramda'; +import { isEmpty, isNil, pathOr } from 'ramda'; import { klona } from 'klona'; // store @@ -23,17 +23,57 @@ import { classNames } from 'primereact/utils'; import { Toast } from 'primereact/toast'; import getDateFromISOstring from '../../helpers/getDateFromISOstring'; import getBandoLabel from '../../helpers/getBandoLabel'; -import { useNavigate } from 'react-router-dom'; +import { useNavigate, useParams } from 'react-router-dom'; +import NumberFlow from '@number-flow/react'; const UserActivity = () => { const [loading, setLoading] = useState(false); const toast = useRef(null); const navigate = useNavigate(); + const { id } = useParams(); + const [user, setUser] = useState({}); + const [roles, setRoles] = useState([]); const goBack = () => { navigate(`/utenti`); } + const getUserCallback = (resp) => { + if (resp.status === 'SUCCESS') { + setUser(resp.data) + } + setLoading(false); + } + + const errGetUserCallback = (resp) => { + set404FromErrorResponse(resp); + setLoading(false); + } + + const getRolesCallback = (resp) => { + if (resp.status === 'SUCCESS') { + setRoles(resp.data) + } + setLoading(false); + } + + const errGetRolesCallback = (resp) => { + set404FromErrorResponse(resp); + setLoading(false); + } + + const getStatValue = (key, fallback = 0) => { + return pathOr(fallback, [key], {}); + } + + useEffect(() => { + if (id && !isEmpty(id)) { + setLoading(true); + UserService.getUser(id, getUserCallback, errGetUserCallback); + UserService.getRoles(getRolesCallback, errGetRolesCallback); + } + }, [id]) + return (
{__('Nome utente', 'gepafin')} - + {`${user.firstName} ${user.lastName}`}
{__('Email', 'gepafin')} - + {user.email}
{__('Ruolo', 'gepafin')} - + {user.role?.roleName}
{__('Data registrazione', 'gepafin')} - + {getDateFromISOstring(user.createdDate)}
{__('Ultimo accesso', 'gepafin')} - + {getDateFromISOstring(user.lastLogin)}
{__('Stato account', 'gepafin')} - + {user.status}