- added role switcher;

- added vatCheckData to add company request;
This commit is contained in:
Vitalii Kiiko
2025-01-02 16:58:40 +01:00
parent 9b4db1b884
commit 645b674276
4 changed files with 64 additions and 194 deletions

View File

@@ -1,4 +1,4 @@
import React, { useEffect, useRef } from 'react'; import React, { useEffect, useRef, useState } from 'react';
import { __ } from '@wordpress/i18n'; import { __ } from '@wordpress/i18n';
import { isEmpty, head } from 'ramda'; import { isEmpty, head } from 'ramda';
import { klona } from 'klona'; import { klona } from 'klona';
@@ -29,6 +29,7 @@ const AddCompany = () => {
const isAsyncRequest = useStore().main.isAsyncRequest(); const isAsyncRequest = useStore().main.isAsyncRequest();
const infoMsgs = useRef(null); const infoMsgs = useRef(null);
const [, debouncedPivaValue, setInputPiva] = useDebounce('', 1000); const [, debouncedPivaValue, setInputPiva] = useDebounce('', 1000);
const [vatCheckResponse, setVatCheckResponse] = useState({});
const { const {
control, control,
@@ -54,14 +55,19 @@ const AddCompany = () => {
address: '', address: '',
companyName: '' companyName: ''
} }
setVatCheckResponse({});
Object.keys(formData).map(k => setValue(k, formData[k])); Object.keys(formData).map(k => setValue(k, formData[k]));
} }
const onSubmit = (formData) => { const onSubmit = (formData) => {
infoMsgs.current.clear(); infoMsgs.current.clear();
storeSet.main.setAsyncRequest(); storeSet.main.setAsyncRequest();
const submitData = {
...formData,
vatCheckResponse
}
CompanyService.createCompany(formData, updateCallback, updateError); CompanyService.createCompany(submitData, updateCallback, updateError);
}; };
const updateCallback = (data) => { const updateCallback = (data) => {
@@ -109,7 +115,7 @@ const AddCompany = () => {
const checkVatCallback = (data) => { const checkVatCallback = (data) => {
if (data.status === 'SUCCESS') { if (data.status === 'SUCCESS') {
const resp = data.data.data; const resp = data.data.vatCheckResponse.data;
if (!isEmpty(resp)) { if (!isEmpty(resp)) {
const { const {
cap, cf, denominazione, piva, indirizzo, comune, dettaglio: { pec } cap, cf, denominazione, piva, indirizzo, comune, dettaglio: { pec }
@@ -126,6 +132,7 @@ const AddCompany = () => {
companyName: denominazione companyName: denominazione
} }
Object.keys(formData).map(k => setValue(k, formData[k])); Object.keys(formData).map(k => setValue(k, formData[k]));
setVatCheckResponse(data.data.vatCheckResponse);
} }
//setData(getFormattedBandiData(data.data)); //setData(getFormattedBandiData(data.data));
} else { } else {

View File

@@ -437,7 +437,7 @@ const SoccorsoEditBeneficiario = () => {
outlined outlined
onClick={goToArchivePage} onClick={goToArchivePage}
label={__('Indietro', 'gepafin')} label={__('Indietro', 'gepafin')}
icon="pi pi-times" iconPos="right"/> icon="pi pi-arrow-left" iconPos="left"/>
</div> </div>
</div> </div>
</div> </div>

View File

@@ -1,175 +0,0 @@
import React, { useState, useEffect } from 'react';
import { __ } from '@wordpress/i18n';
import { uniq } from 'ramda';
import copy from 'copy-to-clipboard';
// store
import { useStore, storeSet } from '../../../../store';
// tools
import getBandoSeverity from '../../../../helpers/getBandoSeverity';
import getBandoLabel from '../../../../helpers/getBandoLabel';
import getDateFromISOstring from '../../../../helpers/getDateFromISOstring';
// api
import UserService from '../../../../service/user-service';
// components
import { FilterMatchMode, FilterOperator } from 'primereact/api';
import { DataTable } from 'primereact/datatable';
import { Column } from 'primereact/column';
import { Dropdown } from 'primereact/dropdown';
import { Button } from 'primereact/button';
import { Calendar } from 'primereact/calendar';
import { Tag } from 'primereact/tag';
import ProperBandoLabel from '../../../../components/ProperBandoLabel';
import translationStrings from '../../../../translationStringsForComponents';
import { Link } from 'react-router-dom';
const AllUsersTable = () => {
const users = useStore().main.users();
const [filters, setFilters] = useState(null);
const [loading, setLoading] = useState(false);
const [statuses, setStatuses] = useState([]);
useEffect(() => {
if (!loading) {
setLoading(true);
UserService.getUsers(getCallback, errGetCallbacks);
}
}, []);
const getCallback = (data) => {
if (data.status === 'SUCCESS') {
storeSet.main.users(getFormattedData(data.data));
setStatuses(uniq(data.data.map(o => o.status)))
initFilters();
}
setLoading(false);
}
const errGetCallbacks = () => {
setLoading(false);
}
const getFormattedData = (data) => {
return data
.filter(o => ['ROLE_SUPER_ADMIN', 'ROLE_PRE_INSTRUCTOR', 'ROLE_INSTRUCTOR_MANAGER'].includes(o.role.roleType));
};
const clearFilter = () => {
initFilters();
};
const initFilters = () => {
setFilters({
global: { value: null, matchMode: FilterMatchMode.CONTAINS },
email: {
operator: FilterOperator.AND,
constraints: [{ value: null, matchMode: FilterMatchMode.STARTS_WITH }]
},
lastLogin: {
operator: FilterOperator.AND,
constraints: [{ value: null, matchMode: FilterMatchMode.DATE_IS }]
}
});
};
const renderHeader = () => {
return (
<div className="appTableHeader">
<Button type="button" icon="pi pi-filter-slash" label={__('Pulisci', 'gepafin')} outlined
onClick={clearFilter}/>
</div>
);
};
const dateLastAccessBodyTemplate = (rowData) => {
return getDateFromISOstring(rowData.lastLogin);
};
const dateFilterTemplate = (options) => {
return <Calendar value={options.value} onChange={(e) => options.filterCallback(e.value, options.index)}
dateFormat="mm/dd/yy" placeholder="mm/dd/yyyy" mask="99/99/9999"/>;
};
const nameBodyTemplate = (rowData) => {
return `${rowData.firstName} ${rowData.lastName}`;
};
const roleEmailTemplate = (rowData) => {
return <div className="appPageSection__tableActions lessGap">
<span className="truncatedText">{rowData.email}</span>
<button className="iconBtn" onClick={() => copy(rowData.email)}>
<i className="pi pi-copy"></i>
</button>
</div>;
};
const roleBodyTemplate = (rowData) => {
return rowData.role.roleName;
};
const statusBodyTemplate = (rowData) => {
return <ProperBandoLabel status={rowData.status}/>;
};
const statusFilterTemplate = (options) => {
return <Dropdown value={options.value} options={statuses}
onChange={(e) => options.filterCallback(e.value, options.index)}
itemTemplate={statusItemTemplate} placeholder={__('Scegli uno', 'gepafin')}
className="p-column-filter"
showClear/>;
};
const statusItemTemplate = (option) => {
return <Tag value={getBandoLabel(option)} severity={getBandoSeverity(option)}/>;
};
const actionsBodyTemplate = (rowData) => {
return <Link to={`/utenti/${rowData.id}`}>
<Button
severity="info"
label={__('Attività', 'gepafin')}
icon="pi pi-eye"
size="small"
iconPos="right"/>
</Link>
}
const header = renderHeader();
return (
<div className="appPageSection__table">
<DataTable value={users} paginator showGridlines rows={10} loading={loading} dataKey="id"
filters={filters} stripedRows removableSort
header={header}
emptyMessage={translationStrings.emptyMessage}
onFilter={(e) => setFilters(e.filters)}>
<Column body={nameBodyTemplate}
header={__('Nome utente', 'gepafin')}
filterPlaceholder={__('Cerca per nome', 'gepafin')}
style={{ minWidth: '12rem' }}/>
<Column body={roleEmailTemplate} header={__('Email', 'gepafin')}
filter sortable
field="email"
filterPlaceholder={__('Cerca per email', 'gepafin')}
style={{ minWidth: '12rem' }}/>
<Column body={roleBodyTemplate} header={__('Ruolo', 'gepafin')}
style={{ minWidth: '12rem' }}/>
<Column field="status" header={__('Stato', 'gepafin')}
filterMenuStyle={{ width: '14rem' }}
style={{ width: '120px' }} body={statusBodyTemplate}
filterElement={statusFilterTemplate}/>
<Column header={__('Ultimo accesso', 'gepafin')}
filterField="lastLogin" dataType="date"
style={{ minWidth: '10rem' }}
body={dateLastAccessBodyTemplate} filter filterElement={dateFilterTemplate}/>
<Column header={__('Azioni', 'gepafin')}
body={actionsBodyTemplate}/>
</DataTable>
</div>
)
}
export default AllUsersTable;

View File

@@ -1,30 +1,21 @@
import React, { useState, useEffect, useRef } from 'react'; import React, { useState, useEffect, useRef } from 'react';
import { __ } from '@wordpress/i18n'; import { __ } from '@wordpress/i18n';
import { isEmpty, isNil, pathOr } from 'ramda'; import { isEmpty, pathOr } from 'ramda';
import { klona } from 'klona'; import { useNavigate, useParams } from 'react-router-dom';
import NumberFlow from '@number-flow/react';
// store
import { storeSet, storeGet } from '../../store';
// service // service
import UserService from '../../service/user-service'; import UserService from '../../service/user-service';
// tools // tools
import set404FromErrorResponse from '../../helpers/set404FromErrorResponse'; import set404FromErrorResponse from '../../helpers/set404FromErrorResponse';
import { isEmail } from '../../helpers/validators'; import getDateFromISOstring from '../../helpers/getDateFromISOstring';
// components // components
import AllUsersTable from './components/AllUsersTable';
import { Button } from 'primereact/button'; import { Button } from 'primereact/button';
import { InputText } from 'primereact/inputtext';
import { Dropdown } from 'primereact/dropdown';
import { Dialog } from 'primereact/dialog';
import { classNames } from 'primereact/utils';
import { Toast } from 'primereact/toast'; import { Toast } from 'primereact/toast';
import getDateFromISOstring from '../../helpers/getDateFromISOstring'; import { Dropdown } from 'primereact/dropdown';
import getBandoLabel from '../../helpers/getBandoLabel';
import { useNavigate, useParams } from 'react-router-dom';
import NumberFlow from '@number-flow/react';
const UserActivity = () => { const UserActivity = () => {
const [loading, setLoading] = useState(false); const [loading, setLoading] = useState(false);
@@ -33,6 +24,7 @@ const UserActivity = () => {
const { id } = useParams(); const { id } = useParams();
const [user, setUser] = useState({}); const [user, setUser] = useState({});
const [roles, setRoles] = useState([]); const [roles, setRoles] = useState([]);
const [chosenRole, setChosenRole] = useState(0);
const goBack = () => { const goBack = () => {
navigate(`/utenti`); navigate(`/utenti`);
@@ -41,6 +33,7 @@ const UserActivity = () => {
const getUserCallback = (resp) => { const getUserCallback = (resp) => {
if (resp.status === 'SUCCESS') { if (resp.status === 'SUCCESS') {
setUser(resp.data) setUser(resp.data)
setChosenRole(resp.data.role?.id);
} }
setLoading(false); setLoading(false);
} }
@@ -66,6 +59,25 @@ const UserActivity = () => {
return pathOr(fallback, [key], {}); return pathOr(fallback, [key], {});
} }
const handleRoleUpdate = () => {
if (user.role?.id !== chosenRole) {
setLoading(true);
UserService.updateUser(user.id, {roleId: chosenRole}, updateRoleCallback, errUpdateRoleCallback)
}
}
const updateRoleCallback = (resp) => {
if (resp.status === 'SUCCESS') {
setUser(resp.data)
}
setLoading(false);
}
const errUpdateRoleCallback = (resp) => {
set404FromErrorResponse(resp);
setLoading(false);
}
useEffect(() => { useEffect(() => {
if (id && !isEmpty(id)) { if (id && !isEmpty(id)) {
setLoading(true); setLoading(true);
@@ -119,6 +131,32 @@ const UserActivity = () => {
</p> </p>
</div> </div>
{['ROLE_PRE_INSTRUCTOR', 'ROLE_INSTRUCTOR_MANAGER'].includes(user.role?.roleType)
? <>
<div className="appPage__spacer"></div>
<div className="appPageSection">
<h3>{__('Cambia ruolo', 'gepafin')}</h3>
<div className="row">
<Dropdown
id="form"
disabled={isEmpty(roles) || loading}
value={chosenRole}
onChange={(e) => setChosenRole(e.value)}
options={roles.filter(o => [3, 5].includes(o.id)).map(o => ({ label: o.roleName, value: o.id }))}
optionLabel="label"
placeholder={__('Seleziona ruolo', 'gepafin')}/>
<Button
type="button"
disabled={loading}
outlined
onClick={handleRoleUpdate}
label={__('Modifica', 'gepafin')}
icon="pi pi-cog" iconPos="right"/>
</div>
</div>
</> : null}
<div className="appPage__spacer"></div> <div className="appPage__spacer"></div>
<div className="appPageSection"> <div className="appPageSection">