import React, { useState, useEffect, useRef } from 'react'; import { __ } from '@wordpress/i18n'; import { useNavigate, useParams } from 'react-router-dom'; import { is, isEmpty, isNil } from 'ramda'; import 'quill/dist/quill.core.css'; // store import { storeSet, useStoreValue } from '../../store'; // tools import getNumberWithCurrency from '../../helpers/getNumberWithCurrency'; import getDateFromISOstring from '../../helpers/getDateFromISOstring'; // components import { Skeleton } from 'primereact/skeleton'; import { Accordion } from 'primereact/accordion'; import { AccordionTab } from 'primereact/accordion'; import { InputTextarea } from 'primereact/inputtextarea'; import { Button } from 'primereact/button'; import BandoService from '../../service/bando-service'; import { Messages } from 'primereact/messages'; import set404FromErrorResponse from '../../helpers/set404FromErrorResponse'; import renderHtmlContent from '../../helpers/renderHtmlContent'; const REACT_APP_HUB_ID = process.env.REACT_APP_HUB_ID; const BandoView = () => { const isAsyncRequest = useStoreValue('isAsyncRequest'); const { id } = useParams(); const navigate = useNavigate(); const [data, setData] = useState({}); const [newQuestion, setNewQuestion] = useState(''); const bandoMsgs = useRef(null); const closePreview = () => { navigate(`/bandi/${id}`); } const getCallback = (data) => { if (data.status === 'SUCCESS') { setData(getFormattedBandiData(data.data)); } storeSet('unsetAsyncRequest'); } const errGetCallback = (data) => { if (bandoMsgs.current && data.message) { bandoMsgs.current.show([ { sticky: true, severity: 'error', summary: '', detail: data.message, closable: true } ]); } set404FromErrorResponse(data); storeSet('unsetAsyncRequest'); } const getFormattedBandiData = (data) => { data.dates = data.dates.map(v => is(String, v) ? new Date(v) : (v ? v : '')); return data; }; useEffect(() => { const parsed = parseInt(id) const bandoId = !isNaN(parsed) ? parsed : 0; BandoService.getBando(bandoId, getCallback, errGetCallback); }, [id]); return (
{__('Data:', 'gepafin')} {getDateFromISOstring(data.createdDate)}
{__('Importo totale', 'gepafin')} {getNumberWithCurrency(data.amount)}
{__('Importo minimo per progetto', 'gepafin')} {getNumberWithCurrency(data.amountMin)}
{__('Importo massimo per progetto', 'gepafin')} {getNumberWithCurrency(data.amountMax)}
{__('Data apertura', 'gepafin')} {getDateFromISOstring(data.dates[0])} {data.startTime}
{__('Data chiusura', 'gepafin')} {getDateFromISOstring(data.dates[1])} {data.endTime}
Email: {data.email}
{!isNil(data.phoneNumber) ?{__('Telefono', 'gepafin')}: +39 {data.phoneNumber}
: null}